-rw-r--r-- | korganizer/calendarview.cpp | 62 | ||||
-rw-r--r-- | korganizer/koagenda.cpp | 4 | ||||
-rw-r--r-- | korganizer/koagendaitem.cpp | 16 | ||||
-rw-r--r-- | korganizer/kolistview.cpp | 12 | ||||
-rw-r--r-- | korganizer/kotodoview.cpp | 4 | ||||
-rw-r--r-- | korganizer/kowhatsnextview.cpp | 10 | ||||
-rw-r--r-- | korganizer/mainwindow.cpp | 10 |
7 files changed, 59 insertions, 59 deletions
diff --git a/korganizer/calendarview.cpp b/korganizer/calendarview.cpp index 720ad78..7c7466b 100644 --- a/korganizer/calendarview.cpp +++ b/korganizer/calendarview.cpp | |||
@@ -45,263 +45,263 @@ | |||
45 | #include <qregexp.h> | 45 | #include <qregexp.h> |
46 | #include <qgroupbox.h> | 46 | #include <qgroupbox.h> |
47 | #include <qfile.h> | 47 | #include <qfile.h> |
48 | #include <qdir.h> | 48 | #include <qdir.h> |
49 | #ifndef KORG_NOSPLITTER | 49 | #ifndef KORG_NOSPLITTER |
50 | #include <qsplitter.h> | 50 | #include <qsplitter.h> |
51 | #endif | 51 | #endif |
52 | 52 | ||
53 | #include <kglobal.h> | 53 | #include <kglobal.h> |
54 | #include <kdebug.h> | 54 | #include <kdebug.h> |
55 | #include <kstandarddirs.h> | 55 | #include <kstandarddirs.h> |
56 | #include <kfiledialog.h> | 56 | #include <kfiledialog.h> |
57 | #include <kmessagebox.h> | 57 | #include <kmessagebox.h> |
58 | #include <knotifyclient.h> | 58 | #include <knotifyclient.h> |
59 | #include <kconfig.h> | 59 | #include <kconfig.h> |
60 | 60 | ||
61 | #include <libkdepim/ksyncprefsdialog.h> | 61 | #include <libkdepim/ksyncprefsdialog.h> |
62 | #include <krun.h> | 62 | #include <krun.h> |
63 | #include <kdirwatch.h> | 63 | #include <kdirwatch.h> |
64 | #include <libkdepim/kdatepicker.h> | 64 | #include <libkdepim/kdatepicker.h> |
65 | #include <libkdepim/ksyncprofile.h> | 65 | #include <libkdepim/ksyncprofile.h> |
66 | #include <libkdepim/kpimglobalprefs.h> | 66 | #include <libkdepim/kpimglobalprefs.h> |
67 | 67 | ||
68 | #include <libkcal/vcaldrag.h> | 68 | #include <libkcal/vcaldrag.h> |
69 | #include <libkcal/icaldrag.h> | 69 | #include <libkcal/icaldrag.h> |
70 | #include <libkcal/icalformat.h> | 70 | #include <libkcal/icalformat.h> |
71 | #include <libkcal/vcalformat.h> | 71 | #include <libkcal/vcalformat.h> |
72 | #include <libkcal/scheduler.h> | 72 | #include <libkcal/scheduler.h> |
73 | #include <libkcal/calendarlocal.h> | 73 | #include <libkcal/calendarlocal.h> |
74 | #include <libkcal/journal.h> | 74 | #include <libkcal/journal.h> |
75 | #include <libkcal/calfilter.h> | 75 | #include <libkcal/calfilter.h> |
76 | #include <libkcal/attendee.h> | 76 | #include <libkcal/attendee.h> |
77 | #include <libkcal/dndfactory.h> | 77 | #include <libkcal/dndfactory.h> |
78 | #include <libkcal/freebusy.h> | 78 | #include <libkcal/freebusy.h> |
79 | #include <libkcal/filestorage.h> | 79 | #include <libkcal/filestorage.h> |
80 | #include <libkcal/calendarresources.h> | 80 | #include <libkcal/calendarresources.h> |
81 | #include <libkcal/qtopiaformat.h> | 81 | #include <libkcal/qtopiaformat.h> |
82 | #include "../kalarmd/alarmdialog.h" | 82 | #include "../kalarmd/alarmdialog.h" |
83 | 83 | ||
84 | #ifndef DESKTOP_VERSION | 84 | #ifndef DESKTOP_VERSION |
85 | #include <libkcal/sharpformat.h> | 85 | #include <libkcal/sharpformat.h> |
86 | #include <externalapphandler.h> | 86 | #include <externalapphandler.h> |
87 | #endif | 87 | #endif |
88 | #include <libkcal/phoneformat.h> | 88 | #include <libkcal/phoneformat.h> |
89 | #ifndef KORG_NOMAIL | 89 | #ifndef KORG_NOMAIL |
90 | #include "komailclient.h" | 90 | #include "komailclient.h" |
91 | #endif | 91 | #endif |
92 | #ifndef KORG_NOPRINTER | 92 | #ifndef KORG_NOPRINTER |
93 | #include "calprinter.h" | 93 | #include "calprinter.h" |
94 | #endif | 94 | #endif |
95 | #ifndef KORG_NOPLUGINS | 95 | #ifndef KORG_NOPLUGINS |
96 | #include "kocore.h" | 96 | #include "kocore.h" |
97 | #endif | 97 | #endif |
98 | #include "koeventeditor.h" | 98 | #include "koeventeditor.h" |
99 | #include "kotodoeditor.h" | 99 | #include "kotodoeditor.h" |
100 | #include "koprefs.h" | 100 | #include "koprefs.h" |
101 | #include "koeventviewerdialog.h" | 101 | #include "koeventviewerdialog.h" |
102 | #include "publishdialog.h" | 102 | #include "publishdialog.h" |
103 | #include "kofilterview.h" | 103 | #include "kofilterview.h" |
104 | #include "koglobals.h" | 104 | #include "koglobals.h" |
105 | #include "koviewmanager.h" | 105 | #include "koviewmanager.h" |
106 | #include "koagendaview.h" | 106 | #include "koagendaview.h" |
107 | #include "kodialogmanager.h" | 107 | #include "kodialogmanager.h" |
108 | #include "outgoingdialog.h" | 108 | #include "outgoingdialog.h" |
109 | #include "incomingdialog.h" | 109 | #include "incomingdialog.h" |
110 | #include "datenavigatorcontainer.h" | 110 | #include "datenavigatorcontainer.h" |
111 | #include "statusdialog.h" | 111 | #include "statusdialog.h" |
112 | #include "kdatenavigator.h" | 112 | #include "kdatenavigator.h" |
113 | #include "kotodoview.h" | 113 | #include "kotodoview.h" |
114 | #include "datenavigator.h" | 114 | #include "datenavigator.h" |
115 | #include "resourceview.h" | 115 | #include "resourceview.h" |
116 | #include "navigatorbar.h" | 116 | #include "navigatorbar.h" |
117 | #include "searchdialog.h" | 117 | #include "searchdialog.h" |
118 | #include "mainwindow.h" | 118 | #include "mainwindow.h" |
119 | 119 | ||
120 | #include "calendarview.h" | 120 | #include "calendarview.h" |
121 | #ifndef DESKTOP_VERSION | 121 | #ifndef DESKTOP_VERSION |
122 | #include <qtopia/alarmserver.h> | 122 | #include <qtopia/alarmserver.h> |
123 | #endif | 123 | #endif |
124 | #ifndef _WIN32_ | 124 | #ifndef _WIN32_ |
125 | #include <stdlib.h> | 125 | #include <stdlib.h> |
126 | #include <stdio.h> | 126 | #include <stdio.h> |
127 | #include <unistd.h> | 127 | #include <unistd.h> |
128 | #else | 128 | #else |
129 | #include <qprocess.h> | 129 | #include <qprocess.h> |
130 | #endif | 130 | #endif |
131 | 131 | ||
132 | #ifdef DESKTOP_VERSION | 132 | #ifdef DESKTOP_VERSION |
133 | #include <kabc/stdaddressbook.h> | 133 | #include <kabc/stdaddressbook.h> |
134 | #endif | 134 | #endif |
135 | using namespace KOrg; | 135 | using namespace KOrg; |
136 | using namespace KCal; | 136 | using namespace KCal; |
137 | extern int globalFlagBlockAgenda; | 137 | extern int globalFlagBlockAgenda; |
138 | extern int globalFlagBlockStartup; | 138 | extern int globalFlagBlockStartup; |
139 | 139 | ||
140 | 140 | ||
141 | MissedAlarmTextBrowser::MissedAlarmTextBrowser(QWidget *parent, QPtrList<Incidence> alarms,QDateTime start ) : QTextBrowser(parent) | 141 | MissedAlarmTextBrowser::MissedAlarmTextBrowser(QWidget *parent, QPtrList<Incidence> alarms,QDateTime start ) : QTextBrowser(parent) |
142 | 142 | ||
143 | { | 143 | { |
144 | mAlarms = alarms; | 144 | mAlarms = alarms; |
145 | viewport()->setBackgroundColor( QColor( 255, 255, 255 ) ); | 145 | viewport()->setBackgroundColor( QColor( 255, 255, 255 ) ); |
146 | QString mText = "<table width=\"100%\">\n"; | 146 | QString mText = "<table width=\"100%\">\n"; |
147 | //mText += "<tr bgcolor=\"#3679AD\"><td><h2>"; | 147 | //mText += "<tr bgcolor=\"#3679AD\"><td><h2>"; |
148 | #ifdef DESKTOP_VERSION | 148 | #ifdef DESKTOP_VERSION |
149 | mText += "<tr bgcolor=\"#5699CD\"><td align=\"center\"><h2>"; | 149 | mText += "<tr bgcolor=\"#5699CD\"><td align=\"center\"><h2>"; |
150 | #else | 150 | #else |
151 | mText += "<tr bgcolor=\"#5699CD\"><td align=\"center\"><h3>"; | 151 | mText += "<tr bgcolor=\"#5699CD\"><td align=\"center\"><h3>"; |
152 | #endif | 152 | #endif |
153 | // mText += "<img src=\""; | 153 | // mText += "<img src=\""; |
154 | // mText += ipath; | 154 | // mText += ipath; |
155 | // mText += "\">"; | 155 | // mText += "\">"; |
156 | //mEventDate = QDate::currentDate(); | 156 | //mEventDate = QDate::currentDate(); |
157 | #ifdef DESKTOP_VERSION | 157 | #ifdef DESKTOP_VERSION |
158 | mText += "<font color=\"#FFFFFF\"> <em>" + i18n("You missed the alarms for the following events or todos:")+"</em></font></h2>"; | 158 | mText += "<font color=\"#FFFFFF\"> <em>" + i18n("You missed the alarms for the following events or todos:")+"</em></font></h2>"; |
159 | #else | 159 | #else |
160 | mText += "<font color=\"#FFFFFF\"> <em>" + i18n("You missed the alarms for the following events or todos:")+"</em></font></h3>"; | 160 | mText += "<font color=\"#FFFFFF\"> <em>" + i18n("You missed the alarms for the following events or todos:")+"</em></font></h3>"; |
161 | #endif | 161 | #endif |
162 | //mText += "</td></tr>\n<tr bgcolor=\"#FF997D\"><td>"; | 162 | //mText += "</td></tr>\n<tr bgcolor=\"#FF997D\"><td>"; |
163 | 163 | ||
164 | Incidence * inc = getNextInc( start ); | 164 | Incidence * inc = getNextInc( start ); |
165 | int time = 0; | 165 | int time = 0; |
166 | //mText += "<table>"; | 166 | //mText += "<table>"; |
167 | while ( inc ) { | 167 | while ( inc ) { |
168 | QDateTime dt ; | 168 | QDateTime dt ; |
169 | QString tempText = "<a "; | 169 | QString tempText = "<a "; |
170 | bool ok; | 170 | bool ok; |
171 | dt = inc->getNextOccurence( start, &ok ); | 171 | dt = inc->getNextOccurence( start, &ok ); |
172 | if ( !ok ) continue; | 172 | if ( !ok ) continue; |
173 | if ( inc->type() == "Event" ) { | 173 | if ( inc->typeID() == eventID ) { |
174 | tempText += "href=\"event:"; | 174 | tempText += "href=\"event:"; |
175 | } else if ( inc->type() == "Todo" ) { | 175 | } else if ( inc->typeID() == todoID ) { |
176 | tempText += "href=\"todo:"; | 176 | tempText += "href=\"todo:"; |
177 | } | 177 | } |
178 | tempText += inc->uid() + "\">"; | 178 | tempText += inc->uid() + "\">"; |
179 | if ( inc->type() == "Todo" ) | 179 | if ( inc->typeID() == todoID ) |
180 | tempText += i18n("Todo: "); | 180 | tempText += i18n("Todo: "); |
181 | if ( inc->summary().length() > 0 ) | 181 | if ( inc->summary().length() > 0 ) |
182 | tempText += inc->summary(); | 182 | tempText += inc->summary(); |
183 | else | 183 | else |
184 | tempText += i18n("-no summary-"); | 184 | tempText += i18n("-no summary-"); |
185 | QString timestr; | 185 | QString timestr; |
186 | if (!inc->doesFloat()) | 186 | if (!inc->doesFloat()) |
187 | timestr = KGlobal::locale()->formatDateTime( dt, KOPrefs::instance()->mShortDateInViewer) +": "; | 187 | timestr = KGlobal::locale()->formatDateTime( dt, KOPrefs::instance()->mShortDateInViewer) +": "; |
188 | else | 188 | else |
189 | timestr = KGlobal::locale()->formatDate( dt.date() , KOPrefs::instance()->mShortDateInViewer) +": "; | 189 | timestr = KGlobal::locale()->formatDate( dt.date() , KOPrefs::instance()->mShortDateInViewer) +": "; |
190 | if ( dt.date() < QDate::currentDate() && time == 0 ) { | 190 | if ( dt.date() < QDate::currentDate() && time == 0 ) { |
191 | mText += "</td></tr>\n<tr bgcolor=\"#FF997D\"><td>"; | 191 | mText += "</td></tr>\n<tr bgcolor=\"#FF997D\"><td>"; |
192 | mText += "<table>"; | 192 | mText += "<table>"; |
193 | time = 1; | 193 | time = 1; |
194 | } | 194 | } |
195 | if ( dt.date() == QDate::currentDate() && time <= 1 ) { | 195 | if ( dt.date() == QDate::currentDate() && time <= 1 ) { |
196 | if ( time > 0 ) | 196 | if ( time > 0 ) |
197 | mText +="</table>"; | 197 | mText +="</table>"; |
198 | mText += "</td></tr>\n<tr bgcolor=\"#FFDC64\"><td>"; | 198 | mText += "</td></tr>\n<tr bgcolor=\"#FFDC64\"><td>"; |
199 | mText += "<table>"; | 199 | mText += "<table>"; |
200 | time = 2; | 200 | time = 2; |
201 | 201 | ||
202 | } | 202 | } |
203 | if ( dt.date() > QDate::currentDate() && time <= 2 ) { | 203 | if ( dt.date() > QDate::currentDate() && time <= 2 ) { |
204 | if ( time > 0 ) | 204 | if ( time > 0 ) |
205 | mText +="</table>"; | 205 | mText +="</table>"; |
206 | mText += "</td></tr>\n<tr bgcolor=\"#6AFF6A\"><td>"; | 206 | mText += "</td></tr>\n<tr bgcolor=\"#6AFF6A\"><td>"; |
207 | mText += "<table>"; | 207 | mText += "<table>"; |
208 | time = 3; | 208 | time = 3; |
209 | } | 209 | } |
210 | mText +="<tr><td><b>"; | 210 | mText +="<tr><td><b>"; |
211 | mText += timestr; | 211 | mText += timestr; |
212 | mText += "</b></td><td>"; | 212 | mText += "</b></td><td>"; |
213 | mText += tempText; | 213 | mText += tempText; |
214 | mText += "</td></tr>\n"; | 214 | mText += "</td></tr>\n"; |
215 | inc = getNextInc( start ); | 215 | inc = getNextInc( start ); |
216 | } | 216 | } |
217 | mText +="</table>"; | 217 | mText +="</table>"; |
218 | setText( mText ); | 218 | setText( mText ); |
219 | } | 219 | } |
220 | 220 | ||
221 | MissedAlarmTextBrowser::~MissedAlarmTextBrowser() | 221 | MissedAlarmTextBrowser::~MissedAlarmTextBrowser() |
222 | { | 222 | { |
223 | //qDebug("delete MissedAlarmTextBrowser::~MissedAlarmTextBrowser() "); | 223 | //qDebug("delete MissedAlarmTextBrowser::~MissedAlarmTextBrowser() "); |
224 | } | 224 | } |
225 | Incidence * MissedAlarmTextBrowser::getNextInc( QDateTime start ) | 225 | Incidence * MissedAlarmTextBrowser::getNextInc( QDateTime start ) |
226 | { | 226 | { |
227 | QDateTime dt ; | 227 | QDateTime dt ; |
228 | Incidence * retInc; | 228 | Incidence * retInc; |
229 | Incidence * inc = mAlarms.first(); | 229 | Incidence * inc = mAlarms.first(); |
230 | if ( inc == 0 ) | 230 | if ( inc == 0 ) |
231 | return 0; | 231 | return 0; |
232 | bool ok; | 232 | bool ok; |
233 | dt = inc->getNextOccurence( start, &ok ); | 233 | dt = inc->getNextOccurence( start, &ok ); |
234 | if ( ! ok ) return 0; | 234 | if ( ! ok ) return 0; |
235 | QDateTime dtn ; | 235 | QDateTime dtn ; |
236 | retInc = inc; | 236 | retInc = inc; |
237 | inc = mAlarms.next(); | 237 | inc = mAlarms.next(); |
238 | while ( inc ) { | 238 | while ( inc ) { |
239 | dtn = inc->getNextOccurence( start, &ok ); | 239 | dtn = inc->getNextOccurence( start, &ok ); |
240 | if ( ! ok ) return 0; | 240 | if ( ! ok ) return 0; |
241 | if ( dtn < dt ) { | 241 | if ( dtn < dt ) { |
242 | dt = dtn; | 242 | dt = dtn; |
243 | retInc = inc; | 243 | retInc = inc; |
244 | } | 244 | } |
245 | inc = mAlarms.next(); | 245 | inc = mAlarms.next(); |
246 | } | 246 | } |
247 | mAlarms.remove( retInc ); | 247 | mAlarms.remove( retInc ); |
248 | return retInc; | 248 | return retInc; |
249 | 249 | ||
250 | } | 250 | } |
251 | void MissedAlarmTextBrowser::setSource(const QString & n) | 251 | void MissedAlarmTextBrowser::setSource(const QString & n) |
252 | { | 252 | { |
253 | if (n.startsWith("event:")) { | 253 | if (n.startsWith("event:")) { |
254 | #ifdef DESKTOP_VERSION | 254 | #ifdef DESKTOP_VERSION |
255 | emit showIncidence(n.mid(8)); | 255 | emit showIncidence(n.mid(8)); |
256 | #else | 256 | #else |
257 | emit showIncidence(n.mid(6)); | 257 | emit showIncidence(n.mid(6)); |
258 | #endif | 258 | #endif |
259 | return; | 259 | return; |
260 | } else if (n.startsWith("todo:")) { | 260 | } else if (n.startsWith("todo:")) { |
261 | #ifdef DESKTOP_VERSION | 261 | #ifdef DESKTOP_VERSION |
262 | emit showIncidence(n.mid(7)); | 262 | emit showIncidence(n.mid(7)); |
263 | #else | 263 | #else |
264 | emit showIncidence(n.mid(5)); | 264 | emit showIncidence(n.mid(5)); |
265 | #endif | 265 | #endif |
266 | return; | 266 | return; |
267 | } | 267 | } |
268 | } | 268 | } |
269 | 269 | ||
270 | 270 | ||
271 | class KOBeamPrefs : public QDialog | 271 | class KOBeamPrefs : public QDialog |
272 | { | 272 | { |
273 | public: | 273 | public: |
274 | KOBeamPrefs( QWidget *parent=0, const char *name=0 ) : | 274 | KOBeamPrefs( QWidget *parent=0, const char *name=0 ) : |
275 | QDialog( parent, name, true ) | 275 | QDialog( parent, name, true ) |
276 | { | 276 | { |
277 | setCaption( i18n("Beam Options") ); | 277 | setCaption( i18n("Beam Options") ); |
278 | QVBoxLayout* lay = new QVBoxLayout( this ); | 278 | QVBoxLayout* lay = new QVBoxLayout( this ); |
279 | lay->setSpacing( 3 ); | 279 | lay->setSpacing( 3 ); |
280 | lay->setMargin( 3 ); | 280 | lay->setMargin( 3 ); |
281 | QButtonGroup* format = new QButtonGroup( 1, Horizontal, i18n("File format"), this ); | 281 | QButtonGroup* format = new QButtonGroup( 1, Horizontal, i18n("File format"), this ); |
282 | lay->addWidget( format ); | 282 | lay->addWidget( format ); |
283 | format->setExclusive ( true ) ; | 283 | format->setExclusive ( true ) ; |
284 | QButtonGroup* time = new QButtonGroup(1, Horizontal, i18n("Time format"), this ); | 284 | QButtonGroup* time = new QButtonGroup(1, Horizontal, i18n("Time format"), this ); |
285 | lay->addWidget( time ); time->setExclusive ( true ) ; | 285 | lay->addWidget( time ); time->setExclusive ( true ) ; |
286 | vcal = new QRadioButton(" vCalendar ", format ); | 286 | vcal = new QRadioButton(" vCalendar ", format ); |
287 | ical = new QRadioButton(" iCalendar ", format ); | 287 | ical = new QRadioButton(" iCalendar ", format ); |
288 | vcal->setChecked( true ); | 288 | vcal->setChecked( true ); |
289 | tz = new QRadioButton(i18n(" With timezone "), time ); | 289 | tz = new QRadioButton(i18n(" With timezone "), time ); |
290 | local = new QRadioButton(i18n(" Local time "), time ); | 290 | local = new QRadioButton(i18n(" Local time "), time ); |
291 | tz->setChecked( true ); | 291 | tz->setChecked( true ); |
292 | QPushButton * ok = new QPushButton( i18n("Beam via IR!"), this ); | 292 | QPushButton * ok = new QPushButton( i18n("Beam via IR!"), this ); |
293 | lay->addWidget( ok ); | 293 | lay->addWidget( ok ); |
294 | QPushButton * cancel = new QPushButton( i18n("Cancel"), this ); | 294 | QPushButton * cancel = new QPushButton( i18n("Cancel"), this ); |
295 | lay->addWidget( cancel ); | 295 | lay->addWidget( cancel ); |
296 | connect ( ok,SIGNAL(clicked() ),this , SLOT ( accept() ) ); | 296 | connect ( ok,SIGNAL(clicked() ),this , SLOT ( accept() ) ); |
297 | connect (cancel, SIGNAL(clicked() ), this, SLOT ( reject()) ); | 297 | connect (cancel, SIGNAL(clicked() ), this, SLOT ( reject()) ); |
298 | resize( 200, 200 ); | 298 | resize( 200, 200 ); |
299 | } | 299 | } |
300 | 300 | ||
301 | bool beamVcal() { return vcal->isChecked(); } | 301 | bool beamVcal() { return vcal->isChecked(); } |
302 | bool beamLocal() { return local->isChecked(); } | 302 | bool beamLocal() { return local->isChecked(); } |
303 | private: | 303 | private: |
304 | QRadioButton* vcal, *ical, *local, *tz; | 304 | QRadioButton* vcal, *ical, *local, *tz; |
305 | }; | 305 | }; |
306 | class KOCatPrefs : public QDialog | 306 | class KOCatPrefs : public QDialog |
307 | { | 307 | { |
@@ -848,690 +848,690 @@ void CalendarView::addAlarm(const QDateTime &qdt, const QString ¬i ) | |||
848 | } | 848 | } |
849 | //qDebug("Alarm timer started with secs: %d ", sec); | 849 | //qDebug("Alarm timer started with secs: %d ", sec); |
850 | mAlarmTimer->start( sec *1000 , true ); | 850 | mAlarmTimer->start( sec *1000 , true ); |
851 | 851 | ||
852 | } | 852 | } |
853 | // called by mRecheckAlarmTimer to get next alarm | 853 | // called by mRecheckAlarmTimer to get next alarm |
854 | // we need this, because a QTimer has only a max range of 25 days | 854 | // we need this, because a QTimer has only a max range of 25 days |
855 | void CalendarView::recheckTimerAlarm() | 855 | void CalendarView::recheckTimerAlarm() |
856 | { | 856 | { |
857 | mAlarmTimer->stop(); | 857 | mAlarmTimer->stop(); |
858 | mRecheckAlarmTimer->stop(); | 858 | mRecheckAlarmTimer->stop(); |
859 | mCalendar->checkAlarmForIncidence( 0, true ); | 859 | mCalendar->checkAlarmForIncidence( 0, true ); |
860 | } | 860 | } |
861 | void CalendarView::removeAlarm(const QDateTime &qdt, const QString ¬i ) | 861 | void CalendarView::removeAlarm(const QDateTime &qdt, const QString ¬i ) |
862 | { | 862 | { |
863 | //qDebug("-----removeAlarm %s %s ", qdt.toString().latin1() , noti.latin1() ); | 863 | //qDebug("-----removeAlarm %s %s ", qdt.toString().latin1() , noti.latin1() ); |
864 | if ( ! KOPrefs::instance()->mUseInternalAlarmNotification ) { | 864 | if ( ! KOPrefs::instance()->mUseInternalAlarmNotification ) { |
865 | #ifndef DESKTOP_VERSION | 865 | #ifndef DESKTOP_VERSION |
866 | AlarmServer::deleteAlarm (qdt ,"koalarm" ,noti.latin1() ); | 866 | AlarmServer::deleteAlarm (qdt ,"koalarm" ,noti.latin1() ); |
867 | #endif | 867 | #endif |
868 | return; | 868 | return; |
869 | } | 869 | } |
870 | mAlarmTimer->stop(); | 870 | mAlarmTimer->stop(); |
871 | } | 871 | } |
872 | void CalendarView::selectWeekNum ( int num ) | 872 | void CalendarView::selectWeekNum ( int num ) |
873 | { | 873 | { |
874 | dateNavigator()->blockSignals( true ); | 874 | dateNavigator()->blockSignals( true ); |
875 | dateNavigator()->selectWeek( num ); | 875 | dateNavigator()->selectWeek( num ); |
876 | dateNavigator()->blockSignals( false ); | 876 | dateNavigator()->blockSignals( false ); |
877 | mViewManager->showWeekView(); | 877 | mViewManager->showWeekView(); |
878 | } | 878 | } |
879 | KOViewManager *CalendarView::viewManager() | 879 | KOViewManager *CalendarView::viewManager() |
880 | { | 880 | { |
881 | return mViewManager; | 881 | return mViewManager; |
882 | } | 882 | } |
883 | 883 | ||
884 | KODialogManager *CalendarView::dialogManager() | 884 | KODialogManager *CalendarView::dialogManager() |
885 | { | 885 | { |
886 | return mDialogManager; | 886 | return mDialogManager; |
887 | } | 887 | } |
888 | 888 | ||
889 | QDate CalendarView::startDate() | 889 | QDate CalendarView::startDate() |
890 | { | 890 | { |
891 | DateList dates = mNavigator->selectedDates(); | 891 | DateList dates = mNavigator->selectedDates(); |
892 | 892 | ||
893 | return dates.first(); | 893 | return dates.first(); |
894 | } | 894 | } |
895 | 895 | ||
896 | QDate CalendarView::endDate() | 896 | QDate CalendarView::endDate() |
897 | { | 897 | { |
898 | DateList dates = mNavigator->selectedDates(); | 898 | DateList dates = mNavigator->selectedDates(); |
899 | 899 | ||
900 | return dates.last(); | 900 | return dates.last(); |
901 | } | 901 | } |
902 | 902 | ||
903 | 903 | ||
904 | void CalendarView::createPrinter() | 904 | void CalendarView::createPrinter() |
905 | { | 905 | { |
906 | #ifndef KORG_NOPRINTER | 906 | #ifndef KORG_NOPRINTER |
907 | if (!mCalPrinter) { | 907 | if (!mCalPrinter) { |
908 | mCalPrinter = new CalPrinter(this, mCalendar); | 908 | mCalPrinter = new CalPrinter(this, mCalendar); |
909 | connect(this, SIGNAL(configChanged()), mCalPrinter, SLOT(updateConfig())); | 909 | connect(this, SIGNAL(configChanged()), mCalPrinter, SLOT(updateConfig())); |
910 | } | 910 | } |
911 | #endif | 911 | #endif |
912 | } | 912 | } |
913 | 913 | ||
914 | 914 | ||
915 | //KOPrefs::instance()->mWriteBackFile | 915 | //KOPrefs::instance()->mWriteBackFile |
916 | //KOPrefs::instance()->mWriteBackExistingOnly | 916 | //KOPrefs::instance()->mWriteBackExistingOnly |
917 | 917 | ||
918 | // 0 syncPrefsGroup->addRadio(i18n("Take local entry on conflict")); | 918 | // 0 syncPrefsGroup->addRadio(i18n("Take local entry on conflict")); |
919 | // 1 syncPrefsGroup->addRadio(i18n("Take remote entry on conflict")); | 919 | // 1 syncPrefsGroup->addRadio(i18n("Take remote entry on conflict")); |
920 | // 2 syncPrefsGroup->addRadio(i18n("Take newest entry on conflict")); | 920 | // 2 syncPrefsGroup->addRadio(i18n("Take newest entry on conflict")); |
921 | // 3 syncPrefsGroup->addRadio(i18n("Ask for every entry on conflict")); | 921 | // 3 syncPrefsGroup->addRadio(i18n("Ask for every entry on conflict")); |
922 | // 4 syncPrefsGroup->addRadio(i18n("Force take local entry always")); | 922 | // 4 syncPrefsGroup->addRadio(i18n("Force take local entry always")); |
923 | // 5 syncPrefsGroup->addRadio(i18n("Force take remote entry always")); | 923 | // 5 syncPrefsGroup->addRadio(i18n("Force take remote entry always")); |
924 | 924 | ||
925 | int CalendarView::takeEvent( Incidence* local, Incidence* remote, int mode , bool full ) | 925 | int CalendarView::takeEvent( Incidence* local, Incidence* remote, int mode , bool full ) |
926 | { | 926 | { |
927 | 927 | ||
928 | // 0 equal | 928 | // 0 equal |
929 | // 1 take local | 929 | // 1 take local |
930 | // 2 take remote | 930 | // 2 take remote |
931 | // 3 cancel | 931 | // 3 cancel |
932 | QDateTime lastSync = mLastCalendarSync; | 932 | QDateTime lastSync = mLastCalendarSync; |
933 | QDateTime localMod = local->lastModified(); | 933 | QDateTime localMod = local->lastModified(); |
934 | QDateTime remoteMod = remote->lastModified(); | 934 | QDateTime remoteMod = remote->lastModified(); |
935 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 935 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
936 | bool remCh, locCh; | 936 | bool remCh, locCh; |
937 | remCh = ( remote->getCsum(mCurrentSyncDevice) != local->getCsum(mCurrentSyncDevice) ); | 937 | remCh = ( remote->getCsum(mCurrentSyncDevice) != local->getCsum(mCurrentSyncDevice) ); |
938 | //if ( remCh ) | 938 | //if ( remCh ) |
939 | //qDebug("loc %s rem %s", local->getCsum(mCurrentSyncDevice).latin1(), remote->getCsum(mCurrentSyncDevice).latin1() ); | 939 | //qDebug("loc %s rem %s", local->getCsum(mCurrentSyncDevice).latin1(), remote->getCsum(mCurrentSyncDevice).latin1() ); |
940 | locCh = ( localMod > mLastCalendarSync ); | 940 | locCh = ( localMod > mLastCalendarSync ); |
941 | if ( !remCh && ! locCh ) { | 941 | if ( !remCh && ! locCh ) { |
942 | //qDebug("both not changed "); | 942 | //qDebug("both not changed "); |
943 | lastSync = localMod.addDays(1); | 943 | lastSync = localMod.addDays(1); |
944 | if ( mode <= SYNC_PREF_ASK ) | 944 | if ( mode <= SYNC_PREF_ASK ) |
945 | return 0; | 945 | return 0; |
946 | } else { | 946 | } else { |
947 | if ( locCh ) { | 947 | if ( locCh ) { |
948 | //qDebug("loc changed %d %s %s", local->revision() , localMod.toString().latin1(), mLastCalendarSync.toString().latin1()); | 948 | //qDebug("loc changed %d %s %s", local->revision() , localMod.toString().latin1(), mLastCalendarSync.toString().latin1()); |
949 | lastSync = localMod.addDays( -1 ); | 949 | lastSync = localMod.addDays( -1 ); |
950 | if ( !remCh ) | 950 | if ( !remCh ) |
951 | remoteMod = ( lastSync.addDays( -1 ) ); | 951 | remoteMod = ( lastSync.addDays( -1 ) ); |
952 | } else { | 952 | } else { |
953 | //qDebug(" not loc changed "); | 953 | //qDebug(" not loc changed "); |
954 | lastSync = localMod.addDays( 1 ); | 954 | lastSync = localMod.addDays( 1 ); |
955 | if ( remCh ) | 955 | if ( remCh ) |
956 | remoteMod =( lastSync.addDays( 1 ) ); | 956 | remoteMod =( lastSync.addDays( 1 ) ); |
957 | 957 | ||
958 | } | 958 | } |
959 | } | 959 | } |
960 | full = true; | 960 | full = true; |
961 | if ( mode < SYNC_PREF_ASK ) | 961 | if ( mode < SYNC_PREF_ASK ) |
962 | mode = SYNC_PREF_ASK; | 962 | mode = SYNC_PREF_ASK; |
963 | } else { | 963 | } else { |
964 | if ( localMod == remoteMod ) | 964 | if ( localMod == remoteMod ) |
965 | // if ( local->revision() == remote->revision() ) | 965 | // if ( local->revision() == remote->revision() ) |
966 | return 0; | 966 | return 0; |
967 | 967 | ||
968 | } | 968 | } |
969 | // qDebug(" %d %d conflict on %s %s ", mode, full, local->summary().latin1(), remote->summary().latin1() ); | 969 | // qDebug(" %d %d conflict on %s %s ", mode, full, local->summary().latin1(), remote->summary().latin1() ); |
970 | 970 | ||
971 | //qDebug("%s %d %s %d", localMod.toString().latin1() , local->revision(), remoteMod.toString().latin1(), remote->revision()); | 971 | //qDebug("%s %d %s %d", localMod.toString().latin1() , local->revision(), remoteMod.toString().latin1(), remote->revision()); |
972 | //qDebug("%d %d %d %d ", localMod.time().second(), localMod.time().msec(), remoteMod.time().second(), remoteMod.time().msec() ); | 972 | //qDebug("%d %d %d %d ", localMod.time().second(), localMod.time().msec(), remoteMod.time().second(), remoteMod.time().msec() ); |
973 | //full = true; //debug only | 973 | //full = true; //debug only |
974 | if ( full ) { | 974 | if ( full ) { |
975 | bool equ = false; | 975 | bool equ = false; |
976 | if ( local->type() == "Event" ) { | 976 | if ( local->typeID() == eventID ) { |
977 | equ = (*((Event*) local) == *((Event*) remote)); | 977 | equ = (*((Event*) local) == *((Event*) remote)); |
978 | } | 978 | } |
979 | else if ( local->type() =="Todo" ) | 979 | else if ( local->typeID() == todoID ) |
980 | equ = (*((Todo*) local) == (*(Todo*) remote)); | 980 | equ = (*((Todo*) local) == (*(Todo*) remote)); |
981 | else if ( local->type() =="Journal" ) | 981 | else if ( local->typeID() == journalID ) |
982 | equ = (*((Journal*) local) == *((Journal*) remote)); | 982 | equ = (*((Journal*) local) == *((Journal*) remote)); |
983 | if ( equ ) { | 983 | if ( equ ) { |
984 | //qDebug("equal "); | 984 | //qDebug("equal "); |
985 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 985 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
986 | local->setCsum( mCurrentSyncDevice, remote->getCsum(mCurrentSyncDevice) ); | 986 | local->setCsum( mCurrentSyncDevice, remote->getCsum(mCurrentSyncDevice) ); |
987 | } | 987 | } |
988 | if ( mode < SYNC_PREF_FORCE_LOCAL ) | 988 | if ( mode < SYNC_PREF_FORCE_LOCAL ) |
989 | return 0; | 989 | return 0; |
990 | 990 | ||
991 | }//else //debug only | 991 | }//else //debug only |
992 | //qDebug("not equal %s %s ", local->summary().latin1(), remote->summary().latin1()); | 992 | //qDebug("not equal %s %s ", local->summary().latin1(), remote->summary().latin1()); |
993 | } | 993 | } |
994 | int result; | 994 | int result; |
995 | bool localIsNew; | 995 | bool localIsNew; |
996 | //qDebug("%s -- %s mLastCalendarSync %s lastsync %s --- local %s remote %s ",local->summary().latin1(), remote->summary().latin1(),mLastCalendarSync.toString().latin1() ,lastSync.toString().latin1() , localMod.toString().latin1() , remoteMod.toString().latin1() ); | 996 | //qDebug("%s -- %s mLastCalendarSync %s lastsync %s --- local %s remote %s ",local->summary().latin1(), remote->summary().latin1(),mLastCalendarSync.toString().latin1() ,lastSync.toString().latin1() , localMod.toString().latin1() , remoteMod.toString().latin1() ); |
997 | 997 | ||
998 | 998 | ||
999 | // ************************************************ | 999 | // ************************************************ |
1000 | // ************************************************ | 1000 | // ************************************************ |
1001 | // ************************************************ | 1001 | // ************************************************ |
1002 | // We may have that lastSync > remoteMod AND lastSync > localMod | 1002 | // We may have that lastSync > remoteMod AND lastSync > localMod |
1003 | // BUT remoteMod != localMod | 1003 | // BUT remoteMod != localMod |
1004 | 1004 | ||
1005 | 1005 | ||
1006 | if ( full && mode < SYNC_PREF_NEWEST ) | 1006 | if ( full && mode < SYNC_PREF_NEWEST ) |
1007 | mode = SYNC_PREF_ASK; | 1007 | mode = SYNC_PREF_ASK; |
1008 | 1008 | ||
1009 | switch( mode ) { | 1009 | switch( mode ) { |
1010 | case SYNC_PREF_LOCAL: | 1010 | case SYNC_PREF_LOCAL: |
1011 | if ( lastSync > remoteMod ) | 1011 | if ( lastSync > remoteMod ) |
1012 | return 1; | 1012 | return 1; |
1013 | if ( lastSync > localMod ) | 1013 | if ( lastSync > localMod ) |
1014 | return 2; | 1014 | return 2; |
1015 | return 1; | 1015 | return 1; |
1016 | break; | 1016 | break; |
1017 | case SYNC_PREF_REMOTE: | 1017 | case SYNC_PREF_REMOTE: |
1018 | if ( lastSync > localMod ) | 1018 | if ( lastSync > localMod ) |
1019 | return 2; | 1019 | return 2; |
1020 | if ( lastSync > remoteMod ) | 1020 | if ( lastSync > remoteMod ) |
1021 | return 1; | 1021 | return 1; |
1022 | return 2; | 1022 | return 2; |
1023 | break; | 1023 | break; |
1024 | case SYNC_PREF_NEWEST: | 1024 | case SYNC_PREF_NEWEST: |
1025 | if ( localMod >= remoteMod ) | 1025 | if ( localMod >= remoteMod ) |
1026 | return 1; | 1026 | return 1; |
1027 | else | 1027 | else |
1028 | return 2; | 1028 | return 2; |
1029 | break; | 1029 | break; |
1030 | case SYNC_PREF_ASK: | 1030 | case SYNC_PREF_ASK: |
1031 | //qDebug("lsy %s --- lo %s --- re %s ", lastSync.toString().latin1(), localMod.toString().latin1(), remoteMod.toString().latin1() ); | 1031 | //qDebug("lsy %s --- lo %s --- re %s ", lastSync.toString().latin1(), localMod.toString().latin1(), remoteMod.toString().latin1() ); |
1032 | if ( lastSync > remoteMod && lastSync > localMod) | 1032 | if ( lastSync > remoteMod && lastSync > localMod) |
1033 | return 0; | 1033 | return 0; |
1034 | if ( lastSync > remoteMod ) | 1034 | if ( lastSync > remoteMod ) |
1035 | return 1; | 1035 | return 1; |
1036 | if ( lastSync > localMod ) | 1036 | if ( lastSync > localMod ) |
1037 | return 2; | 1037 | return 2; |
1038 | //qDebug("lsy %s --- lo %s --- re %s ", lastSync.toString().latin1(), localMod.toString().latin1(), remoteMod.toString().latin1() ); | 1038 | //qDebug("lsy %s --- lo %s --- re %s ", lastSync.toString().latin1(), localMod.toString().latin1(), remoteMod.toString().latin1() ); |
1039 | localIsNew = localMod >= remoteMod; | 1039 | localIsNew = localMod >= remoteMod; |
1040 | if ( localIsNew ) | 1040 | if ( localIsNew ) |
1041 | getEventViewerDialog()->setColorMode( 1 ); | 1041 | getEventViewerDialog()->setColorMode( 1 ); |
1042 | else | 1042 | else |
1043 | getEventViewerDialog()->setColorMode( 2 ); | 1043 | getEventViewerDialog()->setColorMode( 2 ); |
1044 | getEventViewerDialog()->setIncidence(local); | 1044 | getEventViewerDialog()->setIncidence(local); |
1045 | if ( localIsNew ) | 1045 | if ( localIsNew ) |
1046 | getEventViewerDialog()->setColorMode( 2 ); | 1046 | getEventViewerDialog()->setColorMode( 2 ); |
1047 | else | 1047 | else |
1048 | getEventViewerDialog()->setColorMode( 1 ); | 1048 | getEventViewerDialog()->setColorMode( 1 ); |
1049 | getEventViewerDialog()->addIncidence(remote); | 1049 | getEventViewerDialog()->addIncidence(remote); |
1050 | getEventViewerDialog()->setColorMode( 0 ); | 1050 | getEventViewerDialog()->setColorMode( 0 ); |
1051 | //qDebug("local %d remote %d ",local->relatedTo(),remote->relatedTo() ); | 1051 | //qDebug("local %d remote %d ",local->relatedTo(),remote->relatedTo() ); |
1052 | getEventViewerDialog()->setCaption( mCurrentSyncDevice +i18n(" : Conflict! Please choose entry!")); | 1052 | getEventViewerDialog()->setCaption( mCurrentSyncDevice +i18n(" : Conflict! Please choose entry!")); |
1053 | getEventViewerDialog()->showMe(); | 1053 | getEventViewerDialog()->showMe(); |
1054 | result = getEventViewerDialog()->executeS( localIsNew ); | 1054 | result = getEventViewerDialog()->executeS( localIsNew ); |
1055 | return result; | 1055 | return result; |
1056 | 1056 | ||
1057 | break; | 1057 | break; |
1058 | case SYNC_PREF_FORCE_LOCAL: | 1058 | case SYNC_PREF_FORCE_LOCAL: |
1059 | return 1; | 1059 | return 1; |
1060 | break; | 1060 | break; |
1061 | case SYNC_PREF_FORCE_REMOTE: | 1061 | case SYNC_PREF_FORCE_REMOTE: |
1062 | return 2; | 1062 | return 2; |
1063 | break; | 1063 | break; |
1064 | 1064 | ||
1065 | default: | 1065 | default: |
1066 | // SYNC_PREF_TAKE_BOTH not implemented | 1066 | // SYNC_PREF_TAKE_BOTH not implemented |
1067 | break; | 1067 | break; |
1068 | } | 1068 | } |
1069 | return 0; | 1069 | return 0; |
1070 | } | 1070 | } |
1071 | Event* CalendarView::getLastSyncEvent() | 1071 | Event* CalendarView::getLastSyncEvent() |
1072 | { | 1072 | { |
1073 | Event* lse; | 1073 | Event* lse; |
1074 | //qDebug("CurrentSyncDevice %s ",mCurrentSyncDevice .latin1() ); | 1074 | //qDebug("CurrentSyncDevice %s ",mCurrentSyncDevice .latin1() ); |
1075 | lse = mCalendar->event( "last-syncEvent-"+mCurrentSyncDevice ); | 1075 | lse = mCalendar->event( "last-syncEvent-"+mCurrentSyncDevice ); |
1076 | if (!lse) { | 1076 | if (!lse) { |
1077 | lse = new Event(); | 1077 | lse = new Event(); |
1078 | lse->setUid( "last-syncEvent-"+mCurrentSyncDevice ); | 1078 | lse->setUid( "last-syncEvent-"+mCurrentSyncDevice ); |
1079 | QString sum = ""; | 1079 | QString sum = ""; |
1080 | if ( mSyncManager->mExternSyncProfiles.contains( mCurrentSyncDevice ) ) | 1080 | if ( mSyncManager->mExternSyncProfiles.contains( mCurrentSyncDevice ) ) |
1081 | sum = "E: "; | 1081 | sum = "E: "; |
1082 | lse->setSummary(sum+mCurrentSyncDevice + i18n(" - sync event")); | 1082 | lse->setSummary(sum+mCurrentSyncDevice + i18n(" - sync event")); |
1083 | lse->setDtStart( mLastCalendarSync ); | 1083 | lse->setDtStart( mLastCalendarSync ); |
1084 | lse->setDtEnd( mLastCalendarSync.addSecs( 7200 ) ); | 1084 | lse->setDtEnd( mLastCalendarSync.addSecs( 7200 ) ); |
1085 | lse->setCategories( i18n("SyncEvent") ); | 1085 | lse->setCategories( i18n("SyncEvent") ); |
1086 | lse->setReadOnly( true ); | 1086 | lse->setReadOnly( true ); |
1087 | mCalendar->addEvent( lse ); | 1087 | mCalendar->addEvent( lse ); |
1088 | } | 1088 | } |
1089 | 1089 | ||
1090 | return lse; | 1090 | return lse; |
1091 | 1091 | ||
1092 | } | 1092 | } |
1093 | 1093 | ||
1094 | // we check, if the to delete event has a id for a profile | 1094 | // we check, if the to delete event has a id for a profile |
1095 | // if yes, we set this id in the profile to delete | 1095 | // if yes, we set this id in the profile to delete |
1096 | void CalendarView::checkExternSyncEvent( QPtrList<Event> lastSync , Incidence* toDelete ) | 1096 | void CalendarView::checkExternSyncEvent( QPtrList<Event> lastSync , Incidence* toDelete ) |
1097 | { | 1097 | { |
1098 | if ( lastSync.count() == 0 ) { | 1098 | if ( lastSync.count() == 0 ) { |
1099 | //qDebug(" lastSync.count() == 0"); | 1099 | //qDebug(" lastSync.count() == 0"); |
1100 | return; | 1100 | return; |
1101 | } | 1101 | } |
1102 | if ( toDelete->type() == "Journal" ) | 1102 | if ( toDelete->typeID() == journalID ) |
1103 | return; | 1103 | return; |
1104 | 1104 | ||
1105 | Event* eve = lastSync.first(); | 1105 | Event* eve = lastSync.first(); |
1106 | 1106 | ||
1107 | while ( eve ) { | 1107 | while ( eve ) { |
1108 | QString id = toDelete->getID( eve->uid().mid( 15 ) ); // this is the sync profile name | 1108 | QString id = toDelete->getID( eve->uid().mid( 15 ) ); // this is the sync profile name |
1109 | if ( !id.isEmpty() ) { | 1109 | if ( !id.isEmpty() ) { |
1110 | QString des = eve->description(); | 1110 | QString des = eve->description(); |
1111 | QString pref = "e"; | 1111 | QString pref = "e"; |
1112 | if ( toDelete->type() == "Todo" ) | 1112 | if ( toDelete->typeID() == todoID ) |
1113 | pref = "t"; | 1113 | pref = "t"; |
1114 | des += pref+ id + ","; | 1114 | des += pref+ id + ","; |
1115 | eve->setReadOnly( false ); | 1115 | eve->setReadOnly( false ); |
1116 | eve->setDescription( des ); | 1116 | eve->setDescription( des ); |
1117 | //qDebug("setdes %s ", des.latin1()); | 1117 | //qDebug("setdes %s ", des.latin1()); |
1118 | eve->setReadOnly( true ); | 1118 | eve->setReadOnly( true ); |
1119 | } | 1119 | } |
1120 | eve = lastSync.next(); | 1120 | eve = lastSync.next(); |
1121 | } | 1121 | } |
1122 | 1122 | ||
1123 | } | 1123 | } |
1124 | void CalendarView::checkExternalId( Incidence * inc ) | 1124 | void CalendarView::checkExternalId( Incidence * inc ) |
1125 | { | 1125 | { |
1126 | QPtrList<Event> lastSync = mCalendar->getExternLastSyncEvents() ; | 1126 | QPtrList<Event> lastSync = mCalendar->getExternLastSyncEvents() ; |
1127 | checkExternSyncEvent( lastSync, inc ); | 1127 | checkExternSyncEvent( lastSync, inc ); |
1128 | 1128 | ||
1129 | } | 1129 | } |
1130 | bool CalendarView::synchronizeCalendar( Calendar* local, Calendar* remote, int mode ) | 1130 | bool CalendarView::synchronizeCalendar( Calendar* local, Calendar* remote, int mode ) |
1131 | { | 1131 | { |
1132 | bool syncOK = true; | 1132 | bool syncOK = true; |
1133 | int addedEvent = 0; | 1133 | int addedEvent = 0; |
1134 | int addedEventR = 0; | 1134 | int addedEventR = 0; |
1135 | int deletedEventR = 0; | 1135 | int deletedEventR = 0; |
1136 | int deletedEventL = 0; | 1136 | int deletedEventL = 0; |
1137 | int changedLocal = 0; | 1137 | int changedLocal = 0; |
1138 | int changedRemote = 0; | 1138 | int changedRemote = 0; |
1139 | int filteredIN = 0; | 1139 | int filteredIN = 0; |
1140 | int filteredOUT = 0; | 1140 | int filteredOUT = 0; |
1141 | //QPtrList<Event> el = local->rawEvents(); | 1141 | //QPtrList<Event> el = local->rawEvents(); |
1142 | Event* eventR; | 1142 | Event* eventR; |
1143 | QString uid; | 1143 | QString uid; |
1144 | int take; | 1144 | int take; |
1145 | Event* eventL; | 1145 | Event* eventL; |
1146 | Event* eventRSync; | 1146 | Event* eventRSync; |
1147 | Event* eventLSync; | 1147 | Event* eventLSync; |
1148 | clearAllViews(); | 1148 | clearAllViews(); |
1149 | QPtrList<Event> eventRSyncSharp = remote->getExternLastSyncEvents(); | 1149 | QPtrList<Event> eventRSyncSharp = remote->getExternLastSyncEvents(); |
1150 | QPtrList<Event> eventLSyncSharp = local->getExternLastSyncEvents(); | 1150 | QPtrList<Event> eventLSyncSharp = local->getExternLastSyncEvents(); |
1151 | bool fullDateRange = false; | 1151 | bool fullDateRange = false; |
1152 | local->resetTempSyncStat(); | 1152 | local->resetTempSyncStat(); |
1153 | mLastCalendarSync = QDateTime::currentDateTime(); | 1153 | mLastCalendarSync = QDateTime::currentDateTime(); |
1154 | if ( mSyncManager->syncWithDesktop() ) { | 1154 | if ( mSyncManager->syncWithDesktop() ) { |
1155 | remote->resetPilotStat(1); | 1155 | remote->resetPilotStat(1); |
1156 | if ( KSyncManager::mRequestedSyncEvent.isValid() ) { | 1156 | if ( KSyncManager::mRequestedSyncEvent.isValid() ) { |
1157 | mLastCalendarSync = KSyncManager::mRequestedSyncEvent; | 1157 | mLastCalendarSync = KSyncManager::mRequestedSyncEvent; |
1158 | qDebug("KO: using extern time for calendar sync: %s ", mLastCalendarSync.toString().latin1() ); | 1158 | qDebug("KO: using extern time for calendar sync: %s ", mLastCalendarSync.toString().latin1() ); |
1159 | } else { | 1159 | } else { |
1160 | qDebug("KSyncManager::mRequestedSyncEvent has invalid datatime "); | 1160 | qDebug("KSyncManager::mRequestedSyncEvent has invalid datatime "); |
1161 | } | 1161 | } |
1162 | } | 1162 | } |
1163 | QDateTime modifiedCalendar = mLastCalendarSync; | 1163 | QDateTime modifiedCalendar = mLastCalendarSync; |
1164 | eventLSync = getLastSyncEvent(); | 1164 | eventLSync = getLastSyncEvent(); |
1165 | eventR = remote->event("last-syncEvent-"+mCurrentSyncName ); | 1165 | eventR = remote->event("last-syncEvent-"+mCurrentSyncName ); |
1166 | if ( eventR ) { | 1166 | if ( eventR ) { |
1167 | eventRSync = (Event*) eventR->clone(); | 1167 | eventRSync = (Event*) eventR->clone(); |
1168 | remote->deleteEvent(eventR ); | 1168 | remote->deleteEvent(eventR ); |
1169 | 1169 | ||
1170 | } else { | 1170 | } else { |
1171 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL || mSyncManager->syncWithDesktop()) { | 1171 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL || mSyncManager->syncWithDesktop()) { |
1172 | eventRSync = (Event*)eventLSync->clone(); | 1172 | eventRSync = (Event*)eventLSync->clone(); |
1173 | } else { | 1173 | } else { |
1174 | fullDateRange = true; | 1174 | fullDateRange = true; |
1175 | eventRSync = new Event(); | 1175 | eventRSync = new Event(); |
1176 | eventRSync->setSummary(mCurrentSyncName + i18n(" - sync event")); | 1176 | eventRSync->setSummary(mCurrentSyncName + i18n(" - sync event")); |
1177 | eventRSync->setUid("last-syncEvent-"+mCurrentSyncName ); | 1177 | eventRSync->setUid("last-syncEvent-"+mCurrentSyncName ); |
1178 | eventRSync->setDtStart( mLastCalendarSync ); | 1178 | eventRSync->setDtStart( mLastCalendarSync ); |
1179 | eventRSync->setDtEnd( mLastCalendarSync.addSecs( 7200 ) ); | 1179 | eventRSync->setDtEnd( mLastCalendarSync.addSecs( 7200 ) ); |
1180 | eventRSync->setCategories( i18n("SyncEvent") ); | 1180 | eventRSync->setCategories( i18n("SyncEvent") ); |
1181 | } | 1181 | } |
1182 | } | 1182 | } |
1183 | if ( eventLSync->dtStart() == mLastCalendarSync ) | 1183 | if ( eventLSync->dtStart() == mLastCalendarSync ) |
1184 | fullDateRange = true; | 1184 | fullDateRange = true; |
1185 | 1185 | ||
1186 | if ( ! fullDateRange ) { | 1186 | if ( ! fullDateRange ) { |
1187 | if ( eventLSync->dtStart() != eventRSync->dtStart() ) { | 1187 | if ( eventLSync->dtStart() != eventRSync->dtStart() ) { |
1188 | 1188 | ||
1189 | // qDebug("set fulldate to true %s %s" ,eventLSync->dtStart().toString().latin1(), eventRSync->dtStart().toString().latin1() ); | 1189 | // qDebug("set fulldate to true %s %s" ,eventLSync->dtStart().toString().latin1(), eventRSync->dtStart().toString().latin1() ); |
1190 | //qDebug("%d %d %d %d ", eventLSync->dtStart().time().second(), eventLSync->dtStart().time().msec() , eventRSync->dtStart().time().second(), eventRSync->dtStart().time().msec()); | 1190 | //qDebug("%d %d %d %d ", eventLSync->dtStart().time().second(), eventLSync->dtStart().time().msec() , eventRSync->dtStart().time().second(), eventRSync->dtStart().time().msec()); |
1191 | fullDateRange = true; | 1191 | fullDateRange = true; |
1192 | } | 1192 | } |
1193 | } | 1193 | } |
1194 | if ( mSyncManager->syncWithDesktop() ) { | 1194 | if ( mSyncManager->syncWithDesktop() ) { |
1195 | fullDateRange = ( eventLSync->dtStart() <= mLastCalendarSync && eventLSync->dtStart().addSecs(1) >= mLastCalendarSync ); | 1195 | fullDateRange = ( eventLSync->dtStart() <= mLastCalendarSync && eventLSync->dtStart().addSecs(1) >= mLastCalendarSync ); |
1196 | } | 1196 | } |
1197 | if ( fullDateRange ) | 1197 | if ( fullDateRange ) |
1198 | mLastCalendarSync = QDateTime::currentDateTime().addDays( -100*365); | 1198 | mLastCalendarSync = QDateTime::currentDateTime().addDays( -100*365); |
1199 | else | 1199 | else |
1200 | mLastCalendarSync = eventLSync->dtStart(); | 1200 | mLastCalendarSync = eventLSync->dtStart(); |
1201 | // for resyncing if own file has changed | 1201 | // for resyncing if own file has changed |
1202 | if ( mCurrentSyncDevice == "deleteaftersync" ) { | 1202 | if ( mCurrentSyncDevice == "deleteaftersync" ) { |
1203 | mLastCalendarSync = loadedFileVersion; | 1203 | mLastCalendarSync = loadedFileVersion; |
1204 | //qDebug("setting mLastCalendarSync "); | 1204 | //qDebug("setting mLastCalendarSync "); |
1205 | } | 1205 | } |
1206 | //qDebug("*************************** "); | 1206 | //qDebug("*************************** "); |
1207 | qDebug("KO: mLastCalendarSync %s .Full: %d",mLastCalendarSync.toString().latin1(), fullDateRange); | 1207 | qDebug("KO: mLastCalendarSync %s .Full: %d",mLastCalendarSync.toString().latin1(), fullDateRange); |
1208 | QPtrList<Incidence> er = remote->rawIncidences(); | 1208 | QPtrList<Incidence> er = remote->rawIncidences(); |
1209 | Incidence* inR = er.first(); | 1209 | Incidence* inR = er.first(); |
1210 | Incidence* inL; | 1210 | Incidence* inL; |
1211 | QProgressBar bar( er.count(),0 ); | 1211 | QProgressBar bar( er.count(),0 ); |
1212 | bar.setCaption (i18n("Syncing - close to abort!") ); | 1212 | bar.setCaption (i18n("Syncing - close to abort!") ); |
1213 | 1213 | ||
1214 | // ************** setting up filter ************* | 1214 | // ************** setting up filter ************* |
1215 | CalFilter *filterIN = 0; | 1215 | CalFilter *filterIN = 0; |
1216 | CalFilter *filterOUT = 0; | 1216 | CalFilter *filterOUT = 0; |
1217 | CalFilter *filter = mFilters.first(); | 1217 | CalFilter *filter = mFilters.first(); |
1218 | while(filter) { | 1218 | while(filter) { |
1219 | if ( filter->name() == mSyncManager->mFilterInCal ) | 1219 | if ( filter->name() == mSyncManager->mFilterInCal ) |
1220 | filterIN = filter; | 1220 | filterIN = filter; |
1221 | if ( filter->name() == mSyncManager->mFilterOutCal ) | 1221 | if ( filter->name() == mSyncManager->mFilterOutCal ) |
1222 | filterOUT = filter; | 1222 | filterOUT = filter; |
1223 | filter = mFilters.next(); | 1223 | filter = mFilters.next(); |
1224 | } | 1224 | } |
1225 | int w = 300; | 1225 | int w = 300; |
1226 | if ( QApplication::desktop()->width() < 320 ) | 1226 | if ( QApplication::desktop()->width() < 320 ) |
1227 | w = 220; | 1227 | w = 220; |
1228 | int h = bar.sizeHint().height() ; | 1228 | int h = bar.sizeHint().height() ; |
1229 | int dw = QApplication::desktop()->width(); | 1229 | int dw = QApplication::desktop()->width(); |
1230 | int dh = QApplication::desktop()->height(); | 1230 | int dh = QApplication::desktop()->height(); |
1231 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); | 1231 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); |
1232 | bar.show(); | 1232 | bar.show(); |
1233 | int modulo = (er.count()/10)+1; | 1233 | int modulo = (er.count()/10)+1; |
1234 | int incCounter = 0; | 1234 | int incCounter = 0; |
1235 | while ( inR ) { | 1235 | while ( inR ) { |
1236 | if ( ! bar.isVisible() ) | 1236 | if ( ! bar.isVisible() ) |
1237 | return false; | 1237 | return false; |
1238 | if ( incCounter % modulo == 0 ) | 1238 | if ( incCounter % modulo == 0 ) |
1239 | bar.setProgress( incCounter ); | 1239 | bar.setProgress( incCounter ); |
1240 | ++incCounter; | 1240 | ++incCounter; |
1241 | uid = inR->uid(); | 1241 | uid = inR->uid(); |
1242 | bool skipIncidence = false; | 1242 | bool skipIncidence = false; |
1243 | if ( uid.left(15) == QString("last-syncEvent-") ) | 1243 | if ( uid.left(15) == QString("last-syncEvent-") ) |
1244 | skipIncidence = true; | 1244 | skipIncidence = true; |
1245 | QString idS; | 1245 | QString idS; |
1246 | qApp->processEvents(); | 1246 | qApp->processEvents(); |
1247 | if ( !skipIncidence ) { | 1247 | if ( !skipIncidence ) { |
1248 | inL = local->incidence( uid ); | 1248 | inL = local->incidence( uid ); |
1249 | if ( inL ) { // maybe conflict - same uid in both calendars | 1249 | if ( inL ) { // maybe conflict - same uid in both calendars |
1250 | if ( (take = takeEvent( inL, inR, mode, fullDateRange )) > 0 ) { | 1250 | if ( (take = takeEvent( inL, inR, mode, fullDateRange )) > 0 ) { |
1251 | //qDebug("take %d %s ", take, inL->summary().latin1()); | 1251 | //qDebug("take %d %s ", take, inL->summary().latin1()); |
1252 | if ( take == 3 ) | 1252 | if ( take == 3 ) |
1253 | return false; | 1253 | return false; |
1254 | if ( take == 1 ) {// take local ********************** | 1254 | if ( take == 1 ) {// take local ********************** |
1255 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) | 1255 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) |
1256 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); | 1256 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); |
1257 | else | 1257 | else |
1258 | idS = inR->IDStr(); | 1258 | idS = inR->IDStr(); |
1259 | remote->deleteIncidence( inR ); | 1259 | remote->deleteIncidence( inR ); |
1260 | inR = inL->clone(); | 1260 | inR = inL->clone(); |
1261 | inR->setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); | 1261 | inR->setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); |
1262 | if ( mGlobalSyncMode != SYNC_MODE_EXTERNAL ) | 1262 | if ( mGlobalSyncMode != SYNC_MODE_EXTERNAL ) |
1263 | inR->setIDStr( idS ); | 1263 | inR->setIDStr( idS ); |
1264 | remote->addIncidence( inR ); | 1264 | remote->addIncidence( inR ); |
1265 | if ( mSyncManager->syncWithDesktop() ) | 1265 | if ( mSyncManager->syncWithDesktop() ) |
1266 | inR->setPilotId( 2 ); | 1266 | inR->setPilotId( 2 ); |
1267 | ++changedRemote; | 1267 | ++changedRemote; |
1268 | } else {// take remote ********************** | 1268 | } else {// take remote ********************** |
1269 | idS = inL->IDStr(); | 1269 | idS = inL->IDStr(); |
1270 | int pid = inL->pilotId(); | 1270 | int pid = inL->pilotId(); |
1271 | local->deleteIncidence( inL ); | 1271 | local->deleteIncidence( inL ); |
1272 | inL = inR->clone(); | 1272 | inL = inR->clone(); |
1273 | if ( mSyncManager->syncWithDesktop() ) | 1273 | if ( mSyncManager->syncWithDesktop() ) |
1274 | inL->setPilotId( pid ); | 1274 | inL->setPilotId( pid ); |
1275 | inL->setIDStr( idS ); | 1275 | inL->setIDStr( idS ); |
1276 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 1276 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
1277 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); | 1277 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); |
1278 | inL->setID( mCurrentSyncDevice, inR->getID(mCurrentSyncDevice) ); | 1278 | inL->setID( mCurrentSyncDevice, inR->getID(mCurrentSyncDevice) ); |
1279 | } | 1279 | } |
1280 | local->addIncidence( inL ); | 1280 | local->addIncidence( inL ); |
1281 | ++changedLocal; | 1281 | ++changedLocal; |
1282 | } | 1282 | } |
1283 | } | 1283 | } |
1284 | } else { // no conflict ********** add or delete remote | 1284 | } else { // no conflict ********** add or delete remote |
1285 | if ( !filterIN || filterIN->filterCalendarItem( inR ) ){ | 1285 | if ( !filterIN || filterIN->filterCalendarItem( inR ) ){ |
1286 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 1286 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
1287 | QString des = eventLSync->description(); | 1287 | QString des = eventLSync->description(); |
1288 | QString pref = "e"; | 1288 | QString pref = "e"; |
1289 | if ( inR->type() == "Todo" ) | 1289 | if ( inR->typeID() == todoID ) |
1290 | pref = "t"; | 1290 | pref = "t"; |
1291 | if ( des.find(pref+ inR->getID(mCurrentSyncDevice) +"," ) >= 0 && mode != 5) { // delete it | 1291 | if ( des.find(pref+ inR->getID(mCurrentSyncDevice) +"," ) >= 0 && mode != 5) { // delete it |
1292 | inR->setTempSyncStat( SYNC_TEMPSTATE_DELETE ); | 1292 | inR->setTempSyncStat( SYNC_TEMPSTATE_DELETE ); |
1293 | //remote->deleteIncidence( inR ); | 1293 | //remote->deleteIncidence( inR ); |
1294 | ++deletedEventR; | 1294 | ++deletedEventR; |
1295 | } else { | 1295 | } else { |
1296 | inR->setLastModified( modifiedCalendar ); | 1296 | inR->setLastModified( modifiedCalendar ); |
1297 | inL = inR->clone(); | 1297 | inL = inR->clone(); |
1298 | inL->setIDStr( ":" ); | 1298 | inL->setIDStr( ":" ); |
1299 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); | 1299 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); |
1300 | inL->setID( mCurrentSyncDevice, inR->getID(mCurrentSyncDevice) ); | 1300 | inL->setID( mCurrentSyncDevice, inR->getID(mCurrentSyncDevice) ); |
1301 | local->addIncidence( inL ); | 1301 | local->addIncidence( inL ); |
1302 | ++addedEvent; | 1302 | ++addedEvent; |
1303 | 1303 | ||
1304 | } | 1304 | } |
1305 | } else { | 1305 | } else { |
1306 | if ( inR->lastModified() > mLastCalendarSync || mode == 5 ) { | 1306 | if ( inR->lastModified() > mLastCalendarSync || mode == 5 ) { |
1307 | inR->setLastModified( modifiedCalendar ); | 1307 | inR->setLastModified( modifiedCalendar ); |
1308 | inL = inR->clone(); | 1308 | inL = inR->clone(); |
1309 | inL->setIDStr( ":" ); | 1309 | inL->setIDStr( ":" ); |
1310 | local->addIncidence( inL ); | 1310 | local->addIncidence( inL ); |
1311 | ++addedEvent; | 1311 | ++addedEvent; |
1312 | 1312 | ||
1313 | } else { | 1313 | } else { |
1314 | checkExternSyncEvent(eventRSyncSharp, inR); | 1314 | checkExternSyncEvent(eventRSyncSharp, inR); |
1315 | remote->deleteIncidence( inR ); | 1315 | remote->deleteIncidence( inR ); |
1316 | ++deletedEventR; | 1316 | ++deletedEventR; |
1317 | } | 1317 | } |
1318 | } | 1318 | } |
1319 | } else { | 1319 | } else { |
1320 | ++filteredIN; | 1320 | ++filteredIN; |
1321 | } | 1321 | } |
1322 | } | 1322 | } |
1323 | } | 1323 | } |
1324 | inR = er.next(); | 1324 | inR = er.next(); |
1325 | } | 1325 | } |
1326 | QPtrList<Incidence> el = local->rawIncidences(); | 1326 | QPtrList<Incidence> el = local->rawIncidences(); |
1327 | inL = el.first(); | 1327 | inL = el.first(); |
1328 | modulo = (el.count()/10)+1; | 1328 | modulo = (el.count()/10)+1; |
1329 | bar.setCaption (i18n("Add / remove events") ); | 1329 | bar.setCaption (i18n("Add / remove events") ); |
1330 | bar.setTotalSteps ( el.count() ) ; | 1330 | bar.setTotalSteps ( el.count() ) ; |
1331 | bar.show(); | 1331 | bar.show(); |
1332 | incCounter = 0; | 1332 | incCounter = 0; |
1333 | 1333 | ||
1334 | while ( inL ) { | 1334 | while ( inL ) { |
1335 | 1335 | ||
1336 | qApp->processEvents(); | 1336 | qApp->processEvents(); |
1337 | if ( ! bar.isVisible() ) | 1337 | if ( ! bar.isVisible() ) |
1338 | return false; | 1338 | return false; |
1339 | if ( incCounter % modulo == 0 ) | 1339 | if ( incCounter % modulo == 0 ) |
1340 | bar.setProgress( incCounter ); | 1340 | bar.setProgress( incCounter ); |
1341 | ++incCounter; | 1341 | ++incCounter; |
1342 | uid = inL->uid(); | 1342 | uid = inL->uid(); |
1343 | bool skipIncidence = false; | 1343 | bool skipIncidence = false; |
1344 | if ( uid.left(15) == QString("last-syncEvent-") ) | 1344 | if ( uid.left(15) == QString("last-syncEvent-") ) |
1345 | skipIncidence = true; | 1345 | skipIncidence = true; |
1346 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL && inL->type() == "Journal" ) | 1346 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL && inL->typeID() == journalID ) |
1347 | skipIncidence = true; | 1347 | skipIncidence = true; |
1348 | if ( !skipIncidence ) { | 1348 | if ( !skipIncidence ) { |
1349 | inR = remote->incidence( uid ); | 1349 | inR = remote->incidence( uid ); |
1350 | if ( ! inR ) { | 1350 | if ( ! inR ) { |
1351 | if ( !filterOUT || filterOUT->filterCalendarItem( inL ) ){ | 1351 | if ( !filterOUT || filterOUT->filterCalendarItem( inL ) ){ |
1352 | // no conflict ********** add or delete local | 1352 | // no conflict ********** add or delete local |
1353 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 1353 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
1354 | if ( !inL->getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) { | 1354 | if ( !inL->getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) { |
1355 | checkExternSyncEvent(eventLSyncSharp, inL); | 1355 | checkExternSyncEvent(eventLSyncSharp, inL); |
1356 | local->deleteIncidence( inL ); | 1356 | local->deleteIncidence( inL ); |
1357 | ++deletedEventL; | 1357 | ++deletedEventL; |
1358 | } else { | 1358 | } else { |
1359 | if ( ! mSyncManager->mWriteBackExistingOnly ) { | 1359 | if ( ! mSyncManager->mWriteBackExistingOnly ) { |
1360 | inL->removeID(mCurrentSyncDevice ); | 1360 | inL->removeID(mCurrentSyncDevice ); |
1361 | ++addedEventR; | 1361 | ++addedEventR; |
1362 | //qDebug("remote added Incidence %s ", inL->summary().latin1()); | 1362 | //qDebug("remote added Incidence %s ", inL->summary().latin1()); |
1363 | inL->setLastModified( modifiedCalendar ); | 1363 | inL->setLastModified( modifiedCalendar ); |
1364 | inR = inL->clone(); | 1364 | inR = inL->clone(); |
1365 | inR->setIDStr( ":" ); | 1365 | inR->setIDStr( ":" ); |
1366 | inR->setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); | 1366 | inR->setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); |
1367 | remote->addIncidence( inR ); | 1367 | remote->addIncidence( inR ); |
1368 | } | 1368 | } |
1369 | } | 1369 | } |
1370 | } else { | 1370 | } else { |
1371 | if ( inL->lastModified() < mLastCalendarSync && mode != 4 ) { | 1371 | if ( inL->lastModified() < mLastCalendarSync && mode != 4 ) { |
1372 | checkExternSyncEvent(eventLSyncSharp, inL); | 1372 | checkExternSyncEvent(eventLSyncSharp, inL); |
1373 | local->deleteIncidence( inL ); | 1373 | local->deleteIncidence( inL ); |
1374 | ++deletedEventL; | 1374 | ++deletedEventL; |
1375 | } else { | 1375 | } else { |
1376 | if ( ! mSyncManager->mWriteBackExistingOnly ) { | 1376 | if ( ! mSyncManager->mWriteBackExistingOnly ) { |
1377 | ++addedEventR; | 1377 | ++addedEventR; |
1378 | inL->setLastModified( modifiedCalendar ); | 1378 | inL->setLastModified( modifiedCalendar ); |
1379 | inR = inL->clone(); | 1379 | inR = inL->clone(); |
1380 | inR->setIDStr( ":" ); | 1380 | inR->setIDStr( ":" ); |
1381 | remote->addIncidence( inR ); | 1381 | remote->addIncidence( inR ); |
1382 | } | 1382 | } |
1383 | } | 1383 | } |
1384 | } | 1384 | } |
1385 | } else { | 1385 | } else { |
1386 | ++filteredOUT; | 1386 | ++filteredOUT; |
1387 | } | 1387 | } |
1388 | } | 1388 | } |
1389 | } | 1389 | } |
1390 | inL = el.next(); | 1390 | inL = el.next(); |
1391 | } | 1391 | } |
1392 | int delFut = 0; | 1392 | int delFut = 0; |
1393 | int remRem = 0; | 1393 | int remRem = 0; |
1394 | if ( mSyncManager->mWriteBackInFuture ) { | 1394 | if ( mSyncManager->mWriteBackInFuture ) { |
1395 | er = remote->rawIncidences(); | 1395 | er = remote->rawIncidences(); |
1396 | remRem = er.count(); | 1396 | remRem = er.count(); |
1397 | inR = er.first(); | 1397 | inR = er.first(); |
1398 | QDateTime dt; | 1398 | QDateTime dt; |
1399 | QDateTime cur = QDateTime::currentDateTime().addDays( -(mSyncManager->mWriteBackInPast * 7) ); | 1399 | QDateTime cur = QDateTime::currentDateTime().addDays( -(mSyncManager->mWriteBackInPast * 7) ); |
1400 | QDateTime end = QDateTime::currentDateTime().addDays( (mSyncManager->mWriteBackInFuture ) *7 ); | 1400 | QDateTime end = QDateTime::currentDateTime().addDays( (mSyncManager->mWriteBackInFuture ) *7 ); |
1401 | while ( inR ) { | 1401 | while ( inR ) { |
1402 | if ( inR->type() == "Todo" ) { | 1402 | if ( inR->typeID() == todoID ) { |
1403 | Todo * t = (Todo*)inR; | 1403 | Todo * t = (Todo*)inR; |
1404 | if ( t->hasDueDate() ) | 1404 | if ( t->hasDueDate() ) |
1405 | dt = t->dtDue(); | 1405 | dt = t->dtDue(); |
1406 | else | 1406 | else |
1407 | dt = cur.addSecs( 62 ); | 1407 | dt = cur.addSecs( 62 ); |
1408 | } | 1408 | } |
1409 | else if (inR->type() == "Event" ) { | 1409 | else if (inR->typeID() == eventID ) { |
1410 | bool ok; | 1410 | bool ok; |
1411 | dt = inR->getNextOccurence( cur, &ok ); | 1411 | dt = inR->getNextOccurence( cur, &ok ); |
1412 | if ( !ok ) | 1412 | if ( !ok ) |
1413 | dt = cur.addSecs( -62 ); | 1413 | dt = cur.addSecs( -62 ); |
1414 | } | 1414 | } |
1415 | else | 1415 | else |
1416 | dt = inR->dtStart(); | 1416 | dt = inR->dtStart(); |
1417 | if ( dt < cur || dt > end ) { | 1417 | if ( dt < cur || dt > end ) { |
1418 | remote->deleteIncidence( inR ); | 1418 | remote->deleteIncidence( inR ); |
1419 | ++delFut; | 1419 | ++delFut; |
1420 | } | 1420 | } |
1421 | inR = er.next(); | 1421 | inR = er.next(); |
1422 | } | 1422 | } |
1423 | } | 1423 | } |
1424 | bar.hide(); | 1424 | bar.hide(); |
1425 | mLastCalendarSync = QDateTime::currentDateTime().addSecs( 1 ); | 1425 | mLastCalendarSync = QDateTime::currentDateTime().addSecs( 1 ); |
1426 | eventLSync->setReadOnly( false ); | 1426 | eventLSync->setReadOnly( false ); |
1427 | eventLSync->setDtStart( mLastCalendarSync ); | 1427 | eventLSync->setDtStart( mLastCalendarSync ); |
1428 | eventRSync->setDtStart( mLastCalendarSync ); | 1428 | eventRSync->setDtStart( mLastCalendarSync ); |
1429 | eventLSync->setDtEnd( mLastCalendarSync.addSecs( 3600 ) ); | 1429 | eventLSync->setDtEnd( mLastCalendarSync.addSecs( 3600 ) ); |
1430 | eventRSync->setDtEnd( mLastCalendarSync.addSecs( 3600 ) ); | 1430 | eventRSync->setDtEnd( mLastCalendarSync.addSecs( 3600 ) ); |
1431 | eventRSync->setLocation( i18n("Remote from: ")+mCurrentSyncName ) ; | 1431 | eventRSync->setLocation( i18n("Remote from: ")+mCurrentSyncName ) ; |
1432 | eventLSync->setLocation(i18n("Local from: ") + mCurrentSyncName ); | 1432 | eventLSync->setLocation(i18n("Local from: ") + mCurrentSyncName ); |
1433 | eventLSync->setReadOnly( true ); | 1433 | eventLSync->setReadOnly( true ); |
1434 | qDebug("KO: Normal sync: %d ",mGlobalSyncMode == SYNC_MODE_NORMAL ); | 1434 | qDebug("KO: Normal sync: %d ",mGlobalSyncMode == SYNC_MODE_NORMAL ); |
1435 | if ( mGlobalSyncMode == SYNC_MODE_NORMAL && !mSyncManager->syncWithDesktop()) // kde is abnormal... | 1435 | if ( mGlobalSyncMode == SYNC_MODE_NORMAL && !mSyncManager->syncWithDesktop()) // kde is abnormal... |
1436 | remote->addEvent( eventRSync ); | 1436 | remote->addEvent( eventRSync ); |
1437 | else | 1437 | else |
1438 | delete eventRSync; | 1438 | delete eventRSync; |
1439 | qDebug("KO: Sync with desktop %d ",mSyncManager->syncWithDesktop() ); | 1439 | qDebug("KO: Sync with desktop %d ",mSyncManager->syncWithDesktop() ); |
1440 | QString mes; | 1440 | QString mes; |
1441 | mes .sprintf( i18n("Synchronization summary:\n\n %d items added to local\n %d items added to remote\n %d items updated on local\n %d items updated on remote\n %d items deleted on local\n %d items deleted on remote\n %d incoming filtered out\n %d outgoing filtered out\n"),addedEvent, addedEventR, changedLocal, changedRemote, deletedEventL, deletedEventR, filteredIN, filteredOUT ); | 1441 | mes .sprintf( i18n("Synchronization summary:\n\n %d items added to local\n %d items added to remote\n %d items updated on local\n %d items updated on remote\n %d items deleted on local\n %d items deleted on remote\n %d incoming filtered out\n %d outgoing filtered out\n"),addedEvent, addedEventR, changedLocal, changedRemote, deletedEventL, deletedEventR, filteredIN, filteredOUT ); |
1442 | QString delmess; | 1442 | QString delmess; |
1443 | if ( delFut ) { | 1443 | if ( delFut ) { |
1444 | delmess.sprintf( i18n("%d items skipped on remote,\nbecause they are more\nthan %d weeks in the past or\nmore than %d weeks in the future.\nAfter skipping, remote has\n%d calendar/todo items."), delFut,mSyncManager->mWriteBackInPast,mSyncManager->mWriteBackInFuture, remRem-delFut); | 1444 | delmess.sprintf( i18n("%d items skipped on remote,\nbecause they are more\nthan %d weeks in the past or\nmore than %d weeks in the future.\nAfter skipping, remote has\n%d calendar/todo items."), delFut,mSyncManager->mWriteBackInPast,mSyncManager->mWriteBackInFuture, remRem-delFut); |
1445 | mes += delmess; | 1445 | mes += delmess; |
1446 | } | 1446 | } |
1447 | mes = i18n("Local calendar changed!\n") +mes; | 1447 | mes = i18n("Local calendar changed!\n") +mes; |
1448 | mCalendar->checkAlarmForIncidence( 0, true ); | 1448 | mCalendar->checkAlarmForIncidence( 0, true ); |
1449 | qDebug( mes ); | 1449 | qDebug( mes ); |
1450 | if ( mSyncManager->mShowSyncSummary ) { | 1450 | if ( mSyncManager->mShowSyncSummary ) { |
1451 | if ( KMessageBox::Cancel == KMessageBox::warningContinueCancel(this, mes, | 1451 | if ( KMessageBox::Cancel == KMessageBox::warningContinueCancel(this, mes, |
1452 | i18n("KO/Pi Synchronization"),i18n("Write back"))) { | 1452 | i18n("KO/Pi Synchronization"),i18n("Write back"))) { |
1453 | qDebug("KO: WB cancelled "); | 1453 | qDebug("KO: WB cancelled "); |
1454 | mSyncManager->mWriteBackFile = false; | 1454 | mSyncManager->mWriteBackFile = false; |
1455 | return syncOK; | 1455 | return syncOK; |
1456 | } | 1456 | } |
1457 | } | 1457 | } |
1458 | return syncOK; | 1458 | return syncOK; |
1459 | } | 1459 | } |
1460 | 1460 | ||
1461 | void CalendarView::setSyncDevice( QString s ) | 1461 | void CalendarView::setSyncDevice( QString s ) |
1462 | { | 1462 | { |
1463 | mCurrentSyncDevice= s; | 1463 | mCurrentSyncDevice= s; |
1464 | } | 1464 | } |
1465 | void CalendarView::setSyncName( QString s ) | 1465 | void CalendarView::setSyncName( QString s ) |
1466 | { | 1466 | { |
1467 | mCurrentSyncName= s; | 1467 | mCurrentSyncName= s; |
1468 | } | 1468 | } |
1469 | bool CalendarView::syncCalendar(QString filename, int mode) | 1469 | bool CalendarView::syncCalendar(QString filename, int mode) |
1470 | { | 1470 | { |
1471 | //qDebug("syncCalendar %s ", filename.latin1()); | 1471 | //qDebug("syncCalendar %s ", filename.latin1()); |
1472 | mGlobalSyncMode = SYNC_MODE_NORMAL; | 1472 | mGlobalSyncMode = SYNC_MODE_NORMAL; |
1473 | CalendarLocal* calendar = new CalendarLocal(); | 1473 | CalendarLocal* calendar = new CalendarLocal(); |
1474 | calendar->setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); | 1474 | calendar->setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); |
1475 | FileStorage* storage = new FileStorage( calendar ); | 1475 | FileStorage* storage = new FileStorage( calendar ); |
1476 | bool syncOK = false; | 1476 | bool syncOK = false; |
1477 | storage->setFileName( filename ); | 1477 | storage->setFileName( filename ); |
1478 | // qDebug("loading ... "); | 1478 | // qDebug("loading ... "); |
1479 | if ( storage->load() ) { | 1479 | if ( storage->load() ) { |
1480 | getEventViewerDialog()->setSyncMode( true ); | 1480 | getEventViewerDialog()->setSyncMode( true ); |
1481 | syncOK = synchronizeCalendar( mCalendar, calendar, mode ); | 1481 | syncOK = synchronizeCalendar( mCalendar, calendar, mode ); |
1482 | getEventViewerDialog()->setSyncMode( false ); | 1482 | getEventViewerDialog()->setSyncMode( false ); |
1483 | if ( syncOK ) { | 1483 | if ( syncOK ) { |
1484 | if ( mSyncManager->mWriteBackFile ) | 1484 | if ( mSyncManager->mWriteBackFile ) |
1485 | { | 1485 | { |
1486 | storage->setSaveFormat( new ICalFormat() ); | 1486 | storage->setSaveFormat( new ICalFormat() ); |
1487 | storage->save(); | 1487 | storage->save(); |
1488 | } | 1488 | } |
1489 | } | 1489 | } |
1490 | setModified( true ); | 1490 | setModified( true ); |
1491 | } | 1491 | } |
1492 | delete storage; | 1492 | delete storage; |
1493 | delete calendar; | 1493 | delete calendar; |
1494 | if ( syncOK ) | 1494 | if ( syncOK ) |
1495 | updateView(); | 1495 | updateView(); |
1496 | return syncOK; | 1496 | return syncOK; |
1497 | } | 1497 | } |
1498 | 1498 | ||
1499 | void CalendarView::syncExternal( int mode ) | 1499 | void CalendarView::syncExternal( int mode ) |
1500 | { | 1500 | { |
1501 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; | 1501 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; |
1502 | 1502 | ||
1503 | qApp->processEvents(); | 1503 | qApp->processEvents(); |
1504 | CalendarLocal* calendar = new CalendarLocal(); | 1504 | CalendarLocal* calendar = new CalendarLocal(); |
1505 | calendar->setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); | 1505 | calendar->setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); |
1506 | bool syncOK = false; | 1506 | bool syncOK = false; |
1507 | bool loadSuccess = false; | 1507 | bool loadSuccess = false; |
1508 | PhoneFormat* phoneFormat = 0; | 1508 | PhoneFormat* phoneFormat = 0; |
1509 | emit tempDisableBR(true); | 1509 | emit tempDisableBR(true); |
1510 | #ifndef DESKTOP_VERSION | 1510 | #ifndef DESKTOP_VERSION |
1511 | SharpFormat* sharpFormat = 0; | 1511 | SharpFormat* sharpFormat = 0; |
1512 | if ( mode == 0 ) { // sharp | 1512 | if ( mode == 0 ) { // sharp |
1513 | sharpFormat = new SharpFormat () ; | 1513 | sharpFormat = new SharpFormat () ; |
1514 | loadSuccess = sharpFormat->load( calendar, mCalendar ); | 1514 | loadSuccess = sharpFormat->load( calendar, mCalendar ); |
1515 | 1515 | ||
1516 | } else | 1516 | } else |
1517 | #endif | 1517 | #endif |
1518 | if ( mode == 1 ) { // phone | 1518 | if ( mode == 1 ) { // phone |
1519 | phoneFormat = new PhoneFormat (mCurrentSyncDevice, | 1519 | phoneFormat = new PhoneFormat (mCurrentSyncDevice, |
1520 | mSyncManager->mPhoneDevice, | 1520 | mSyncManager->mPhoneDevice, |
1521 | mSyncManager->mPhoneConnection, | 1521 | mSyncManager->mPhoneConnection, |
1522 | mSyncManager->mPhoneModel); | 1522 | mSyncManager->mPhoneModel); |
1523 | loadSuccess = phoneFormat->load( calendar,mCalendar); | 1523 | loadSuccess = phoneFormat->load( calendar,mCalendar); |
1524 | 1524 | ||
1525 | } else { | 1525 | } else { |
1526 | emit tempDisableBR(false); | 1526 | emit tempDisableBR(false); |
1527 | return; | 1527 | return; |
1528 | } | 1528 | } |
1529 | if ( loadSuccess ) { | 1529 | if ( loadSuccess ) { |
1530 | getEventViewerDialog()->setSyncMode( true ); | 1530 | getEventViewerDialog()->setSyncMode( true ); |
1531 | syncOK = synchronizeCalendar( mCalendar, calendar, mSyncManager->mSyncAlgoPrefs ); | 1531 | syncOK = synchronizeCalendar( mCalendar, calendar, mSyncManager->mSyncAlgoPrefs ); |
1532 | getEventViewerDialog()->setSyncMode( false ); | 1532 | getEventViewerDialog()->setSyncMode( false ); |
1533 | qApp->processEvents(); | 1533 | qApp->processEvents(); |
1534 | if ( syncOK ) { | 1534 | if ( syncOK ) { |
1535 | if ( mSyncManager->mWriteBackFile ) | 1535 | if ( mSyncManager->mWriteBackFile ) |
1536 | { | 1536 | { |
1537 | QPtrList<Incidence> iL = mCalendar->rawIncidences(); | 1537 | QPtrList<Incidence> iL = mCalendar->rawIncidences(); |
@@ -2352,680 +2352,680 @@ void CalendarView::updateConfig() | |||
2352 | //mViewManager->raiseCurrentView(); | 2352 | //mViewManager->raiseCurrentView(); |
2353 | } | 2353 | } |
2354 | 2354 | ||
2355 | 2355 | ||
2356 | void CalendarView::eventChanged(Event *event) | 2356 | void CalendarView::eventChanged(Event *event) |
2357 | { | 2357 | { |
2358 | changeEventDisplay(event,KOGlobals::EVENTEDITED); | 2358 | changeEventDisplay(event,KOGlobals::EVENTEDITED); |
2359 | //updateUnmanagedViews(); | 2359 | //updateUnmanagedViews(); |
2360 | } | 2360 | } |
2361 | 2361 | ||
2362 | void CalendarView::eventAdded(Event *event) | 2362 | void CalendarView::eventAdded(Event *event) |
2363 | { | 2363 | { |
2364 | changeEventDisplay(event,KOGlobals::EVENTADDED); | 2364 | changeEventDisplay(event,KOGlobals::EVENTADDED); |
2365 | } | 2365 | } |
2366 | 2366 | ||
2367 | void CalendarView::eventToBeDeleted(Event *) | 2367 | void CalendarView::eventToBeDeleted(Event *) |
2368 | { | 2368 | { |
2369 | kdDebug() << "CalendarView::eventToBeDeleted(): to be implemented" << endl; | 2369 | kdDebug() << "CalendarView::eventToBeDeleted(): to be implemented" << endl; |
2370 | } | 2370 | } |
2371 | 2371 | ||
2372 | void CalendarView::eventDeleted() | 2372 | void CalendarView::eventDeleted() |
2373 | { | 2373 | { |
2374 | changeEventDisplay(0,KOGlobals::EVENTDELETED); | 2374 | changeEventDisplay(0,KOGlobals::EVENTDELETED); |
2375 | } | 2375 | } |
2376 | void CalendarView::changeTodoDisplay(Todo *which, int action) | 2376 | void CalendarView::changeTodoDisplay(Todo *which, int action) |
2377 | { | 2377 | { |
2378 | changeIncidenceDisplay((Incidence *)which, action); | 2378 | changeIncidenceDisplay((Incidence *)which, action); |
2379 | mDateNavigator->updateView(); //LR | 2379 | mDateNavigator->updateView(); //LR |
2380 | //mDialogManager->updateSearchDialog(); | 2380 | //mDialogManager->updateSearchDialog(); |
2381 | 2381 | ||
2382 | if (which) { | 2382 | if (which) { |
2383 | mViewManager->updateWNview(); | 2383 | mViewManager->updateWNview(); |
2384 | //mTodoList->updateView(); | 2384 | //mTodoList->updateView(); |
2385 | } | 2385 | } |
2386 | 2386 | ||
2387 | } | 2387 | } |
2388 | 2388 | ||
2389 | void CalendarView::changeIncidenceDisplay(Incidence *which, int action) | 2389 | void CalendarView::changeIncidenceDisplay(Incidence *which, int action) |
2390 | { | 2390 | { |
2391 | updateUnmanagedViews(); | 2391 | updateUnmanagedViews(); |
2392 | //qDebug(" CalendarView::changeIncidenceDisplay++++++++++++++++++++++++++ %d %d ",which, action ); | 2392 | //qDebug(" CalendarView::changeIncidenceDisplay++++++++++++++++++++++++++ %d %d ",which, action ); |
2393 | if ( action == KOGlobals::EVENTDELETED ) { //delete | 2393 | if ( action == KOGlobals::EVENTDELETED ) { //delete |
2394 | mCalendar->checkAlarmForIncidence( 0, true ); | 2394 | mCalendar->checkAlarmForIncidence( 0, true ); |
2395 | if ( mEventViewerDialog ) | 2395 | if ( mEventViewerDialog ) |
2396 | mEventViewerDialog->hide(); | 2396 | mEventViewerDialog->hide(); |
2397 | } | 2397 | } |
2398 | else | 2398 | else |
2399 | mCalendar->checkAlarmForIncidence( which , false ); | 2399 | mCalendar->checkAlarmForIncidence( which , false ); |
2400 | } | 2400 | } |
2401 | 2401 | ||
2402 | // most of the changeEventDisplays() right now just call the view's | 2402 | // most of the changeEventDisplays() right now just call the view's |
2403 | // total update mode, but they SHOULD be recoded to be more refresh-efficient. | 2403 | // total update mode, but they SHOULD be recoded to be more refresh-efficient. |
2404 | void CalendarView::changeEventDisplay(Event *which, int action) | 2404 | void CalendarView::changeEventDisplay(Event *which, int action) |
2405 | { | 2405 | { |
2406 | // kdDebug() << "CalendarView::changeEventDisplay" << endl; | 2406 | // kdDebug() << "CalendarView::changeEventDisplay" << endl; |
2407 | changeIncidenceDisplay((Incidence *)which, action); | 2407 | changeIncidenceDisplay((Incidence *)which, action); |
2408 | mDateNavigator->updateView(); | 2408 | mDateNavigator->updateView(); |
2409 | //mDialogManager->updateSearchDialog(); | 2409 | //mDialogManager->updateSearchDialog(); |
2410 | 2410 | ||
2411 | if (which) { | 2411 | if (which) { |
2412 | // If there is an event view visible update the display | 2412 | // If there is an event view visible update the display |
2413 | mViewManager->currentView()->changeEventDisplay(which,action); | 2413 | mViewManager->currentView()->changeEventDisplay(which,action); |
2414 | // TODO: check, if update needed | 2414 | // TODO: check, if update needed |
2415 | // if (which->getTodoStatus()) { | 2415 | // if (which->getTodoStatus()) { |
2416 | mTodoList->updateView(); | 2416 | mTodoList->updateView(); |
2417 | // } | 2417 | // } |
2418 | } else { | 2418 | } else { |
2419 | mViewManager->currentView()->updateView(); | 2419 | mViewManager->currentView()->updateView(); |
2420 | } | 2420 | } |
2421 | } | 2421 | } |
2422 | 2422 | ||
2423 | 2423 | ||
2424 | void CalendarView::updateTodoViews() | 2424 | void CalendarView::updateTodoViews() |
2425 | { | 2425 | { |
2426 | mTodoList->updateView(); | 2426 | mTodoList->updateView(); |
2427 | mViewManager->currentView()->updateView(); | 2427 | mViewManager->currentView()->updateView(); |
2428 | 2428 | ||
2429 | } | 2429 | } |
2430 | 2430 | ||
2431 | 2431 | ||
2432 | void CalendarView::updateView(const QDate &start, const QDate &end) | 2432 | void CalendarView::updateView(const QDate &start, const QDate &end) |
2433 | { | 2433 | { |
2434 | mTodoList->updateView(); | 2434 | mTodoList->updateView(); |
2435 | mViewManager->updateView(start, end); | 2435 | mViewManager->updateView(start, end); |
2436 | //mDateNavigator->updateView(); | 2436 | //mDateNavigator->updateView(); |
2437 | } | 2437 | } |
2438 | 2438 | ||
2439 | void CalendarView::clearAllViews() | 2439 | void CalendarView::clearAllViews() |
2440 | { | 2440 | { |
2441 | mTodoList->clearList(); | 2441 | mTodoList->clearList(); |
2442 | mViewManager->clearAllViews(); | 2442 | mViewManager->clearAllViews(); |
2443 | SearchDialog * sd = mDialogManager->getSearchDialog(); | 2443 | SearchDialog * sd = mDialogManager->getSearchDialog(); |
2444 | if ( sd ) { | 2444 | if ( sd ) { |
2445 | KOListView* kol = sd->listview(); | 2445 | KOListView* kol = sd->listview(); |
2446 | if ( kol ) | 2446 | if ( kol ) |
2447 | kol->clearList(); | 2447 | kol->clearList(); |
2448 | } | 2448 | } |
2449 | } | 2449 | } |
2450 | void CalendarView::updateView() | 2450 | void CalendarView::updateView() |
2451 | { | 2451 | { |
2452 | DateList tmpList = mNavigator->selectedDates(); | 2452 | DateList tmpList = mNavigator->selectedDates(); |
2453 | 2453 | ||
2454 | if ( KOPrefs::instance()->mHideNonStartedTodos ) | 2454 | if ( KOPrefs::instance()->mHideNonStartedTodos ) |
2455 | mTodoList->updateView(); | 2455 | mTodoList->updateView(); |
2456 | // We assume that the navigator only selects consecutive days. | 2456 | // We assume that the navigator only selects consecutive days. |
2457 | updateView( tmpList.first(), tmpList.last() ); | 2457 | updateView( tmpList.first(), tmpList.last() ); |
2458 | } | 2458 | } |
2459 | 2459 | ||
2460 | void CalendarView::updateUnmanagedViews() | 2460 | void CalendarView::updateUnmanagedViews() |
2461 | { | 2461 | { |
2462 | mDateNavigator->updateDayMatrix(); | 2462 | mDateNavigator->updateDayMatrix(); |
2463 | } | 2463 | } |
2464 | 2464 | ||
2465 | int CalendarView::msgItemDelete(const QString name) | 2465 | int CalendarView::msgItemDelete(const QString name) |
2466 | { | 2466 | { |
2467 | return KMessageBox::warningContinueCancel(this,name +"\n\n"+ | 2467 | return KMessageBox::warningContinueCancel(this,name +"\n\n"+ |
2468 | i18n("This item will be\npermanently deleted."), | 2468 | i18n("This item will be\npermanently deleted."), |
2469 | i18n("KO/Pi Confirmation"),i18n("Delete")); | 2469 | i18n("KO/Pi Confirmation"),i18n("Delete")); |
2470 | } | 2470 | } |
2471 | 2471 | ||
2472 | 2472 | ||
2473 | void CalendarView::edit_cut() | 2473 | void CalendarView::edit_cut() |
2474 | { | 2474 | { |
2475 | Event *anEvent=0; | 2475 | Event *anEvent=0; |
2476 | 2476 | ||
2477 | Incidence *incidence = mViewManager->currentView()->selectedIncidences().first(); | 2477 | Incidence *incidence = mViewManager->currentView()->selectedIncidences().first(); |
2478 | 2478 | ||
2479 | if (mViewManager->currentView()->isEventView()) { | 2479 | if (mViewManager->currentView()->isEventView()) { |
2480 | if ( incidence && incidence->type() == "Event" ) { | 2480 | if ( incidence && incidence->typeID() == eventID ) { |
2481 | anEvent = static_cast<Event *>(incidence); | 2481 | anEvent = static_cast<Event *>(incidence); |
2482 | } | 2482 | } |
2483 | } | 2483 | } |
2484 | 2484 | ||
2485 | if (!anEvent) { | 2485 | if (!anEvent) { |
2486 | KNotifyClient::beep(); | 2486 | KNotifyClient::beep(); |
2487 | return; | 2487 | return; |
2488 | } | 2488 | } |
2489 | DndFactory factory( mCalendar ); | 2489 | DndFactory factory( mCalendar ); |
2490 | factory.cutIncidence(anEvent); | 2490 | factory.cutIncidence(anEvent); |
2491 | changeEventDisplay(anEvent, KOGlobals::EVENTDELETED); | 2491 | changeEventDisplay(anEvent, KOGlobals::EVENTDELETED); |
2492 | } | 2492 | } |
2493 | 2493 | ||
2494 | void CalendarView::edit_copy() | 2494 | void CalendarView::edit_copy() |
2495 | { | 2495 | { |
2496 | Event *anEvent=0; | 2496 | Event *anEvent=0; |
2497 | 2497 | ||
2498 | Incidence *incidence = mViewManager->currentView()->selectedIncidences().first(); | 2498 | Incidence *incidence = mViewManager->currentView()->selectedIncidences().first(); |
2499 | 2499 | ||
2500 | if (mViewManager->currentView()->isEventView()) { | 2500 | if (mViewManager->currentView()->isEventView()) { |
2501 | if ( incidence && incidence->type() == "Event" ) { | 2501 | if ( incidence && incidence->typeID() == eventID ) { |
2502 | anEvent = static_cast<Event *>(incidence); | 2502 | anEvent = static_cast<Event *>(incidence); |
2503 | } | 2503 | } |
2504 | } | 2504 | } |
2505 | 2505 | ||
2506 | if (!anEvent) { | 2506 | if (!anEvent) { |
2507 | KNotifyClient::beep(); | 2507 | KNotifyClient::beep(); |
2508 | return; | 2508 | return; |
2509 | } | 2509 | } |
2510 | DndFactory factory( mCalendar ); | 2510 | DndFactory factory( mCalendar ); |
2511 | factory.copyIncidence(anEvent); | 2511 | factory.copyIncidence(anEvent); |
2512 | } | 2512 | } |
2513 | 2513 | ||
2514 | void CalendarView::edit_paste() | 2514 | void CalendarView::edit_paste() |
2515 | { | 2515 | { |
2516 | QDate date = mNavigator->selectedDates().first(); | 2516 | QDate date = mNavigator->selectedDates().first(); |
2517 | 2517 | ||
2518 | DndFactory factory( mCalendar ); | 2518 | DndFactory factory( mCalendar ); |
2519 | Event *pastedEvent = (Event *)factory.pasteIncidence( date ); | 2519 | Event *pastedEvent = (Event *)factory.pasteIncidence( date ); |
2520 | 2520 | ||
2521 | changeEventDisplay( pastedEvent, KOGlobals::EVENTADDED ); | 2521 | changeEventDisplay( pastedEvent, KOGlobals::EVENTADDED ); |
2522 | } | 2522 | } |
2523 | 2523 | ||
2524 | void CalendarView::edit_options() | 2524 | void CalendarView::edit_options() |
2525 | { | 2525 | { |
2526 | QString tz = KPimGlobalPrefs::instance()->mTimeZoneId; | 2526 | QString tz = KPimGlobalPrefs::instance()->mTimeZoneId; |
2527 | emit save(); | 2527 | emit save(); |
2528 | emit saveStopTimer(); | 2528 | emit saveStopTimer(); |
2529 | mDialogManager->showOptionsDialog(); | 2529 | mDialogManager->showOptionsDialog(); |
2530 | if ( tz != KPimGlobalPrefs::instance()->mTimeZoneId) { | 2530 | if ( tz != KPimGlobalPrefs::instance()->mTimeZoneId) { |
2531 | emit saveStopTimer(); | 2531 | emit saveStopTimer(); |
2532 | if ( KMessageBox::Cancel == KMessageBox::warningContinueCancel(this, i18n("The timezone has changed!\nShould the calendar be reloaded\nto apply timezone changes?\nPlease read Menu: Help->FAQ:\n\"How do I change the timezone?\"\nas well!"), | 2532 | if ( KMessageBox::Cancel == KMessageBox::warningContinueCancel(this, i18n("The timezone has changed!\nShould the calendar be reloaded\nto apply timezone changes?\nPlease read Menu: Help->FAQ:\n\"How do I change the timezone?\"\nas well!"), |
2533 | i18n("Timezone settings"),i18n("Reload"))) { | 2533 | i18n("Timezone settings"),i18n("Reload"))) { |
2534 | qDebug("KO: TZ reload cancelled "); | 2534 | qDebug("KO: TZ reload cancelled "); |
2535 | return; | 2535 | return; |
2536 | } | 2536 | } |
2537 | qDebug("KO: Timezone change "); | 2537 | qDebug("KO: Timezone change "); |
2538 | openCalendar( MainWindow::defaultFileName() ); | 2538 | openCalendar( MainWindow::defaultFileName() ); |
2539 | setModified(true); | 2539 | setModified(true); |
2540 | } | 2540 | } |
2541 | else | 2541 | else |
2542 | qDebug("KO: No tz change "); | 2542 | qDebug("KO: No tz change "); |
2543 | 2543 | ||
2544 | } | 2544 | } |
2545 | 2545 | ||
2546 | 2546 | ||
2547 | void CalendarView::slotSelectPickerDate( QDate d) | 2547 | void CalendarView::slotSelectPickerDate( QDate d) |
2548 | { | 2548 | { |
2549 | mDateFrame->hide(); | 2549 | mDateFrame->hide(); |
2550 | if ( mDatePickerMode == 1 ) { | 2550 | if ( mDatePickerMode == 1 ) { |
2551 | mNavigator->slotDaySelect( d ); | 2551 | mNavigator->slotDaySelect( d ); |
2552 | } else if ( mDatePickerMode == 2 ) { | 2552 | } else if ( mDatePickerMode == 2 ) { |
2553 | if ( mMoveIncidence->type() == "Todo" ) { | 2553 | if ( mMoveIncidence->typeID() == todoID ) { |
2554 | Todo * to = (Todo *) mMoveIncidence; | 2554 | Todo * to = (Todo *) mMoveIncidence; |
2555 | QTime tim; | 2555 | QTime tim; |
2556 | int len = 0; | 2556 | int len = 0; |
2557 | if ( to->hasStartDate() && to->hasDueDate() ) | 2557 | if ( to->hasStartDate() && to->hasDueDate() ) |
2558 | len = to->dtStart().secsTo( to->dtDue()); | 2558 | len = to->dtStart().secsTo( to->dtDue()); |
2559 | if ( to->hasDueDate() ) | 2559 | if ( to->hasDueDate() ) |
2560 | tim = to->dtDue().time(); | 2560 | tim = to->dtDue().time(); |
2561 | else { | 2561 | else { |
2562 | tim = QTime ( 0,0,0 ); | 2562 | tim = QTime ( 0,0,0 ); |
2563 | to->setFloats( true ); | 2563 | to->setFloats( true ); |
2564 | to->setHasDueDate( true ); | 2564 | to->setHasDueDate( true ); |
2565 | } | 2565 | } |
2566 | QDateTime dt ( d,tim ); | 2566 | QDateTime dt ( d,tim ); |
2567 | to->setDtDue( dt ); | 2567 | to->setDtDue( dt ); |
2568 | 2568 | ||
2569 | if ( to->hasStartDate() ) { | 2569 | if ( to->hasStartDate() ) { |
2570 | if ( len>0 ) | 2570 | if ( len>0 ) |
2571 | to->setDtStart(to->dtDue().addSecs( -len )); | 2571 | to->setDtStart(to->dtDue().addSecs( -len )); |
2572 | else | 2572 | else |
2573 | if (to->dtStart() > to->dtDue() ) | 2573 | if (to->dtStart() > to->dtDue() ) |
2574 | to->setDtStart(to->dtDue().addDays( -3 )); | 2574 | to->setDtStart(to->dtDue().addDays( -3 )); |
2575 | } | 2575 | } |
2576 | 2576 | ||
2577 | todoChanged( to ); | 2577 | todoChanged( to ); |
2578 | } else { | 2578 | } else { |
2579 | if ( mMoveIncidence->doesRecur() ) { | 2579 | if ( mMoveIncidence->doesRecur() ) { |
2580 | #if 0 | 2580 | #if 0 |
2581 | // PENDING implement this | 2581 | // PENDING implement this |
2582 | Incidence* newInc = mMoveIncidence->recreateCloneException( mMoveIncidenceOldDate ); | 2582 | Incidence* newInc = mMoveIncidence->recreateCloneException( mMoveIncidenceOldDate ); |
2583 | mCalendar()->addIncidence( newInc ); | 2583 | mCalendar()->addIncidence( newInc ); |
2584 | if ( mMoveIncidence->type() == "Todo" ) | 2584 | if ( mMoveIncidence->typeID() == todoID ) |
2585 | emit todoMoved((Todo*)mMoveIncidence, KOGlobals::EVENTEDITED ); | 2585 | emit todoMoved((Todo*)mMoveIncidence, KOGlobals::EVENTEDITED ); |
2586 | else | 2586 | else |
2587 | emit incidenceChanged(mMoveIncidence, KOGlobals::EVENTEDITED); | 2587 | emit incidenceChanged(mMoveIncidence, KOGlobals::EVENTEDITED); |
2588 | mMoveIncidence = newInc; | 2588 | mMoveIncidence = newInc; |
2589 | 2589 | ||
2590 | #endif | 2590 | #endif |
2591 | } | 2591 | } |
2592 | QTime tim = mMoveIncidence->dtStart().time(); | 2592 | QTime tim = mMoveIncidence->dtStart().time(); |
2593 | int secs = mMoveIncidence->dtStart().secsTo( mMoveIncidence->dtEnd()); | 2593 | int secs = mMoveIncidence->dtStart().secsTo( mMoveIncidence->dtEnd()); |
2594 | QDateTime dt ( d,tim ); | 2594 | QDateTime dt ( d,tim ); |
2595 | mMoveIncidence->setDtStart( dt ); | 2595 | mMoveIncidence->setDtStart( dt ); |
2596 | ((Event*)mMoveIncidence)->setDtEnd( dt.addSecs( secs ) ); | 2596 | ((Event*)mMoveIncidence)->setDtEnd( dt.addSecs( secs ) ); |
2597 | changeEventDisplay((Event*)mMoveIncidence, KOGlobals::EVENTEDITED); | 2597 | changeEventDisplay((Event*)mMoveIncidence, KOGlobals::EVENTEDITED); |
2598 | } | 2598 | } |
2599 | 2599 | ||
2600 | mMoveIncidence->setRevision( mMoveIncidence->revision()+1 ); | 2600 | mMoveIncidence->setRevision( mMoveIncidence->revision()+1 ); |
2601 | } | 2601 | } |
2602 | } | 2602 | } |
2603 | 2603 | ||
2604 | void CalendarView::removeCategories() | 2604 | void CalendarView::removeCategories() |
2605 | { | 2605 | { |
2606 | QPtrList<Incidence> incList = mCalendar->rawIncidences(); | 2606 | QPtrList<Incidence> incList = mCalendar->rawIncidences(); |
2607 | QStringList catList = KOPrefs::instance()->mCustomCategories; | 2607 | QStringList catList = KOPrefs::instance()->mCustomCategories; |
2608 | QStringList catIncList; | 2608 | QStringList catIncList; |
2609 | QStringList newCatList; | 2609 | QStringList newCatList; |
2610 | Incidence* inc = incList.first(); | 2610 | Incidence* inc = incList.first(); |
2611 | int i; | 2611 | int i; |
2612 | int count = 0; | 2612 | int count = 0; |
2613 | while ( inc ) { | 2613 | while ( inc ) { |
2614 | newCatList.clear(); | 2614 | newCatList.clear(); |
2615 | catIncList = inc->categories() ; | 2615 | catIncList = inc->categories() ; |
2616 | for( i = 0; i< catIncList.count(); ++i ) { | 2616 | for( i = 0; i< catIncList.count(); ++i ) { |
2617 | if ( catList.contains (catIncList[i])) | 2617 | if ( catList.contains (catIncList[i])) |
2618 | newCatList.append( catIncList[i] ); | 2618 | newCatList.append( catIncList[i] ); |
2619 | } | 2619 | } |
2620 | newCatList.sort(); | 2620 | newCatList.sort(); |
2621 | inc->setCategories( newCatList.join(",") ); | 2621 | inc->setCategories( newCatList.join(",") ); |
2622 | inc = incList.next(); | 2622 | inc = incList.next(); |
2623 | } | 2623 | } |
2624 | } | 2624 | } |
2625 | 2625 | ||
2626 | int CalendarView::addCategories() | 2626 | int CalendarView::addCategories() |
2627 | { | 2627 | { |
2628 | QPtrList<Incidence> incList = mCalendar->rawIncidences(); | 2628 | QPtrList<Incidence> incList = mCalendar->rawIncidences(); |
2629 | QStringList catList = KOPrefs::instance()->mCustomCategories; | 2629 | QStringList catList = KOPrefs::instance()->mCustomCategories; |
2630 | QStringList catIncList; | 2630 | QStringList catIncList; |
2631 | Incidence* inc = incList.first(); | 2631 | Incidence* inc = incList.first(); |
2632 | int i; | 2632 | int i; |
2633 | int count = 0; | 2633 | int count = 0; |
2634 | while ( inc ) { | 2634 | while ( inc ) { |
2635 | catIncList = inc->categories() ; | 2635 | catIncList = inc->categories() ; |
2636 | for( i = 0; i< catIncList.count(); ++i ) { | 2636 | for( i = 0; i< catIncList.count(); ++i ) { |
2637 | if ( !catList.contains (catIncList[i])) { | 2637 | if ( !catList.contains (catIncList[i])) { |
2638 | catList.append( catIncList[i] ); | 2638 | catList.append( catIncList[i] ); |
2639 | //qDebug("add cat %s ", catIncList[i].latin1()); | 2639 | //qDebug("add cat %s ", catIncList[i].latin1()); |
2640 | ++count; | 2640 | ++count; |
2641 | } | 2641 | } |
2642 | } | 2642 | } |
2643 | inc = incList.next(); | 2643 | inc = incList.next(); |
2644 | } | 2644 | } |
2645 | catList.sort(); | 2645 | catList.sort(); |
2646 | KOPrefs::instance()->mCustomCategories = catList; | 2646 | KOPrefs::instance()->mCustomCategories = catList; |
2647 | return count; | 2647 | return count; |
2648 | } | 2648 | } |
2649 | 2649 | ||
2650 | void CalendarView::manageCategories() | 2650 | void CalendarView::manageCategories() |
2651 | { | 2651 | { |
2652 | KOCatPrefs* cp = new KOCatPrefs(); | 2652 | KOCatPrefs* cp = new KOCatPrefs(); |
2653 | cp->show(); | 2653 | cp->show(); |
2654 | int w =cp->sizeHint().width() ; | 2654 | int w =cp->sizeHint().width() ; |
2655 | int h = cp->sizeHint().height() ; | 2655 | int h = cp->sizeHint().height() ; |
2656 | int dw = QApplication::desktop()->width(); | 2656 | int dw = QApplication::desktop()->width(); |
2657 | int dh = QApplication::desktop()->height(); | 2657 | int dh = QApplication::desktop()->height(); |
2658 | cp->setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); | 2658 | cp->setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); |
2659 | if ( !cp->exec() ) { | 2659 | if ( !cp->exec() ) { |
2660 | delete cp; | 2660 | delete cp; |
2661 | return; | 2661 | return; |
2662 | } | 2662 | } |
2663 | int count = 0; | 2663 | int count = 0; |
2664 | if ( cp->addCat() ) { | 2664 | if ( cp->addCat() ) { |
2665 | count = addCategories(); | 2665 | count = addCategories(); |
2666 | if ( count ) { | 2666 | if ( count ) { |
2667 | topLevelWidget()->setCaption(QString::number( count )+ i18n(" Categories added to list! ")); | 2667 | topLevelWidget()->setCaption(QString::number( count )+ i18n(" Categories added to list! ")); |
2668 | writeSettings(); | 2668 | writeSettings(); |
2669 | } else | 2669 | } else |
2670 | topLevelWidget()->setCaption(QString::number( 0 )+ i18n(" Categories added to list! ")); | 2670 | topLevelWidget()->setCaption(QString::number( 0 )+ i18n(" Categories added to list! ")); |
2671 | } else { | 2671 | } else { |
2672 | removeCategories(); | 2672 | removeCategories(); |
2673 | updateView(); | 2673 | updateView(); |
2674 | } | 2674 | } |
2675 | delete cp; | 2675 | delete cp; |
2676 | } | 2676 | } |
2677 | 2677 | ||
2678 | void CalendarView::beamIncidence(Incidence * Inc) | 2678 | void CalendarView::beamIncidence(Incidence * Inc) |
2679 | { | 2679 | { |
2680 | QPtrList<Incidence> delSel ; | 2680 | QPtrList<Incidence> delSel ; |
2681 | delSel.append(Inc); | 2681 | delSel.append(Inc); |
2682 | beamIncidenceList( delSel ); | 2682 | beamIncidenceList( delSel ); |
2683 | } | 2683 | } |
2684 | void CalendarView::beamCalendar() | 2684 | void CalendarView::beamCalendar() |
2685 | { | 2685 | { |
2686 | QPtrList<Incidence> delSel = mCalendar->rawIncidences(); | 2686 | QPtrList<Incidence> delSel = mCalendar->rawIncidences(); |
2687 | //qDebug("beamCalendar() "); | 2687 | //qDebug("beamCalendar() "); |
2688 | beamIncidenceList( delSel ); | 2688 | beamIncidenceList( delSel ); |
2689 | } | 2689 | } |
2690 | void CalendarView::beamFilteredCalendar() | 2690 | void CalendarView::beamFilteredCalendar() |
2691 | { | 2691 | { |
2692 | QPtrList<Incidence> delSel = mCalendar->incidences(); | 2692 | QPtrList<Incidence> delSel = mCalendar->incidences(); |
2693 | //qDebug("beamFilteredCalendar() "); | 2693 | //qDebug("beamFilteredCalendar() "); |
2694 | beamIncidenceList( delSel ); | 2694 | beamIncidenceList( delSel ); |
2695 | } | 2695 | } |
2696 | void CalendarView::beamIncidenceList(QPtrList<Incidence> delSel ) | 2696 | void CalendarView::beamIncidenceList(QPtrList<Incidence> delSel ) |
2697 | { | 2697 | { |
2698 | if ( beamDialog->exec () == QDialog::Rejected ) | 2698 | if ( beamDialog->exec () == QDialog::Rejected ) |
2699 | return; | 2699 | return; |
2700 | #ifdef DESKTOP_VERSION | 2700 | #ifdef DESKTOP_VERSION |
2701 | QString fn = locateLocal( "tmp", "kopibeamfile" ); | 2701 | QString fn = locateLocal( "tmp", "kopibeamfile" ); |
2702 | #else | 2702 | #else |
2703 | QString fn = "/tmp/kopibeamfile"; | 2703 | QString fn = "/tmp/kopibeamfile"; |
2704 | #endif | 2704 | #endif |
2705 | QString mes; | 2705 | QString mes; |
2706 | bool createbup = true; | 2706 | bool createbup = true; |
2707 | if ( createbup ) { | 2707 | if ( createbup ) { |
2708 | QString description = "\n"; | 2708 | QString description = "\n"; |
2709 | CalendarLocal* cal = new CalendarLocal(); | 2709 | CalendarLocal* cal = new CalendarLocal(); |
2710 | if ( beamDialog->beamLocal() ) | 2710 | if ( beamDialog->beamLocal() ) |
2711 | cal->setLocalTime(); | 2711 | cal->setLocalTime(); |
2712 | else | 2712 | else |
2713 | cal->setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); | 2713 | cal->setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); |
2714 | Incidence *incidence = delSel.first(); | 2714 | Incidence *incidence = delSel.first(); |
2715 | bool addText = false; | 2715 | bool addText = false; |
2716 | if ( delSel.count() < 10 ) | 2716 | if ( delSel.count() < 10 ) |
2717 | addText = true; | 2717 | addText = true; |
2718 | else { | 2718 | else { |
2719 | description.sprintf(i18n(" %d items?"),delSel.count() ); | 2719 | description.sprintf(i18n(" %d items?"),delSel.count() ); |
2720 | } | 2720 | } |
2721 | while ( incidence ) { | 2721 | while ( incidence ) { |
2722 | Incidence *in = incidence->clone(); | 2722 | Incidence *in = incidence->clone(); |
2723 | if ( ! in->summary().isEmpty() ) { | 2723 | if ( ! in->summary().isEmpty() ) { |
2724 | in->setDescription(""); | 2724 | in->setDescription(""); |
2725 | } else { | 2725 | } else { |
2726 | in->setSummary( in->description().left(20)); | 2726 | in->setSummary( in->description().left(20)); |
2727 | in->setDescription(""); | 2727 | in->setDescription(""); |
2728 | } | 2728 | } |
2729 | if ( addText ) | 2729 | if ( addText ) |
2730 | description += in->summary() + "\n"; | 2730 | description += in->summary() + "\n"; |
2731 | cal->addIncidence( in ); | 2731 | cal->addIncidence( in ); |
2732 | incidence = delSel.next(); | 2732 | incidence = delSel.next(); |
2733 | } | 2733 | } |
2734 | if ( beamDialog->beamVcal() ) { | 2734 | if ( beamDialog->beamVcal() ) { |
2735 | fn += ".vcs"; | 2735 | fn += ".vcs"; |
2736 | FileStorage storage( cal, fn, new VCalFormat ); | 2736 | FileStorage storage( cal, fn, new VCalFormat ); |
2737 | storage.save(); | 2737 | storage.save(); |
2738 | } else { | 2738 | } else { |
2739 | fn += ".ics"; | 2739 | fn += ".ics"; |
2740 | FileStorage storage( cal, fn, new ICalFormat( ) ); | 2740 | FileStorage storage( cal, fn, new ICalFormat( ) ); |
2741 | storage.save(); | 2741 | storage.save(); |
2742 | } | 2742 | } |
2743 | delete cal; | 2743 | delete cal; |
2744 | mes = i18n("KO/Pi: Ready for beaming"); | 2744 | mes = i18n("KO/Pi: Ready for beaming"); |
2745 | topLevelWidget()->setCaption(mes); | 2745 | topLevelWidget()->setCaption(mes); |
2746 | KApplication::convert2latin1( fn ); | 2746 | KApplication::convert2latin1( fn ); |
2747 | #ifndef DESKTOP_VERSION | 2747 | #ifndef DESKTOP_VERSION |
2748 | Ir *ir = new Ir( this ); | 2748 | Ir *ir = new Ir( this ); |
2749 | connect( ir, SIGNAL( done( Ir * ) ), this, SLOT( beamDone( Ir * ) ) ); | 2749 | connect( ir, SIGNAL( done( Ir * ) ), this, SLOT( beamDone( Ir * ) ) ); |
2750 | ir->send( fn, description, "text/x-vCalendar" ); | 2750 | ir->send( fn, description, "text/x-vCalendar" ); |
2751 | #endif | 2751 | #endif |
2752 | } | 2752 | } |
2753 | } | 2753 | } |
2754 | void CalendarView::beamDone( Ir *ir ) | 2754 | void CalendarView::beamDone( Ir *ir ) |
2755 | { | 2755 | { |
2756 | #ifndef DESKTOP_VERSION | 2756 | #ifndef DESKTOP_VERSION |
2757 | delete ir; | 2757 | delete ir; |
2758 | #endif | 2758 | #endif |
2759 | topLevelWidget()->setCaption( i18n("KO/Pi: Beaming done.") ); | 2759 | topLevelWidget()->setCaption( i18n("KO/Pi: Beaming done.") ); |
2760 | topLevelWidget()->raise(); | 2760 | topLevelWidget()->raise(); |
2761 | } | 2761 | } |
2762 | 2762 | ||
2763 | void CalendarView::moveIncidence(Incidence * inc ) | 2763 | void CalendarView::moveIncidence(Incidence * inc ) |
2764 | { | 2764 | { |
2765 | if ( !inc ) return; | 2765 | if ( !inc ) return; |
2766 | showDatePickerPopup(); | 2766 | showDatePickerPopup(); |
2767 | mDatePickerMode = 2; | 2767 | mDatePickerMode = 2; |
2768 | mMoveIncidence = inc ; | 2768 | mMoveIncidence = inc ; |
2769 | QDate da; | 2769 | QDate da; |
2770 | if ( mMoveIncidence->type() == "Todo" ) { | 2770 | if ( mMoveIncidence->typeID() == todoID ) { |
2771 | Todo * to = (Todo *) mMoveIncidence; | 2771 | Todo * to = (Todo *) mMoveIncidence; |
2772 | if ( to->hasDueDate() ) | 2772 | if ( to->hasDueDate() ) |
2773 | da = to->dtDue().date(); | 2773 | da = to->dtDue().date(); |
2774 | else | 2774 | else |
2775 | da = QDate::currentDate(); | 2775 | da = QDate::currentDate(); |
2776 | } else { | 2776 | } else { |
2777 | da = mMoveIncidence->dtStart().date(); | 2777 | da = mMoveIncidence->dtStart().date(); |
2778 | } | 2778 | } |
2779 | //PENDING set date for recurring incidence to date of recurrence | 2779 | //PENDING set date for recurring incidence to date of recurrence |
2780 | //mMoveIncidenceOldDate; | 2780 | //mMoveIncidenceOldDate; |
2781 | mDatePicker->setDate( da ); | 2781 | mDatePicker->setDate( da ); |
2782 | } | 2782 | } |
2783 | void CalendarView::showDatePickerPopup() | 2783 | void CalendarView::showDatePickerPopup() |
2784 | { | 2784 | { |
2785 | if ( mDateFrame->isVisible() ) | 2785 | if ( mDateFrame->isVisible() ) |
2786 | mDateFrame->hide(); | 2786 | mDateFrame->hide(); |
2787 | else { | 2787 | else { |
2788 | int offX = 0, offY = 0; | 2788 | int offX = 0, offY = 0; |
2789 | #ifdef DESKTOP_VERSION | 2789 | #ifdef DESKTOP_VERSION |
2790 | int w =mDatePicker->sizeHint().width() ; | 2790 | int w =mDatePicker->sizeHint().width() ; |
2791 | int h = mDatePicker->sizeHint().height() ; | 2791 | int h = mDatePicker->sizeHint().height() ; |
2792 | int dw = topLevelWidget()->width(); | 2792 | int dw = topLevelWidget()->width(); |
2793 | int dh = topLevelWidget()->height(); | 2793 | int dh = topLevelWidget()->height(); |
2794 | offX = topLevelWidget()->x(); | 2794 | offX = topLevelWidget()->x(); |
2795 | offY = topLevelWidget()->y(); | 2795 | offY = topLevelWidget()->y(); |
2796 | #else | 2796 | #else |
2797 | int w =mDatePicker->sizeHint().width() ; | 2797 | int w =mDatePicker->sizeHint().width() ; |
2798 | int h = mDatePicker->sizeHint().height() ; | 2798 | int h = mDatePicker->sizeHint().height() ; |
2799 | int dw = QApplication::desktop()->width(); | 2799 | int dw = QApplication::desktop()->width(); |
2800 | int dh = QApplication::desktop()->height(); | 2800 | int dh = QApplication::desktop()->height(); |
2801 | #endif | 2801 | #endif |
2802 | mDateFrame->setGeometry( (dw-w)/2+offX, (dh - h )/2+offY ,w,h ); | 2802 | mDateFrame->setGeometry( (dw-w)/2+offX, (dh - h )/2+offY ,w,h ); |
2803 | mDateFrame->show(); | 2803 | mDateFrame->show(); |
2804 | } | 2804 | } |
2805 | } | 2805 | } |
2806 | void CalendarView::showDatePicker( ) | 2806 | void CalendarView::showDatePicker( ) |
2807 | { | 2807 | { |
2808 | showDatePickerPopup(); | 2808 | showDatePickerPopup(); |
2809 | mDatePickerMode = 1; | 2809 | mDatePickerMode = 1; |
2810 | mDatePicker->setDate( mNavigator->selectedDates().first() ); | 2810 | mDatePicker->setDate( mNavigator->selectedDates().first() ); |
2811 | } | 2811 | } |
2812 | 2812 | ||
2813 | void CalendarView::showEventEditor() | 2813 | void CalendarView::showEventEditor() |
2814 | { | 2814 | { |
2815 | #ifdef DESKTOP_VERSION | 2815 | #ifdef DESKTOP_VERSION |
2816 | int x,y,w,h; | 2816 | int x,y,w,h; |
2817 | x = mEventEditor->geometry().x(); | 2817 | x = mEventEditor->geometry().x(); |
2818 | y = mEventEditor->geometry().y(); | 2818 | y = mEventEditor->geometry().y(); |
2819 | w = mEventEditor->width(); | 2819 | w = mEventEditor->width(); |
2820 | h = mEventEditor->height(); | 2820 | h = mEventEditor->height(); |
2821 | mEventEditor->show(); | 2821 | mEventEditor->show(); |
2822 | mEventEditor->setGeometry(x,y,w,h); | 2822 | mEventEditor->setGeometry(x,y,w,h); |
2823 | #else | 2823 | #else |
2824 | if ( mEventEditor->width() < QApplication::desktop()->width() -60 || mEventEditor->width() > QApplication::desktop()->width() ) { | 2824 | if ( mEventEditor->width() < QApplication::desktop()->width() -60 || mEventEditor->width() > QApplication::desktop()->width() ) { |
2825 | topLevelWidget()->setCaption( i18n("Recreating edit dialog. Please wait...") ); | 2825 | topLevelWidget()->setCaption( i18n("Recreating edit dialog. Please wait...") ); |
2826 | qDebug("KO: CalendarView: recreate mEventEditor %d %d", mEventEditor->width(), QApplication::desktop()->width() ); | 2826 | qDebug("KO: CalendarView: recreate mEventEditor %d %d", mEventEditor->width(), QApplication::desktop()->width() ); |
2827 | qApp->processEvents(); | 2827 | qApp->processEvents(); |
2828 | delete mEventEditor; | 2828 | delete mEventEditor; |
2829 | mEventEditor = mDialogManager->getEventEditor(); | 2829 | mEventEditor = mDialogManager->getEventEditor(); |
2830 | topLevelWidget()->setCaption( i18n("") ); | 2830 | topLevelWidget()->setCaption( i18n("") ); |
2831 | } | 2831 | } |
2832 | mEventEditor->showMaximized(); | 2832 | mEventEditor->showMaximized(); |
2833 | #endif | 2833 | #endif |
2834 | } | 2834 | } |
2835 | void CalendarView::showTodoEditor() | 2835 | void CalendarView::showTodoEditor() |
2836 | { | 2836 | { |
2837 | #ifdef DESKTOP_VERSION | 2837 | #ifdef DESKTOP_VERSION |
2838 | int x,y,w,h; | 2838 | int x,y,w,h; |
2839 | x = mTodoEditor->geometry().x(); | 2839 | x = mTodoEditor->geometry().x(); |
2840 | y = mTodoEditor->geometry().y(); | 2840 | y = mTodoEditor->geometry().y(); |
2841 | w = mTodoEditor->width(); | 2841 | w = mTodoEditor->width(); |
2842 | h = mTodoEditor->height(); | 2842 | h = mTodoEditor->height(); |
2843 | mTodoEditor->show(); | 2843 | mTodoEditor->show(); |
2844 | mTodoEditor->setGeometry(x,y,w,h); | 2844 | mTodoEditor->setGeometry(x,y,w,h); |
2845 | #else | 2845 | #else |
2846 | if ( mTodoEditor->width() < QApplication::desktop()->width() -60|| mTodoEditor->width() > QApplication::desktop()->width() ) { | 2846 | if ( mTodoEditor->width() < QApplication::desktop()->width() -60|| mTodoEditor->width() > QApplication::desktop()->width() ) { |
2847 | topLevelWidget()->setCaption( i18n("Recreating edit dialog. Please wait...") ); | 2847 | topLevelWidget()->setCaption( i18n("Recreating edit dialog. Please wait...") ); |
2848 | qDebug("KO: CalendarView: recreate mTodoEditor %d %d ", mTodoEditor->width() ,QApplication::desktop()->width() ); | 2848 | qDebug("KO: CalendarView: recreate mTodoEditor %d %d ", mTodoEditor->width() ,QApplication::desktop()->width() ); |
2849 | qApp->processEvents(); | 2849 | qApp->processEvents(); |
2850 | delete mTodoEditor; | 2850 | delete mTodoEditor; |
2851 | mTodoEditor = mDialogManager->getTodoEditor(); | 2851 | mTodoEditor = mDialogManager->getTodoEditor(); |
2852 | topLevelWidget()->setCaption( i18n("") ); | 2852 | topLevelWidget()->setCaption( i18n("") ); |
2853 | } | 2853 | } |
2854 | mTodoEditor->showMaximized(); | 2854 | mTodoEditor->showMaximized(); |
2855 | #endif | 2855 | #endif |
2856 | } | 2856 | } |
2857 | 2857 | ||
2858 | void CalendarView::cloneIncidence() | 2858 | void CalendarView::cloneIncidence() |
2859 | { | 2859 | { |
2860 | Incidence *incidence = currentSelection(); | 2860 | Incidence *incidence = currentSelection(); |
2861 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); | 2861 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); |
2862 | if ( incidence ) { | 2862 | if ( incidence ) { |
2863 | cloneIncidence(incidence); | 2863 | cloneIncidence(incidence); |
2864 | } | 2864 | } |
2865 | } | 2865 | } |
2866 | void CalendarView::moveIncidence() | 2866 | void CalendarView::moveIncidence() |
2867 | { | 2867 | { |
2868 | Incidence *incidence = currentSelection(); | 2868 | Incidence *incidence = currentSelection(); |
2869 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); | 2869 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); |
2870 | if ( incidence ) { | 2870 | if ( incidence ) { |
2871 | moveIncidence(incidence); | 2871 | moveIncidence(incidence); |
2872 | } | 2872 | } |
2873 | } | 2873 | } |
2874 | void CalendarView::beamIncidence() | 2874 | void CalendarView::beamIncidence() |
2875 | { | 2875 | { |
2876 | Incidence *incidence = currentSelection(); | 2876 | Incidence *incidence = currentSelection(); |
2877 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); | 2877 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); |
2878 | if ( incidence ) { | 2878 | if ( incidence ) { |
2879 | beamIncidence(incidence); | 2879 | beamIncidence(incidence); |
2880 | } | 2880 | } |
2881 | } | 2881 | } |
2882 | void CalendarView::toggleCancelIncidence() | 2882 | void CalendarView::toggleCancelIncidence() |
2883 | { | 2883 | { |
2884 | Incidence *incidence = currentSelection(); | 2884 | Incidence *incidence = currentSelection(); |
2885 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); | 2885 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); |
2886 | if ( incidence ) { | 2886 | if ( incidence ) { |
2887 | cancelIncidence(incidence); | 2887 | cancelIncidence(incidence); |
2888 | } | 2888 | } |
2889 | } | 2889 | } |
2890 | 2890 | ||
2891 | 2891 | ||
2892 | void CalendarView::cancelIncidence(Incidence * inc ) | 2892 | void CalendarView::cancelIncidence(Incidence * inc ) |
2893 | { | 2893 | { |
2894 | inc->setCancelled( ! inc->cancelled() ); | 2894 | inc->setCancelled( ! inc->cancelled() ); |
2895 | changeIncidenceDisplay( inc,KOGlobals::EVENTEDITED ); | 2895 | changeIncidenceDisplay( inc,KOGlobals::EVENTEDITED ); |
2896 | updateView(); | 2896 | updateView(); |
2897 | } | 2897 | } |
2898 | void CalendarView::cloneIncidence(Incidence * orgInc ) | 2898 | void CalendarView::cloneIncidence(Incidence * orgInc ) |
2899 | { | 2899 | { |
2900 | Incidence * newInc = orgInc->clone(); | 2900 | Incidence * newInc = orgInc->clone(); |
2901 | newInc->recreate(); | 2901 | newInc->recreate(); |
2902 | 2902 | ||
2903 | if ( newInc->type() == "Todo" ) { | 2903 | if ( newInc->typeID() == todoID ) { |
2904 | Todo* t = (Todo*) newInc; | 2904 | Todo* t = (Todo*) newInc; |
2905 | bool cloneSub = false; | 2905 | bool cloneSub = false; |
2906 | if ( orgInc->relations().count() ) { | 2906 | if ( orgInc->relations().count() ) { |
2907 | int result = KMessageBox::warningYesNoCancel(this, | 2907 | int result = KMessageBox::warningYesNoCancel(this, |
2908 | i18n("The todo\n%1\nwill be cloned!\nIt has subtodos!\nDo you want to clone\nall subtodos as well?").arg( newInc->summary().left ( 25 ) ), | 2908 | i18n("The todo\n%1\nwill be cloned!\nIt has subtodos!\nDo you want to clone\nall subtodos as well?").arg( newInc->summary().left ( 25 ) ), |
2909 | i18n("Todo has subtodos"), | 2909 | i18n("Todo has subtodos"), |
2910 | i18n("Yes"), | 2910 | i18n("Yes"), |
2911 | i18n("No")); | 2911 | i18n("No")); |
2912 | 2912 | ||
2913 | if ( result == KMessageBox::Cancel ) { | 2913 | if ( result == KMessageBox::Cancel ) { |
2914 | delete t; | 2914 | delete t; |
2915 | return; | 2915 | return; |
2916 | } | 2916 | } |
2917 | if (result == KMessageBox::Yes) cloneSub = true; | 2917 | if (result == KMessageBox::Yes) cloneSub = true; |
2918 | } | 2918 | } |
2919 | showTodoEditor(); | 2919 | showTodoEditor(); |
2920 | mTodoEditor->editTodo( t ); | 2920 | mTodoEditor->editTodo( t ); |
2921 | if ( mTodoEditor->exec() ) { | 2921 | if ( mTodoEditor->exec() ) { |
2922 | if ( cloneSub ) { | 2922 | if ( cloneSub ) { |
2923 | orgInc->cloneRelations( t ); | 2923 | orgInc->cloneRelations( t ); |
2924 | mCalendar->addIncidenceBranch( t ); | 2924 | mCalendar->addIncidenceBranch( t ); |
2925 | updateView(); | 2925 | updateView(); |
2926 | 2926 | ||
2927 | } else { | 2927 | } else { |
2928 | mCalendar->addTodo( t ); | 2928 | mCalendar->addTodo( t ); |
2929 | updateView(); | 2929 | updateView(); |
2930 | } | 2930 | } |
2931 | } else { | 2931 | } else { |
2932 | delete t; | 2932 | delete t; |
2933 | } | 2933 | } |
2934 | } | 2934 | } |
2935 | else { | 2935 | else { |
2936 | Event* e = (Event*) newInc; | 2936 | Event* e = (Event*) newInc; |
2937 | showEventEditor(); | 2937 | showEventEditor(); |
2938 | mEventEditor->editEvent( e ); | 2938 | mEventEditor->editEvent( e ); |
2939 | if ( mEventEditor->exec() ) { | 2939 | if ( mEventEditor->exec() ) { |
2940 | mCalendar->addEvent( e ); | 2940 | mCalendar->addEvent( e ); |
2941 | updateView(); | 2941 | updateView(); |
2942 | } else { | 2942 | } else { |
2943 | delete e; | 2943 | delete e; |
2944 | } | 2944 | } |
2945 | } | 2945 | } |
2946 | setActiveWindow(); | 2946 | setActiveWindow(); |
2947 | } | 2947 | } |
2948 | 2948 | ||
2949 | void CalendarView::newEvent() | 2949 | void CalendarView::newEvent() |
2950 | { | 2950 | { |
2951 | // TODO: Replace this code by a common eventDurationHint of KOBaseView. | 2951 | // TODO: Replace this code by a common eventDurationHint of KOBaseView. |
2952 | KOAgendaView *aView = mViewManager->agendaView(); | 2952 | KOAgendaView *aView = mViewManager->agendaView(); |
2953 | if (aView) { | 2953 | if (aView) { |
2954 | if (aView->selectionStart().isValid()) { | 2954 | if (aView->selectionStart().isValid()) { |
2955 | if (aView->selectedIsAllDay()) { | 2955 | if (aView->selectedIsAllDay()) { |
2956 | newEvent(aView->selectionStart(),aView->selectionEnd(),true); | 2956 | newEvent(aView->selectionStart(),aView->selectionEnd(),true); |
2957 | } else { | 2957 | } else { |
2958 | newEvent(aView->selectionStart(),aView->selectionEnd()); | 2958 | newEvent(aView->selectionStart(),aView->selectionEnd()); |
2959 | } | 2959 | } |
2960 | return; | 2960 | return; |
2961 | } | 2961 | } |
2962 | } | 2962 | } |
2963 | 2963 | ||
2964 | QDate date = mNavigator->selectedDates().first(); | 2964 | QDate date = mNavigator->selectedDates().first(); |
2965 | QDateTime current = QDateTime::currentDateTime(); | 2965 | QDateTime current = QDateTime::currentDateTime(); |
2966 | if ( date <= current.date() ) { | 2966 | if ( date <= current.date() ) { |
2967 | int hour = current.time().hour() +1; | 2967 | int hour = current.time().hour() +1; |
2968 | newEvent( QDateTime( current.date(), QTime( hour, 0, 0 ) ), | 2968 | newEvent( QDateTime( current.date(), QTime( hour, 0, 0 ) ), |
2969 | QDateTime( current.date(), QTime( hour+ KOPrefs::instance()->mDefaultDuration, 0, 0 ) ) ); | 2969 | QDateTime( current.date(), QTime( hour+ KOPrefs::instance()->mDefaultDuration, 0, 0 ) ) ); |
2970 | } else | 2970 | } else |
2971 | newEvent( QDateTime( date, QTime( KOPrefs::instance()->mStartTime, 0, 0 ) ), | 2971 | newEvent( QDateTime( date, QTime( KOPrefs::instance()->mStartTime, 0, 0 ) ), |
2972 | QDateTime( date, QTime( KOPrefs::instance()->mStartTime + | 2972 | QDateTime( date, QTime( KOPrefs::instance()->mStartTime + |
2973 | KOPrefs::instance()->mDefaultDuration, 0, 0 ) ) ); | 2973 | KOPrefs::instance()->mDefaultDuration, 0, 0 ) ) ); |
2974 | } | 2974 | } |
2975 | 2975 | ||
2976 | void CalendarView::newEvent(QDateTime fh) | 2976 | void CalendarView::newEvent(QDateTime fh) |
2977 | { | 2977 | { |
2978 | newEvent(fh, | 2978 | newEvent(fh, |
2979 | QDateTime(fh.addSecs(3600*KOPrefs::instance()->mDefaultDuration))); | 2979 | QDateTime(fh.addSecs(3600*KOPrefs::instance()->mDefaultDuration))); |
2980 | } | 2980 | } |
2981 | 2981 | ||
2982 | void CalendarView::newEvent(QDate dt) | 2982 | void CalendarView::newEvent(QDate dt) |
2983 | { | 2983 | { |
2984 | newEvent(QDateTime(dt, QTime(0,0,0)), | 2984 | newEvent(QDateTime(dt, QTime(0,0,0)), |
2985 | QDateTime(dt, QTime(0,0,0)), true); | 2985 | QDateTime(dt, QTime(0,0,0)), true); |
2986 | } | 2986 | } |
2987 | void CalendarView::newEvent(QDateTime fromHint, QDateTime toHint) | 2987 | void CalendarView::newEvent(QDateTime fromHint, QDateTime toHint) |
2988 | { | 2988 | { |
2989 | newEvent(fromHint, toHint, false); | 2989 | newEvent(fromHint, toHint, false); |
2990 | } | 2990 | } |
2991 | void CalendarView::newEvent(QDateTime fromHint, QDateTime toHint, bool allDay) | 2991 | void CalendarView::newEvent(QDateTime fromHint, QDateTime toHint, bool allDay) |
2992 | { | 2992 | { |
2993 | 2993 | ||
2994 | showEventEditor(); | 2994 | showEventEditor(); |
2995 | mEventEditor->newEvent(fromHint,toHint,allDay); | 2995 | mEventEditor->newEvent(fromHint,toHint,allDay); |
2996 | if ( mFilterView->filtersEnabled() ) { | 2996 | if ( mFilterView->filtersEnabled() ) { |
2997 | CalFilter *filter = mFilterView->selectedFilter(); | 2997 | CalFilter *filter = mFilterView->selectedFilter(); |
2998 | if (filter && filter->showCategories()) { | 2998 | if (filter && filter->showCategories()) { |
2999 | mEventEditor->setCategories(filter->categoryList().join(",") ); | 2999 | mEventEditor->setCategories(filter->categoryList().join(",") ); |
3000 | } | 3000 | } |
3001 | if ( filter ) | 3001 | if ( filter ) |
3002 | mEventEditor->setSecrecy( filter->getSecrecy() ); | 3002 | mEventEditor->setSecrecy( filter->getSecrecy() ); |
3003 | } | 3003 | } |
3004 | mEventEditor->exec(); | 3004 | mEventEditor->exec(); |
3005 | setActiveWindow(); | 3005 | setActiveWindow(); |
3006 | } | 3006 | } |
3007 | void CalendarView::todoAdded(Todo * t) | 3007 | void CalendarView::todoAdded(Todo * t) |
3008 | { | 3008 | { |
3009 | 3009 | ||
3010 | changeTodoDisplay ( t ,KOGlobals::EVENTADDED); | 3010 | changeTodoDisplay ( t ,KOGlobals::EVENTADDED); |
3011 | updateTodoViews(); | 3011 | updateTodoViews(); |
3012 | } | 3012 | } |
3013 | void CalendarView::todoChanged(Todo * t) | 3013 | void CalendarView::todoChanged(Todo * t) |
3014 | { | 3014 | { |
3015 | emit todoModified( t, 4 ); | 3015 | emit todoModified( t, 4 ); |
3016 | // updateTodoViews(); | 3016 | // updateTodoViews(); |
3017 | } | 3017 | } |
3018 | void CalendarView::todoToBeDeleted(Todo *) | 3018 | void CalendarView::todoToBeDeleted(Todo *) |
3019 | { | 3019 | { |
3020 | //qDebug("todoToBeDeleted(Todo *) "); | 3020 | //qDebug("todoToBeDeleted(Todo *) "); |
3021 | updateTodoViews(); | 3021 | updateTodoViews(); |
3022 | } | 3022 | } |
3023 | void CalendarView::todoDeleted() | 3023 | void CalendarView::todoDeleted() |
3024 | { | 3024 | { |
3025 | //qDebug(" todoDeleted()"); | 3025 | //qDebug(" todoDeleted()"); |
3026 | updateTodoViews(); | 3026 | updateTodoViews(); |
3027 | } | 3027 | } |
3028 | 3028 | ||
3029 | 3029 | ||
3030 | void CalendarView::newTodoDateTime( QDateTime dt, bool allday ) | 3030 | void CalendarView::newTodoDateTime( QDateTime dt, bool allday ) |
3031 | { | 3031 | { |
@@ -3039,1163 +3039,1163 @@ void CalendarView::newTodoDateTime( QDateTime dt, bool allday ) | |||
3039 | if ( filter ) | 3039 | if ( filter ) |
3040 | mTodoEditor->setSecrecy( filter->getSecrecy() ); | 3040 | mTodoEditor->setSecrecy( filter->getSecrecy() ); |
3041 | } | 3041 | } |
3042 | mTodoEditor->exec(); | 3042 | mTodoEditor->exec(); |
3043 | setActiveWindow(); | 3043 | setActiveWindow(); |
3044 | } | 3044 | } |
3045 | 3045 | ||
3046 | void CalendarView::newTodo() | 3046 | void CalendarView::newTodo() |
3047 | { | 3047 | { |
3048 | newTodoDateTime( QDateTime(),true ); | 3048 | newTodoDateTime( QDateTime(),true ); |
3049 | } | 3049 | } |
3050 | 3050 | ||
3051 | void CalendarView::newSubTodo() | 3051 | void CalendarView::newSubTodo() |
3052 | { | 3052 | { |
3053 | Todo *todo = selectedTodo(); | 3053 | Todo *todo = selectedTodo(); |
3054 | if ( todo ) newSubTodo( todo ); | 3054 | if ( todo ) newSubTodo( todo ); |
3055 | } | 3055 | } |
3056 | 3056 | ||
3057 | void CalendarView::newSubTodo(Todo *parentEvent) | 3057 | void CalendarView::newSubTodo(Todo *parentEvent) |
3058 | { | 3058 | { |
3059 | 3059 | ||
3060 | showTodoEditor(); | 3060 | showTodoEditor(); |
3061 | mTodoEditor->newTodo(QDateTime(),parentEvent,true); | 3061 | mTodoEditor->newTodo(QDateTime(),parentEvent,true); |
3062 | mTodoEditor->exec(); | 3062 | mTodoEditor->exec(); |
3063 | setActiveWindow(); | 3063 | setActiveWindow(); |
3064 | } | 3064 | } |
3065 | 3065 | ||
3066 | void CalendarView::newFloatingEvent() | 3066 | void CalendarView::newFloatingEvent() |
3067 | { | 3067 | { |
3068 | DateList tmpList = mNavigator->selectedDates(); | 3068 | DateList tmpList = mNavigator->selectedDates(); |
3069 | QDate date = tmpList.first(); | 3069 | QDate date = tmpList.first(); |
3070 | 3070 | ||
3071 | newEvent( QDateTime( date, QTime( 12, 0, 0 ) ), | 3071 | newEvent( QDateTime( date, QTime( 12, 0, 0 ) ), |
3072 | QDateTime( date, QTime( 12, 0, 0 ) ), true ); | 3072 | QDateTime( date, QTime( 12, 0, 0 ) ), true ); |
3073 | } | 3073 | } |
3074 | 3074 | ||
3075 | 3075 | ||
3076 | void CalendarView::editEvent( Event *event ) | 3076 | void CalendarView::editEvent( Event *event ) |
3077 | { | 3077 | { |
3078 | 3078 | ||
3079 | if ( !event ) return; | 3079 | if ( !event ) return; |
3080 | if ( event->isReadOnly() ) { | 3080 | if ( event->isReadOnly() ) { |
3081 | showEvent( event ); | 3081 | showEvent( event ); |
3082 | return; | 3082 | return; |
3083 | } | 3083 | } |
3084 | showEventEditor(); | 3084 | showEventEditor(); |
3085 | mEventEditor->editEvent( event , mFlagEditDescription); | 3085 | mEventEditor->editEvent( event , mFlagEditDescription); |
3086 | mEventEditor->exec(); | 3086 | mEventEditor->exec(); |
3087 | setActiveWindow(); | 3087 | setActiveWindow(); |
3088 | 3088 | ||
3089 | } | 3089 | } |
3090 | void CalendarView::editJournal( Journal *jour ) | 3090 | void CalendarView::editJournal( Journal *jour ) |
3091 | { | 3091 | { |
3092 | if ( !jour ) return; | 3092 | if ( !jour ) return; |
3093 | mDialogManager->hideSearchDialog(); | 3093 | mDialogManager->hideSearchDialog(); |
3094 | mViewManager->showJournalView(); | 3094 | mViewManager->showJournalView(); |
3095 | mNavigator->slotDaySelect( jour->dtStart().date() ); | 3095 | mNavigator->slotDaySelect( jour->dtStart().date() ); |
3096 | } | 3096 | } |
3097 | void CalendarView::editTodo( Todo *todo ) | 3097 | void CalendarView::editTodo( Todo *todo ) |
3098 | { | 3098 | { |
3099 | if ( !todo ) return; | 3099 | if ( !todo ) return; |
3100 | 3100 | ||
3101 | if ( todo->isReadOnly() ) { | 3101 | if ( todo->isReadOnly() ) { |
3102 | showTodo( todo ); | 3102 | showTodo( todo ); |
3103 | return; | 3103 | return; |
3104 | } | 3104 | } |
3105 | showTodoEditor(); | 3105 | showTodoEditor(); |
3106 | mTodoEditor->editTodo( todo ,mFlagEditDescription); | 3106 | mTodoEditor->editTodo( todo ,mFlagEditDescription); |
3107 | mTodoEditor->exec(); | 3107 | mTodoEditor->exec(); |
3108 | setActiveWindow(); | 3108 | setActiveWindow(); |
3109 | 3109 | ||
3110 | } | 3110 | } |
3111 | 3111 | ||
3112 | KOEventViewerDialog* CalendarView::getEventViewerDialog() | 3112 | KOEventViewerDialog* CalendarView::getEventViewerDialog() |
3113 | { | 3113 | { |
3114 | if ( !mEventViewerDialog ) { | 3114 | if ( !mEventViewerDialog ) { |
3115 | mEventViewerDialog = new KOEventViewerDialog(0); | 3115 | mEventViewerDialog = new KOEventViewerDialog(0); |
3116 | connect( mEventViewerDialog, SIGNAL( editIncidence( Incidence* )), this, SLOT(editIncidence( Incidence* ) ) ); | 3116 | connect( mEventViewerDialog, SIGNAL( editIncidence( Incidence* )), this, SLOT(editIncidence( Incidence* ) ) ); |
3117 | connect( this, SIGNAL(configChanged()), mEventViewerDialog, SLOT(updateConfig())); | 3117 | connect( this, SIGNAL(configChanged()), mEventViewerDialog, SLOT(updateConfig())); |
3118 | connect( mEventViewerDialog, SIGNAL(jumpToTime( const QDate &)), | 3118 | connect( mEventViewerDialog, SIGNAL(jumpToTime( const QDate &)), |
3119 | dateNavigator(), SLOT( selectWeek( const QDate & ) ) ); | 3119 | dateNavigator(), SLOT( selectWeek( const QDate & ) ) ); |
3120 | connect( mEventViewerDialog, SIGNAL(showAgendaView( bool ) ), | 3120 | connect( mEventViewerDialog, SIGNAL(showAgendaView( bool ) ), |
3121 | viewManager(), SLOT( showAgendaView( bool ) ) ); | 3121 | viewManager(), SLOT( showAgendaView( bool ) ) ); |
3122 | connect( mEventViewerDialog, SIGNAL(signalViewerClosed()), | 3122 | connect( mEventViewerDialog, SIGNAL(signalViewerClosed()), |
3123 | this, SLOT( slotViewerClosed() ) ); | 3123 | this, SLOT( slotViewerClosed() ) ); |
3124 | connect( mEventViewerDialog, SIGNAL( todoCompleted(Todo *) ), | 3124 | connect( mEventViewerDialog, SIGNAL( todoCompleted(Todo *) ), |
3125 | this, SLOT( todoChanged(Todo *) ) ); | 3125 | this, SLOT( todoChanged(Todo *) ) ); |
3126 | mEventViewerDialog->resize( 640, 480 ); | 3126 | mEventViewerDialog->resize( 640, 480 ); |
3127 | 3127 | ||
3128 | } | 3128 | } |
3129 | return mEventViewerDialog; | 3129 | return mEventViewerDialog; |
3130 | } | 3130 | } |
3131 | void CalendarView::showEvent(Event *event) | 3131 | void CalendarView::showEvent(Event *event) |
3132 | { | 3132 | { |
3133 | getEventViewerDialog()->setEvent(event); | 3133 | getEventViewerDialog()->setEvent(event); |
3134 | getEventViewerDialog()->showMe(); | 3134 | getEventViewerDialog()->showMe(); |
3135 | } | 3135 | } |
3136 | 3136 | ||
3137 | void CalendarView::showTodo(Todo *event) | 3137 | void CalendarView::showTodo(Todo *event) |
3138 | { | 3138 | { |
3139 | getEventViewerDialog()->setTodo(event); | 3139 | getEventViewerDialog()->setTodo(event); |
3140 | getEventViewerDialog()->showMe(); | 3140 | getEventViewerDialog()->showMe(); |
3141 | } | 3141 | } |
3142 | void CalendarView::showJournal( Journal *jour ) | 3142 | void CalendarView::showJournal( Journal *jour ) |
3143 | { | 3143 | { |
3144 | getEventViewerDialog()->setJournal(jour); | 3144 | getEventViewerDialog()->setJournal(jour); |
3145 | getEventViewerDialog()->showMe(); | 3145 | getEventViewerDialog()->showMe(); |
3146 | 3146 | ||
3147 | } | 3147 | } |
3148 | // void CalendarView::todoModified (Todo *event, int changed) | 3148 | // void CalendarView::todoModified (Todo *event, int changed) |
3149 | // { | 3149 | // { |
3150 | // // if (mDialogList.find (event) != mDialogList.end ()) { | 3150 | // // if (mDialogList.find (event) != mDialogList.end ()) { |
3151 | // // kdDebug() << "Todo modified and open" << endl; | 3151 | // // kdDebug() << "Todo modified and open" << endl; |
3152 | // // KOTodoEditor* temp = (KOTodoEditor *) mDialogList[event]; | 3152 | // // KOTodoEditor* temp = (KOTodoEditor *) mDialogList[event]; |
3153 | // // temp->modified (changed); | 3153 | // // temp->modified (changed); |
3154 | 3154 | ||
3155 | // // } | 3155 | // // } |
3156 | 3156 | ||
3157 | // mViewManager->updateView(); | 3157 | // mViewManager->updateView(); |
3158 | // } | 3158 | // } |
3159 | 3159 | ||
3160 | void CalendarView::appointment_show() | 3160 | void CalendarView::appointment_show() |
3161 | { | 3161 | { |
3162 | Event *anEvent = 0; | 3162 | Event *anEvent = 0; |
3163 | 3163 | ||
3164 | Incidence *incidence = mViewManager->currentView()->selectedIncidences().first(); | 3164 | Incidence *incidence = mViewManager->currentView()->selectedIncidences().first(); |
3165 | 3165 | ||
3166 | if (mViewManager->currentView()->isEventView()) { | 3166 | if (mViewManager->currentView()->isEventView()) { |
3167 | if ( incidence && incidence->type() == "Event" ) { | 3167 | if ( incidence && incidence->typeID() == eventID ) { |
3168 | anEvent = static_cast<Event *>(incidence); | 3168 | anEvent = static_cast<Event *>(incidence); |
3169 | } | 3169 | } |
3170 | } | 3170 | } |
3171 | 3171 | ||
3172 | if (!anEvent) { | 3172 | if (!anEvent) { |
3173 | KNotifyClient::beep(); | 3173 | KNotifyClient::beep(); |
3174 | return; | 3174 | return; |
3175 | } | 3175 | } |
3176 | 3176 | ||
3177 | showEvent(anEvent); | 3177 | showEvent(anEvent); |
3178 | } | 3178 | } |
3179 | 3179 | ||
3180 | void CalendarView::appointment_edit() | 3180 | void CalendarView::appointment_edit() |
3181 | { | 3181 | { |
3182 | Event *anEvent = 0; | 3182 | Event *anEvent = 0; |
3183 | 3183 | ||
3184 | Incidence *incidence = mViewManager->currentView()->selectedIncidences().first(); | 3184 | Incidence *incidence = mViewManager->currentView()->selectedIncidences().first(); |
3185 | 3185 | ||
3186 | if (mViewManager->currentView()->isEventView()) { | 3186 | if (mViewManager->currentView()->isEventView()) { |
3187 | if ( incidence && incidence->type() == "Event" ) { | 3187 | if ( incidence && incidence->typeID() == eventID ) { |
3188 | anEvent = static_cast<Event *>(incidence); | 3188 | anEvent = static_cast<Event *>(incidence); |
3189 | } | 3189 | } |
3190 | } | 3190 | } |
3191 | 3191 | ||
3192 | if (!anEvent) { | 3192 | if (!anEvent) { |
3193 | KNotifyClient::beep(); | 3193 | KNotifyClient::beep(); |
3194 | return; | 3194 | return; |
3195 | } | 3195 | } |
3196 | 3196 | ||
3197 | editEvent(anEvent); | 3197 | editEvent(anEvent); |
3198 | } | 3198 | } |
3199 | 3199 | ||
3200 | void CalendarView::appointment_delete() | 3200 | void CalendarView::appointment_delete() |
3201 | { | 3201 | { |
3202 | Event *anEvent = 0; | 3202 | Event *anEvent = 0; |
3203 | 3203 | ||
3204 | Incidence *incidence = mViewManager->currentView()->selectedIncidences().first(); | 3204 | Incidence *incidence = mViewManager->currentView()->selectedIncidences().first(); |
3205 | 3205 | ||
3206 | if (mViewManager->currentView()->isEventView()) { | 3206 | if (mViewManager->currentView()->isEventView()) { |
3207 | if ( incidence && incidence->type() == "Event" ) { | 3207 | if ( incidence && incidence->typeID() == eventID ) { |
3208 | anEvent = static_cast<Event *>(incidence); | 3208 | anEvent = static_cast<Event *>(incidence); |
3209 | } | 3209 | } |
3210 | } | 3210 | } |
3211 | 3211 | ||
3212 | if (!anEvent) { | 3212 | if (!anEvent) { |
3213 | KNotifyClient::beep(); | 3213 | KNotifyClient::beep(); |
3214 | return; | 3214 | return; |
3215 | } | 3215 | } |
3216 | 3216 | ||
3217 | deleteEvent(anEvent); | 3217 | deleteEvent(anEvent); |
3218 | } | 3218 | } |
3219 | 3219 | ||
3220 | void CalendarView::todo_resub( Todo * parent, Todo * sub ) | 3220 | void CalendarView::todo_resub( Todo * parent, Todo * sub ) |
3221 | { | 3221 | { |
3222 | if (!sub) return; | 3222 | if (!sub) return; |
3223 | if ( sub->relatedTo() == parent ) | 3223 | if ( sub->relatedTo() == parent ) |
3224 | return; | 3224 | return; |
3225 | sub->setRelatedTo(parent); | 3225 | sub->setRelatedTo(parent); |
3226 | sub->updated(); | 3226 | sub->updated(); |
3227 | setModified(true); | 3227 | setModified(true); |
3228 | updateView(); | 3228 | updateView(); |
3229 | } | 3229 | } |
3230 | void CalendarView::todo_unsub(Todo *anTodo ) | 3230 | void CalendarView::todo_unsub(Todo *anTodo ) |
3231 | { | 3231 | { |
3232 | todo_resub( 0, anTodo ); | 3232 | todo_resub( 0, anTodo ); |
3233 | } | 3233 | } |
3234 | 3234 | ||
3235 | void CalendarView::deleteTodo(Todo *todo) | 3235 | void CalendarView::deleteTodo(Todo *todo) |
3236 | { | 3236 | { |
3237 | if (!todo) { | 3237 | if (!todo) { |
3238 | KNotifyClient::beep(); | 3238 | KNotifyClient::beep(); |
3239 | return; | 3239 | return; |
3240 | } | 3240 | } |
3241 | if (KOPrefs::instance()->mConfirm) { | 3241 | if (KOPrefs::instance()->mConfirm) { |
3242 | QString text = todo->summary().left(20); | 3242 | QString text = todo->summary().left(20); |
3243 | if (!todo->relations().isEmpty()) { | 3243 | if (!todo->relations().isEmpty()) { |
3244 | text += i18n("\nhas sub-todos.\nAll completed sub-todos\nwill be deleted as well!"); | 3244 | text += i18n("\nhas sub-todos.\nAll completed sub-todos\nwill be deleted as well!"); |
3245 | 3245 | ||
3246 | } | 3246 | } |
3247 | switch (msgItemDelete(text)) { | 3247 | switch (msgItemDelete(text)) { |
3248 | case KMessageBox::Continue: // OK | 3248 | case KMessageBox::Continue: // OK |
3249 | bool deleteT = false; | 3249 | bool deleteT = false; |
3250 | if (!todo->relations().isEmpty()) { | 3250 | if (!todo->relations().isEmpty()) { |
3251 | deleteT = removeCompletedSubTodos( todo ); | 3251 | deleteT = removeCompletedSubTodos( todo ); |
3252 | } | 3252 | } |
3253 | // deleteT == true: todo already deleted in removeCompletedSubTodos | 3253 | // deleteT == true: todo already deleted in removeCompletedSubTodos |
3254 | if ( !deleteT ) { | 3254 | if ( !deleteT ) { |
3255 | checkExternalId( todo ); | 3255 | checkExternalId( todo ); |
3256 | calendar()->deleteTodo(todo); | 3256 | calendar()->deleteTodo(todo); |
3257 | changeTodoDisplay( todo,KOGlobals::EVENTDELETED ); | 3257 | changeTodoDisplay( todo,KOGlobals::EVENTDELETED ); |
3258 | updateView(); | 3258 | updateView(); |
3259 | } | 3259 | } |
3260 | break; | 3260 | break; |
3261 | } // switch | 3261 | } // switch |
3262 | } else { | 3262 | } else { |
3263 | checkExternalId( todo ); | 3263 | checkExternalId( todo ); |
3264 | mCalendar->deleteTodo(todo); | 3264 | mCalendar->deleteTodo(todo); |
3265 | changeTodoDisplay( todo,KOGlobals::EVENTDELETED ); | 3265 | changeTodoDisplay( todo,KOGlobals::EVENTDELETED ); |
3266 | updateView(); | 3266 | updateView(); |
3267 | } | 3267 | } |
3268 | 3268 | ||
3269 | emit updateSearchDialog(); | 3269 | emit updateSearchDialog(); |
3270 | } | 3270 | } |
3271 | void CalendarView::deleteJournal(Journal *jour) | 3271 | void CalendarView::deleteJournal(Journal *jour) |
3272 | { | 3272 | { |
3273 | if (!jour) { | 3273 | if (!jour) { |
3274 | KNotifyClient::beep(); | 3274 | KNotifyClient::beep(); |
3275 | return; | 3275 | return; |
3276 | } | 3276 | } |
3277 | if (KOPrefs::instance()->mConfirm) { | 3277 | if (KOPrefs::instance()->mConfirm) { |
3278 | switch (msgItemDelete( jour->description().left(20))) { | 3278 | switch (msgItemDelete( jour->description().left(20))) { |
3279 | case KMessageBox::Continue: // OK | 3279 | case KMessageBox::Continue: // OK |
3280 | calendar()->deleteJournal(jour); | 3280 | calendar()->deleteJournal(jour); |
3281 | updateView(); | 3281 | updateView(); |
3282 | break; | 3282 | break; |
3283 | } // switch | 3283 | } // switch |
3284 | } else { | 3284 | } else { |
3285 | calendar()->deleteJournal(jour);; | 3285 | calendar()->deleteJournal(jour);; |
3286 | updateView(); | 3286 | updateView(); |
3287 | } | 3287 | } |
3288 | emit updateSearchDialog(); | 3288 | emit updateSearchDialog(); |
3289 | } | 3289 | } |
3290 | 3290 | ||
3291 | void CalendarView::deleteEvent(Event *anEvent) | 3291 | void CalendarView::deleteEvent(Event *anEvent) |
3292 | { | 3292 | { |
3293 | if (!anEvent) { | 3293 | if (!anEvent) { |
3294 | KNotifyClient::beep(); | 3294 | KNotifyClient::beep(); |
3295 | return; | 3295 | return; |
3296 | } | 3296 | } |
3297 | 3297 | ||
3298 | if (anEvent->recurrence()->doesRecur()) { | 3298 | if (anEvent->recurrence()->doesRecur()) { |
3299 | QDate itemDate = mViewManager->currentSelectionDate(); | 3299 | QDate itemDate = mViewManager->currentSelectionDate(); |
3300 | int km; | 3300 | int km; |
3301 | if (!itemDate.isValid()) { | 3301 | if (!itemDate.isValid()) { |
3302 | //kdDebug() << "Date Not Valid" << endl; | 3302 | //kdDebug() << "Date Not Valid" << endl; |
3303 | if (KOPrefs::instance()->mConfirm) { | 3303 | if (KOPrefs::instance()->mConfirm) { |
3304 | km = KMessageBox::warningContinueCancel(this,anEvent->summary().left(25) + | 3304 | km = KMessageBox::warningContinueCancel(this,anEvent->summary().left(25) + |
3305 | i18n("\nThis event recurs\nover multiple dates.\nAre you sure you want\nto delete this event\nand all its recurrences?"), | 3305 | i18n("\nThis event recurs\nover multiple dates.\nAre you sure you want\nto delete this event\nand all its recurrences?"), |
3306 | i18n("KO/Pi Confirmation"),i18n("Delete All")); | 3306 | i18n("KO/Pi Confirmation"),i18n("Delete All")); |
3307 | if ( km == KMessageBox::Continue ) | 3307 | if ( km == KMessageBox::Continue ) |
3308 | km = KMessageBox::No; // No = all below | 3308 | km = KMessageBox::No; // No = all below |
3309 | } else | 3309 | } else |
3310 | km = KMessageBox::No; | 3310 | km = KMessageBox::No; |
3311 | } else { | 3311 | } else { |
3312 | km = KMessageBox::warningYesNoCancel(this,anEvent->summary().left(25) + | 3312 | km = KMessageBox::warningYesNoCancel(this,anEvent->summary().left(25) + |
3313 | i18n("\nThis event recurs\nover multiple dates.\nDo you want to delete\nall it's recurrences,\nor only the current one on:\n")+ | 3313 | i18n("\nThis event recurs\nover multiple dates.\nDo you want to delete\nall it's recurrences,\nor only the current one on:\n")+ |
3314 | KGlobal::locale()->formatDate(itemDate)+i18n(" ?\n\nDelete:\n"), | 3314 | KGlobal::locale()->formatDate(itemDate)+i18n(" ?\n\nDelete:\n"), |
3315 | i18n("KO/Pi Confirmation"),i18n("Current"), | 3315 | i18n("KO/Pi Confirmation"),i18n("Current"), |
3316 | i18n("All")); | 3316 | i18n("All")); |
3317 | } | 3317 | } |
3318 | switch(km) { | 3318 | switch(km) { |
3319 | 3319 | ||
3320 | case KMessageBox::No: // Continue // all | 3320 | case KMessageBox::No: // Continue // all |
3321 | //qDebug("KMessageBox::No "); | 3321 | //qDebug("KMessageBox::No "); |
3322 | if (anEvent->organizer()==KOPrefs::instance()->email() && anEvent->attendeeCount()>0) | 3322 | if (anEvent->organizer()==KOPrefs::instance()->email() && anEvent->attendeeCount()>0) |
3323 | schedule(Scheduler::Cancel,anEvent); | 3323 | schedule(Scheduler::Cancel,anEvent); |
3324 | 3324 | ||
3325 | checkExternalId( anEvent); | 3325 | checkExternalId( anEvent); |
3326 | mCalendar->deleteEvent(anEvent); | 3326 | mCalendar->deleteEvent(anEvent); |
3327 | changeEventDisplay(anEvent,KOGlobals::EVENTDELETED); | 3327 | changeEventDisplay(anEvent,KOGlobals::EVENTDELETED); |
3328 | break; | 3328 | break; |
3329 | 3329 | ||
3330 | // Disabled because it does not work | 3330 | // Disabled because it does not work |
3331 | //#if 0 | 3331 | //#if 0 |
3332 | case KMessageBox::Yes: // just this one | 3332 | case KMessageBox::Yes: // just this one |
3333 | //QDate qd = mNavigator->selectedDates().first(); | 3333 | //QDate qd = mNavigator->selectedDates().first(); |
3334 | //if (!qd.isValid()) { | 3334 | //if (!qd.isValid()) { |
3335 | // kdDebug() << "no date selected, or invalid date" << endl; | 3335 | // kdDebug() << "no date selected, or invalid date" << endl; |
3336 | // KNotifyClient::beep(); | 3336 | // KNotifyClient::beep(); |
3337 | // return; | 3337 | // return; |
3338 | //} | 3338 | //} |
3339 | //while (!anEvent->recursOn(qd)) qd = qd.addDays(1); | 3339 | //while (!anEvent->recursOn(qd)) qd = qd.addDays(1); |
3340 | if (itemDate!=QDate(1,1,1) || itemDate.isValid()) { | 3340 | if (itemDate!=QDate(1,1,1) || itemDate.isValid()) { |
3341 | anEvent->addExDate(itemDate); | 3341 | anEvent->addExDate(itemDate); |
3342 | int duration = anEvent->recurrence()->duration(); | 3342 | int duration = anEvent->recurrence()->duration(); |
3343 | if ( duration > 0 ) { | 3343 | if ( duration > 0 ) { |
3344 | anEvent->recurrence()->setDuration( duration - 1 ); | 3344 | anEvent->recurrence()->setDuration( duration - 1 ); |
3345 | } | 3345 | } |
3346 | changeEventDisplay(anEvent, KOGlobals::EVENTEDITED); | 3346 | changeEventDisplay(anEvent, KOGlobals::EVENTEDITED); |
3347 | } | 3347 | } |
3348 | break; | 3348 | break; |
3349 | //#endif | 3349 | //#endif |
3350 | } // switch | 3350 | } // switch |
3351 | } else { | 3351 | } else { |
3352 | if (KOPrefs::instance()->mConfirm) { | 3352 | if (KOPrefs::instance()->mConfirm) { |
3353 | switch (KMessageBox::warningContinueCancel(this,anEvent->summary().left(25) + | 3353 | switch (KMessageBox::warningContinueCancel(this,anEvent->summary().left(25) + |
3354 | i18n("\nAre you sure you want\nto delete this event?"), | 3354 | i18n("\nAre you sure you want\nto delete this event?"), |
3355 | i18n("KO/Pi Confirmation"),i18n("Delete"))) { | 3355 | i18n("KO/Pi Confirmation"),i18n("Delete"))) { |
3356 | case KMessageBox::Continue: // OK | 3356 | case KMessageBox::Continue: // OK |
3357 | if (anEvent->organizer()==KOPrefs::instance()->email() && anEvent->attendeeCount()>0) | 3357 | if (anEvent->organizer()==KOPrefs::instance()->email() && anEvent->attendeeCount()>0) |
3358 | schedule(Scheduler::Cancel,anEvent); | 3358 | schedule(Scheduler::Cancel,anEvent); |
3359 | checkExternalId( anEvent); | 3359 | checkExternalId( anEvent); |
3360 | mCalendar->deleteEvent(anEvent); | 3360 | mCalendar->deleteEvent(anEvent); |
3361 | changeEventDisplay(anEvent, KOGlobals::EVENTDELETED); | 3361 | changeEventDisplay(anEvent, KOGlobals::EVENTDELETED); |
3362 | break; | 3362 | break; |
3363 | } // switch | 3363 | } // switch |
3364 | } else { | 3364 | } else { |
3365 | if (anEvent->organizer()==KOPrefs::instance()->email() && anEvent->attendeeCount()>0) | 3365 | if (anEvent->organizer()==KOPrefs::instance()->email() && anEvent->attendeeCount()>0) |
3366 | schedule(Scheduler::Cancel,anEvent); | 3366 | schedule(Scheduler::Cancel,anEvent); |
3367 | checkExternalId( anEvent); | 3367 | checkExternalId( anEvent); |
3368 | mCalendar->deleteEvent(anEvent); | 3368 | mCalendar->deleteEvent(anEvent); |
3369 | changeEventDisplay(anEvent, KOGlobals::EVENTDELETED); | 3369 | changeEventDisplay(anEvent, KOGlobals::EVENTDELETED); |
3370 | } | 3370 | } |
3371 | } // if-else | 3371 | } // if-else |
3372 | emit updateSearchDialog(); | 3372 | emit updateSearchDialog(); |
3373 | } | 3373 | } |
3374 | 3374 | ||
3375 | bool CalendarView::deleteEvent(const QString &uid) | 3375 | bool CalendarView::deleteEvent(const QString &uid) |
3376 | { | 3376 | { |
3377 | Event *ev = mCalendar->event(uid); | 3377 | Event *ev = mCalendar->event(uid); |
3378 | if (ev) { | 3378 | if (ev) { |
3379 | deleteEvent(ev); | 3379 | deleteEvent(ev); |
3380 | return true; | 3380 | return true; |
3381 | } else { | 3381 | } else { |
3382 | return false; | 3382 | return false; |
3383 | } | 3383 | } |
3384 | } | 3384 | } |
3385 | 3385 | ||
3386 | /*****************************************************************************/ | 3386 | /*****************************************************************************/ |
3387 | 3387 | ||
3388 | void CalendarView::action_mail() | 3388 | void CalendarView::action_mail() |
3389 | { | 3389 | { |
3390 | #ifndef KORG_NOMAIL | 3390 | #ifndef KORG_NOMAIL |
3391 | KOMailClient mailClient; | 3391 | KOMailClient mailClient; |
3392 | 3392 | ||
3393 | Incidence *incidence = currentSelection(); | 3393 | Incidence *incidence = currentSelection(); |
3394 | 3394 | ||
3395 | if (!incidence) { | 3395 | if (!incidence) { |
3396 | KMessageBox::sorry(this,i18n("Can't generate mail:\nNo event selected.")); | 3396 | KMessageBox::sorry(this,i18n("Can't generate mail:\nNo event selected.")); |
3397 | return; | 3397 | return; |
3398 | } | 3398 | } |
3399 | if(incidence->attendeeCount() == 0 ) { | 3399 | if(incidence->attendeeCount() == 0 ) { |
3400 | KMessageBox::sorry(this, | 3400 | KMessageBox::sorry(this, |
3401 | i18n("Can't generate mail:\nNo attendees defined.\n")); | 3401 | i18n("Can't generate mail:\nNo attendees defined.\n")); |
3402 | return; | 3402 | return; |
3403 | } | 3403 | } |
3404 | 3404 | ||
3405 | CalendarLocal cal_tmp; | 3405 | CalendarLocal cal_tmp; |
3406 | Event *event = 0; | 3406 | Event *event = 0; |
3407 | Event *ev = 0; | 3407 | Event *ev = 0; |
3408 | if ( incidence && incidence->type() == "Event" ) { | 3408 | if ( incidence && incidence->typeID() == eventID ) { |
3409 | event = static_cast<Event *>(incidence); | 3409 | event = static_cast<Event *>(incidence); |
3410 | ev = new Event(*event); | 3410 | ev = new Event(*event); |
3411 | cal_tmp.addEvent(ev); | 3411 | cal_tmp.addEvent(ev); |
3412 | } | 3412 | } |
3413 | ICalFormat mForm(); | 3413 | ICalFormat mForm(); |
3414 | QString attachment = mForm.toString( &cal_tmp ); | 3414 | QString attachment = mForm.toString( &cal_tmp ); |
3415 | if (ev) delete(ev); | 3415 | if (ev) delete(ev); |
3416 | 3416 | ||
3417 | mailClient.mailAttendees(currentSelection(), attachment); | 3417 | mailClient.mailAttendees(currentSelection(), attachment); |
3418 | 3418 | ||
3419 | #endif | 3419 | #endif |
3420 | 3420 | ||
3421 | #if 0 | 3421 | #if 0 |
3422 | Event *anEvent = 0; | 3422 | Event *anEvent = 0; |
3423 | if (mViewManager->currentView()->isEventView()) { | 3423 | if (mViewManager->currentView()->isEventView()) { |
3424 | anEvent = dynamic_cast<Event *>((mViewManager->currentView()->selectedIncidences()).first()); | 3424 | anEvent = dynamic_cast<Event *>((mViewManager->currentView()->selectedIncidences()).first()); |
3425 | } | 3425 | } |
3426 | 3426 | ||
3427 | if (!anEvent) { | 3427 | if (!anEvent) { |
3428 | KMessageBox::sorry(this,i18n("Can't generate mail:\nNo event selected.")); | 3428 | KMessageBox::sorry(this,i18n("Can't generate mail:\nNo event selected.")); |
3429 | return; | 3429 | return; |
3430 | } | 3430 | } |
3431 | if(anEvent->attendeeCount() == 0 ) { | 3431 | if(anEvent->attendeeCount() == 0 ) { |
3432 | KMessageBox::sorry(this, | 3432 | KMessageBox::sorry(this, |
3433 | i18n("Can't generate mail:\nNo attendees defined.\n")); | 3433 | i18n("Can't generate mail:\nNo attendees defined.\n")); |
3434 | return; | 3434 | return; |
3435 | } | 3435 | } |
3436 | 3436 | ||
3437 | mailobject.emailEvent(anEvent); | 3437 | mailobject.emailEvent(anEvent); |
3438 | #endif | 3438 | #endif |
3439 | } | 3439 | } |
3440 | 3440 | ||
3441 | 3441 | ||
3442 | void CalendarView::schedule_publish(Incidence *incidence) | 3442 | void CalendarView::schedule_publish(Incidence *incidence) |
3443 | { | 3443 | { |
3444 | Event *event = 0; | 3444 | Event *event = 0; |
3445 | Todo *todo = 0; | 3445 | Todo *todo = 0; |
3446 | 3446 | ||
3447 | if (incidence == 0) { | 3447 | if (incidence == 0) { |
3448 | incidence = mViewManager->currentView()->selectedIncidences().first(); | 3448 | incidence = mViewManager->currentView()->selectedIncidences().first(); |
3449 | if (incidence == 0) { | 3449 | if (incidence == 0) { |
3450 | incidence = mTodoList->selectedIncidences().first(); | 3450 | incidence = mTodoList->selectedIncidences().first(); |
3451 | } | 3451 | } |
3452 | } | 3452 | } |
3453 | if ( incidence && incidence->type() == "Event" ) { | 3453 | if ( incidence && incidence->typeID() == eventID ) { |
3454 | event = static_cast<Event *>(incidence); | 3454 | event = static_cast<Event *>(incidence); |
3455 | } else { | 3455 | } else { |
3456 | if ( incidence && incidence->type() == "Todo" ) { | 3456 | if ( incidence && incidence->typeID() == todoID ) { |
3457 | todo = static_cast<Todo *>(incidence); | 3457 | todo = static_cast<Todo *>(incidence); |
3458 | } | 3458 | } |
3459 | } | 3459 | } |
3460 | 3460 | ||
3461 | if (!event && !todo) { | 3461 | if (!event && !todo) { |
3462 | KMessageBox::sorry(this,i18n("No event selected.")); | 3462 | KMessageBox::sorry(this,i18n("No event selected.")); |
3463 | return; | 3463 | return; |
3464 | } | 3464 | } |
3465 | 3465 | ||
3466 | PublishDialog *publishdlg = new PublishDialog(); | 3466 | PublishDialog *publishdlg = new PublishDialog(); |
3467 | if (incidence->attendeeCount()>0) { | 3467 | if (incidence->attendeeCount()>0) { |
3468 | QPtrList<Attendee> attendees = incidence->attendees(); | 3468 | QPtrList<Attendee> attendees = incidence->attendees(); |
3469 | attendees.first(); | 3469 | attendees.first(); |
3470 | while ( attendees.current()!=0 ) { | 3470 | while ( attendees.current()!=0 ) { |
3471 | publishdlg->addAttendee(attendees.current()); | 3471 | publishdlg->addAttendee(attendees.current()); |
3472 | attendees.next(); | 3472 | attendees.next(); |
3473 | } | 3473 | } |
3474 | } | 3474 | } |
3475 | bool send = true; | 3475 | bool send = true; |
3476 | if ( KOPrefs::instance()->mMailClient == KOPrefs::MailClientSendmail ) { | 3476 | if ( KOPrefs::instance()->mMailClient == KOPrefs::MailClientSendmail ) { |
3477 | if ( publishdlg->exec() != QDialog::Accepted ) | 3477 | if ( publishdlg->exec() != QDialog::Accepted ) |
3478 | send = false; | 3478 | send = false; |
3479 | } | 3479 | } |
3480 | if ( send ) { | 3480 | if ( send ) { |
3481 | OutgoingDialog *dlg = mDialogManager->outgoingDialog(); | 3481 | OutgoingDialog *dlg = mDialogManager->outgoingDialog(); |
3482 | if ( event ) { | 3482 | if ( event ) { |
3483 | Event *ev = new Event(*event); | 3483 | Event *ev = new Event(*event); |
3484 | ev->registerObserver(0); | 3484 | ev->registerObserver(0); |
3485 | ev->clearAttendees(); | 3485 | ev->clearAttendees(); |
3486 | if (!dlg->addMessage(ev,Scheduler::Publish,publishdlg->addresses())) { | 3486 | if (!dlg->addMessage(ev,Scheduler::Publish,publishdlg->addresses())) { |
3487 | delete(ev); | 3487 | delete(ev); |
3488 | } | 3488 | } |
3489 | } else { | 3489 | } else { |
3490 | if ( todo ) { | 3490 | if ( todo ) { |
3491 | Todo *ev = new Todo(*todo); | 3491 | Todo *ev = new Todo(*todo); |
3492 | ev->registerObserver(0); | 3492 | ev->registerObserver(0); |
3493 | ev->clearAttendees(); | 3493 | ev->clearAttendees(); |
3494 | if (!dlg->addMessage(ev,Scheduler::Publish,publishdlg->addresses())) { | 3494 | if (!dlg->addMessage(ev,Scheduler::Publish,publishdlg->addresses())) { |
3495 | delete(ev); | 3495 | delete(ev); |
3496 | } | 3496 | } |
3497 | } | 3497 | } |
3498 | } | 3498 | } |
3499 | } | 3499 | } |
3500 | delete publishdlg; | 3500 | delete publishdlg; |
3501 | } | 3501 | } |
3502 | 3502 | ||
3503 | void CalendarView::schedule_request(Incidence *incidence) | 3503 | void CalendarView::schedule_request(Incidence *incidence) |
3504 | { | 3504 | { |
3505 | schedule(Scheduler::Request,incidence); | 3505 | schedule(Scheduler::Request,incidence); |
3506 | } | 3506 | } |
3507 | 3507 | ||
3508 | void CalendarView::schedule_refresh(Incidence *incidence) | 3508 | void CalendarView::schedule_refresh(Incidence *incidence) |
3509 | { | 3509 | { |
3510 | schedule(Scheduler::Refresh,incidence); | 3510 | schedule(Scheduler::Refresh,incidence); |
3511 | } | 3511 | } |
3512 | 3512 | ||
3513 | void CalendarView::schedule_cancel(Incidence *incidence) | 3513 | void CalendarView::schedule_cancel(Incidence *incidence) |
3514 | { | 3514 | { |
3515 | schedule(Scheduler::Cancel,incidence); | 3515 | schedule(Scheduler::Cancel,incidence); |
3516 | } | 3516 | } |
3517 | 3517 | ||
3518 | void CalendarView::schedule_add(Incidence *incidence) | 3518 | void CalendarView::schedule_add(Incidence *incidence) |
3519 | { | 3519 | { |
3520 | schedule(Scheduler::Add,incidence); | 3520 | schedule(Scheduler::Add,incidence); |
3521 | } | 3521 | } |
3522 | 3522 | ||
3523 | void CalendarView::schedule_reply(Incidence *incidence) | 3523 | void CalendarView::schedule_reply(Incidence *incidence) |
3524 | { | 3524 | { |
3525 | schedule(Scheduler::Reply,incidence); | 3525 | schedule(Scheduler::Reply,incidence); |
3526 | } | 3526 | } |
3527 | 3527 | ||
3528 | void CalendarView::schedule_counter(Incidence *incidence) | 3528 | void CalendarView::schedule_counter(Incidence *incidence) |
3529 | { | 3529 | { |
3530 | schedule(Scheduler::Counter,incidence); | 3530 | schedule(Scheduler::Counter,incidence); |
3531 | } | 3531 | } |
3532 | 3532 | ||
3533 | void CalendarView::schedule_declinecounter(Incidence *incidence) | 3533 | void CalendarView::schedule_declinecounter(Incidence *incidence) |
3534 | { | 3534 | { |
3535 | schedule(Scheduler::Declinecounter,incidence); | 3535 | schedule(Scheduler::Declinecounter,incidence); |
3536 | } | 3536 | } |
3537 | 3537 | ||
3538 | void CalendarView::schedule_publish_freebusy(int daysToPublish) | 3538 | void CalendarView::schedule_publish_freebusy(int daysToPublish) |
3539 | { | 3539 | { |
3540 | QDateTime start = QDateTime::currentDateTime(); | 3540 | QDateTime start = QDateTime::currentDateTime(); |
3541 | QDateTime end = start.addDays(daysToPublish); | 3541 | QDateTime end = start.addDays(daysToPublish); |
3542 | 3542 | ||
3543 | FreeBusy *freebusy = new FreeBusy(mCalendar, start, end); | 3543 | FreeBusy *freebusy = new FreeBusy(mCalendar, start, end); |
3544 | freebusy->setOrganizer(KOPrefs::instance()->email()); | 3544 | freebusy->setOrganizer(KOPrefs::instance()->email()); |
3545 | 3545 | ||
3546 | 3546 | ||
3547 | PublishDialog *publishdlg = new PublishDialog(); | 3547 | PublishDialog *publishdlg = new PublishDialog(); |
3548 | if ( publishdlg->exec() == QDialog::Accepted ) { | 3548 | if ( publishdlg->exec() == QDialog::Accepted ) { |
3549 | OutgoingDialog *dlg = mDialogManager->outgoingDialog(); | 3549 | OutgoingDialog *dlg = mDialogManager->outgoingDialog(); |
3550 | if (!dlg->addMessage(freebusy,Scheduler::Publish,publishdlg->addresses())) { | 3550 | if (!dlg->addMessage(freebusy,Scheduler::Publish,publishdlg->addresses())) { |
3551 | delete(freebusy); | 3551 | delete(freebusy); |
3552 | } | 3552 | } |
3553 | } | 3553 | } |
3554 | delete publishdlg; | 3554 | delete publishdlg; |
3555 | } | 3555 | } |
3556 | 3556 | ||
3557 | void CalendarView::schedule(Scheduler::Method method, Incidence *incidence) | 3557 | void CalendarView::schedule(Scheduler::Method method, Incidence *incidence) |
3558 | { | 3558 | { |
3559 | Event *event = 0; | 3559 | Event *event = 0; |
3560 | Todo *todo = 0; | 3560 | Todo *todo = 0; |
3561 | 3561 | ||
3562 | if (incidence == 0) { | 3562 | if (incidence == 0) { |
3563 | incidence = mViewManager->currentView()->selectedIncidences().first(); | 3563 | incidence = mViewManager->currentView()->selectedIncidences().first(); |
3564 | if (incidence == 0) { | 3564 | if (incidence == 0) { |
3565 | incidence = mTodoList->selectedIncidences().first(); | 3565 | incidence = mTodoList->selectedIncidences().first(); |
3566 | } | 3566 | } |
3567 | } | 3567 | } |
3568 | if ( incidence && incidence->type() == "Event" ) { | 3568 | if ( incidence && incidence->typeID() == eventID ) { |
3569 | event = static_cast<Event *>(incidence); | 3569 | event = static_cast<Event *>(incidence); |
3570 | } | 3570 | } |
3571 | if ( incidence && incidence->type() == "Todo" ) { | 3571 | if ( incidence && incidence->typeID() == todoID ) { |
3572 | todo = static_cast<Todo *>(incidence); | 3572 | todo = static_cast<Todo *>(incidence); |
3573 | } | 3573 | } |
3574 | 3574 | ||
3575 | if (!event && !todo) { | 3575 | if (!event && !todo) { |
3576 | KMessageBox::sorry(this,i18n("No event selected.")); | 3576 | KMessageBox::sorry(this,i18n("No event selected.")); |
3577 | return; | 3577 | return; |
3578 | } | 3578 | } |
3579 | 3579 | ||
3580 | if( incidence->attendeeCount() == 0 && method != Scheduler::Publish ) { | 3580 | if( incidence->attendeeCount() == 0 && method != Scheduler::Publish ) { |
3581 | KMessageBox::sorry(this,i18n("The event has no attendees.")); | 3581 | KMessageBox::sorry(this,i18n("The event has no attendees.")); |
3582 | return; | 3582 | return; |
3583 | } | 3583 | } |
3584 | 3584 | ||
3585 | Event *ev = 0; | 3585 | Event *ev = 0; |
3586 | if (event) ev = new Event(*event); | 3586 | if (event) ev = new Event(*event); |
3587 | Todo *to = 0; | 3587 | Todo *to = 0; |
3588 | if (todo) to = new Todo(*todo); | 3588 | if (todo) to = new Todo(*todo); |
3589 | 3589 | ||
3590 | if (method == Scheduler::Reply || method == Scheduler::Refresh) { | 3590 | if (method == Scheduler::Reply || method == Scheduler::Refresh) { |
3591 | Attendee *me = incidence->attendeeByMails(KOPrefs::instance()->mAdditionalMails,KOPrefs::instance()->email()); | 3591 | Attendee *me = incidence->attendeeByMails(KOPrefs::instance()->mAdditionalMails,KOPrefs::instance()->email()); |
3592 | if (!me) { | 3592 | if (!me) { |
3593 | KMessageBox::sorry(this,i18n("Could not find your attendee entry.\nPlease check the emails.")); | 3593 | KMessageBox::sorry(this,i18n("Could not find your attendee entry.\nPlease check the emails.")); |
3594 | return; | 3594 | return; |
3595 | } | 3595 | } |
3596 | if (me->status()==Attendee::NeedsAction && me->RSVP() && method==Scheduler::Reply) { | 3596 | if (me->status()==Attendee::NeedsAction && me->RSVP() && method==Scheduler::Reply) { |
3597 | StatusDialog *statdlg = new StatusDialog(this); | 3597 | StatusDialog *statdlg = new StatusDialog(this); |
3598 | if (!statdlg->exec()==QDialog::Accepted) return; | 3598 | if (!statdlg->exec()==QDialog::Accepted) return; |
3599 | me->setStatus( statdlg->status() ); | 3599 | me->setStatus( statdlg->status() ); |
3600 | delete(statdlg); | 3600 | delete(statdlg); |
3601 | } | 3601 | } |
3602 | Attendee *menew = new Attendee(*me); | 3602 | Attendee *menew = new Attendee(*me); |
3603 | if (ev) { | 3603 | if (ev) { |
3604 | ev->clearAttendees(); | 3604 | ev->clearAttendees(); |
3605 | ev->addAttendee(menew,false); | 3605 | ev->addAttendee(menew,false); |
3606 | } else { | 3606 | } else { |
3607 | if (to) { | 3607 | if (to) { |
3608 | todo->clearAttendees(); | 3608 | todo->clearAttendees(); |
3609 | todo->addAttendee(menew,false); | 3609 | todo->addAttendee(menew,false); |
3610 | } | 3610 | } |
3611 | } | 3611 | } |
3612 | } | 3612 | } |
3613 | 3613 | ||
3614 | OutgoingDialog *dlg = mDialogManager->outgoingDialog(); | 3614 | OutgoingDialog *dlg = mDialogManager->outgoingDialog(); |
3615 | if (ev) { | 3615 | if (ev) { |
3616 | if ( !dlg->addMessage(ev,method) ) delete(ev); | 3616 | if ( !dlg->addMessage(ev,method) ) delete(ev); |
3617 | } else { | 3617 | } else { |
3618 | if (to) { | 3618 | if (to) { |
3619 | if ( !dlg->addMessage(to,method) ) delete(to); | 3619 | if ( !dlg->addMessage(to,method) ) delete(to); |
3620 | } | 3620 | } |
3621 | } | 3621 | } |
3622 | } | 3622 | } |
3623 | 3623 | ||
3624 | void CalendarView::openAddressbook() | 3624 | void CalendarView::openAddressbook() |
3625 | { | 3625 | { |
3626 | KRun::runCommand("kaddressbook"); | 3626 | KRun::runCommand("kaddressbook"); |
3627 | } | 3627 | } |
3628 | 3628 | ||
3629 | void CalendarView::setModified(bool modified) | 3629 | void CalendarView::setModified(bool modified) |
3630 | { | 3630 | { |
3631 | if ( modified ) | 3631 | if ( modified ) |
3632 | emit signalmodified(); | 3632 | emit signalmodified(); |
3633 | if (mModified != modified) { | 3633 | if (mModified != modified) { |
3634 | mModified = modified; | 3634 | mModified = modified; |
3635 | emit modifiedChanged(mModified); | 3635 | emit modifiedChanged(mModified); |
3636 | } | 3636 | } |
3637 | } | 3637 | } |
3638 | 3638 | ||
3639 | bool CalendarView::isReadOnly() | 3639 | bool CalendarView::isReadOnly() |
3640 | { | 3640 | { |
3641 | return mReadOnly; | 3641 | return mReadOnly; |
3642 | } | 3642 | } |
3643 | 3643 | ||
3644 | void CalendarView::setReadOnly(bool readOnly) | 3644 | void CalendarView::setReadOnly(bool readOnly) |
3645 | { | 3645 | { |
3646 | if (mReadOnly != readOnly) { | 3646 | if (mReadOnly != readOnly) { |
3647 | mReadOnly = readOnly; | 3647 | mReadOnly = readOnly; |
3648 | emit readOnlyChanged(mReadOnly); | 3648 | emit readOnlyChanged(mReadOnly); |
3649 | } | 3649 | } |
3650 | } | 3650 | } |
3651 | 3651 | ||
3652 | bool CalendarView::isModified() | 3652 | bool CalendarView::isModified() |
3653 | { | 3653 | { |
3654 | return mModified; | 3654 | return mModified; |
3655 | } | 3655 | } |
3656 | void CalendarView::slotprintSelInc() | 3656 | void CalendarView::slotprintSelInc() |
3657 | { | 3657 | { |
3658 | if ( currentSelection() == 0 ) { | 3658 | if ( currentSelection() == 0 ) { |
3659 | KMessageBox::sorry(this,i18n("There is nothing selected!")); | 3659 | KMessageBox::sorry(this,i18n("There is nothing selected!")); |
3660 | return; | 3660 | return; |
3661 | } | 3661 | } |
3662 | showIncidence(); | 3662 | showIncidence(); |
3663 | getEventViewerDialog()->print(); | 3663 | getEventViewerDialog()->print(); |
3664 | 3664 | ||
3665 | } | 3665 | } |
3666 | void CalendarView::printSetup() | 3666 | void CalendarView::printSetup() |
3667 | { | 3667 | { |
3668 | #ifndef KORG_NOPRINTER | 3668 | #ifndef KORG_NOPRINTER |
3669 | createPrinter(); | 3669 | createPrinter(); |
3670 | 3670 | ||
3671 | mCalPrinter->setupPrinter(); | 3671 | mCalPrinter->setupPrinter(); |
3672 | #endif | 3672 | #endif |
3673 | } | 3673 | } |
3674 | 3674 | ||
3675 | void CalendarView::print() | 3675 | void CalendarView::print() |
3676 | { | 3676 | { |
3677 | #ifndef KORG_NOPRINTER | 3677 | #ifndef KORG_NOPRINTER |
3678 | createPrinter(); | 3678 | createPrinter(); |
3679 | 3679 | ||
3680 | DateList tmpDateList = mNavigator->selectedDates(); | 3680 | DateList tmpDateList = mNavigator->selectedDates(); |
3681 | mCalPrinter->print(CalPrinter::Month, | 3681 | mCalPrinter->print(CalPrinter::Month, |
3682 | tmpDateList.first(), tmpDateList.last()); | 3682 | tmpDateList.first(), tmpDateList.last()); |
3683 | #endif | 3683 | #endif |
3684 | } | 3684 | } |
3685 | 3685 | ||
3686 | void CalendarView::printPreview() | 3686 | void CalendarView::printPreview() |
3687 | { | 3687 | { |
3688 | #ifndef KORG_NOPRINTER | 3688 | #ifndef KORG_NOPRINTER |
3689 | kdDebug() << "CalendarView::printPreview()" << endl; | 3689 | kdDebug() << "CalendarView::printPreview()" << endl; |
3690 | 3690 | ||
3691 | createPrinter(); | 3691 | createPrinter(); |
3692 | 3692 | ||
3693 | DateList tmpDateList = mNavigator->selectedDates(); | 3693 | DateList tmpDateList = mNavigator->selectedDates(); |
3694 | 3694 | ||
3695 | mViewManager->currentView()->printPreview(mCalPrinter,tmpDateList.first(), | 3695 | mViewManager->currentView()->printPreview(mCalPrinter,tmpDateList.first(), |
3696 | tmpDateList.last()); | 3696 | tmpDateList.last()); |
3697 | #endif | 3697 | #endif |
3698 | } | 3698 | } |
3699 | 3699 | ||
3700 | void CalendarView::exportICalendar() | 3700 | void CalendarView::exportICalendar() |
3701 | { | 3701 | { |
3702 | QString filename = KFileDialog::getSaveFileName("icalout.ics",i18n("*.ics|ICalendars"),this); | 3702 | QString filename = KFileDialog::getSaveFileName("icalout.ics",i18n("*.ics|ICalendars"),this); |
3703 | 3703 | ||
3704 | // Force correct extension | 3704 | // Force correct extension |
3705 | if (filename.right(4) != ".ics") filename += ".ics"; | 3705 | if (filename.right(4) != ".ics") filename += ".ics"; |
3706 | 3706 | ||
3707 | FileStorage storage( mCalendar, filename, new ICalFormat() ); | 3707 | FileStorage storage( mCalendar, filename, new ICalFormat() ); |
3708 | storage.save(); | 3708 | storage.save(); |
3709 | } | 3709 | } |
3710 | 3710 | ||
3711 | bool CalendarView::exportVCalendar( QString filename ) | 3711 | bool CalendarView::exportVCalendar( QString filename ) |
3712 | { | 3712 | { |
3713 | if (mCalendar->journals().count() > 0) { | 3713 | if (mCalendar->journals().count() > 0) { |
3714 | int result = KMessageBox::warningContinueCancel(this, | 3714 | int result = KMessageBox::warningContinueCancel(this, |
3715 | i18n("The journal entries can not be\nexported to a vCalendar file."), | 3715 | i18n("The journal entries can not be\nexported to a vCalendar file."), |
3716 | i18n("Data Loss Warning"),i18n("Proceed"),i18n("Cancel"), | 3716 | i18n("Data Loss Warning"),i18n("Proceed"),i18n("Cancel"), |
3717 | true); | 3717 | true); |
3718 | if (result != KMessageBox::Continue) return false; | 3718 | if (result != KMessageBox::Continue) return false; |
3719 | } | 3719 | } |
3720 | 3720 | ||
3721 | //QString filename = KFileDialog::getSaveFileName("vcalout.vcs",i18n("*.vcs|VCalendars"),this); | 3721 | //QString filename = KFileDialog::getSaveFileName("vcalout.vcs",i18n("*.vcs|VCalendars"),this); |
3722 | 3722 | ||
3723 | // Force correct extension | 3723 | // Force correct extension |
3724 | if (filename.right(4) != ".vcs") filename += ".vcs"; | 3724 | if (filename.right(4) != ".vcs") filename += ".vcs"; |
3725 | 3725 | ||
3726 | FileStorage storage( mCalendar, filename, new VCalFormat ); | 3726 | FileStorage storage( mCalendar, filename, new VCalFormat ); |
3727 | return storage.save(); | 3727 | return storage.save(); |
3728 | 3728 | ||
3729 | } | 3729 | } |
3730 | 3730 | ||
3731 | void CalendarView::eventUpdated(Incidence *) | 3731 | void CalendarView::eventUpdated(Incidence *) |
3732 | { | 3732 | { |
3733 | setModified(); | 3733 | setModified(); |
3734 | // Don't call updateView here. The code, which has caused the update of the | 3734 | // Don't call updateView here. The code, which has caused the update of the |
3735 | // event is responsible for updating the view. | 3735 | // event is responsible for updating the view. |
3736 | // updateView(); | 3736 | // updateView(); |
3737 | } | 3737 | } |
3738 | 3738 | ||
3739 | void CalendarView::adaptNavigationUnits() | 3739 | void CalendarView::adaptNavigationUnits() |
3740 | { | 3740 | { |
3741 | if (mViewManager->currentView()->isEventView()) { | 3741 | if (mViewManager->currentView()->isEventView()) { |
3742 | int days = mViewManager->currentView()->currentDateCount(); | 3742 | int days = mViewManager->currentView()->currentDateCount(); |
3743 | if (days == 1) { | 3743 | if (days == 1) { |
3744 | emit changeNavStringPrev(i18n("&Previous Day")); | 3744 | emit changeNavStringPrev(i18n("&Previous Day")); |
3745 | emit changeNavStringNext(i18n("&Next Day")); | 3745 | emit changeNavStringNext(i18n("&Next Day")); |
3746 | } else { | 3746 | } else { |
3747 | emit changeNavStringPrev(i18n("&Previous Week")); | 3747 | emit changeNavStringPrev(i18n("&Previous Week")); |
3748 | emit changeNavStringNext(i18n("&Next Week")); | 3748 | emit changeNavStringNext(i18n("&Next Week")); |
3749 | } | 3749 | } |
3750 | } | 3750 | } |
3751 | } | 3751 | } |
3752 | 3752 | ||
3753 | void CalendarView::processMainViewSelection( Incidence *incidence ) | 3753 | void CalendarView::processMainViewSelection( Incidence *incidence ) |
3754 | { | 3754 | { |
3755 | if ( incidence ) mTodoList->clearSelection(); | 3755 | if ( incidence ) mTodoList->clearSelection(); |
3756 | processIncidenceSelection( incidence ); | 3756 | processIncidenceSelection( incidence ); |
3757 | } | 3757 | } |
3758 | 3758 | ||
3759 | void CalendarView::processTodoListSelection( Incidence *incidence ) | 3759 | void CalendarView::processTodoListSelection( Incidence *incidence ) |
3760 | { | 3760 | { |
3761 | if ( incidence && mViewManager->currentView() ) { | 3761 | if ( incidence && mViewManager->currentView() ) { |
3762 | mViewManager->currentView()->clearSelection(); | 3762 | mViewManager->currentView()->clearSelection(); |
3763 | } | 3763 | } |
3764 | processIncidenceSelection( incidence ); | 3764 | processIncidenceSelection( incidence ); |
3765 | } | 3765 | } |
3766 | 3766 | ||
3767 | void CalendarView::processIncidenceSelection( Incidence *incidence ) | 3767 | void CalendarView::processIncidenceSelection( Incidence *incidence ) |
3768 | { | 3768 | { |
3769 | if ( incidence == mSelectedIncidence ) return; | 3769 | if ( incidence == mSelectedIncidence ) return; |
3770 | 3770 | ||
3771 | mSelectedIncidence = incidence; | 3771 | mSelectedIncidence = incidence; |
3772 | 3772 | ||
3773 | emit incidenceSelected( mSelectedIncidence ); | 3773 | emit incidenceSelected( mSelectedIncidence ); |
3774 | 3774 | ||
3775 | if ( incidence && incidence->type() == "Event" ) { | 3775 | if ( incidence && incidence->typeID() == eventID ) { |
3776 | Event *event = static_cast<Event *>( incidence ); | 3776 | Event *event = static_cast<Event *>( incidence ); |
3777 | if ( event->organizer() == KOPrefs::instance()->email() ) { | 3777 | if ( event->organizer() == KOPrefs::instance()->email() ) { |
3778 | emit organizerEventsSelected( true ); | 3778 | emit organizerEventsSelected( true ); |
3779 | } else { | 3779 | } else { |
3780 | emit organizerEventsSelected(false); | 3780 | emit organizerEventsSelected(false); |
3781 | } | 3781 | } |
3782 | if (event->attendeeByMails( KOPrefs::instance()->mAdditionalMails, | 3782 | if (event->attendeeByMails( KOPrefs::instance()->mAdditionalMails, |
3783 | KOPrefs::instance()->email() ) ) { | 3783 | KOPrefs::instance()->email() ) ) { |
3784 | emit groupEventsSelected( true ); | 3784 | emit groupEventsSelected( true ); |
3785 | } else { | 3785 | } else { |
3786 | emit groupEventsSelected(false); | 3786 | emit groupEventsSelected(false); |
3787 | } | 3787 | } |
3788 | return; | 3788 | return; |
3789 | } else { | 3789 | } else { |
3790 | if ( incidence && incidence->type() == "Todo" ) { | 3790 | if ( incidence && incidence->typeID() == todoID ) { |
3791 | emit todoSelected( true ); | 3791 | emit todoSelected( true ); |
3792 | Todo *event = static_cast<Todo *>( incidence ); | 3792 | Todo *event = static_cast<Todo *>( incidence ); |
3793 | if ( event->organizer() == KOPrefs::instance()->email() ) { | 3793 | if ( event->organizer() == KOPrefs::instance()->email() ) { |
3794 | emit organizerEventsSelected( true ); | 3794 | emit organizerEventsSelected( true ); |
3795 | } else { | 3795 | } else { |
3796 | emit organizerEventsSelected(false); | 3796 | emit organizerEventsSelected(false); |
3797 | } | 3797 | } |
3798 | if (event->attendeeByMails( KOPrefs::instance()->mAdditionalMails, | 3798 | if (event->attendeeByMails( KOPrefs::instance()->mAdditionalMails, |
3799 | KOPrefs::instance()->email() ) ) { | 3799 | KOPrefs::instance()->email() ) ) { |
3800 | emit groupEventsSelected( true ); | 3800 | emit groupEventsSelected( true ); |
3801 | } else { | 3801 | } else { |
3802 | emit groupEventsSelected(false); | 3802 | emit groupEventsSelected(false); |
3803 | } | 3803 | } |
3804 | return; | 3804 | return; |
3805 | } else { | 3805 | } else { |
3806 | emit todoSelected( false ); | 3806 | emit todoSelected( false ); |
3807 | emit organizerEventsSelected(false); | 3807 | emit organizerEventsSelected(false); |
3808 | emit groupEventsSelected(false); | 3808 | emit groupEventsSelected(false); |
3809 | } | 3809 | } |
3810 | return; | 3810 | return; |
3811 | } | 3811 | } |
3812 | 3812 | ||
3813 | /* if ( incidence && incidence->type() == "Todo" ) { | 3813 | /* if ( incidence && incidence->typeID() == todoID ) { |
3814 | emit todoSelected( true ); | 3814 | emit todoSelected( true ); |
3815 | } else { | 3815 | } else { |
3816 | emit todoSelected( false ); | 3816 | emit todoSelected( false ); |
3817 | }*/ | 3817 | }*/ |
3818 | } | 3818 | } |
3819 | 3819 | ||
3820 | 3820 | ||
3821 | void CalendarView::checkClipboard() | 3821 | void CalendarView::checkClipboard() |
3822 | { | 3822 | { |
3823 | #ifndef KORG_NODND | 3823 | #ifndef KORG_NODND |
3824 | if (ICalDrag::canDecode(QApplication::clipboard()->data())) { | 3824 | if (ICalDrag::canDecode(QApplication::clipboard()->data())) { |
3825 | emit pasteEnabled(true); | 3825 | emit pasteEnabled(true); |
3826 | } else { | 3826 | } else { |
3827 | emit pasteEnabled(false); | 3827 | emit pasteEnabled(false); |
3828 | } | 3828 | } |
3829 | #endif | 3829 | #endif |
3830 | } | 3830 | } |
3831 | 3831 | ||
3832 | void CalendarView::showDates(const DateList &selectedDates) | 3832 | void CalendarView::showDates(const DateList &selectedDates) |
3833 | { | 3833 | { |
3834 | // kdDebug() << "CalendarView::selectDates()" << endl; | 3834 | // kdDebug() << "CalendarView::selectDates()" << endl; |
3835 | 3835 | ||
3836 | 3836 | ||
3837 | if ( !mBlockShowDates ) { | 3837 | if ( !mBlockShowDates ) { |
3838 | if ( mViewManager->currentView() ) { | 3838 | if ( mViewManager->currentView() ) { |
3839 | updateView( selectedDates.first(), selectedDates.last() ); | 3839 | updateView( selectedDates.first(), selectedDates.last() ); |
3840 | } else { | 3840 | } else { |
3841 | mViewManager->showAgendaView(); | 3841 | mViewManager->showAgendaView(); |
3842 | } | 3842 | } |
3843 | } | 3843 | } |
3844 | 3844 | ||
3845 | QDate date = selectedDates.first(); | 3845 | QDate date = selectedDates.first(); |
3846 | if ( ! date.isValid() ) { | 3846 | if ( ! date.isValid() ) { |
3847 | topLevelWidget()->setCaption(""); | 3847 | topLevelWidget()->setCaption(""); |
3848 | return; | 3848 | return; |
3849 | } | 3849 | } |
3850 | 3850 | ||
3851 | QString selDates; | 3851 | QString selDates; |
3852 | selDates = KGlobal::locale()->formatDate( date, true); | 3852 | selDates = KGlobal::locale()->formatDate( date, true); |
3853 | if (selectedDates.first() < selectedDates.last() ) | 3853 | if (selectedDates.first() < selectedDates.last() ) |
3854 | selDates += " - " + KGlobal::locale()->formatDate( selectedDates.last(),true); | 3854 | selDates += " - " + KGlobal::locale()->formatDate( selectedDates.last(),true); |
3855 | else { | 3855 | else { |
3856 | QString addString; | 3856 | QString addString; |
3857 | if ( date == QDateTime::currentDateTime().date() ) | 3857 | if ( date == QDateTime::currentDateTime().date() ) |
3858 | addString = i18n("Today"); | 3858 | addString = i18n("Today"); |
3859 | else if ( date == QDateTime::currentDateTime().date().addDays(1) ) | 3859 | else if ( date == QDateTime::currentDateTime().date().addDays(1) ) |
3860 | addString = i18n("Tomorrow"); | 3860 | addString = i18n("Tomorrow"); |
3861 | else if ( date == QDateTime::currentDateTime().date().addDays(-1) ) | 3861 | else if ( date == QDateTime::currentDateTime().date().addDays(-1) ) |
3862 | addString = i18n("Yesterday"); | 3862 | addString = i18n("Yesterday"); |
3863 | else if ( date == QDateTime::currentDateTime().date().addDays(-2) ) | 3863 | else if ( date == QDateTime::currentDateTime().date().addDays(-2) ) |
3864 | addString = i18n("Day before yesterday"); | 3864 | addString = i18n("Day before yesterday"); |
3865 | else if ( date == QDateTime::currentDateTime().date().addDays(2) ) | 3865 | else if ( date == QDateTime::currentDateTime().date().addDays(2) ) |
3866 | addString = i18n("Day after tomorrow"); | 3866 | addString = i18n("Day after tomorrow"); |
3867 | if ( !addString.isEmpty() ) { | 3867 | if ( !addString.isEmpty() ) { |
3868 | topLevelWidget()->setCaption( addString+", " + selDates ); | 3868 | topLevelWidget()->setCaption( addString+", " + selDates ); |
3869 | return; | 3869 | return; |
3870 | } | 3870 | } |
3871 | } | 3871 | } |
3872 | topLevelWidget()->setCaption( i18n("Dates: ") + selDates ); | 3872 | topLevelWidget()->setCaption( i18n("Dates: ") + selDates ); |
3873 | 3873 | ||
3874 | } | 3874 | } |
3875 | 3875 | ||
3876 | QPtrList<CalFilter> CalendarView::filters() | 3876 | QPtrList<CalFilter> CalendarView::filters() |
3877 | { | 3877 | { |
3878 | return mFilters; | 3878 | return mFilters; |
3879 | 3879 | ||
3880 | } | 3880 | } |
3881 | void CalendarView::editFilters() | 3881 | void CalendarView::editFilters() |
3882 | { | 3882 | { |
3883 | // kdDebug() << "CalendarView::editFilters()" << endl; | 3883 | // kdDebug() << "CalendarView::editFilters()" << endl; |
3884 | 3884 | ||
3885 | CalFilter *filter = mFilters.first(); | 3885 | CalFilter *filter = mFilters.first(); |
3886 | while(filter) { | 3886 | while(filter) { |
3887 | kdDebug() << " Filter: " << filter->name() << endl; | 3887 | kdDebug() << " Filter: " << filter->name() << endl; |
3888 | filter = mFilters.next(); | 3888 | filter = mFilters.next(); |
3889 | } | 3889 | } |
3890 | 3890 | ||
3891 | mDialogManager->showFilterEditDialog(&mFilters); | 3891 | mDialogManager->showFilterEditDialog(&mFilters); |
3892 | } | 3892 | } |
3893 | void CalendarView::toggleFilter() | 3893 | void CalendarView::toggleFilter() |
3894 | { | 3894 | { |
3895 | showFilter(! mFilterView->isVisible()); | 3895 | showFilter(! mFilterView->isVisible()); |
3896 | } | 3896 | } |
3897 | 3897 | ||
3898 | KOFilterView *CalendarView::filterView() | 3898 | KOFilterView *CalendarView::filterView() |
3899 | { | 3899 | { |
3900 | return mFilterView; | 3900 | return mFilterView; |
3901 | } | 3901 | } |
3902 | void CalendarView::selectFilter( int fil ) | 3902 | void CalendarView::selectFilter( int fil ) |
3903 | { | 3903 | { |
3904 | mFilterView->setSelectedFilter( fil ); | 3904 | mFilterView->setSelectedFilter( fil ); |
3905 | } | 3905 | } |
3906 | void CalendarView::showFilter(bool visible) | 3906 | void CalendarView::showFilter(bool visible) |
3907 | { | 3907 | { |
3908 | if (visible) mFilterView->show(); | 3908 | if (visible) mFilterView->show(); |
3909 | else mFilterView->hide(); | 3909 | else mFilterView->hide(); |
3910 | } | 3910 | } |
3911 | void CalendarView::toggleFilerEnabled( ) | 3911 | void CalendarView::toggleFilerEnabled( ) |
3912 | { | 3912 | { |
3913 | mFilterView->setFiltersEnabled ( !mFilterView->filtersEnabled() ); | 3913 | mFilterView->setFiltersEnabled ( !mFilterView->filtersEnabled() ); |
3914 | if ( !mFilterView->filtersEnabled() ) | 3914 | if ( !mFilterView->filtersEnabled() ) |
3915 | topLevelWidget()->setCaption( i18n("Filter disabled ") ); | 3915 | topLevelWidget()->setCaption( i18n("Filter disabled ") ); |
3916 | 3916 | ||
3917 | } | 3917 | } |
3918 | void CalendarView::updateFilter() | 3918 | void CalendarView::updateFilter() |
3919 | { | 3919 | { |
3920 | CalFilter *filter = mFilterView->selectedFilter(); | 3920 | CalFilter *filter = mFilterView->selectedFilter(); |
3921 | if (filter) { | 3921 | if (filter) { |
3922 | QString mess; | 3922 | QString mess; |
3923 | if (mFilterView->filtersEnabled()) { | 3923 | if (mFilterView->filtersEnabled()) { |
3924 | mess = i18n("Filter selected: ")+filter->name(); | 3924 | mess = i18n("Filter selected: ")+filter->name(); |
3925 | filter->setEnabled(true); | 3925 | filter->setEnabled(true); |
3926 | } | 3926 | } |
3927 | else filter->setEnabled(false); | 3927 | else filter->setEnabled(false); |
3928 | mCalendar->setFilter(filter); | 3928 | mCalendar->setFilter(filter); |
3929 | updateView(); | 3929 | updateView(); |
3930 | if ( !mess.isEmpty() ) | 3930 | if ( !mess.isEmpty() ) |
3931 | topLevelWidget()->setCaption( mess ); | 3931 | topLevelWidget()->setCaption( mess ); |
3932 | 3932 | ||
3933 | } | 3933 | } |
3934 | } | 3934 | } |
3935 | 3935 | ||
3936 | void CalendarView::filterEdited() | 3936 | void CalendarView::filterEdited() |
3937 | { | 3937 | { |
3938 | mFilterView->updateFilters(); | 3938 | mFilterView->updateFilters(); |
3939 | updateFilter(); | 3939 | updateFilter(); |
3940 | writeSettings(); | 3940 | writeSettings(); |
3941 | } | 3941 | } |
3942 | 3942 | ||
3943 | 3943 | ||
3944 | void CalendarView::takeOverEvent() | 3944 | void CalendarView::takeOverEvent() |
3945 | { | 3945 | { |
3946 | Incidence *incidence = currentSelection(); | 3946 | Incidence *incidence = currentSelection(); |
3947 | 3947 | ||
3948 | if (!incidence) return; | 3948 | if (!incidence) return; |
3949 | 3949 | ||
3950 | incidence->setOrganizer(KOPrefs::instance()->email()); | 3950 | incidence->setOrganizer(KOPrefs::instance()->email()); |
3951 | incidence->recreate(); | 3951 | incidence->recreate(); |
3952 | incidence->setReadOnly(false); | 3952 | incidence->setReadOnly(false); |
3953 | 3953 | ||
3954 | updateView(); | 3954 | updateView(); |
3955 | } | 3955 | } |
3956 | 3956 | ||
3957 | void CalendarView::takeOverCalendar() | 3957 | void CalendarView::takeOverCalendar() |
3958 | { | 3958 | { |
3959 | // TODO: Create Calendar::allIncidences() function and use it here | 3959 | // TODO: Create Calendar::allIncidences() function and use it here |
3960 | 3960 | ||
3961 | clearAllViews(); | 3961 | clearAllViews(); |
3962 | QPtrList<Event> events = mCalendar->events(); | 3962 | QPtrList<Event> events = mCalendar->events(); |
3963 | for(uint i=0; i<events.count(); ++i) { | 3963 | for(uint i=0; i<events.count(); ++i) { |
3964 | events.at(i)->setOrganizer(KOPrefs::instance()->email()); | 3964 | events.at(i)->setOrganizer(KOPrefs::instance()->email()); |
3965 | events.at(i)->recreate(); | 3965 | events.at(i)->recreate(); |
3966 | events.at(i)->setReadOnly(false); | 3966 | events.at(i)->setReadOnly(false); |
3967 | } | 3967 | } |
3968 | 3968 | ||
3969 | QPtrList<Todo> todos = mCalendar->todos(); | 3969 | QPtrList<Todo> todos = mCalendar->todos(); |
3970 | for(uint i=0; i<todos.count(); ++i) { | 3970 | for(uint i=0; i<todos.count(); ++i) { |
3971 | todos.at(i)->setOrganizer(KOPrefs::instance()->email()); | 3971 | todos.at(i)->setOrganizer(KOPrefs::instance()->email()); |
3972 | todos.at(i)->recreate(); | 3972 | todos.at(i)->recreate(); |
3973 | todos.at(i)->setReadOnly(false); | 3973 | todos.at(i)->setReadOnly(false); |
3974 | } | 3974 | } |
3975 | 3975 | ||
3976 | QPtrList<Journal> journals = mCalendar->journals(); | 3976 | QPtrList<Journal> journals = mCalendar->journals(); |
3977 | for(uint i=0; i<journals.count(); ++i) { | 3977 | for(uint i=0; i<journals.count(); ++i) { |
3978 | journals.at(i)->setOrganizer(KOPrefs::instance()->email()); | 3978 | journals.at(i)->setOrganizer(KOPrefs::instance()->email()); |
3979 | journals.at(i)->recreate(); | 3979 | journals.at(i)->recreate(); |
3980 | journals.at(i)->setReadOnly(false); | 3980 | journals.at(i)->setReadOnly(false); |
3981 | } | 3981 | } |
3982 | 3982 | ||
3983 | updateView(); | 3983 | updateView(); |
3984 | } | 3984 | } |
3985 | 3985 | ||
3986 | void CalendarView::showIntro() | 3986 | void CalendarView::showIntro() |
3987 | { | 3987 | { |
3988 | kdDebug() << "To be implemented." << endl; | 3988 | kdDebug() << "To be implemented." << endl; |
3989 | } | 3989 | } |
3990 | 3990 | ||
3991 | QWidgetStack *CalendarView::viewStack() | 3991 | QWidgetStack *CalendarView::viewStack() |
3992 | { | 3992 | { |
3993 | return mRightFrame; | 3993 | return mRightFrame; |
3994 | } | 3994 | } |
3995 | 3995 | ||
3996 | QWidget *CalendarView::leftFrame() | 3996 | QWidget *CalendarView::leftFrame() |
3997 | { | 3997 | { |
3998 | return ( QWidget *)mLeftFrame; | 3998 | return ( QWidget *)mLeftFrame; |
3999 | } | 3999 | } |
4000 | 4000 | ||
4001 | DateNavigator *CalendarView::dateNavigator() | 4001 | DateNavigator *CalendarView::dateNavigator() |
4002 | { | 4002 | { |
4003 | return mNavigator; | 4003 | return mNavigator; |
4004 | } | 4004 | } |
4005 | 4005 | ||
4006 | KDateNavigator* CalendarView::dateNavigatorWidget() | 4006 | KDateNavigator* CalendarView::dateNavigatorWidget() |
4007 | { | 4007 | { |
4008 | return mDateNavigator->navigatorView(); | 4008 | return mDateNavigator->navigatorView(); |
4009 | } | 4009 | } |
4010 | void CalendarView::toggleDateNavigatorWidget() | 4010 | void CalendarView::toggleDateNavigatorWidget() |
4011 | { | 4011 | { |
4012 | KOPrefs::instance()->mShowDateNavigator = !KOPrefs::instance()->mShowDateNavigator ; | 4012 | KOPrefs::instance()->mShowDateNavigator = !KOPrefs::instance()->mShowDateNavigator ; |
4013 | 4013 | ||
4014 | if (!KOPrefs::instance()->mShowDateNavigator ) | 4014 | if (!KOPrefs::instance()->mShowDateNavigator ) |
4015 | mDateNavigator->hide(); | 4015 | mDateNavigator->hide(); |
4016 | else | 4016 | else |
4017 | mDateNavigator->show(); | 4017 | mDateNavigator->show(); |
4018 | } | 4018 | } |
4019 | void CalendarView::addView(KOrg::BaseView *view) | 4019 | void CalendarView::addView(KOrg::BaseView *view) |
4020 | { | 4020 | { |
4021 | mViewManager->addView(view); | 4021 | mViewManager->addView(view); |
4022 | } | 4022 | } |
4023 | 4023 | ||
4024 | void CalendarView::showView(KOrg::BaseView *view) | 4024 | void CalendarView::showView(KOrg::BaseView *view) |
4025 | { | 4025 | { |
4026 | mViewManager->showView(view, mLeftFrame->isVisible()); | 4026 | mViewManager->showView(view, mLeftFrame->isVisible()); |
4027 | } | 4027 | } |
4028 | 4028 | ||
4029 | Incidence *CalendarView::currentSelection() | 4029 | Incidence *CalendarView::currentSelection() |
4030 | { | 4030 | { |
4031 | return mViewManager->currentSelection(); | 4031 | return mViewManager->currentSelection(); |
4032 | } | 4032 | } |
4033 | void CalendarView::toggleAllDaySize() | 4033 | void CalendarView::toggleAllDaySize() |
4034 | { | 4034 | { |
4035 | /* | 4035 | /* |
4036 | if ( KOPrefs::instance()->mAllDaySize > 47 ) | 4036 | if ( KOPrefs::instance()->mAllDaySize > 47 ) |
4037 | KOPrefs::instance()->mAllDaySize = KOPrefs::instance()->mAllDaySize /2; | 4037 | KOPrefs::instance()->mAllDaySize = KOPrefs::instance()->mAllDaySize /2; |
4038 | else | 4038 | else |
4039 | KOPrefs::instance()->mAllDaySize = KOPrefs::instance()->mAllDaySize *2; | 4039 | KOPrefs::instance()->mAllDaySize = KOPrefs::instance()->mAllDaySize *2; |
4040 | */ | 4040 | */ |
4041 | viewManager()->agendaView()->toggleAllDay(); | 4041 | viewManager()->agendaView()->toggleAllDay(); |
4042 | } | 4042 | } |
4043 | void CalendarView::toggleExpand() | 4043 | void CalendarView::toggleExpand() |
4044 | { | 4044 | { |
4045 | // if ( mLeftFrame->isHidden() ) { | 4045 | // if ( mLeftFrame->isHidden() ) { |
4046 | // mLeftFrame->show(); | 4046 | // mLeftFrame->show(); |
4047 | // emit calendarViewExpanded( false ); | 4047 | // emit calendarViewExpanded( false ); |
4048 | // } else { | 4048 | // } else { |
4049 | // mLeftFrame->hide(); | 4049 | // mLeftFrame->hide(); |
4050 | // emit calendarViewExpanded( true ); | 4050 | // emit calendarViewExpanded( true ); |
4051 | // } | 4051 | // } |
4052 | //qDebug(" CalendarView::toggleExpand()"); | 4052 | //qDebug(" CalendarView::toggleExpand()"); |
4053 | globalFlagBlockAgenda = 1; | 4053 | globalFlagBlockAgenda = 1; |
4054 | emit calendarViewExpanded( !mLeftFrame->isHidden() ); | 4054 | emit calendarViewExpanded( !mLeftFrame->isHidden() ); |
4055 | globalFlagBlockAgenda = 5; | 4055 | globalFlagBlockAgenda = 5; |
4056 | mViewManager->raiseCurrentView( !mLeftFrame->isHidden() ); | 4056 | mViewManager->raiseCurrentView( !mLeftFrame->isHidden() ); |
4057 | //mViewManager->showView( 0, true ); | 4057 | //mViewManager->showView( 0, true ); |
4058 | } | 4058 | } |
4059 | 4059 | ||
4060 | void CalendarView::calendarModified( bool modified, Calendar * ) | 4060 | void CalendarView::calendarModified( bool modified, Calendar * ) |
4061 | { | 4061 | { |
4062 | setModified( modified ); | 4062 | setModified( modified ); |
4063 | } | 4063 | } |
4064 | 4064 | ||
4065 | Todo *CalendarView::selectedTodo() | 4065 | Todo *CalendarView::selectedTodo() |
4066 | { | 4066 | { |
4067 | Incidence *incidence = currentSelection(); | 4067 | Incidence *incidence = currentSelection(); |
4068 | if ( incidence && incidence->type() == "Todo" ) { | 4068 | if ( incidence && incidence->typeID() == todoID ) { |
4069 | return static_cast<Todo *>( incidence ); | 4069 | return static_cast<Todo *>( incidence ); |
4070 | } | 4070 | } |
4071 | 4071 | ||
4072 | incidence = mTodoList->selectedIncidences().first(); | 4072 | incidence = mTodoList->selectedIncidences().first(); |
4073 | if ( incidence && incidence->type() == "Todo" ) { | 4073 | if ( incidence && incidence->typeID() == todoID ) { |
4074 | return static_cast<Todo *>( incidence ); | 4074 | return static_cast<Todo *>( incidence ); |
4075 | } | 4075 | } |
4076 | 4076 | ||
4077 | return 0; | 4077 | return 0; |
4078 | } | 4078 | } |
4079 | 4079 | ||
4080 | void CalendarView::dialogClosing(Incidence *in) | 4080 | void CalendarView::dialogClosing(Incidence *in) |
4081 | { | 4081 | { |
4082 | // mDialogList.remove(in); | 4082 | // mDialogList.remove(in); |
4083 | } | 4083 | } |
4084 | 4084 | ||
4085 | void CalendarView::showIncidence() | 4085 | void CalendarView::showIncidence() |
4086 | { | 4086 | { |
4087 | mViewerCallerIsSearchDialog = false; | 4087 | mViewerCallerIsSearchDialog = false; |
4088 | Incidence *incidence = currentSelection(); | 4088 | Incidence *incidence = currentSelection(); |
4089 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); | 4089 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); |
4090 | if ( incidence ) { | 4090 | if ( incidence ) { |
4091 | ShowIncidenceVisitor v; | 4091 | ShowIncidenceVisitor v; |
4092 | v.act( incidence, this ); | 4092 | v.act( incidence, this ); |
4093 | } | 4093 | } |
4094 | } | 4094 | } |
4095 | void CalendarView::editIncidenceDescription() | 4095 | void CalendarView::editIncidenceDescription() |
4096 | { | 4096 | { |
4097 | mFlagEditDescription = true; | 4097 | mFlagEditDescription = true; |
4098 | editIncidence(); | 4098 | editIncidence(); |
4099 | mFlagEditDescription = false; | 4099 | mFlagEditDescription = false; |
4100 | } | 4100 | } |
4101 | void CalendarView::editIncidence() | 4101 | void CalendarView::editIncidence() |
4102 | { | 4102 | { |
4103 | // qDebug("editIncidence() "); | 4103 | // qDebug("editIncidence() "); |
4104 | Incidence *incidence = currentSelection(); | 4104 | Incidence *incidence = currentSelection(); |
4105 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); | 4105 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); |
4106 | if ( incidence ) { | 4106 | if ( incidence ) { |
4107 | EditIncidenceVisitor v; | 4107 | EditIncidenceVisitor v; |
4108 | v.act( incidence, this ); | 4108 | v.act( incidence, this ); |
4109 | } | 4109 | } |
4110 | } | 4110 | } |
4111 | 4111 | ||
4112 | void CalendarView::deleteIncidence() | 4112 | void CalendarView::deleteIncidence() |
4113 | { | 4113 | { |
4114 | Incidence *incidence = currentSelection(); | 4114 | Incidence *incidence = currentSelection(); |
4115 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); | 4115 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); |
4116 | if ( incidence ) { | 4116 | if ( incidence ) { |
4117 | deleteIncidence(incidence); | 4117 | deleteIncidence(incidence); |
4118 | } | 4118 | } |
4119 | } | 4119 | } |
4120 | void CalendarView::showIncidence(QString uid) | 4120 | void CalendarView::showIncidence(QString uid) |
4121 | { | 4121 | { |
4122 | Incidence *inc = mCalendar->incidence( uid ); | 4122 | Incidence *inc = mCalendar->incidence( uid ); |
4123 | if ( inc ) | 4123 | if ( inc ) |
4124 | showIncidence( inc ); | 4124 | showIncidence( inc ); |
4125 | } | 4125 | } |
4126 | void CalendarView::showIncidence(Incidence *incidence) | 4126 | void CalendarView::showIncidence(Incidence *incidence) |
4127 | { | 4127 | { |
4128 | mViewerCallerIsSearchDialog = false; | 4128 | mViewerCallerIsSearchDialog = false; |
4129 | //qDebug("%x %x ",sender (), mDialogManager->getSearchDialog() ); | 4129 | //qDebug("%x %x ",sender (), mDialogManager->getSearchDialog() ); |
4130 | if ( sender() && mDialogManager->getSearchDialog() ) { | 4130 | if ( sender() && mDialogManager->getSearchDialog() ) { |
4131 | if ( sender () == mDialogManager->getSearchDialog()->listview() ) { | 4131 | if ( sender () == mDialogManager->getSearchDialog()->listview() ) { |
4132 | mViewerCallerIsSearchDialog = true; | 4132 | mViewerCallerIsSearchDialog = true; |
4133 | } | 4133 | } |
4134 | } | 4134 | } |
4135 | if ( incidence ) { | 4135 | if ( incidence ) { |
4136 | ShowIncidenceVisitor v; | 4136 | ShowIncidenceVisitor v; |
4137 | v.act( incidence, this ); | 4137 | v.act( incidence, this ); |
4138 | } | 4138 | } |
4139 | } | 4139 | } |
4140 | 4140 | ||
4141 | void CalendarView::editIncidence(Incidence *incidence) | 4141 | void CalendarView::editIncidence(Incidence *incidence) |
4142 | { | 4142 | { |
4143 | if ( incidence ) { | 4143 | if ( incidence ) { |
4144 | 4144 | ||
4145 | EditIncidenceVisitor v; | 4145 | EditIncidenceVisitor v; |
4146 | v.act( incidence, this ); | 4146 | v.act( incidence, this ); |
4147 | 4147 | ||
4148 | } | 4148 | } |
4149 | } | 4149 | } |
4150 | 4150 | ||
4151 | void CalendarView::deleteIncidence(Incidence *incidence) | 4151 | void CalendarView::deleteIncidence(Incidence *incidence) |
4152 | { | 4152 | { |
4153 | //qDebug(" CalendarView::deleteIncidence "); | 4153 | //qDebug(" CalendarView::deleteIncidence "); |
4154 | if ( incidence ) { | 4154 | if ( incidence ) { |
4155 | DeleteIncidenceVisitor v; | 4155 | DeleteIncidenceVisitor v; |
4156 | v.act( incidence, this ); | 4156 | v.act( incidence, this ); |
4157 | } | 4157 | } |
4158 | } | 4158 | } |
4159 | 4159 | ||
4160 | 4160 | ||
4161 | void CalendarView::lookForOutgoingMessages() | 4161 | void CalendarView::lookForOutgoingMessages() |
4162 | { | 4162 | { |
4163 | OutgoingDialog *ogd = mDialogManager->outgoingDialog(); | 4163 | OutgoingDialog *ogd = mDialogManager->outgoingDialog(); |
4164 | ogd->loadMessages(); | 4164 | ogd->loadMessages(); |
4165 | } | 4165 | } |
4166 | 4166 | ||
4167 | void CalendarView::lookForIncomingMessages() | 4167 | void CalendarView::lookForIncomingMessages() |
4168 | { | 4168 | { |
4169 | IncomingDialog *icd = mDialogManager->incomingDialog(); | 4169 | IncomingDialog *icd = mDialogManager->incomingDialog(); |
4170 | icd->retrieve(); | 4170 | icd->retrieve(); |
4171 | } | 4171 | } |
4172 | 4172 | ||
4173 | bool CalendarView::removeCompletedSubTodos( Todo* t ) | 4173 | bool CalendarView::removeCompletedSubTodos( Todo* t ) |
4174 | { | 4174 | { |
4175 | bool deleteTodo = true; | 4175 | bool deleteTodo = true; |
4176 | QPtrList<Incidence> subTodos; | 4176 | QPtrList<Incidence> subTodos; |
4177 | Incidence *aTodo; | 4177 | Incidence *aTodo; |
4178 | subTodos = t->relations(); | 4178 | subTodos = t->relations(); |
4179 | for (aTodo = subTodos.first(); aTodo; aTodo = subTodos.next()) { | 4179 | for (aTodo = subTodos.first(); aTodo; aTodo = subTodos.next()) { |
4180 | if (! removeCompletedSubTodos( (Todo*) aTodo )) | 4180 | if (! removeCompletedSubTodos( (Todo*) aTodo )) |
4181 | deleteTodo = false; | 4181 | deleteTodo = false; |
4182 | } | 4182 | } |
4183 | if ( deleteTodo ) { | 4183 | if ( deleteTodo ) { |
4184 | if ( t->isCompleted() && !t->doesRecur()) { | 4184 | if ( t->isCompleted() && !t->doesRecur()) { |
4185 | checkExternalId( t ); | 4185 | checkExternalId( t ); |
4186 | mCalendar->deleteTodo( t ); | 4186 | mCalendar->deleteTodo( t ); |
4187 | changeTodoDisplay( t,KOGlobals::EVENTDELETED ); | 4187 | changeTodoDisplay( t,KOGlobals::EVENTDELETED ); |
4188 | } | 4188 | } |
4189 | else | 4189 | else |
4190 | deleteTodo = false; | 4190 | deleteTodo = false; |
4191 | } | 4191 | } |
4192 | return deleteTodo; | 4192 | return deleteTodo; |
4193 | 4193 | ||
4194 | } | 4194 | } |
4195 | void CalendarView::purgeCompleted() | 4195 | void CalendarView::purgeCompleted() |
4196 | { | 4196 | { |
4197 | int result = KMessageBox::warningContinueCancel(this, | 4197 | int result = KMessageBox::warningContinueCancel(this, |
4198 | i18n("Delete all completed todos?\n(Completed recurring todos\nwill not be deleted!)"),i18n("Purge Todos"),i18n("Purge")); | 4198 | i18n("Delete all completed todos?\n(Completed recurring todos\nwill not be deleted!)"),i18n("Purge Todos"),i18n("Purge")); |
4199 | 4199 | ||
4200 | if (result == KMessageBox::Continue) { | 4200 | if (result == KMessageBox::Continue) { |
4201 | 4201 | ||
diff --git a/korganizer/koagenda.cpp b/korganizer/koagenda.cpp index 2a2acb1..fc213d8 100644 --- a/korganizer/koagenda.cpp +++ b/korganizer/koagenda.cpp | |||
@@ -628,416 +628,416 @@ void KOAgenda::newItem( int item ) | |||
628 | void KOAgenda::slotClearSelection() | 628 | void KOAgenda::slotClearSelection() |
629 | { | 629 | { |
630 | if (mSelectionHeight) { | 630 | if (mSelectionHeight) { |
631 | int selectionX = mSelectionCellX * mGridSpacingX; | 631 | int selectionX = mSelectionCellX * mGridSpacingX; |
632 | int top = mSelectionYTop - 2 *mGridSpacingY; | 632 | int top = mSelectionYTop - 2 *mGridSpacingY; |
633 | int hei = mSelectionHeight + 4 *mGridSpacingY; | 633 | int hei = mSelectionHeight + 4 *mGridSpacingY; |
634 | clearSelection(); | 634 | clearSelection(); |
635 | repaintContents( selectionX, top, | 635 | repaintContents( selectionX, top, |
636 | mGridSpacingX, hei ,false ); | 636 | mGridSpacingX, hei ,false ); |
637 | } | 637 | } |
638 | 638 | ||
639 | } | 639 | } |
640 | void KOAgenda::startSelectAction(QPoint viewportPos) | 640 | void KOAgenda::startSelectAction(QPoint viewportPos) |
641 | { | 641 | { |
642 | 642 | ||
643 | emit signalClearSelection(); | 643 | emit signalClearSelection(); |
644 | slotClearSelection(); | 644 | slotClearSelection(); |
645 | 645 | ||
646 | mActionType = SELECT; | 646 | mActionType = SELECT; |
647 | 647 | ||
648 | int x,y; | 648 | int x,y; |
649 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 649 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
650 | int gx,gy; | 650 | int gx,gy; |
651 | contentsToGrid(x,y,gx,gy); | 651 | contentsToGrid(x,y,gx,gy); |
652 | 652 | ||
653 | mStartCellX = gx; | 653 | mStartCellX = gx; |
654 | mStartCellY = gy; | 654 | mStartCellY = gy; |
655 | mCurrentCellX = gx; | 655 | mCurrentCellX = gx; |
656 | mCurrentCellY = gy; | 656 | mCurrentCellY = gy; |
657 | 657 | ||
658 | // Store new selection | 658 | // Store new selection |
659 | mSelectionCellX = gx; | 659 | mSelectionCellX = gx; |
660 | mSelectionYTop = gy * mGridSpacingY; | 660 | mSelectionYTop = gy * mGridSpacingY; |
661 | mSelectionHeight = mGridSpacingY; | 661 | mSelectionHeight = mGridSpacingY; |
662 | 662 | ||
663 | // Paint new selection | 663 | // Paint new selection |
664 | repaintContents( mSelectionCellX * mGridSpacingX+1, mSelectionYTop, | 664 | repaintContents( mSelectionCellX * mGridSpacingX+1, mSelectionYTop, |
665 | mGridSpacingX-1, mSelectionHeight ); | 665 | mGridSpacingX-1, mSelectionHeight ); |
666 | } | 666 | } |
667 | 667 | ||
668 | void KOAgenda::performSelectAction(QPoint viewportPos) | 668 | void KOAgenda::performSelectAction(QPoint viewportPos) |
669 | { | 669 | { |
670 | int x,y; | 670 | int x,y; |
671 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 671 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
672 | int gx,gy; | 672 | int gx,gy; |
673 | contentsToGrid(x,y,gx,gy); | 673 | contentsToGrid(x,y,gx,gy); |
674 | 674 | ||
675 | QPoint clipperPos = clipper()-> | 675 | QPoint clipperPos = clipper()-> |
676 | mapFromGlobal(viewport()->mapToGlobal(viewportPos)); | 676 | mapFromGlobal(viewport()->mapToGlobal(viewportPos)); |
677 | 677 | ||
678 | // Scroll if cursor was moved to upper or lower end of agenda. | 678 | // Scroll if cursor was moved to upper or lower end of agenda. |
679 | if (clipperPos.y() < mScrollBorderWidth) { | 679 | if (clipperPos.y() < mScrollBorderWidth) { |
680 | mScrollUpTimer.start(mScrollDelay); | 680 | mScrollUpTimer.start(mScrollDelay); |
681 | } else if (visibleHeight() - clipperPos.y() < | 681 | } else if (visibleHeight() - clipperPos.y() < |
682 | mScrollBorderWidth) { | 682 | mScrollBorderWidth) { |
683 | mScrollDownTimer.start(mScrollDelay); | 683 | mScrollDownTimer.start(mScrollDelay); |
684 | } else { | 684 | } else { |
685 | mScrollUpTimer.stop(); | 685 | mScrollUpTimer.stop(); |
686 | mScrollDownTimer.stop(); | 686 | mScrollDownTimer.stop(); |
687 | } | 687 | } |
688 | 688 | ||
689 | if ( gy > mCurrentCellY ) { | 689 | if ( gy > mCurrentCellY ) { |
690 | mSelectionHeight = ( gy + 1 ) * mGridSpacingY - mSelectionYTop; | 690 | mSelectionHeight = ( gy + 1 ) * mGridSpacingY - mSelectionYTop; |
691 | 691 | ||
692 | 692 | ||
693 | repaintContents( (KOGlobals::self()->reverseLayout() ? | 693 | repaintContents( (KOGlobals::self()->reverseLayout() ? |
694 | mColumns - 1 - mSelectionCellX : mSelectionCellX) * | 694 | mColumns - 1 - mSelectionCellX : mSelectionCellX) * |
695 | mGridSpacingX, mSelectionYTop, | 695 | mGridSpacingX, mSelectionYTop, |
696 | mGridSpacingX, mSelectionHeight , false); | 696 | mGridSpacingX, mSelectionHeight , false); |
697 | 697 | ||
698 | mCurrentCellY = gy; | 698 | mCurrentCellY = gy; |
699 | } else if ( gy < mCurrentCellY ) { | 699 | } else if ( gy < mCurrentCellY ) { |
700 | if ( gy >= mStartCellY ) { | 700 | if ( gy >= mStartCellY ) { |
701 | int selectionHeight = mSelectionHeight; | 701 | int selectionHeight = mSelectionHeight; |
702 | mSelectionHeight = ( gy + 1 ) * mGridSpacingY - mSelectionYTop; | 702 | mSelectionHeight = ( gy + 1 ) * mGridSpacingY - mSelectionYTop; |
703 | 703 | ||
704 | repaintContents( (KOGlobals::self()->reverseLayout() ? | 704 | repaintContents( (KOGlobals::self()->reverseLayout() ? |
705 | mColumns - 1 - mSelectionCellX : mSelectionCellX) * | 705 | mColumns - 1 - mSelectionCellX : mSelectionCellX) * |
706 | mGridSpacingX, mSelectionYTop, | 706 | mGridSpacingX, mSelectionYTop, |
707 | mGridSpacingX, selectionHeight,false ); | 707 | mGridSpacingX, selectionHeight,false ); |
708 | 708 | ||
709 | mCurrentCellY = gy; | 709 | mCurrentCellY = gy; |
710 | } else { | 710 | } else { |
711 | } | 711 | } |
712 | } | 712 | } |
713 | } | 713 | } |
714 | 714 | ||
715 | void KOAgenda::endSelectAction( bool emitNewEvent ) | 715 | void KOAgenda::endSelectAction( bool emitNewEvent ) |
716 | { | 716 | { |
717 | mActionType = NOP; | 717 | mActionType = NOP; |
718 | mScrollUpTimer.stop(); | 718 | mScrollUpTimer.stop(); |
719 | mScrollDownTimer.stop(); | 719 | mScrollDownTimer.stop(); |
720 | 720 | ||
721 | emit newTimeSpanSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY); | 721 | emit newTimeSpanSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY); |
722 | if ( emitNewEvent && mStartCellY < mCurrentCellY ) { | 722 | if ( emitNewEvent && mStartCellY < mCurrentCellY ) { |
723 | emit newEventSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY); | 723 | emit newEventSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY); |
724 | } | 724 | } |
725 | } | 725 | } |
726 | 726 | ||
727 | void KOAgenda::startItemAction(QPoint viewportPos) | 727 | void KOAgenda::startItemAction(QPoint viewportPos) |
728 | { | 728 | { |
729 | int x,y; | 729 | int x,y; |
730 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 730 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
731 | int gx,gy; | 731 | int gx,gy; |
732 | contentsToGrid(x,y,gx,gy); | 732 | contentsToGrid(x,y,gx,gy); |
733 | 733 | ||
734 | mStartCellX = gx; | 734 | mStartCellX = gx; |
735 | mStartCellY = gy; | 735 | mStartCellY = gy; |
736 | mCurrentCellX = gx; | 736 | mCurrentCellX = gx; |
737 | mCurrentCellY = gy; | 737 | mCurrentCellY = gy; |
738 | 738 | ||
739 | if (mAllDayMode) { | 739 | if (mAllDayMode) { |
740 | int gridDistanceX = (x - gx * mGridSpacingX); | 740 | int gridDistanceX = (x - gx * mGridSpacingX); |
741 | if (gridDistanceX < mResizeBorderWidth && | 741 | if (gridDistanceX < mResizeBorderWidth && |
742 | mActionItem->cellX() == mCurrentCellX) { | 742 | mActionItem->cellX() == mCurrentCellX) { |
743 | mActionType = RESIZELEFT; | 743 | mActionType = RESIZELEFT; |
744 | setCursor(sizeHorCursor); | 744 | setCursor(sizeHorCursor); |
745 | } else if ((mGridSpacingX - gridDistanceX) < mResizeBorderWidth && | 745 | } else if ((mGridSpacingX - gridDistanceX) < mResizeBorderWidth && |
746 | mActionItem->cellXWidth() == mCurrentCellX) { | 746 | mActionItem->cellXWidth() == mCurrentCellX) { |
747 | mActionType = RESIZERIGHT; | 747 | mActionType = RESIZERIGHT; |
748 | setCursor(sizeHorCursor); | 748 | setCursor(sizeHorCursor); |
749 | } else { | 749 | } else { |
750 | mActionType = MOVE; | 750 | mActionType = MOVE; |
751 | mActionItem->startMove(); | 751 | mActionItem->startMove(); |
752 | setCursor(sizeAllCursor); | 752 | setCursor(sizeAllCursor); |
753 | } | 753 | } |
754 | } else { | 754 | } else { |
755 | int gridDistanceY = (y - gy * mGridSpacingY); | 755 | int gridDistanceY = (y - gy * mGridSpacingY); |
756 | bool allowResize = ( mActionItem->incidence()->type() != "Todo" ); | 756 | bool allowResize = ( mActionItem->incidence()->typeID() != todoID ); |
757 | if (allowResize && gridDistanceY < mResizeBorderWidth && | 757 | if (allowResize && gridDistanceY < mResizeBorderWidth && |
758 | mActionItem->cellYTop() == mCurrentCellY && | 758 | mActionItem->cellYTop() == mCurrentCellY && |
759 | !mActionItem->firstMultiItem()) { | 759 | !mActionItem->firstMultiItem()) { |
760 | mActionType = RESIZETOP; | 760 | mActionType = RESIZETOP; |
761 | setCursor(sizeVerCursor); | 761 | setCursor(sizeVerCursor); |
762 | } else if (allowResize &&(mGridSpacingY - gridDistanceY) < mResizeBorderWidth && | 762 | } else if (allowResize &&(mGridSpacingY - gridDistanceY) < mResizeBorderWidth && |
763 | mActionItem->cellYBottom() == mCurrentCellY && | 763 | mActionItem->cellYBottom() == mCurrentCellY && |
764 | !mActionItem->lastMultiItem()) { | 764 | !mActionItem->lastMultiItem()) { |
765 | mActionType = RESIZEBOTTOM; | 765 | mActionType = RESIZEBOTTOM; |
766 | setCursor(sizeVerCursor); | 766 | setCursor(sizeVerCursor); |
767 | } else { | 767 | } else { |
768 | mActionType = MOVE; | 768 | mActionType = MOVE; |
769 | mActionItem->startMove(); | 769 | mActionItem->startMove(); |
770 | setCursor(sizeAllCursor); | 770 | setCursor(sizeAllCursor); |
771 | } | 771 | } |
772 | } | 772 | } |
773 | } | 773 | } |
774 | 774 | ||
775 | void KOAgenda::performItemAction(QPoint viewportPos) | 775 | void KOAgenda::performItemAction(QPoint viewportPos) |
776 | { | 776 | { |
777 | // kdDebug() << "viewportPos: " << viewportPos.x() << "," << viewportPos.y() << endl; | 777 | // kdDebug() << "viewportPos: " << viewportPos.x() << "," << viewportPos.y() << endl; |
778 | // QPoint point = viewport()->mapToGlobal(viewportPos); | 778 | // QPoint point = viewport()->mapToGlobal(viewportPos); |
779 | // kdDebug() << "Global: " << point.x() << "," << point.y() << endl; | 779 | // kdDebug() << "Global: " << point.x() << "," << point.y() << endl; |
780 | // point = clipper()->mapFromGlobal(point); | 780 | // point = clipper()->mapFromGlobal(point); |
781 | // kdDebug() << "clipper: " << point.x() << "," << point.y() << endl; | 781 | // kdDebug() << "clipper: " << point.x() << "," << point.y() << endl; |
782 | // kdDebug() << "visible height: " << visibleHeight() << endl; | 782 | // kdDebug() << "visible height: " << visibleHeight() << endl; |
783 | int x,y; | 783 | int x,y; |
784 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 784 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
785 | // kdDebug() << "contents: " << x << "," << y << "\n" << endl; | 785 | // kdDebug() << "contents: " << x << "," << y << "\n" << endl; |
786 | int gx,gy; | 786 | int gx,gy; |
787 | contentsToGrid(x,y,gx,gy); | 787 | contentsToGrid(x,y,gx,gy); |
788 | QPoint clipperPos = clipper()-> | 788 | QPoint clipperPos = clipper()-> |
789 | mapFromGlobal(viewport()->mapToGlobal(viewportPos)); | 789 | mapFromGlobal(viewport()->mapToGlobal(viewportPos)); |
790 | 790 | ||
791 | // Cursor left active agenda area. | 791 | // Cursor left active agenda area. |
792 | // This starts a drag. | 792 | // This starts a drag. |
793 | if ( /*clipperPos.y() < 0 || clipperPos.y() > visibleHeight() ||*/ | 793 | if ( /*clipperPos.y() < 0 || clipperPos.y() > visibleHeight() ||*/ |
794 | clipperPos.x() < 0 || clipperPos.x() > visibleWidth() ) { | 794 | clipperPos.x() < 0 || clipperPos.x() > visibleWidth() ) { |
795 | if ( mActionType == MOVE ) { | 795 | if ( mActionType == MOVE ) { |
796 | mScrollUpTimer.stop(); | 796 | mScrollUpTimer.stop(); |
797 | mScrollDownTimer.stop(); | 797 | mScrollDownTimer.stop(); |
798 | mActionItem->resetMove(); | 798 | mActionItem->resetMove(); |
799 | placeSubCells( mActionItem ); | 799 | placeSubCells( mActionItem ); |
800 | // emit startDragSignal( mActionItem->incidence() ); | 800 | // emit startDragSignal( mActionItem->incidence() ); |
801 | setCursor( arrowCursor ); | 801 | setCursor( arrowCursor ); |
802 | mActionItem = 0; | 802 | mActionItem = 0; |
803 | mActionType = NOP; | 803 | mActionType = NOP; |
804 | mItemMoved = 0; | 804 | mItemMoved = 0; |
805 | return; | 805 | return; |
806 | } | 806 | } |
807 | } else { | 807 | } else { |
808 | switch ( mActionType ) { | 808 | switch ( mActionType ) { |
809 | case MOVE: | 809 | case MOVE: |
810 | setCursor( sizeAllCursor ); | 810 | setCursor( sizeAllCursor ); |
811 | break; | 811 | break; |
812 | case RESIZETOP: | 812 | case RESIZETOP: |
813 | case RESIZEBOTTOM: | 813 | case RESIZEBOTTOM: |
814 | setCursor( sizeVerCursor ); | 814 | setCursor( sizeVerCursor ); |
815 | break; | 815 | break; |
816 | case RESIZELEFT: | 816 | case RESIZELEFT: |
817 | case RESIZERIGHT: | 817 | case RESIZERIGHT: |
818 | setCursor( sizeHorCursor ); | 818 | setCursor( sizeHorCursor ); |
819 | break; | 819 | break; |
820 | default: | 820 | default: |
821 | setCursor( arrowCursor ); | 821 | setCursor( arrowCursor ); |
822 | } | 822 | } |
823 | } | 823 | } |
824 | 824 | ||
825 | // Scroll if item was moved to upper or lower end of agenda. | 825 | // Scroll if item was moved to upper or lower end of agenda. |
826 | if (clipperPos.y() < mScrollBorderWidth) { | 826 | if (clipperPos.y() < mScrollBorderWidth) { |
827 | mScrollUpTimer.start(mScrollDelay); | 827 | mScrollUpTimer.start(mScrollDelay); |
828 | } else if (visibleHeight() - clipperPos.y() < | 828 | } else if (visibleHeight() - clipperPos.y() < |
829 | mScrollBorderWidth) { | 829 | mScrollBorderWidth) { |
830 | mScrollDownTimer.start(mScrollDelay); | 830 | mScrollDownTimer.start(mScrollDelay); |
831 | } else { | 831 | } else { |
832 | mScrollUpTimer.stop(); | 832 | mScrollUpTimer.stop(); |
833 | mScrollDownTimer.stop(); | 833 | mScrollDownTimer.stop(); |
834 | } | 834 | } |
835 | 835 | ||
836 | // Move or resize item if necessary | 836 | // Move or resize item if necessary |
837 | if (mCurrentCellX != gx || mCurrentCellY != gy) { | 837 | if (mCurrentCellX != gx || mCurrentCellY != gy) { |
838 | mItemMoved = true; | 838 | mItemMoved = true; |
839 | mActionItem->raise(); | 839 | mActionItem->raise(); |
840 | if (mActionType == MOVE) { | 840 | if (mActionType == MOVE) { |
841 | // Move all items belonging to a multi item | 841 | // Move all items belonging to a multi item |
842 | KOAgendaItem *moveItem = mActionItem->firstMultiItem(); | 842 | KOAgendaItem *moveItem = mActionItem->firstMultiItem(); |
843 | bool isMultiItem = (moveItem || mActionItem->lastMultiItem()); | 843 | bool isMultiItem = (moveItem || mActionItem->lastMultiItem()); |
844 | if (!moveItem) moveItem = mActionItem; | 844 | if (!moveItem) moveItem = mActionItem; |
845 | while (moveItem) { | 845 | while (moveItem) { |
846 | int dy; | 846 | int dy; |
847 | if (isMultiItem) dy = 0; | 847 | if (isMultiItem) dy = 0; |
848 | else dy = gy - mCurrentCellY; | 848 | else dy = gy - mCurrentCellY; |
849 | moveItem->moveRelative(gx - mCurrentCellX,dy); | 849 | moveItem->moveRelative(gx - mCurrentCellX,dy); |
850 | int x,y; | 850 | int x,y; |
851 | gridToContents(moveItem->cellX(),moveItem->cellYTop(),x,y); | 851 | gridToContents(moveItem->cellX(),moveItem->cellYTop(),x,y); |
852 | moveItem->resize(mGridSpacingX * moveItem->cellWidth(), | 852 | moveItem->resize(mGridSpacingX * moveItem->cellWidth(), |
853 | mGridSpacingY * moveItem->cellHeight()); | 853 | mGridSpacingY * moveItem->cellHeight()); |
854 | moveChild(moveItem,x,y); | 854 | moveChild(moveItem,x,y); |
855 | moveItem = moveItem->nextMultiItem(); | 855 | moveItem = moveItem->nextMultiItem(); |
856 | } | 856 | } |
857 | } else if (mActionType == RESIZETOP) { | 857 | } else if (mActionType == RESIZETOP) { |
858 | if (mCurrentCellY <= mActionItem->cellYBottom()) { | 858 | if (mCurrentCellY <= mActionItem->cellYBottom()) { |
859 | mActionItem->expandTop(gy - mCurrentCellY); | 859 | mActionItem->expandTop(gy - mCurrentCellY); |
860 | mActionItem->resize(mActionItem->width(), | 860 | mActionItem->resize(mActionItem->width(), |
861 | mGridSpacingY * mActionItem->cellHeight()); | 861 | mGridSpacingY * mActionItem->cellHeight()); |
862 | int x,y; | 862 | int x,y; |
863 | gridToContents(mCurrentCellX,mActionItem->cellYTop(),x,y); | 863 | gridToContents(mCurrentCellX,mActionItem->cellYTop(),x,y); |
864 | //moveChild(mActionItem,childX(mActionItem),y); | 864 | //moveChild(mActionItem,childX(mActionItem),y); |
865 | QScrollView::moveChild( mActionItem,childX(mActionItem),y ); | 865 | QScrollView::moveChild( mActionItem,childX(mActionItem),y ); |
866 | } | 866 | } |
867 | } else if (mActionType == RESIZEBOTTOM) { | 867 | } else if (mActionType == RESIZEBOTTOM) { |
868 | if (mCurrentCellY >= mActionItem->cellYTop()) { | 868 | if (mCurrentCellY >= mActionItem->cellYTop()) { |
869 | mActionItem->expandBottom(gy - mCurrentCellY); | 869 | mActionItem->expandBottom(gy - mCurrentCellY); |
870 | mActionItem->resize(mActionItem->width(), | 870 | mActionItem->resize(mActionItem->width(), |
871 | mGridSpacingY * mActionItem->cellHeight()); | 871 | mGridSpacingY * mActionItem->cellHeight()); |
872 | } | 872 | } |
873 | } else if (mActionType == RESIZELEFT) { | 873 | } else if (mActionType == RESIZELEFT) { |
874 | if (mCurrentCellX <= mActionItem->cellXWidth()) { | 874 | if (mCurrentCellX <= mActionItem->cellXWidth()) { |
875 | mActionItem->expandLeft(gx - mCurrentCellX); | 875 | mActionItem->expandLeft(gx - mCurrentCellX); |
876 | mActionItem->resize(mGridSpacingX * mActionItem->cellWidth(), | 876 | mActionItem->resize(mGridSpacingX * mActionItem->cellWidth(), |
877 | mActionItem->height()); | 877 | mActionItem->height()); |
878 | int x,y; | 878 | int x,y; |
879 | gridToContents(mActionItem->cellX(),mActionItem->cellYTop(),x,y); | 879 | gridToContents(mActionItem->cellX(),mActionItem->cellYTop(),x,y); |
880 | moveChild(mActionItem,x,childY(mActionItem)); | 880 | moveChild(mActionItem,x,childY(mActionItem)); |
881 | } | 881 | } |
882 | } else if (mActionType == RESIZERIGHT) { | 882 | } else if (mActionType == RESIZERIGHT) { |
883 | if (mCurrentCellX >= mActionItem->cellX()) { | 883 | if (mCurrentCellX >= mActionItem->cellX()) { |
884 | mActionItem->expandRight(gx - mCurrentCellX); | 884 | mActionItem->expandRight(gx - mCurrentCellX); |
885 | mActionItem->resize(mGridSpacingX * mActionItem->cellWidth(), | 885 | mActionItem->resize(mGridSpacingX * mActionItem->cellWidth(), |
886 | mActionItem->height()); | 886 | mActionItem->height()); |
887 | } | 887 | } |
888 | } | 888 | } |
889 | mCurrentCellX = gx; | 889 | mCurrentCellX = gx; |
890 | mCurrentCellY = gy; | 890 | mCurrentCellY = gy; |
891 | } | 891 | } |
892 | } | 892 | } |
893 | 893 | ||
894 | void KOAgenda::endItemAction() | 894 | void KOAgenda::endItemAction() |
895 | { | 895 | { |
896 | 896 | ||
897 | if ( mItemMoved ) { | 897 | if ( mItemMoved ) { |
898 | KOAgendaItem *placeItem = mActionItem->firstMultiItem(); | 898 | KOAgendaItem *placeItem = mActionItem->firstMultiItem(); |
899 | if ( !placeItem ) { | 899 | if ( !placeItem ) { |
900 | placeItem = mActionItem; | 900 | placeItem = mActionItem; |
901 | } | 901 | } |
902 | if ( placeItem->incidence()->recurrence()->doesRecur() ) { | 902 | if ( placeItem->incidence()->recurrence()->doesRecur() ) { |
903 | Incidence* oldInc = placeItem->incidence(); | 903 | Incidence* oldInc = placeItem->incidence(); |
904 | placeItem->recreateIncidence(); | 904 | placeItem->recreateIncidence(); |
905 | emit addToCalSignal(placeItem->incidence(), oldInc ); | 905 | emit addToCalSignal(placeItem->incidence(), oldInc ); |
906 | } | 906 | } |
907 | int type = mActionType; | 907 | int type = mActionType; |
908 | if ( mAllDayMode ) | 908 | if ( mAllDayMode ) |
909 | type = -1; | 909 | type = -1; |
910 | KOAgendaItem *modifiedItem = placeItem; | 910 | KOAgendaItem *modifiedItem = placeItem; |
911 | //emit itemModified( placeItem, mActionType /*KOGlobals::EVENTEDITED */); | 911 | //emit itemModified( placeItem, mActionType /*KOGlobals::EVENTEDITED */); |
912 | QPtrList<KOAgendaItem> oldconflictItems ;//= placeItem->conflictItems(); | 912 | QPtrList<KOAgendaItem> oldconflictItems ;//= placeItem->conflictItems(); |
913 | KOAgendaItem *item; | 913 | KOAgendaItem *item; |
914 | 914 | ||
915 | if ( placeItem->incidence()->type() == "Todo" ) { | 915 | if ( placeItem->incidence()->typeID() == todoID ) { |
916 | mSelectedItem = 0; | 916 | mSelectedItem = 0; |
917 | //qDebug("todo %d %d %d ", mCurrentCellX, modifiedItem->cellX() ,modifiedItem->cellXWidth()); | 917 | //qDebug("todo %d %d %d ", mCurrentCellX, modifiedItem->cellX() ,modifiedItem->cellXWidth()); |
918 | modifiedItem->mLastMoveXPos = mCurrentCellX; | 918 | modifiedItem->mLastMoveXPos = mCurrentCellX; |
919 | emit itemModified( modifiedItem, mActionType ); | 919 | emit itemModified( modifiedItem, mActionType ); |
920 | } | 920 | } |
921 | else { | 921 | else { |
922 | 922 | ||
923 | 923 | ||
924 | globalFlagBlockAgendaItemPaint = 1; | 924 | globalFlagBlockAgendaItemPaint = 1; |
925 | for ( item=oldconflictItems.first(); item != 0; | 925 | for ( item=oldconflictItems.first(); item != 0; |
926 | item=oldconflictItems.next() ) { | 926 | item=oldconflictItems.next() ) { |
927 | placeSubCells(item); | 927 | placeSubCells(item); |
928 | } | 928 | } |
929 | while ( placeItem ) { | 929 | while ( placeItem ) { |
930 | //qDebug("placeItem %s ", placeItem->incidence()->summary().latin1()); | 930 | //qDebug("placeItem %s ", placeItem->incidence()->summary().latin1()); |
931 | oldconflictItems = placeItem->conflictItems(); | 931 | oldconflictItems = placeItem->conflictItems(); |
932 | for ( item=oldconflictItems.first(); item != 0; | 932 | for ( item=oldconflictItems.first(); item != 0; |
933 | item=oldconflictItems.next() ) { | 933 | item=oldconflictItems.next() ) { |
934 | placeSubCells(item); | 934 | placeSubCells(item); |
935 | } | 935 | } |
936 | placeSubCells( placeItem ); | 936 | placeSubCells( placeItem ); |
937 | placeItem = placeItem->nextMultiItem(); | 937 | placeItem = placeItem->nextMultiItem(); |
938 | } | 938 | } |
939 | globalFlagBlockAgendaItemPaint = 0; | 939 | globalFlagBlockAgendaItemPaint = 0; |
940 | for ( item=oldconflictItems.first(); item != 0; | 940 | for ( item=oldconflictItems.first(); item != 0; |
941 | item=oldconflictItems.next() ) { | 941 | item=oldconflictItems.next() ) { |
942 | globalFlagBlockAgendaItemUpdate = 0; | 942 | globalFlagBlockAgendaItemUpdate = 0; |
943 | item->repaintMe(); | 943 | item->repaintMe(); |
944 | globalFlagBlockAgendaItemUpdate = 1; | 944 | globalFlagBlockAgendaItemUpdate = 1; |
945 | item->repaint( false ); | 945 | item->repaint( false ); |
946 | } | 946 | } |
947 | placeItem = modifiedItem; | 947 | placeItem = modifiedItem; |
948 | 948 | ||
949 | while ( placeItem ) { | 949 | while ( placeItem ) { |
950 | //qDebug("placeItem %s ", placeItem->incidence()->summary().latin1()); | 950 | //qDebug("placeItem %s ", placeItem->incidence()->summary().latin1()); |
951 | globalFlagBlockAgendaItemUpdate = 0; | 951 | globalFlagBlockAgendaItemUpdate = 0; |
952 | placeItem->repaintMe(); | 952 | placeItem->repaintMe(); |
953 | globalFlagBlockAgendaItemUpdate = 1; | 953 | globalFlagBlockAgendaItemUpdate = 1; |
954 | placeItem->repaint(false); | 954 | placeItem->repaint(false); |
955 | placeItem = placeItem->nextMultiItem(); | 955 | placeItem = placeItem->nextMultiItem(); |
956 | } | 956 | } |
957 | emit itemModified( modifiedItem, mActionType ); | 957 | emit itemModified( modifiedItem, mActionType ); |
958 | 958 | ||
959 | 959 | ||
960 | placeItem = modifiedItem; | 960 | placeItem = modifiedItem; |
961 | while ( placeItem ) { | 961 | while ( placeItem ) { |
962 | oldconflictItems = placeItem->conflictItems(); | 962 | oldconflictItems = placeItem->conflictItems(); |
963 | for ( item=oldconflictItems.first(); item != 0; | 963 | for ( item=oldconflictItems.first(); item != 0; |
964 | item=oldconflictItems.next() ) { | 964 | item=oldconflictItems.next() ) { |
965 | placeSubCells(item); | 965 | placeSubCells(item); |
966 | } | 966 | } |
967 | placeSubCells( placeItem ); | 967 | placeSubCells( placeItem ); |
968 | placeItem = placeItem->nextMultiItem(); | 968 | placeItem = placeItem->nextMultiItem(); |
969 | 969 | ||
970 | } | 970 | } |
971 | placeItem = modifiedItem; | 971 | placeItem = modifiedItem; |
972 | while ( placeItem ) { | 972 | while ( placeItem ) { |
973 | oldconflictItems = placeItem->conflictItems(); | 973 | oldconflictItems = placeItem->conflictItems(); |
974 | for ( item=oldconflictItems.first(); item != 0; | 974 | for ( item=oldconflictItems.first(); item != 0; |
975 | item=oldconflictItems.next() ) { | 975 | item=oldconflictItems.next() ) { |
976 | globalFlagBlockAgendaItemUpdate = 0; | 976 | globalFlagBlockAgendaItemUpdate = 0; |
977 | item->repaintMe(); | 977 | item->repaintMe(); |
978 | globalFlagBlockAgendaItemUpdate = 1; | 978 | globalFlagBlockAgendaItemUpdate = 1; |
979 | item->repaint(false); | 979 | item->repaint(false); |
980 | } | 980 | } |
981 | placeItem = placeItem->nextMultiItem(); | 981 | placeItem = placeItem->nextMultiItem(); |
982 | } | 982 | } |
983 | /* | 983 | /* |
984 | 984 | ||
985 | oldconflictItems = modifiedItem->conflictItems(); | 985 | oldconflictItems = modifiedItem->conflictItems(); |
986 | for ( item=oldconflictItems.first(); item != 0; | 986 | for ( item=oldconflictItems.first(); item != 0; |
987 | item=oldconflictItems.next() ) { | 987 | item=oldconflictItems.next() ) { |
988 | globalFlagBlockAgendaItemUpdate = 0; | 988 | globalFlagBlockAgendaItemUpdate = 0; |
989 | item->paintMe(false); | 989 | item->paintMe(false); |
990 | globalFlagBlockAgendaItemUpdate = 1; | 990 | globalFlagBlockAgendaItemUpdate = 1; |
991 | item->repaint(false); | 991 | item->repaint(false); |
992 | } | 992 | } |
993 | */ | 993 | */ |
994 | 994 | ||
995 | 995 | ||
996 | } | 996 | } |
997 | 997 | ||
998 | } | 998 | } |
999 | 999 | ||
1000 | mScrollUpTimer.stop(); | 1000 | mScrollUpTimer.stop(); |
1001 | mScrollDownTimer.stop(); | 1001 | mScrollDownTimer.stop(); |
1002 | setCursor( arrowCursor ); | 1002 | setCursor( arrowCursor ); |
1003 | mActionItem = 0; | 1003 | mActionItem = 0; |
1004 | mActionType = NOP; | 1004 | mActionType = NOP; |
1005 | mItemMoved = 0; | 1005 | mItemMoved = 0; |
1006 | 1006 | ||
1007 | } | 1007 | } |
1008 | 1008 | ||
1009 | void KOAgenda::setNoActionCursor(KOAgendaItem *moveItem,QPoint viewportPos) | 1009 | void KOAgenda::setNoActionCursor(KOAgendaItem *moveItem,QPoint viewportPos) |
1010 | { | 1010 | { |
1011 | // kdDebug() << "viewportPos: " << viewportPos.x() << "," << viewportPos.y() << endl; | 1011 | // kdDebug() << "viewportPos: " << viewportPos.x() << "," << viewportPos.y() << endl; |
1012 | // QPoint point = viewport()->mapToGlobal(viewportPos); | 1012 | // QPoint point = viewport()->mapToGlobal(viewportPos); |
1013 | // kdDebug() << "Global: " << point.x() << "," << point.y() << endl; | 1013 | // kdDebug() << "Global: " << point.x() << "," << point.y() << endl; |
1014 | // point = clipper()->mapFromGlobal(point); | 1014 | // point = clipper()->mapFromGlobal(point); |
1015 | // kdDebug() << "clipper: " << point.x() << "," << point.y() << endl; | 1015 | // kdDebug() << "clipper: " << point.x() << "," << point.y() << endl; |
1016 | 1016 | ||
1017 | int x,y; | 1017 | int x,y; |
1018 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 1018 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
1019 | // kdDebug() << "contents: " << x << "," << y << "\n" << endl; | 1019 | // kdDebug() << "contents: " << x << "," << y << "\n" << endl; |
1020 | int gx,gy; | 1020 | int gx,gy; |
1021 | contentsToGrid(x,y,gx,gy); | 1021 | contentsToGrid(x,y,gx,gy); |
1022 | 1022 | ||
1023 | // Change cursor to resize cursor if appropriate | 1023 | // Change cursor to resize cursor if appropriate |
1024 | if (mAllDayMode) { | 1024 | if (mAllDayMode) { |
1025 | int gridDistanceX = (x - gx * mGridSpacingX); | 1025 | int gridDistanceX = (x - gx * mGridSpacingX); |
1026 | if (gridDistanceX < mResizeBorderWidth && | 1026 | if (gridDistanceX < mResizeBorderWidth && |
1027 | moveItem->cellX() == gx) { | 1027 | moveItem->cellX() == gx) { |
1028 | setCursor(sizeHorCursor); | 1028 | setCursor(sizeHorCursor); |
1029 | } else if ((mGridSpacingX - gridDistanceX) < mResizeBorderWidth && | 1029 | } else if ((mGridSpacingX - gridDistanceX) < mResizeBorderWidth && |
1030 | moveItem->cellXWidth() == gx) { | 1030 | moveItem->cellXWidth() == gx) { |
1031 | setCursor(sizeHorCursor); | 1031 | setCursor(sizeHorCursor); |
1032 | } else { | 1032 | } else { |
1033 | setCursor(arrowCursor); | 1033 | setCursor(arrowCursor); |
1034 | } | 1034 | } |
1035 | } else { | 1035 | } else { |
1036 | int gridDistanceY = (y - gy * mGridSpacingY); | 1036 | int gridDistanceY = (y - gy * mGridSpacingY); |
1037 | if (gridDistanceY < mResizeBorderWidth && | 1037 | if (gridDistanceY < mResizeBorderWidth && |
1038 | moveItem->cellYTop() == gy && | 1038 | moveItem->cellYTop() == gy && |
1039 | !moveItem->firstMultiItem()) { | 1039 | !moveItem->firstMultiItem()) { |
1040 | setCursor(sizeVerCursor); | 1040 | setCursor(sizeVerCursor); |
1041 | } else if ((mGridSpacingY - gridDistanceY) < mResizeBorderWidth && | 1041 | } else if ((mGridSpacingY - gridDistanceY) < mResizeBorderWidth && |
1042 | moveItem->cellYBottom() == gy && | 1042 | moveItem->cellYBottom() == gy && |
1043 | !moveItem->lastMultiItem()) { | 1043 | !moveItem->lastMultiItem()) { |
diff --git a/korganizer/koagendaitem.cpp b/korganizer/koagendaitem.cpp index df2e478..5a3c4d2 100644 --- a/korganizer/koagendaitem.cpp +++ b/korganizer/koagendaitem.cpp | |||
@@ -1,719 +1,719 @@ | |||
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 | 19 | ||
20 | #include <qlabel.h> | 20 | #include <qlabel.h> |
21 | #include <qlayout.h> | 21 | #include <qlayout.h> |
22 | #include <qhbox.h> | 22 | #include <qhbox.h> |
23 | #include <qvbox.h> | 23 | #include <qvbox.h> |
24 | #include <qtooltip.h> | 24 | #include <qtooltip.h> |
25 | #include <qwhatsthis.h> | 25 | #include <qwhatsthis.h> |
26 | #include <qdragobject.h> | 26 | #include <qdragobject.h> |
27 | #include <qdrawutil.h> | 27 | #include <qdrawutil.h> |
28 | #include <qpainter.h> | 28 | #include <qpainter.h> |
29 | 29 | ||
30 | #include <kiconloader.h> | 30 | #include <kiconloader.h> |
31 | #include <kdebug.h> | 31 | #include <kdebug.h> |
32 | #include <kglobal.h> | 32 | #include <kglobal.h> |
33 | #include <klocale.h> | 33 | #include <klocale.h> |
34 | #ifndef DESKTOP_VERSION | 34 | #ifndef DESKTOP_VERSION |
35 | #include <qpe/qpeapplication.h> | 35 | #include <qpe/qpeapplication.h> |
36 | #define AGENDA_ICON_SIZE 5 | 36 | #define AGENDA_ICON_SIZE 5 |
37 | #else | 37 | #else |
38 | #include <qapplication.h> | 38 | #include <qapplication.h> |
39 | #define AGENDA_ICON_SIZE 7 | 39 | #define AGENDA_ICON_SIZE 7 |
40 | #endif | 40 | #endif |
41 | #include <libkcal/icaldrag.h> | 41 | #include <libkcal/icaldrag.h> |
42 | #include <libkcal/vcaldrag.h> | 42 | #include <libkcal/vcaldrag.h> |
43 | #include <libkcal/kincidenceformatter.h> | 43 | #include <libkcal/kincidenceformatter.h> |
44 | extern int globalFlagBlockAgenda; | 44 | extern int globalFlagBlockAgenda; |
45 | extern int globalFlagBlockAgendaItemPaint; | 45 | extern int globalFlagBlockAgendaItemPaint; |
46 | extern int globalFlagBlockAgendaItemUpdate; | 46 | extern int globalFlagBlockAgendaItemUpdate; |
47 | 47 | ||
48 | #include "koprefs.h" | 48 | #include "koprefs.h" |
49 | 49 | ||
50 | #include "koagendaitem.h" | 50 | #include "koagendaitem.h" |
51 | //#include "koagendaitem.moc" | 51 | //#include "koagendaitem.moc" |
52 | 52 | ||
53 | 53 | ||
54 | //-------------------------------------------------------------------------- | 54 | //-------------------------------------------------------------------------- |
55 | 55 | ||
56 | QToolTipGroup *KOAgendaItem::mToolTipGroup = 0; | 56 | QToolTipGroup *KOAgendaItem::mToolTipGroup = 0; |
57 | 57 | ||
58 | //-------------------------------------------------------------------------- | 58 | //-------------------------------------------------------------------------- |
59 | 59 | ||
60 | class KOAgendaItemWhatsThis :public QWhatsThis | 60 | class KOAgendaItemWhatsThis :public QWhatsThis |
61 | { | 61 | { |
62 | public: | 62 | public: |
63 | KOAgendaItemWhatsThis( KOAgendaItem* view ) : QWhatsThis( view ),_view (view) { }; | 63 | KOAgendaItemWhatsThis( KOAgendaItem* view ) : QWhatsThis( view ),_view (view) { }; |
64 | 64 | ||
65 | protected: | 65 | protected: |
66 | virtual QString text( const QPoint& ) | 66 | virtual QString text( const QPoint& ) |
67 | { | 67 | { |
68 | return _view->getWhatsThisText() ; | 68 | return _view->getWhatsThisText() ; |
69 | } | 69 | } |
70 | private: | 70 | private: |
71 | KOAgendaItem * _view; | 71 | KOAgendaItem * _view; |
72 | }; | 72 | }; |
73 | 73 | ||
74 | KOAgendaItem::KOAgendaItem(Incidence *incidence, QDate qd, QWidget *parent,bool allday, | 74 | KOAgendaItem::KOAgendaItem(Incidence *incidence, QDate qd, QWidget *parent,bool allday, |
75 | const char *name,WFlags) : | 75 | const char *name,WFlags) : |
76 | QWidget(parent, name), mIncidence(incidence), mDate(qd) | 76 | QWidget(parent, name), mIncidence(incidence), mDate(qd) |
77 | { | 77 | { |
78 | #ifndef DESKTOP_VERSION | 78 | #ifndef DESKTOP_VERSION |
79 | //QPEApplication::setStylusOperation( this, QPEApplication::RightOnHold ); | 79 | //QPEApplication::setStylusOperation( this, QPEApplication::RightOnHold ); |
80 | #endif | 80 | #endif |
81 | mKOAgendaItemWhatsThis = new KOAgendaItemWhatsThis(this); | 81 | mKOAgendaItemWhatsThis = new KOAgendaItemWhatsThis(this); |
82 | int wflags = getWFlags() |WRepaintNoErase;// WResizeNoErase | 82 | int wflags = getWFlags() |WRepaintNoErase;// WResizeNoErase |
83 | setWFlags ( wflags); | 83 | setWFlags ( wflags); |
84 | mAllDay = allday; | 84 | mAllDay = allday; |
85 | init ( incidence, qd ); | 85 | init ( incidence, qd ); |
86 | //setMouseTracking(true); | 86 | //setMouseTracking(true); |
87 | //setAcceptDrops(true); | 87 | //setAcceptDrops(true); |
88 | xPaintCoord = -1; | 88 | xPaintCoord = -1; |
89 | yPaintCoord = -1; | 89 | yPaintCoord = -1; |
90 | } | 90 | } |
91 | QString KOAgendaItem::getWhatsThisText() | 91 | QString KOAgendaItem::getWhatsThisText() |
92 | { | 92 | { |
93 | if ( mIncidence ) | 93 | if ( mIncidence ) |
94 | return KIncidenceFormatter::instance()->getFormattedText( mIncidence, | 94 | return KIncidenceFormatter::instance()->getFormattedText( mIncidence, |
95 | KOPrefs::instance()->mWTshowDetails, | 95 | KOPrefs::instance()->mWTshowDetails, |
96 | KOPrefs::instance()->mWTshowCreated, | 96 | KOPrefs::instance()->mWTshowCreated, |
97 | KOPrefs::instance()->mWTshowChanged); | 97 | KOPrefs::instance()->mWTshowChanged); |
98 | return "KOAgendaItem::getWhatsThisText()::internal error"; | 98 | return "KOAgendaItem::getWhatsThisText()::internal error"; |
99 | } | 99 | } |
100 | void KOAgendaItem::init ( Incidence *incidence, QDate qd ) | 100 | void KOAgendaItem::init ( Incidence *incidence, QDate qd ) |
101 | { | 101 | { |
102 | mIncidence = incidence; | 102 | mIncidence = incidence; |
103 | mDate = qd; | 103 | mDate = qd; |
104 | mFirstMultiItem = 0; | 104 | mFirstMultiItem = 0; |
105 | mNextMultiItem = 0; | 105 | mNextMultiItem = 0; |
106 | mLastMultiItem = 0; | 106 | mLastMultiItem = 0; |
107 | computeText(); | 107 | computeText(); |
108 | 108 | ||
109 | if ( (incidence->type() == "Todo") && | 109 | if ( (incidence->typeID() == todoID ) && |
110 | ( !((static_cast<Todo*>(incidence))->isCompleted()) && | 110 | ( !((static_cast<Todo*>(incidence))->isCompleted()) && |
111 | ((static_cast<Todo*>(incidence))->dtDue().date() <= QDate::currentDate()) ) ) { | 111 | ((static_cast<Todo*>(incidence))->dtDue().date() <= QDate::currentDate()) ) ) { |
112 | if ( (static_cast<Todo*>(incidence))->dtDue() < QDateTime::currentDateTime().date()) | 112 | if ( (static_cast<Todo*>(incidence))->dtDue() < QDateTime::currentDateTime().date()) |
113 | mBackgroundColor = KOPrefs::instance()->mTodoOverdueColor ; | 113 | mBackgroundColor = KOPrefs::instance()->mTodoOverdueColor ; |
114 | else | 114 | else |
115 | mBackgroundColor = KOPrefs::instance()->mTodoDueTodayColor; | 115 | mBackgroundColor = KOPrefs::instance()->mTodoDueTodayColor; |
116 | } | 116 | } |
117 | else { | 117 | else { |
118 | QStringList categories = mIncidence->categories(); | 118 | QStringList categories = mIncidence->categories(); |
119 | QString cat = categories.first(); | 119 | QString cat = categories.first(); |
120 | if (cat.isEmpty()) { | 120 | if (cat.isEmpty()) { |
121 | if ( (incidence->type() == "Todo") &&((static_cast<Todo*>(incidence))->isCompleted()) ) | 121 | if ( (incidence->typeID() == todoID ) &&((static_cast<Todo*>(incidence))->isCompleted()) ) |
122 | mBackgroundColor =KOPrefs::instance()->mTodoDoneColor; | 122 | mBackgroundColor =KOPrefs::instance()->mTodoDoneColor; |
123 | else | 123 | else |
124 | mBackgroundColor =KOPrefs::instance()->mEventColor; | 124 | mBackgroundColor =KOPrefs::instance()->mEventColor; |
125 | } else { | 125 | } else { |
126 | mBackgroundColor = *KOPrefs::instance()->categoryColor(cat); | 126 | mBackgroundColor = *KOPrefs::instance()->categoryColor(cat); |
127 | if ( (incidence->type() == "Todo") &&((static_cast<Todo*>(incidence))->isCompleted()) ) { | 127 | if ( (incidence->typeID() == todoID ) &&((static_cast<Todo*>(incidence))->isCompleted()) ) { |
128 | if ( mBackgroundColor == KOPrefs::instance()->mEventColor ) | 128 | if ( mBackgroundColor == KOPrefs::instance()->mEventColor ) |
129 | mBackgroundColor =KOPrefs::instance()->mTodoDoneColor; | 129 | mBackgroundColor =KOPrefs::instance()->mTodoDoneColor; |
130 | } | 130 | } |
131 | } | 131 | } |
132 | 132 | ||
133 | } | 133 | } |
134 | mColorGroup = QColorGroup( mBackgroundColor.light(), | 134 | mColorGroup = QColorGroup( mBackgroundColor.light(), |
135 | mBackgroundColor.dark(),mBackgroundColor.light(), | 135 | mBackgroundColor.dark(),mBackgroundColor.light(), |
136 | mBackgroundColor.dark(),mBackgroundColor, black, mBackgroundColor) ; | 136 | mBackgroundColor.dark(),mBackgroundColor, black, mBackgroundColor) ; |
137 | setBackgroundColor( mBackgroundColor ); | 137 | setBackgroundColor( mBackgroundColor ); |
138 | 138 | ||
139 | mConflictItems.clear(); | 139 | mConflictItems.clear(); |
140 | setCellXY(0,0,1); | 140 | setCellXY(0,0,1); |
141 | setCellXWidth(0); | 141 | setCellXWidth(0); |
142 | setSubCell(0); | 142 | setSubCell(0); |
143 | setSubCells(1); | 143 | setSubCells(1); |
144 | setMultiItem(0,0,0); | 144 | setMultiItem(0,0,0); |
145 | startMove(); | 145 | startMove(); |
146 | mSelected = true; | 146 | mSelected = true; |
147 | select(false); | 147 | select(false); |
148 | QFontMetrics fontinf(KOPrefs::instance()->mAgendaViewFont); | 148 | QFontMetrics fontinf(KOPrefs::instance()->mAgendaViewFont); |
149 | mFontPixelSize = fontinf.height();; | 149 | mFontPixelSize = fontinf.height();; |
150 | hide(); | 150 | hide(); |
151 | xPaintCoord = -1; | 151 | xPaintCoord = -1; |
152 | yPaintCoord = -1; | 152 | yPaintCoord = -1; |
153 | } | 153 | } |
154 | 154 | ||
155 | 155 | ||
156 | KOAgendaItem::~KOAgendaItem() | 156 | KOAgendaItem::~KOAgendaItem() |
157 | { | 157 | { |
158 | #if QT_VERSION >= 0x030000 | 158 | #if QT_VERSION >= 0x030000 |
159 | 159 | ||
160 | #else | 160 | #else |
161 | delete mKOAgendaItemWhatsThis; | 161 | delete mKOAgendaItemWhatsThis; |
162 | #endif | 162 | #endif |
163 | 163 | ||
164 | } | 164 | } |
165 | 165 | ||
166 | void KOAgendaItem::recreateIncidence() | 166 | void KOAgendaItem::recreateIncidence() |
167 | { | 167 | { |
168 | #if 0 | 168 | #if 0 |
169 | Incidence* newInc = mIncidence->clone(); | 169 | Incidence* newInc = mIncidence->clone(); |
170 | newInc->recreate(); | 170 | newInc->recreate(); |
171 | if ( mIncidence->doesRecur() ) { | 171 | if ( mIncidence->doesRecur() ) { |
172 | mIncidence->addExDate( mDate ); | 172 | mIncidence->addExDate( mDate ); |
173 | newInc->recurrence()->unsetRecurs(); | 173 | newInc->recurrence()->unsetRecurs(); |
174 | int len = mIncidence->dtStart().secsTo( ((Event*)mIncidence)->dtEnd()); | 174 | int len = mIncidence->dtStart().secsTo( ((Event*)mIncidence)->dtEnd()); |
175 | QTime tim = mIncidence->dtStart().time(); | 175 | QTime tim = mIncidence->dtStart().time(); |
176 | newInc->setDtStart( QDateTime(mDate, tim) ); | 176 | newInc->setDtStart( QDateTime(mDate, tim) ); |
177 | ((Event*)newInc)->setDtEnd( newInc->dtStart().addSecs( len ) ); | 177 | ((Event*)newInc)->setDtEnd( newInc->dtStart().addSecs( len ) ); |
178 | } | 178 | } |
179 | #endif | 179 | #endif |
180 | mIncidence = mIncidence->recreateCloneException( mDate ); | 180 | mIncidence = mIncidence->recreateCloneException( mDate ); |
181 | } | 181 | } |
182 | bool KOAgendaItem::updateIcons(QPainter * p, bool horLayout) | 182 | bool KOAgendaItem::updateIcons(QPainter * p, bool horLayout) |
183 | { | 183 | { |
184 | int size = AGENDA_ICON_SIZE; | 184 | int size = AGENDA_ICON_SIZE; |
185 | 185 | ||
186 | int yOff = 0; | 186 | int yOff = 0; |
187 | int xOff = 0; | 187 | int xOff = 0; |
188 | int x = pos().x() +3; | 188 | int x = pos().x() +3; |
189 | int y; | 189 | int y; |
190 | if ( mAllDay ) | 190 | if ( mAllDay ) |
191 | y = pos().y()+3; | 191 | y = pos().y()+3; |
192 | else | 192 | else |
193 | y = mCellYTop * ( height() / cellHeight() ) +3; | 193 | y = mCellYTop * ( height() / cellHeight() ) +3; |
194 | if (mIncidence->cancelled()) { | 194 | if (mIncidence->cancelled()) { |
195 | int xpos = xOff*( 1 +AGENDA_ICON_SIZE )+x; | 195 | int xpos = xOff*( 1 +AGENDA_ICON_SIZE )+x; |
196 | int ypos = yOff*( 1 +AGENDA_ICON_SIZE)+y; | 196 | int ypos = yOff*( 1 +AGENDA_ICON_SIZE)+y; |
197 | p->drawLine( xpos, ypos, xpos+AGENDA_ICON_SIZE-1, ypos+AGENDA_ICON_SIZE-1 ); | 197 | p->drawLine( xpos, ypos, xpos+AGENDA_ICON_SIZE-1, ypos+AGENDA_ICON_SIZE-1 ); |
198 | p->drawLine( xpos, ypos+AGENDA_ICON_SIZE-1, xpos+AGENDA_ICON_SIZE-1, ypos ); | 198 | p->drawLine( xpos, ypos+AGENDA_ICON_SIZE-1, xpos+AGENDA_ICON_SIZE-1, ypos ); |
199 | if ( horLayout ) | 199 | if ( horLayout ) |
200 | ++xOff; | 200 | ++xOff; |
201 | else | 201 | else |
202 | ++yOff; | 202 | ++yOff; |
203 | } | 203 | } |
204 | if (mIncidence->isAlarmEnabled()) { | 204 | if (mIncidence->isAlarmEnabled()) { |
205 | p->fillRect ( xOff*( 1 +AGENDA_ICON_SIZE )+x, yOff*( 1 +AGENDA_ICON_SIZE)+y, AGENDA_ICON_SIZE, AGENDA_ICON_SIZE, red ); | 205 | p->fillRect ( xOff*( 1 +AGENDA_ICON_SIZE )+x, yOff*( 1 +AGENDA_ICON_SIZE)+y, AGENDA_ICON_SIZE, AGENDA_ICON_SIZE, red ); |
206 | if ( horLayout ) | 206 | if ( horLayout ) |
207 | ++xOff; | 207 | ++xOff; |
208 | else | 208 | else |
209 | ++yOff; | 209 | ++yOff; |
210 | } | 210 | } |
211 | if (mIncidence->recurrence()->doesRecur()) { | 211 | if (mIncidence->recurrence()->doesRecur()) { |
212 | p->fillRect ( xOff*( 1 +AGENDA_ICON_SIZE )+x, yOff*( 1 +AGENDA_ICON_SIZE)+y, AGENDA_ICON_SIZE, AGENDA_ICON_SIZE, blue ); | 212 | p->fillRect ( xOff*( 1 +AGENDA_ICON_SIZE )+x, yOff*( 1 +AGENDA_ICON_SIZE)+y, AGENDA_ICON_SIZE, AGENDA_ICON_SIZE, blue ); |
213 | if ( horLayout ) | 213 | if ( horLayout ) |
214 | ++xOff; | 214 | ++xOff; |
215 | else | 215 | else |
216 | ++yOff; | 216 | ++yOff; |
217 | } | 217 | } |
218 | if (mIncidence->description().length() > 0) { | 218 | if (mIncidence->description().length() > 0) { |
219 | p->fillRect ( xOff*( 1 +AGENDA_ICON_SIZE )+x, yOff*( 1 +AGENDA_ICON_SIZE)+y, AGENDA_ICON_SIZE, AGENDA_ICON_SIZE, darkGreen ); | 219 | p->fillRect ( xOff*( 1 +AGENDA_ICON_SIZE )+x, yOff*( 1 +AGENDA_ICON_SIZE)+y, AGENDA_ICON_SIZE, AGENDA_ICON_SIZE, darkGreen ); |
220 | if ( horLayout ) | 220 | if ( horLayout ) |
221 | ++xOff; | 221 | ++xOff; |
222 | else | 222 | else |
223 | ++yOff; | 223 | ++yOff; |
224 | } | 224 | } |
225 | if (mIncidence->isReadOnly()) { | 225 | if (mIncidence->isReadOnly()) { |
226 | p->fillRect ( xOff*( 1 +AGENDA_ICON_SIZE )+x, yOff*( 1 +AGENDA_ICON_SIZE)+y, AGENDA_ICON_SIZE, AGENDA_ICON_SIZE, white ); | 226 | p->fillRect ( xOff*( 1 +AGENDA_ICON_SIZE )+x, yOff*( 1 +AGENDA_ICON_SIZE)+y, AGENDA_ICON_SIZE, AGENDA_ICON_SIZE, white ); |
227 | if ( horLayout ) | 227 | if ( horLayout ) |
228 | ++xOff; | 228 | ++xOff; |
229 | else | 229 | else |
230 | ++yOff; | 230 | ++yOff; |
231 | } | 231 | } |
232 | 232 | ||
233 | if (mIncidence->attendeeCount()>0) { | 233 | if (mIncidence->attendeeCount()>0) { |
234 | 234 | ||
235 | if (mIncidence->organizer() == KOPrefs::instance()->email()) { | 235 | if (mIncidence->organizer() == KOPrefs::instance()->email()) { |
236 | p->fillRect ( xOff*( 1 +AGENDA_ICON_SIZE )+x, yOff*( 1 +AGENDA_ICON_SIZE)+y, AGENDA_ICON_SIZE, AGENDA_ICON_SIZE, black ); | 236 | p->fillRect ( xOff*( 1 +AGENDA_ICON_SIZE )+x, yOff*( 1 +AGENDA_ICON_SIZE)+y, AGENDA_ICON_SIZE, AGENDA_ICON_SIZE, black ); |
237 | if ( horLayout ) | 237 | if ( horLayout ) |
238 | ++xOff; | 238 | ++xOff; |
239 | else | 239 | else |
240 | ++yOff; | 240 | ++yOff; |
241 | } else { | 241 | } else { |
242 | Attendee *me = mIncidence->attendeeByMails(KOPrefs::instance()->mAdditionalMails,KOPrefs::instance()->email()); | 242 | Attendee *me = mIncidence->attendeeByMails(KOPrefs::instance()->mAdditionalMails,KOPrefs::instance()->email()); |
243 | if (me!=0) { | 243 | if (me!=0) { |
244 | 244 | ||
245 | 245 | ||
246 | } else { | 246 | } else { |
247 | p->fillRect ( xOff*( 1 +AGENDA_ICON_SIZE )+x, yOff*( 1 +AGENDA_ICON_SIZE)+y, AGENDA_ICON_SIZE, AGENDA_ICON_SIZE, yellow ); | 247 | p->fillRect ( xOff*( 1 +AGENDA_ICON_SIZE )+x, yOff*( 1 +AGENDA_ICON_SIZE)+y, AGENDA_ICON_SIZE, AGENDA_ICON_SIZE, yellow ); |
248 | if ( horLayout ) | 248 | if ( horLayout ) |
249 | ++xOff; | 249 | ++xOff; |
250 | else | 250 | else |
251 | ++yOff; | 251 | ++yOff; |
252 | 252 | ||
253 | } | 253 | } |
254 | p->fillRect ( xOff*( 1 +AGENDA_ICON_SIZE )+x, yOff*( 1 +AGENDA_ICON_SIZE)+y, AGENDA_ICON_SIZE, AGENDA_ICON_SIZE, darkYellow ); | 254 | p->fillRect ( xOff*( 1 +AGENDA_ICON_SIZE )+x, yOff*( 1 +AGENDA_ICON_SIZE)+y, AGENDA_ICON_SIZE, AGENDA_ICON_SIZE, darkYellow ); |
255 | if ( horLayout ) | 255 | if ( horLayout ) |
256 | ++xOff; | 256 | ++xOff; |
257 | else | 257 | else |
258 | ++yOff; | 258 | ++yOff; |
259 | 259 | ||
260 | } | 260 | } |
261 | 261 | ||
262 | } | 262 | } |
263 | return ( yOff || xOff ); | 263 | return ( yOff || xOff ); |
264 | } | 264 | } |
265 | 265 | ||
266 | 266 | ||
267 | void KOAgendaItem::select(bool selected) | 267 | void KOAgendaItem::select(bool selected) |
268 | { | 268 | { |
269 | //qDebug("select %d %d",firstMultiItem(), nextMultiItem() ); | 269 | //qDebug("select %d %d",firstMultiItem(), nextMultiItem() ); |
270 | if (mSelected == selected) return; | 270 | if (mSelected == selected) return; |
271 | mSelected = selected; | 271 | mSelected = selected; |
272 | if ( ! isVisible() ) | 272 | if ( ! isVisible() ) |
273 | return; | 273 | return; |
274 | if ( firstMultiItem() ) | 274 | if ( firstMultiItem() ) |
275 | firstMultiItem()->select( selected ); | 275 | firstMultiItem()->select( selected ); |
276 | if ( !firstMultiItem() && nextMultiItem() ) { | 276 | if ( !firstMultiItem() && nextMultiItem() ) { |
277 | KOAgendaItem * placeItem = nextMultiItem(); | 277 | KOAgendaItem * placeItem = nextMultiItem(); |
278 | while ( placeItem ) { | 278 | while ( placeItem ) { |
279 | placeItem->select( selected ); | 279 | placeItem->select( selected ); |
280 | placeItem = placeItem->nextMultiItem(); | 280 | placeItem = placeItem->nextMultiItem(); |
281 | } | 281 | } |
282 | } | 282 | } |
283 | globalFlagBlockAgendaItemUpdate = 0; | 283 | globalFlagBlockAgendaItemUpdate = 0; |
284 | paintMe( selected ); | 284 | paintMe( selected ); |
285 | globalFlagBlockAgendaItemUpdate = 1; | 285 | globalFlagBlockAgendaItemUpdate = 1; |
286 | repaint( false ); | 286 | repaint( false ); |
287 | } | 287 | } |
288 | 288 | ||
289 | 289 | ||
290 | /* | 290 | /* |
291 | The eventFilter has to filter the mouse events of the agenda item childs. The | 291 | The eventFilter has to filter the mouse events of the agenda item childs. The |
292 | events are fed into the event handling method of KOAgendaItem. This allows the | 292 | events are fed into the event handling method of KOAgendaItem. This allows the |
293 | KOAgenda to handle the KOAgendaItems by using an eventFilter. | 293 | KOAgenda to handle the KOAgendaItems by using an eventFilter. |
294 | */ | 294 | */ |
295 | bool KOAgendaItem::eventFilter ( QObject *object, QEvent *e ) | 295 | bool KOAgendaItem::eventFilter ( QObject *object, QEvent *e ) |
296 | { | 296 | { |
297 | if (e->type() == QEvent::MouseButtonPress || | 297 | if (e->type() == QEvent::MouseButtonPress || |
298 | e->type() == QEvent::MouseButtonDblClick || | 298 | e->type() == QEvent::MouseButtonDblClick || |
299 | e->type() == QEvent::MouseButtonRelease || | 299 | e->type() == QEvent::MouseButtonRelease || |
300 | e->type() == QEvent::MouseMove) { | 300 | e->type() == QEvent::MouseMove) { |
301 | QMouseEvent *me = (QMouseEvent *)e; | 301 | QMouseEvent *me = (QMouseEvent *)e; |
302 | QPoint itemPos = this->mapFromGlobal(((QWidget *)object)-> | 302 | QPoint itemPos = this->mapFromGlobal(((QWidget *)object)-> |
303 | mapToGlobal(me->pos())); | 303 | mapToGlobal(me->pos())); |
304 | QMouseEvent returnEvent (e->type(),itemPos,me->button(),me->state()); | 304 | QMouseEvent returnEvent (e->type(),itemPos,me->button(),me->state()); |
305 | return event(&returnEvent); | 305 | return event(&returnEvent); |
306 | } else { | 306 | } else { |
307 | return false; | 307 | return false; |
308 | } | 308 | } |
309 | } | 309 | } |
310 | void KOAgendaItem::repaintMe( ) | 310 | void KOAgendaItem::repaintMe( ) |
311 | { | 311 | { |
312 | paintMe ( mSelected ); | 312 | paintMe ( mSelected ); |
313 | } | 313 | } |
314 | void KOAgendaItem::paintMe( bool selected, QPainter* paint ) | 314 | void KOAgendaItem::paintMe( bool selected, QPainter* paint ) |
315 | { | 315 | { |
316 | if ( globalFlagBlockAgendaItemUpdate && ! selected) | 316 | if ( globalFlagBlockAgendaItemUpdate && ! selected) |
317 | return; | 317 | return; |
318 | QPainter pa; | 318 | QPainter pa; |
319 | 319 | ||
320 | if ( mSelected ) { | 320 | if ( mSelected ) { |
321 | pa.begin( paintPixSel() ); | 321 | pa.begin( paintPixSel() ); |
322 | } else { | 322 | } else { |
323 | if ( mAllDay ) | 323 | if ( mAllDay ) |
324 | pa.begin( paintPixAllday() ); | 324 | pa.begin( paintPixAllday() ); |
325 | else | 325 | else |
326 | pa.begin( paintPix() ); | 326 | pa.begin( paintPix() ); |
327 | } | 327 | } |
328 | int x, yy, w, h; | 328 | int x, yy, w, h; |
329 | float nfh = 7.0; | 329 | float nfh = 7.0; |
330 | x = pos().x(); w = width(); h = height (); | 330 | x = pos().x(); w = width(); h = height (); |
331 | if ( mAllDay ) | 331 | if ( mAllDay ) |
332 | yy = y(); | 332 | yy = y(); |
333 | else | 333 | else |
334 | yy = mCellYTop * ( height() / cellHeight() ); | 334 | yy = mCellYTop * ( height() / cellHeight() ); |
335 | xPaintCoord= x; | 335 | xPaintCoord= x; |
336 | yPaintCoord = yy; | 336 | yPaintCoord = yy; |
337 | wPaintCoord = width(); | 337 | wPaintCoord = width(); |
338 | hPaintCoord = height(); | 338 | hPaintCoord = height(); |
339 | //qDebug("paintMe %s %d %d %d %d",incidence()->summary().latin1(), x, yy, width(), height()); | 339 | //qDebug("paintMe %s %d %d %d %d",incidence()->summary().latin1(), x, yy, width(), height()); |
340 | if ( paint == 0 ) | 340 | if ( paint == 0 ) |
341 | paint = &pa; | 341 | paint = &pa; |
342 | bool horLayout = ( w < h ); | 342 | bool horLayout = ( w < h ); |
343 | int maxhei = mFontPixelSize+4; | 343 | int maxhei = mFontPixelSize+4; |
344 | if ( horLayout ) | 344 | if ( horLayout ) |
345 | maxhei += AGENDA_ICON_SIZE -4; | 345 | maxhei += AGENDA_ICON_SIZE -4; |
346 | bool small = ( h < maxhei ); | 346 | bool small = ( h < maxhei ); |
347 | if ( ! small ) | 347 | if ( ! small ) |
348 | paint->setFont(KOPrefs::instance()->mAgendaViewFont); | 348 | paint->setFont(KOPrefs::instance()->mAgendaViewFont); |
349 | else { | 349 | else { |
350 | QFont f = KOPrefs::instance()->mAgendaViewFont; | 350 | QFont f = KOPrefs::instance()->mAgendaViewFont; |
351 | f.setBold( false ); | 351 | f.setBold( false ); |
352 | int fh = f.pointSize(); | 352 | int fh = f.pointSize(); |
353 | nfh = (((float)height())/(float)(mFontPixelSize+4))*fh; | 353 | nfh = (((float)height())/(float)(mFontPixelSize+4))*fh; |
354 | if ( nfh < 6 ) | 354 | if ( nfh < 6 ) |
355 | nfh = 6; | 355 | nfh = 6; |
356 | f.setPointSize( nfh ); | 356 | f.setPointSize( nfh ); |
357 | paint->setFont(f); | 357 | paint->setFont(f); |
358 | } | 358 | } |
359 | paint->fillRect ( x, yy, w, h, mBackgroundColor ); | 359 | paint->fillRect ( x, yy, w, h, mBackgroundColor ); |
360 | static const QPixmap completedPxmp = SmallIcon("greenhook16"); | 360 | static const QPixmap completedPxmp = SmallIcon("greenhook16"); |
361 | static const QPixmap overduePxmp = SmallIcon("redcross16"); | 361 | static const QPixmap overduePxmp = SmallIcon("redcross16"); |
362 | if ( mIncidence->type() == "Todo" ) { | 362 | if ( mIncidence->typeID() == todoID ) { |
363 | Todo* tempTodo = static_cast<Todo*>(mIncidence); | 363 | Todo* tempTodo = static_cast<Todo*>(mIncidence); |
364 | int xx = pos().x()+(width()-completedPxmp.width()-3 ); | 364 | int xx = pos().x()+(width()-completedPxmp.width()-3 ); |
365 | int yyy = yy+3; | 365 | int yyy = yy+3; |
366 | if ( tempTodo->isCompleted() ) | 366 | if ( tempTodo->isCompleted() ) |
367 | paint->drawPixmap ( xx, yyy, completedPxmp ); | 367 | paint->drawPixmap ( xx, yyy, completedPxmp ); |
368 | else { | 368 | else { |
369 | paint->drawPixmap ( xx, yyy, overduePxmp ); | 369 | paint->drawPixmap ( xx, yyy, overduePxmp ); |
370 | 370 | ||
371 | } | 371 | } |
372 | } | 372 | } |
373 | bool addIcon = false; | 373 | bool addIcon = false; |
374 | if ( ! small || w > 3 * h || h > 3* w ) | 374 | if ( ! small || w > 3 * h || h > 3* w ) |
375 | addIcon = updateIcons( paint, horLayout ); | 375 | addIcon = updateIcons( paint, horLayout ); |
376 | 376 | ||
377 | qDrawShadePanel (paint, x, yy, w, h, mColorGroup, selected , 2, 0); | 377 | qDrawShadePanel (paint, x, yy, w, h, mColorGroup, selected , 2, 0); |
378 | //qDebug("draw rect %d %d %d %d ",x, yy, w, h ); | 378 | //qDebug("draw rect %d %d %d %d ",x, yy, w, h ); |
379 | if ( ! small ) { | 379 | if ( ! small ) { |
380 | x += 3; yy += 3;w -= 6; h-= 5; | 380 | x += 3; yy += 3;w -= 6; h-= 5; |
381 | } else { | 381 | } else { |
382 | x += 2; yy += 1;w -= 4; h-= 4; | 382 | x += 2; yy += 1;w -= 4; h-= 4; |
383 | if ( nfh < 6.01 ) { | 383 | if ( nfh < 6.01 ) { |
384 | yy -= 2; | 384 | yy -= 2; |
385 | h += 4; | 385 | h += 4; |
386 | } | 386 | } |
387 | else | 387 | else |
388 | if ( nfh < h -2 ) | 388 | if ( nfh < h -2 ) |
389 | ++yy; | 389 | ++yy; |
390 | } | 390 | } |
391 | int align; | 391 | int align; |
392 | #ifndef DESKTOP_VERSION | 392 | #ifndef DESKTOP_VERSION |
393 | align = ( AlignLeft|WordBreak|AlignTop); | 393 | align = ( AlignLeft|WordBreak|AlignTop); |
394 | #else | 394 | #else |
395 | align = ( AlignLeft|BreakAnywhere|WordBreak|AlignTop); | 395 | align = ( AlignLeft|BreakAnywhere|WordBreak|AlignTop); |
396 | #endif | 396 | #endif |
397 | if ( addIcon ) { | 397 | if ( addIcon ) { |
398 | if ( ! horLayout ) { | 398 | if ( ! horLayout ) { |
399 | x += AGENDA_ICON_SIZE+3; | 399 | x += AGENDA_ICON_SIZE+3; |
400 | w -= (AGENDA_ICON_SIZE+3); | 400 | w -= (AGENDA_ICON_SIZE+3); |
401 | } | 401 | } |
402 | else { | 402 | else { |
403 | yy+= AGENDA_ICON_SIZE+2; | 403 | yy+= AGENDA_ICON_SIZE+2; |
404 | h -=(AGENDA_ICON_SIZE+3); | 404 | h -=(AGENDA_ICON_SIZE+3); |
405 | } | 405 | } |
406 | } | 406 | } |
407 | int colsum = mBackgroundColor.red() + mBackgroundColor.green() + mBackgroundColor.blue(); | 407 | int colsum = mBackgroundColor.red() + mBackgroundColor.green() + mBackgroundColor.blue(); |
408 | if ( colsum < 250 ) | 408 | if ( colsum < 250 ) |
409 | paint->setPen ( white); | 409 | paint->setPen ( white); |
410 | if ( x < 0 ) { | 410 | if ( x < 0 ) { |
411 | w = w+x-3; | 411 | w = w+x-3; |
412 | x = 3; | 412 | x = 3; |
413 | if ( w > parentWidget()->width() ){ | 413 | if ( w > parentWidget()->width() ){ |
414 | w = parentWidget()->width() - 6; | 414 | w = parentWidget()->width() - 6; |
415 | #ifndef DESKTOP_VERSION | 415 | #ifndef DESKTOP_VERSION |
416 | align = ( AlignHCenter|WordBreak|AlignTop); | 416 | align = ( AlignHCenter|WordBreak|AlignTop); |
417 | #else | 417 | #else |
418 | align = ( AlignHCenter|BreakAnywhere|WordBreak|AlignTop); | 418 | align = ( AlignHCenter|BreakAnywhere|WordBreak|AlignTop); |
419 | #endif | 419 | #endif |
420 | 420 | ||
421 | } | 421 | } |
422 | } | 422 | } |
423 | QRect dr; | 423 | QRect dr; |
424 | if ( w + x > parentWidget()->width() ) | 424 | if ( w + x > parentWidget()->width() ) |
425 | w = parentWidget()->width()-x; | 425 | w = parentWidget()->width()-x; |
426 | paint->drawText ( x, yy, w, h, align, mDisplayedText, -1, &dr ); | 426 | paint->drawText ( x, yy, w, h, align, mDisplayedText, -1, &dr ); |
427 | //qDebug("%d %d %d %d ", x, yy, w, h ); | 427 | //qDebug("%d %d %d %d ", x, yy, w, h ); |
428 | if ( mIncidence->cancelled() ){ | 428 | if ( mIncidence->cancelled() ){ |
429 | 429 | ||
430 | 430 | ||
431 | small = ( height() < 20 ); | 431 | small = ( height() < 20 ); |
432 | 432 | ||
433 | if ( ! small ) { | 433 | if ( ! small ) { |
434 | QFontMetrics fm ( paint->font() ); | 434 | QFontMetrics fm ( paint->font() ); |
435 | paint->drawLine(dr.left(), yy+fm.height()/2, dr.right()-2, yy+fm.height()/2); | 435 | paint->drawLine(dr.left(), yy+fm.height()/2, dr.right()-2, yy+fm.height()/2); |
436 | } | 436 | } |
437 | 437 | ||
438 | } | 438 | } |
439 | pa.end(); | 439 | pa.end(); |
440 | 440 | ||
441 | } | 441 | } |
442 | void KOAgendaItem::resizePixmap( int w , int h ) | 442 | void KOAgendaItem::resizePixmap( int w , int h ) |
443 | { | 443 | { |
444 | paintPix()->resize( w, h ); | 444 | paintPix()->resize( w, h ); |
445 | paintPixSel()->resize( w, h ); | 445 | paintPixSel()->resize( w, h ); |
446 | 446 | ||
447 | } | 447 | } |
448 | QPixmap * KOAgendaItem::paintPix() | 448 | QPixmap * KOAgendaItem::paintPix() |
449 | { | 449 | { |
450 | static QPixmap* mPaintPix = 0; | 450 | static QPixmap* mPaintPix = 0; |
451 | if ( ! mPaintPix ) { | 451 | if ( ! mPaintPix ) { |
452 | int w = QApplication::desktop()->width(); | 452 | int w = QApplication::desktop()->width(); |
453 | int h = QApplication::desktop()->height(); | 453 | int h = QApplication::desktop()->height(); |
454 | mPaintPix = new QPixmap(w,h); | 454 | mPaintPix = new QPixmap(w,h); |
455 | } | 455 | } |
456 | return mPaintPix ; | 456 | return mPaintPix ; |
457 | } | 457 | } |
458 | QPixmap * KOAgendaItem::paintPixAllday() | 458 | QPixmap * KOAgendaItem::paintPixAllday() |
459 | { | 459 | { |
460 | static QPixmap* mPaintPixA = 0; | 460 | static QPixmap* mPaintPixA = 0; |
461 | if ( ! mPaintPixA ) { | 461 | if ( ! mPaintPixA ) { |
462 | int w = QApplication::desktop()->width(); | 462 | int w = QApplication::desktop()->width(); |
463 | int h = QApplication::desktop()->height()/3; | 463 | int h = QApplication::desktop()->height()/3; |
464 | mPaintPixA = new QPixmap(w,h); | 464 | mPaintPixA = new QPixmap(w,h); |
465 | } | 465 | } |
466 | return mPaintPixA ; | 466 | return mPaintPixA ; |
467 | } | 467 | } |
468 | QPixmap * KOAgendaItem::paintPixSel() | 468 | QPixmap * KOAgendaItem::paintPixSel() |
469 | { | 469 | { |
470 | static QPixmap* mPaintPixSel = 0; | 470 | static QPixmap* mPaintPixSel = 0; |
471 | if ( ! mPaintPixSel ) { | 471 | if ( ! mPaintPixSel ) { |
472 | int w = QApplication::desktop()->width(); | 472 | int w = QApplication::desktop()->width(); |
473 | int h = QApplication::desktop()->height(); | 473 | int h = QApplication::desktop()->height(); |
474 | mPaintPixSel = new QPixmap(w,h); | 474 | mPaintPixSel = new QPixmap(w,h); |
475 | } | 475 | } |
476 | return mPaintPixSel ; | 476 | return mPaintPixSel ; |
477 | } | 477 | } |
478 | void KOAgendaItem::paintEvent ( QPaintEvent *e ) | 478 | void KOAgendaItem::paintEvent ( QPaintEvent *e ) |
479 | { | 479 | { |
480 | 480 | ||
481 | if ( globalFlagBlockAgendaItemPaint ) | 481 | if ( globalFlagBlockAgendaItemPaint ) |
482 | return; | 482 | return; |
483 | if ( globalFlagBlockAgenda > 0 && globalFlagBlockAgenda < 5 ) | 483 | if ( globalFlagBlockAgenda > 0 && globalFlagBlockAgenda < 5 ) |
484 | return; | 484 | return; |
485 | int yy; | 485 | int yy; |
486 | if ( mAllDay ) | 486 | if ( mAllDay ) |
487 | yy = y(); | 487 | yy = y(); |
488 | else | 488 | else |
489 | yy = mCellYTop * ( height() / cellHeight() ); | 489 | yy = mCellYTop * ( height() / cellHeight() ); |
490 | int xx = x(); | 490 | int xx = x(); |
491 | 491 | ||
492 | if ( xPaintCoord != xx || yPaintCoord != yy || | 492 | if ( xPaintCoord != xx || yPaintCoord != yy || |
493 | wPaintCoord != width() || hPaintCoord != height()) { | 493 | wPaintCoord != width() || hPaintCoord != height()) { |
494 | xPaintCoord= xx; | 494 | xPaintCoord= xx; |
495 | yPaintCoord = yy; | 495 | yPaintCoord = yy; |
496 | wPaintCoord = width(); | 496 | wPaintCoord = width(); |
497 | hPaintCoord = height(); | 497 | hPaintCoord = height(); |
498 | globalFlagBlockAgendaItemUpdate = 0; | 498 | globalFlagBlockAgendaItemUpdate = 0; |
499 | paintMe( mSelected ); | 499 | paintMe( mSelected ); |
500 | //qDebug("calling paintMe "); | 500 | //qDebug("calling paintMe "); |
501 | globalFlagBlockAgendaItemUpdate = 1; | 501 | globalFlagBlockAgendaItemUpdate = 1; |
502 | } | 502 | } |
503 | int rx, ry, rw, rh; | 503 | int rx, ry, rw, rh; |
504 | rx = e->rect().x(); | 504 | rx = e->rect().x(); |
505 | ry = e->rect().y(); | 505 | ry = e->rect().y(); |
506 | rw = e->rect().width(); | 506 | rw = e->rect().width(); |
507 | rh = e->rect().height(); | 507 | rh = e->rect().height(); |
508 | //qDebug(" paintevent %s %d %d %d %d", mIncidence->summary().latin1(), x(), yy, width(), height()); | 508 | //qDebug(" paintevent %s %d %d %d %d", mIncidence->summary().latin1(), x(), yy, width(), height()); |
509 | 509 | ||
510 | QPixmap* paintFrom ; | 510 | QPixmap* paintFrom ; |
511 | if ( mSelected ) { | 511 | if ( mSelected ) { |
512 | paintFrom = paintPixSel(); | 512 | paintFrom = paintPixSel(); |
513 | } else { | 513 | } else { |
514 | if ( mAllDay ) | 514 | if ( mAllDay ) |
515 | paintFrom = paintPixAllday(); | 515 | paintFrom = paintPixAllday(); |
516 | else | 516 | else |
517 | paintFrom = paintPix(); | 517 | paintFrom = paintPix(); |
518 | } | 518 | } |
519 | xx += rx; | 519 | xx += rx; |
520 | 520 | ||
521 | if ( xx < 0 ) { | 521 | if ( xx < 0 ) { |
522 | rw = rw + xx; | 522 | rw = rw + xx; |
523 | rx -= xx; | 523 | rx -= xx; |
524 | xx = 0; | 524 | xx = 0; |
525 | if ( rw <= 1 ) { | 525 | if ( rw <= 1 ) { |
526 | //qDebug("KOAgendaItem::Width1 <= 1 (%d). Returning. %s",rw,mDisplayedText.latin1()); | 526 | //qDebug("KOAgendaItem::Width1 <= 1 (%d). Returning. %s",rw,mDisplayedText.latin1()); |
527 | return; | 527 | return; |
528 | } | 528 | } |
529 | } | 529 | } |
530 | if ( paintFrom->width() < xx+rw ) { | 530 | if ( paintFrom->width() < xx+rw ) { |
531 | rw = paintFrom->width() - xx; | 531 | rw = paintFrom->width() - xx; |
532 | if ( rw <= 1 ) { | 532 | if ( rw <= 1 ) { |
533 | //qDebug("KOAgendaItem::Width2 <= 1 (%d). Returning.%s ",rw,mDisplayedText.latin1() ); | 533 | //qDebug("KOAgendaItem::Width2 <= 1 (%d). Returning.%s ",rw,mDisplayedText.latin1() ); |
534 | return; | 534 | return; |
535 | } | 535 | } |
536 | } | 536 | } |
537 | //qDebug("%d %d %d %d %d %d %d",rx, ry, paintFrom, xx ,yPaintCoord+ry, rw, rh); | 537 | //qDebug("%d %d %d %d %d %d %d",rx, ry, paintFrom, xx ,yPaintCoord+ry, rw, rh); |
538 | bitBlt (this, rx, ry, paintFrom, xx ,yPaintCoord+ry, rw, rh ,CopyROP); | 538 | bitBlt (this, rx, ry, paintFrom, xx ,yPaintCoord+ry, rw, rh ,CopyROP); |
539 | } | 539 | } |
540 | void KOAgendaItem::computeText() | 540 | void KOAgendaItem::computeText() |
541 | { | 541 | { |
542 | mDisplayedText = mIncidence->summary(); | 542 | mDisplayedText = mIncidence->summary(); |
543 | if ( (mIncidence->type() == "Todo") ) { | 543 | if ( (mIncidence->typeID() == todoID ) ) { |
544 | if ( static_cast<Todo*>(mIncidence)->hasDueDate() ) { | 544 | if ( static_cast<Todo*>(mIncidence)->hasDueDate() ) { |
545 | if ( static_cast<Todo*>(mIncidence)->dtDue().date() < QDate::currentDate() ) | 545 | if ( static_cast<Todo*>(mIncidence)->dtDue().date() < QDate::currentDate() ) |
546 | mDisplayedText += i18n(" (") +KGlobal::locale()->formatDate((static_cast<Todo*>(mIncidence))->dtDue().date(), true)+")"; | 546 | mDisplayedText += i18n(" (") +KGlobal::locale()->formatDate((static_cast<Todo*>(mIncidence))->dtDue().date(), true)+")"; |
547 | else if ( !(mIncidence->doesFloat())) | 547 | else if ( !(mIncidence->doesFloat())) |
548 | mDisplayedText += i18n(" (") +KGlobal::locale()->formatTime((static_cast<Todo*>(mIncidence))->dtDue().time())+")"; | 548 | mDisplayedText += i18n(" (") +KGlobal::locale()->formatTime((static_cast<Todo*>(mIncidence))->dtDue().time())+")"; |
549 | } | 549 | } |
550 | } else { | 550 | } else { |
551 | if ( !(mIncidence->doesFloat()) && KOPrefs::instance()->mShowTimeInAgenda) | 551 | if ( !(mIncidence->doesFloat()) && KOPrefs::instance()->mShowTimeInAgenda) |
552 | mDisplayedText += ": " +KGlobal::locale()->formatTime((static_cast<Event*>(mIncidence))->dtStart().time()) + " - " + KGlobal::locale()->formatTime((static_cast<Event*>(mIncidence))->dtEnd().time()) ; | 552 | mDisplayedText += ": " +KGlobal::locale()->formatTime((static_cast<Event*>(mIncidence))->dtStart().time()) + " - " + KGlobal::locale()->formatTime((static_cast<Event*>(mIncidence))->dtEnd().time()) ; |
553 | 553 | ||
554 | if ( mAllDay ) { | 554 | if ( mAllDay ) { |
555 | if ( mIncidence->dtStart().date().addDays(3) < mIncidence->dtEnd().date() ) { | 555 | if ( mIncidence->dtStart().date().addDays(3) < mIncidence->dtEnd().date() ) { |
556 | if ( mIncidence->doesRecur() ) { | 556 | if ( mIncidence->doesRecur() ) { |
557 | mDisplayedText += " (" + mIncidence->recurrence()->recurrenceText() + ")"; | 557 | mDisplayedText += " (" + mIncidence->recurrence()->recurrenceText() + ")"; |
558 | } else { | 558 | } else { |
559 | mDisplayedText += ": " +KGlobal::locale()->formatDate((static_cast<Event*>(mIncidence))->dtStart().date(), true) + " - " + KGlobal::locale()->formatDate((static_cast<Event*>(mIncidence))->dtEnd().date(), true) ; | 559 | mDisplayedText += ": " +KGlobal::locale()->formatDate((static_cast<Event*>(mIncidence))->dtStart().date(), true) + " - " + KGlobal::locale()->formatDate((static_cast<Event*>(mIncidence))->dtEnd().date(), true) ; |
560 | } | 560 | } |
561 | } | 561 | } |
562 | } | 562 | } |
563 | } | 563 | } |
564 | 564 | ||
565 | if ( !mIncidence->location().isEmpty() ) { | 565 | if ( !mIncidence->location().isEmpty() ) { |
566 | if ( mAllDay ) | 566 | if ( mAllDay ) |
567 | mDisplayedText += " ("; | 567 | mDisplayedText += " ("; |
568 | else | 568 | else |
569 | mDisplayedText += "\n("; | 569 | mDisplayedText += "\n("; |
570 | mDisplayedText += mIncidence->location() +")"; | 570 | mDisplayedText += mIncidence->location() +")"; |
571 | } | 571 | } |
572 | #ifdef DESKTOP_VERSION | 572 | #ifdef DESKTOP_VERSION |
573 | QString tipText = mIncidence->summary(); | 573 | QString tipText = mIncidence->summary(); |
574 | if ( !mIncidence->doesFloat() ) { | 574 | if ( !mIncidence->doesFloat() ) { |
575 | if ( mIncidence->type() == "Event" ) { | 575 | if ( mIncidence->typeID() == eventID ) { |
576 | if ( (static_cast<Event*>(mIncidence))->isMultiDay() ) { | 576 | if ( (static_cast<Event*>(mIncidence))->isMultiDay() ) { |
577 | tipText += "\n"+i18n("From: ")+mIncidence->dtStartStr(); | 577 | tipText += "\n"+i18n("From: ")+mIncidence->dtStartStr(); |
578 | tipText += "\n"+i18n("To: ")+(static_cast<Event*>(mIncidence))->dtEndStr(); | 578 | tipText += "\n"+i18n("To: ")+(static_cast<Event*>(mIncidence))->dtEndStr(); |
579 | } | 579 | } |
580 | else { | 580 | else { |
581 | tipText += "\n"+i18n("Time: ")+mIncidence->dtStartTimeStr(); | 581 | tipText += "\n"+i18n("Time: ")+mIncidence->dtStartTimeStr(); |
582 | tipText += " - "+(static_cast<Event*>(mIncidence))->dtEndTimeStr(); | 582 | tipText += " - "+(static_cast<Event*>(mIncidence))->dtEndTimeStr(); |
583 | } | 583 | } |
584 | } | 584 | } |
585 | else if ( mIncidence->type() == "Todo" ) { | 585 | else if ( mIncidence->typeID() == todoID ) { |
586 | if (mIncidence->hasStartDate()) | 586 | if (mIncidence->hasStartDate()) |
587 | tipText += "\n"+i18n("Start: ")+ (static_cast<Todo*>(mIncidence))->dtStartStr(); | 587 | tipText += "\n"+i18n("Start: ")+ (static_cast<Todo*>(mIncidence))->dtStartStr(); |
588 | if (((Todo*)mIncidence)->hasDueDate()) | 588 | if (((Todo*)mIncidence)->hasDueDate()) |
589 | tipText += "\n"+i18n("Due: ")+ (static_cast<Todo*>(mIncidence))->dtDueStr(); | 589 | tipText += "\n"+i18n("Due: ")+ (static_cast<Todo*>(mIncidence))->dtDueStr(); |
590 | } | 590 | } |
591 | } else if ( mIncidence->type() == "Todo" ) { | 591 | } else if ( mIncidence->typeID() == todoID ) { |
592 | if (mIncidence->hasStartDate()) | 592 | if (mIncidence->hasStartDate()) |
593 | tipText += "\n"+i18n("Start: ")+ (static_cast<Todo*>(mIncidence))->dtStartDateStr(); | 593 | tipText += "\n"+i18n("Start: ")+ (static_cast<Todo*>(mIncidence))->dtStartDateStr(); |
594 | if (((Todo*)mIncidence)->hasDueDate()) | 594 | if (((Todo*)mIncidence)->hasDueDate()) |
595 | tipText += "\n"+i18n("Due: ")+ (static_cast<Todo*>(mIncidence))->dtDueDateStr(); | 595 | tipText += "\n"+i18n("Due: ")+ (static_cast<Todo*>(mIncidence))->dtDueDateStr(); |
596 | } | 596 | } |
597 | 597 | ||
598 | if (!mIncidence->location().isEmpty()) { | 598 | if (!mIncidence->location().isEmpty()) { |
599 | tipText += "\n"+i18n("Location: ")+mIncidence->location(); | 599 | tipText += "\n"+i18n("Location: ")+mIncidence->location(); |
600 | } | 600 | } |
601 | QToolTip::add(this,tipText,toolTipGroup(),""); | 601 | QToolTip::add(this,tipText,toolTipGroup(),""); |
602 | #endif | 602 | #endif |
603 | } | 603 | } |
604 | void KOAgendaItem::updateItem() | 604 | void KOAgendaItem::updateItem() |
605 | { | 605 | { |
606 | computeText(); | 606 | computeText(); |
607 | 607 | ||
608 | //qDebug("KOAgendaItem:: updateItem() %s %d %d ",incidence()->summary().latin1(), x(), y()); | 608 | //qDebug("KOAgendaItem:: updateItem() %s %d %d ",incidence()->summary().latin1(), x(), y()); |
609 | paintMe( mSelected ); | 609 | paintMe( mSelected ); |
610 | repaint( false); | 610 | repaint( false); |
611 | } | 611 | } |
612 | 612 | ||
613 | void KOAgendaItem::resizeEvent ( QResizeEvent *ev ) | 613 | void KOAgendaItem::resizeEvent ( QResizeEvent *ev ) |
614 | { | 614 | { |
615 | //qDebug("KOAgendaItem::resizeEvent %s ", mIncidence->summary().latin1()); | 615 | //qDebug("KOAgendaItem::resizeEvent %s ", mIncidence->summary().latin1()); |
616 | paintMe( mSelected ); | 616 | paintMe( mSelected ); |
617 | repaint( false ); | 617 | repaint( false ); |
618 | } | 618 | } |
619 | 619 | ||
620 | /* | 620 | /* |
621 | Return height of item in units of agenda cells | 621 | Return height of item in units of agenda cells |
622 | */ | 622 | */ |
623 | int KOAgendaItem::cellHeight() | 623 | int KOAgendaItem::cellHeight() |
624 | { | 624 | { |
625 | int ret = mCellYBottom - mCellYTop + 1; | 625 | int ret = mCellYBottom - mCellYTop + 1; |
626 | if ( ret <= 0 ) { | 626 | if ( ret <= 0 ) { |
627 | ret = 1; | 627 | ret = 1; |
628 | mCellYBottom = 0; | 628 | mCellYBottom = 0; |
629 | mCellYTop = 0; | 629 | mCellYTop = 0; |
630 | } | 630 | } |
631 | return ret; | 631 | return ret; |
632 | } | 632 | } |
633 | 633 | ||
634 | /* | 634 | /* |
635 | Return height of item in units of agenda cells | 635 | Return height of item in units of agenda cells |
636 | */ | 636 | */ |
637 | int KOAgendaItem::cellWidth() | 637 | int KOAgendaItem::cellWidth() |
638 | { | 638 | { |
639 | return mCellXWidth - mCellX + 1; | 639 | return mCellXWidth - mCellX + 1; |
640 | } | 640 | } |
641 | 641 | ||
642 | void KOAgendaItem::setItemDate(QDate qd) | 642 | void KOAgendaItem::setItemDate(QDate qd) |
643 | { | 643 | { |
644 | mDate = qd; | 644 | mDate = qd; |
645 | } | 645 | } |
646 | 646 | ||
647 | void KOAgendaItem::setCellXY(int X, int YTop, int YBottom) | 647 | void KOAgendaItem::setCellXY(int X, int YTop, int YBottom) |
648 | { | 648 | { |
649 | mCellX = X; | 649 | mCellX = X; |
650 | mCellYTop = YTop; | 650 | mCellYTop = YTop; |
651 | mCellYBottom = YBottom; | 651 | mCellYBottom = YBottom; |
652 | } | 652 | } |
653 | 653 | ||
654 | void KOAgendaItem::setCellXWidth(int xwidth) | 654 | void KOAgendaItem::setCellXWidth(int xwidth) |
655 | { | 655 | { |
656 | mCellXWidth = xwidth; | 656 | mCellXWidth = xwidth; |
657 | } | 657 | } |
658 | 658 | ||
659 | void KOAgendaItem::setCellX(int XLeft, int XRight) | 659 | void KOAgendaItem::setCellX(int XLeft, int XRight) |
660 | { | 660 | { |
661 | mCellX = XLeft; | 661 | mCellX = XLeft; |
662 | mCellXWidth = XRight; | 662 | mCellXWidth = XRight; |
663 | } | 663 | } |
664 | 664 | ||
665 | void KOAgendaItem::setCellY(int YTop, int YBottom) | 665 | void KOAgendaItem::setCellY(int YTop, int YBottom) |
666 | { | 666 | { |
667 | mCellYTop = YTop; | 667 | mCellYTop = YTop; |
668 | mCellYBottom = YBottom; | 668 | mCellYBottom = YBottom; |
669 | } | 669 | } |
670 | 670 | ||
671 | void KOAgendaItem::setSubCell(int subCell) | 671 | void KOAgendaItem::setSubCell(int subCell) |
672 | { | 672 | { |
673 | mSubCell = subCell; | 673 | mSubCell = subCell; |
674 | } | 674 | } |
675 | 675 | ||
676 | void KOAgendaItem::setSubCells(int subCells) | 676 | void KOAgendaItem::setSubCells(int subCells) |
677 | { | 677 | { |
678 | mSubCells = subCells; | 678 | mSubCells = subCells; |
679 | } | 679 | } |
680 | 680 | ||
681 | void KOAgendaItem::setMultiItem(KOAgendaItem *first,KOAgendaItem *next, | 681 | void KOAgendaItem::setMultiItem(KOAgendaItem *first,KOAgendaItem *next, |
682 | KOAgendaItem *last) | 682 | KOAgendaItem *last) |
683 | { | 683 | { |
684 | mFirstMultiItem = first; | 684 | mFirstMultiItem = first; |
685 | mNextMultiItem = next; | 685 | mNextMultiItem = next; |
686 | mLastMultiItem = last; | 686 | mLastMultiItem = last; |
687 | } | 687 | } |
688 | 688 | ||
689 | void KOAgendaItem::startMove() | 689 | void KOAgendaItem::startMove() |
690 | { | 690 | { |
691 | mStartCellX = mCellX; | 691 | mStartCellX = mCellX; |
692 | mStartCellXWidth = mCellXWidth; | 692 | mStartCellXWidth = mCellXWidth; |
693 | mStartCellYTop = mCellYTop; | 693 | mStartCellYTop = mCellYTop; |
694 | mStartCellYBottom = mCellYBottom; | 694 | mStartCellYBottom = mCellYBottom; |
695 | } | 695 | } |
696 | 696 | ||
697 | void KOAgendaItem::resetMove() | 697 | void KOAgendaItem::resetMove() |
698 | { | 698 | { |
699 | mCellX = mStartCellX; | 699 | mCellX = mStartCellX; |
700 | mCellXWidth = mStartCellXWidth; | 700 | mCellXWidth = mStartCellXWidth; |
701 | mCellYTop = mStartCellYTop; | 701 | mCellYTop = mStartCellYTop; |
702 | mCellYBottom = mStartCellYBottom; | 702 | mCellYBottom = mStartCellYBottom; |
703 | } | 703 | } |
704 | 704 | ||
705 | void KOAgendaItem::moveRelative(int dx, int dy) | 705 | void KOAgendaItem::moveRelative(int dx, int dy) |
706 | { | 706 | { |
707 | int newX = cellX() + dx; | 707 | int newX = cellX() + dx; |
708 | int newXWidth = cellXWidth() + dx; | 708 | int newXWidth = cellXWidth() + dx; |
709 | int newYTop = cellYTop() + dy; | 709 | int newYTop = cellYTop() + dy; |
710 | int newYBottom = cellYBottom() + dy; | 710 | int newYBottom = cellYBottom() + dy; |
711 | setCellXY(newX,newYTop,newYBottom); | 711 | setCellXY(newX,newYTop,newYBottom); |
712 | setCellXWidth(newXWidth); | 712 | setCellXWidth(newXWidth); |
713 | } | 713 | } |
714 | 714 | ||
715 | void KOAgendaItem::expandTop(int dy) | 715 | void KOAgendaItem::expandTop(int dy) |
716 | { | 716 | { |
717 | int newYTop = cellYTop() + dy; | 717 | int newYTop = cellYTop() + dy; |
718 | int newYBottom = cellYBottom(); | 718 | int newYBottom = cellYBottom(); |
719 | if (newYTop > newYBottom) newYTop = newYBottom; | 719 | if (newYTop > newYBottom) newYTop = newYBottom; |
diff --git a/korganizer/kolistview.cpp b/korganizer/kolistview.cpp index 7022e02..be51694 100644 --- a/korganizer/kolistview.cpp +++ b/korganizer/kolistview.cpp | |||
@@ -275,526 +275,526 @@ KOListView::KOListView(Calendar *calendar, QWidget *parent, | |||
275 | mListView->setFont ( KOPrefs::instance()->mListViewFont ); | 275 | mListView->setFont ( KOPrefs::instance()->mListViewFont ); |
276 | mPopupMenu = eventPopup(); | 276 | mPopupMenu = eventPopup(); |
277 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), | 277 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), |
278 | i18n("Select all"),this, | 278 | i18n("Select all"),this, |
279 | SLOT(allSelection()),true); | 279 | SLOT(allSelection()),true); |
280 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), | 280 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), |
281 | i18n("Deselect all"),this, | 281 | i18n("Deselect all"),this, |
282 | SLOT(clearSelection()),true); | 282 | SLOT(clearSelection()),true); |
283 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), | 283 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), |
284 | i18n("Delete all selected"),this, | 284 | i18n("Delete all selected"),this, |
285 | SLOT(deleteAll()),true); | 285 | SLOT(deleteAll()),true); |
286 | #ifdef DESKTOP_VERSION | 286 | #ifdef DESKTOP_VERSION |
287 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), | 287 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), |
288 | i18n("Hide all selected"),this, | 288 | i18n("Hide all selected"),this, |
289 | SLOT(hideAll()),true); | 289 | SLOT(hideAll()),true); |
290 | #endif | 290 | #endif |
291 | mPopupMenu->insertSeparator(); | 291 | mPopupMenu->insertSeparator(); |
292 | #ifdef DESKTOP_VERSION | 292 | #ifdef DESKTOP_VERSION |
293 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), | 293 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), |
294 | i18n("Print complete list"),this, | 294 | i18n("Print complete list"),this, |
295 | SLOT(printList()),true); | 295 | SLOT(printList()),true); |
296 | mPopupMenu->insertSeparator(); | 296 | mPopupMenu->insertSeparator(); |
297 | #endif | 297 | #endif |
298 | QPopupMenu * exportPO = new QPopupMenu ( this ); | 298 | QPopupMenu * exportPO = new QPopupMenu ( this ); |
299 | mPopupMenu->insertItem( i18n("Export selected"), exportPO ); | 299 | mPopupMenu->insertItem( i18n("Export selected"), exportPO ); |
300 | exportPO->insertItem( i18n("As iCal (ics) file..."),this, | 300 | exportPO->insertItem( i18n("As iCal (ics) file..."),this, |
301 | SLOT(saveToFile())); | 301 | SLOT(saveToFile())); |
302 | exportPO->insertItem( i18n("As vCal (vcs) file..."),this, | 302 | exportPO->insertItem( i18n("As vCal (vcs) file..."),this, |
303 | SLOT(saveToFileVCS())); | 303 | SLOT(saveToFileVCS())); |
304 | exportPO->insertItem( i18n("Journal/Details..."),this, | 304 | exportPO->insertItem( i18n("Journal/Details..."),this, |
305 | SLOT(saveDescriptionToFile())); | 305 | SLOT(saveDescriptionToFile())); |
306 | // mPopupMenu->insertSeparator(); | 306 | // mPopupMenu->insertSeparator(); |
307 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), | 307 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), |
308 | i18n("Add Categ. to selected..."),this, | 308 | i18n("Add Categ. to selected..."),this, |
309 | SLOT(addCat()),true); | 309 | SLOT(addCat()),true); |
310 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), | 310 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), |
311 | i18n("Set Categ. for selected..."),this, | 311 | i18n("Set Categ. for selected..."),this, |
312 | SLOT(setCat()),true); | 312 | SLOT(setCat()),true); |
313 | //mPopupMenu->insertSeparator(); | 313 | //mPopupMenu->insertSeparator(); |
314 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), | 314 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), |
315 | i18n("Set alarm for selected..."),this, | 315 | i18n("Set alarm for selected..."),this, |
316 | SLOT(setAlarm()),true); | 316 | SLOT(setAlarm()),true); |
317 | 317 | ||
318 | 318 | ||
319 | #ifndef DESKTOP_VERSION | 319 | #ifndef DESKTOP_VERSION |
320 | mPopupMenu->insertSeparator(); | 320 | mPopupMenu->insertSeparator(); |
321 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), | 321 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), |
322 | i18n("Beam selected via IR"),this, | 322 | i18n("Beam selected via IR"),this, |
323 | SLOT(beamSelected()),true); | 323 | SLOT(beamSelected()),true); |
324 | #endif | 324 | #endif |
325 | /* | 325 | /* |
326 | mPopupMenu = new QPopupMenu; | 326 | mPopupMenu = new QPopupMenu; |
327 | mPopupMenu->insertItem(i18n("Edit Event"), this, | 327 | mPopupMenu->insertItem(i18n("Edit Event"), this, |
328 | SLOT (editEvent())); | 328 | SLOT (editEvent())); |
329 | mPopupMenu->insertItem(SmallIcon("delete"), i18n("Delete Event"), this, | 329 | mPopupMenu->insertItem(SmallIcon("delete"), i18n("Delete Event"), this, |
330 | SLOT (deleteEvent())); | 330 | SLOT (deleteEvent())); |
331 | mPopupMenu->insertSeparator(); | 331 | mPopupMenu->insertSeparator(); |
332 | mPopupMenu->insertItem(i18n("Show Dates"), this, | 332 | mPopupMenu->insertItem(i18n("Show Dates"), this, |
333 | SLOT(showDates())); | 333 | SLOT(showDates())); |
334 | mPopupMenu->insertItem(i18n("Hide Dates"), this, | 334 | mPopupMenu->insertItem(i18n("Hide Dates"), this, |
335 | SLOT(hideDates())); | 335 | SLOT(hideDates())); |
336 | */ | 336 | */ |
337 | QObject::connect(mListView,SIGNAL( newEvent()), | 337 | QObject::connect(mListView,SIGNAL( newEvent()), |
338 | this,SIGNAL(signalNewEvent())); | 338 | this,SIGNAL(signalNewEvent())); |
339 | QObject::connect(mListView,SIGNAL(doubleClicked(QListViewItem *)), | 339 | QObject::connect(mListView,SIGNAL(doubleClicked(QListViewItem *)), |
340 | this,SLOT(defaultItemAction(QListViewItem *))); | 340 | this,SLOT(defaultItemAction(QListViewItem *))); |
341 | QObject::connect(mListView,SIGNAL(rightButtonPressed( QListViewItem *, | 341 | QObject::connect(mListView,SIGNAL(rightButtonPressed( QListViewItem *, |
342 | const QPoint &, int )), | 342 | const QPoint &, int )), |
343 | this,SLOT(popupMenu(QListViewItem *,const QPoint &,int))); | 343 | this,SLOT(popupMenu(QListViewItem *,const QPoint &,int))); |
344 | QObject::connect(mListView,SIGNAL(currentChanged(QListViewItem *)), | 344 | QObject::connect(mListView,SIGNAL(currentChanged(QListViewItem *)), |
345 | SLOT(processSelectionChange(QListViewItem *))); | 345 | SLOT(processSelectionChange(QListViewItem *))); |
346 | QObject::connect(mListView,SIGNAL(showIncidence(Incidence *)), | 346 | QObject::connect(mListView,SIGNAL(showIncidence(Incidence *)), |
347 | SIGNAL(showIncidenceSignal(Incidence *)) ); | 347 | SIGNAL(showIncidenceSignal(Incidence *)) ); |
348 | 348 | ||
349 | readSettings(KOGlobals::config(),"KOListView Layout"); | 349 | readSettings(KOGlobals::config(),"KOListView Layout"); |
350 | } | 350 | } |
351 | 351 | ||
352 | KOListView::~KOListView() | 352 | KOListView::~KOListView() |
353 | { | 353 | { |
354 | delete mPopupMenu; | 354 | delete mPopupMenu; |
355 | #if QT_VERSION >= 0x030000 | 355 | #if QT_VERSION >= 0x030000 |
356 | 356 | ||
357 | #else | 357 | #else |
358 | delete mKOListViewWhatsThis; | 358 | delete mKOListViewWhatsThis; |
359 | #endif | 359 | #endif |
360 | } | 360 | } |
361 | 361 | ||
362 | QString KOListView::getWhatsThisText(QPoint p) | 362 | QString KOListView::getWhatsThisText(QPoint p) |
363 | { | 363 | { |
364 | KOListViewItem* item = ( KOListViewItem* ) mListView->itemAt( p ); | 364 | KOListViewItem* item = ( KOListViewItem* ) mListView->itemAt( p ); |
365 | if ( item ) | 365 | if ( item ) |
366 | return KIncidenceFormatter::instance()->getFormattedText( item->data(), | 366 | return KIncidenceFormatter::instance()->getFormattedText( item->data(), |
367 | KOPrefs::instance()->mWTshowDetails, | 367 | KOPrefs::instance()->mWTshowDetails, |
368 | KOPrefs::instance()->mWTshowCreated, | 368 | KOPrefs::instance()->mWTshowCreated, |
369 | KOPrefs::instance()->mWTshowChanged); | 369 | KOPrefs::instance()->mWTshowChanged); |
370 | return i18n("That is the list view" ); | 370 | return i18n("That is the list view" ); |
371 | 371 | ||
372 | } | 372 | } |
373 | 373 | ||
374 | void KOListView::updateList() | 374 | void KOListView::updateList() |
375 | { | 375 | { |
376 | // qDebug(" KOListView::updateList() "); | 376 | // qDebug(" KOListView::updateList() "); |
377 | 377 | ||
378 | } | 378 | } |
379 | 379 | ||
380 | void KOListView::clearList() | 380 | void KOListView::clearList() |
381 | { | 381 | { |
382 | clear (); | 382 | clear (); |
383 | } | 383 | } |
384 | void KOListView::addCat( ) | 384 | void KOListView::addCat( ) |
385 | { | 385 | { |
386 | setCategories( false ); | 386 | setCategories( false ); |
387 | } | 387 | } |
388 | void KOListView::setCat() | 388 | void KOListView::setCat() |
389 | { | 389 | { |
390 | setCategories( true ); | 390 | setCategories( true ); |
391 | } | 391 | } |
392 | void KOListView::setAlarm() | 392 | void KOListView::setAlarm() |
393 | { | 393 | { |
394 | KOAlarmPrefs kap( this); | 394 | KOAlarmPrefs kap( this); |
395 | if ( !kap.exec() ) | 395 | if ( !kap.exec() ) |
396 | return; | 396 | return; |
397 | QStringList itemList; | 397 | QStringList itemList; |
398 | QPtrList<KOListViewItem> sel ; | 398 | QPtrList<KOListViewItem> sel ; |
399 | QListViewItem *qitem = mListView->firstChild (); | 399 | QListViewItem *qitem = mListView->firstChild (); |
400 | while ( qitem ) { | 400 | while ( qitem ) { |
401 | if ( qitem->isSelected() ) { | 401 | if ( qitem->isSelected() ) { |
402 | Incidence* inc = ((KOListViewItem *) qitem)->data(); | 402 | Incidence* inc = ((KOListViewItem *) qitem)->data(); |
403 | if ( inc->type() != "Journal" ) { | 403 | if ( inc->typeID() != journalID ) { |
404 | if ( inc->type() == "Todo" ) { | 404 | if ( inc->typeID() == todoID ) { |
405 | if ( ((Todo*)inc)->hasDueDate() ) | 405 | if ( ((Todo*)inc)->hasDueDate() ) |
406 | sel.append(((KOListViewItem *)qitem)); | 406 | sel.append(((KOListViewItem *)qitem)); |
407 | } else | 407 | } else |
408 | sel.append(((KOListViewItem *)qitem)); | 408 | sel.append(((KOListViewItem *)qitem)); |
409 | } | 409 | } |
410 | } | 410 | } |
411 | qitem = qitem->nextSibling(); | 411 | qitem = qitem->nextSibling(); |
412 | } | 412 | } |
413 | int count = 0; | 413 | int count = 0; |
414 | KOListViewItem * item, *temp; | 414 | KOListViewItem * item, *temp; |
415 | item = sel.first(); | 415 | item = sel.first(); |
416 | Incidence* inc; | 416 | Incidence* inc; |
417 | while ( item ) { | 417 | while ( item ) { |
418 | inc = item->data(); | 418 | inc = item->data(); |
419 | ++count; | 419 | ++count; |
420 | if (kap.mAlarmButton->isChecked()) { | 420 | if (kap.mAlarmButton->isChecked()) { |
421 | if (inc->alarms().count() == 0) | 421 | if (inc->alarms().count() == 0) |
422 | inc->newAlarm(); | 422 | inc->newAlarm(); |
423 | QPtrList<Alarm> alarms = inc->alarms(); | 423 | QPtrList<Alarm> alarms = inc->alarms(); |
424 | Alarm *alarm; | 424 | Alarm *alarm; |
425 | for (alarm = alarms.first(); alarm; alarm = alarms.next() ) { | 425 | for (alarm = alarms.first(); alarm; alarm = alarms.next() ) { |
426 | alarm->setEnabled(true); | 426 | alarm->setEnabled(true); |
427 | int j = kap.mAlarmTimeEdit->value()* -60; | 427 | int j = kap.mAlarmTimeEdit->value()* -60; |
428 | if (kap.mAlarmIncrCombo->currentItem() == 1) | 428 | if (kap.mAlarmIncrCombo->currentItem() == 1) |
429 | j = j * 60; | 429 | j = j * 60; |
430 | else if (kap.mAlarmIncrCombo->currentItem() == 2) | 430 | else if (kap.mAlarmIncrCombo->currentItem() == 2) |
431 | j = j * (60 * 24); | 431 | j = j * (60 * 24); |
432 | alarm->setStartOffset( j ); | 432 | alarm->setStartOffset( j ); |
433 | 433 | ||
434 | if (!kap.mAlarmProgram.isEmpty() && kap.mAlarmProgramButton->isOn()) { | 434 | if (!kap.mAlarmProgram.isEmpty() && kap.mAlarmProgramButton->isOn()) { |
435 | alarm->setProcedureAlarm(kap.mAlarmProgram); | 435 | alarm->setProcedureAlarm(kap.mAlarmProgram); |
436 | } | 436 | } |
437 | else if (!kap.mAlarmSound.isEmpty() && kap.mAlarmSoundButton->isOn()) | 437 | else if (!kap.mAlarmSound.isEmpty() && kap.mAlarmSoundButton->isOn()) |
438 | alarm->setAudioAlarm(kap.mAlarmSound); | 438 | alarm->setAudioAlarm(kap.mAlarmSound); |
439 | else | 439 | else |
440 | alarm->setType(Alarm::Invalid); | 440 | alarm->setType(Alarm::Invalid); |
441 | //alarm->setAudioAlarm("default"); | 441 | //alarm->setAudioAlarm("default"); |
442 | // TODO: Deal with multiple alarms | 442 | // TODO: Deal with multiple alarms |
443 | break; // For now, stop after the first alarm | 443 | break; // For now, stop after the first alarm |
444 | } | 444 | } |
445 | } else { | 445 | } else { |
446 | Alarm* alarm = inc->alarms().first(); | 446 | Alarm* alarm = inc->alarms().first(); |
447 | if ( alarm ) { | 447 | if ( alarm ) { |
448 | alarm->setEnabled(false); | 448 | alarm->setEnabled(false); |
449 | alarm->setType(Alarm::Invalid); | 449 | alarm->setType(Alarm::Invalid); |
450 | } | 450 | } |
451 | } | 451 | } |
452 | ListItemVisitor v(item, mStartDate ); | 452 | ListItemVisitor v(item, mStartDate ); |
453 | inc->accept(v); | 453 | inc->accept(v); |
454 | item = sel.next(); | 454 | item = sel.next(); |
455 | } | 455 | } |
456 | topLevelWidget()->setCaption( i18n("Changed alarm for %1 items").arg( count ) ); | 456 | topLevelWidget()->setCaption( i18n("Changed alarm for %1 items").arg( count ) ); |
457 | qDebug("KO: Set alarm for %d items", count); | 457 | qDebug("KO: Set alarm for %d items", count); |
458 | calendar()->reInitAlarmSettings(); | 458 | calendar()->reInitAlarmSettings(); |
459 | QTimer::singleShot( 1, this, SLOT ( resetFocus() ) ); | 459 | QTimer::singleShot( 1, this, SLOT ( resetFocus() ) ); |
460 | } | 460 | } |
461 | void KOListView::setCategories( bool removeOld ) | 461 | void KOListView::setCategories( bool removeOld ) |
462 | { | 462 | { |
463 | 463 | ||
464 | KPIM::CategorySelectDialog* csd = new KPIM::CategorySelectDialog( KOPrefs::instance(), 0 ); | 464 | KPIM::CategorySelectDialog* csd = new KPIM::CategorySelectDialog( KOPrefs::instance(), 0 ); |
465 | csd->setColorEnabled(); | 465 | csd->setColorEnabled(); |
466 | if (! csd->exec()) { | 466 | if (! csd->exec()) { |
467 | delete csd; | 467 | delete csd; |
468 | return; | 468 | return; |
469 | } | 469 | } |
470 | QStringList catList = csd->selectedCategories(); | 470 | QStringList catList = csd->selectedCategories(); |
471 | delete csd; | 471 | delete csd; |
472 | // if ( catList.count() == 0 ) | 472 | // if ( catList.count() == 0 ) |
473 | // return; | 473 | // return; |
474 | //catList.sort(); | 474 | //catList.sort(); |
475 | QString categoriesStr = catList.join(","); | 475 | QString categoriesStr = catList.join(","); |
476 | int i; | 476 | int i; |
477 | QStringList itemList; | 477 | QStringList itemList; |
478 | QPtrList<KOListViewItem> sel ; | 478 | QPtrList<KOListViewItem> sel ; |
479 | QListViewItem *qitem = mListView->firstChild (); | 479 | QListViewItem *qitem = mListView->firstChild (); |
480 | while ( qitem ) { | 480 | while ( qitem ) { |
481 | if ( qitem->isSelected() ) { | 481 | if ( qitem->isSelected() ) { |
482 | sel.append(((KOListViewItem *)qitem)); | 482 | sel.append(((KOListViewItem *)qitem)); |
483 | } | 483 | } |
484 | qitem = qitem->nextSibling(); | 484 | qitem = qitem->nextSibling(); |
485 | } | 485 | } |
486 | KOListViewItem * item, *temp; | 486 | KOListViewItem * item, *temp; |
487 | item = sel.first(); | 487 | item = sel.first(); |
488 | if( item ) { | 488 | if( item ) { |
489 | Incidence* inc = item->data() ; | 489 | Incidence* inc = item->data() ; |
490 | bool setSub = false; | 490 | bool setSub = false; |
491 | if( inc->type() == "Todo" && sel.count() == 1 && inc->relations().count() > 0 ) { | 491 | if( inc->typeID() == todoID && sel.count() == 1 && inc->relations().count() > 0 ) { |
492 | int result = KMessageBox::warningYesNoCancel(this, | 492 | int result = KMessageBox::warningYesNoCancel(this, |
493 | i18n("The todo\n%1\nhas subtodos!\nDo you want to set\nthe categories for\nall subtodos as well?").arg( inc->summary().left ( 25 ) ), | 493 | i18n("The todo\n%1\nhas subtodos!\nDo you want to set\nthe categories for\nall subtodos as well?").arg( inc->summary().left ( 25 ) ), |
494 | i18n("Todo has subtodos"), | 494 | i18n("Todo has subtodos"), |
495 | i18n("Yes"), | 495 | i18n("Yes"), |
496 | i18n("No")); | 496 | i18n("No")); |
497 | if (result == KMessageBox::Cancel) item = 0; | 497 | if (result == KMessageBox::Cancel) item = 0; |
498 | if (result == KMessageBox::Yes) setSub = true; | 498 | if (result == KMessageBox::Yes) setSub = true; |
499 | } | 499 | } |
500 | while ( item ) { | 500 | while ( item ) { |
501 | inc = item->data(); | 501 | inc = item->data(); |
502 | if ( removeOld ) { | 502 | if ( removeOld ) { |
503 | inc->setCategories( catList, setSub ); | 503 | inc->setCategories( catList, setSub ); |
504 | } else { | 504 | } else { |
505 | inc->addCategories( catList, setSub ); | 505 | inc->addCategories( catList, setSub ); |
506 | } | 506 | } |
507 | ListItemVisitor v(item, mStartDate ); | 507 | ListItemVisitor v(item, mStartDate ); |
508 | inc->accept(v); | 508 | inc->accept(v); |
509 | item = sel.next(); | 509 | item = sel.next(); |
510 | } | 510 | } |
511 | } | 511 | } |
512 | QTimer::singleShot( 1, this, SLOT ( resetFocus() ) ); | 512 | QTimer::singleShot( 1, this, SLOT ( resetFocus() ) ); |
513 | } | 513 | } |
514 | 514 | ||
515 | void KOListView::beamSelected() | 515 | void KOListView::beamSelected() |
516 | { | 516 | { |
517 | int icount = 0; | 517 | int icount = 0; |
518 | QPtrList<Incidence> delSel ; | 518 | QPtrList<Incidence> delSel ; |
519 | QListViewItem *item = mListView->firstChild (); | 519 | QListViewItem *item = mListView->firstChild (); |
520 | while ( item ) { | 520 | while ( item ) { |
521 | if ( item->isSelected() ) { | 521 | if ( item->isSelected() ) { |
522 | delSel.append(((KOListViewItem *)item)->data()); | 522 | delSel.append(((KOListViewItem *)item)->data()); |
523 | ++icount; | 523 | ++icount; |
524 | } | 524 | } |
525 | 525 | ||
526 | item = item->nextSibling(); | 526 | item = item->nextSibling(); |
527 | } | 527 | } |
528 | if ( icount ) { | 528 | if ( icount ) { |
529 | emit beamIncidenceList( delSel ); | 529 | emit beamIncidenceList( delSel ); |
530 | return; | 530 | return; |
531 | QString fn ; | 531 | QString fn ; |
532 | fn = QDir::homeDirPath()+"/kopitempbeamfile.vcs"; | 532 | fn = QDir::homeDirPath()+"/kopitempbeamfile.vcs"; |
533 | QString mes; | 533 | QString mes; |
534 | bool createbup = true; | 534 | bool createbup = true; |
535 | if ( createbup ) { | 535 | if ( createbup ) { |
536 | QString description = "\n"; | 536 | QString description = "\n"; |
537 | CalendarLocal* cal = new CalendarLocal(); | 537 | CalendarLocal* cal = new CalendarLocal(); |
538 | cal->setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); | 538 | cal->setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); |
539 | Incidence *incidence = delSel.first(); | 539 | Incidence *incidence = delSel.first(); |
540 | while ( incidence ) { | 540 | while ( incidence ) { |
541 | Incidence *in = incidence->clone(); | 541 | Incidence *in = incidence->clone(); |
542 | description += in->summary() + "\n"; | 542 | description += in->summary() + "\n"; |
543 | cal->addIncidence( in ); | 543 | cal->addIncidence( in ); |
544 | incidence = delSel.next(); | 544 | incidence = delSel.next(); |
545 | } | 545 | } |
546 | FileStorage storage( cal, fn, new VCalFormat ); | 546 | FileStorage storage( cal, fn, new VCalFormat ); |
547 | storage.save(); | 547 | storage.save(); |
548 | delete cal; | 548 | delete cal; |
549 | mes = i18n("KO/Pi: Ready for beaming"); | 549 | mes = i18n("KO/Pi: Ready for beaming"); |
550 | topLevelWidget()->setCaption(mes); | 550 | topLevelWidget()->setCaption(mes); |
551 | 551 | ||
552 | #ifndef DESKTOP_VERSION | 552 | #ifndef DESKTOP_VERSION |
553 | Ir *ir = new Ir( this ); | 553 | Ir *ir = new Ir( this ); |
554 | connect( ir, SIGNAL( done( Ir * ) ), this, SLOT( beamDone( Ir * ) ) ); | 554 | connect( ir, SIGNAL( done( Ir * ) ), this, SLOT( beamDone( Ir * ) ) ); |
555 | ir->send( fn, description, "text/x-vCalendar" ); | 555 | ir->send( fn, description, "text/x-vCalendar" ); |
556 | #endif | 556 | #endif |
557 | } | 557 | } |
558 | } | 558 | } |
559 | } | 559 | } |
560 | void KOListView::beamDone( Ir *ir ) | 560 | void KOListView::beamDone( Ir *ir ) |
561 | { | 561 | { |
562 | #ifndef DESKTOP_VERSION | 562 | #ifndef DESKTOP_VERSION |
563 | delete ir; | 563 | delete ir; |
564 | #endif | 564 | #endif |
565 | topLevelWidget()->setCaption(i18n("KO/Pi:Beaming done")); | 565 | topLevelWidget()->setCaption(i18n("KO/Pi:Beaming done")); |
566 | } | 566 | } |
567 | 567 | ||
568 | void KOListView::saveDescriptionToFile() | 568 | void KOListView::saveDescriptionToFile() |
569 | { | 569 | { |
570 | 570 | ||
571 | int result = QMessageBox::warning( this, i18n("KO/Pi: Information!"), | 571 | int result = QMessageBox::warning( this, i18n("KO/Pi: Information!"), |
572 | i18n("This saves the text/details of selected\nJournals and Events/Todos\nto a text file."), | 572 | i18n("This saves the text/details of selected\nJournals and Events/Todos\nto a text file."), |
573 | i18n("Continue"), i18n("Cancel"), 0, | 573 | i18n("Continue"), i18n("Cancel"), 0, |
574 | 0, 1 ); | 574 | 0, 1 ); |
575 | if ( result != 0 ) { | 575 | if ( result != 0 ) { |
576 | return; | 576 | return; |
577 | } | 577 | } |
578 | int icount = 0; | 578 | int icount = 0; |
579 | QPtrList<Incidence> delSel ; | 579 | QPtrList<Incidence> delSel ; |
580 | QListViewItem *item = mListView->firstChild (); | 580 | QListViewItem *item = mListView->firstChild (); |
581 | while ( item ) { | 581 | while ( item ) { |
582 | if ( item->isSelected() ) { | 582 | if ( item->isSelected() ) { |
583 | delSel.append(((KOListViewItem *)item)->data()); | 583 | delSel.append(((KOListViewItem *)item)->data()); |
584 | ++icount; | 584 | ++icount; |
585 | } | 585 | } |
586 | 586 | ||
587 | item = item->nextSibling(); | 587 | item = item->nextSibling(); |
588 | } | 588 | } |
589 | if ( icount ) { | 589 | if ( icount ) { |
590 | QString fn = KOPrefs::instance()->mLastSaveFile; | 590 | QString fn = KOPrefs::instance()->mLastSaveFile; |
591 | fn = KFileDialog::getSaveFileName( fn, i18n("Save filename"), this ); | 591 | fn = KFileDialog::getSaveFileName( fn, i18n("Save filename"), this ); |
592 | 592 | ||
593 | if ( fn == "" ) | 593 | if ( fn == "" ) |
594 | return; | 594 | return; |
595 | QFileInfo info; | 595 | QFileInfo info; |
596 | info.setFile( fn ); | 596 | info.setFile( fn ); |
597 | QString mes; | 597 | QString mes; |
598 | bool createbup = true; | 598 | bool createbup = true; |
599 | if ( info. exists() ) { | 599 | if ( info. exists() ) { |
600 | mes = i18n("File already exists!\nOld file from:\n%1\nOverwrite?\n").arg (KGlobal::locale()->formatDateTime(info.lastModified (), true, false ) ); | 600 | mes = i18n("File already exists!\nOld file from:\n%1\nOverwrite?\n").arg (KGlobal::locale()->formatDateTime(info.lastModified (), true, false ) ); |
601 | int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"),mes, | 601 | int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"),mes, |
602 | i18n("Overwrite!"), i18n("Cancel"), 0, | 602 | i18n("Overwrite!"), i18n("Cancel"), 0, |
603 | 0, 1 ); | 603 | 0, 1 ); |
604 | if ( result != 0 ) { | 604 | if ( result != 0 ) { |
605 | createbup = false; | 605 | createbup = false; |
606 | } | 606 | } |
607 | } | 607 | } |
608 | if ( createbup ) { | 608 | if ( createbup ) { |
609 | QString text = i18n("KO/Pi Description/Journal save file.\nSave date: ") + | 609 | QString text = i18n("KO/Pi Description/Journal save file.\nSave date: ") + |
610 | KGlobal::locale()->formatDateTime(QDateTime::currentDateTime(), false); | 610 | KGlobal::locale()->formatDateTime(QDateTime::currentDateTime(), false); |
611 | Incidence *incidence = delSel.first(); | 611 | Incidence *incidence = delSel.first(); |
612 | icount = 0; | 612 | icount = 0; |
613 | while ( incidence ) { | 613 | while ( incidence ) { |
614 | if ( incidence->type() == "Journal" ) { | 614 | if ( incidence->typeID() == journalID ) { |
615 | text += "\n************************************\n"; | 615 | text += "\n************************************\n"; |
616 | text += i18n("Journal from: ") +incidence->dtStartDateStr( false ); | 616 | text += i18n("Journal from: ") +incidence->dtStartDateStr( false ); |
617 | text +="\n" + i18n("Last modified: ") +KGlobal::locale()->formatDateTime(incidence->lastModified(), false); | 617 | text +="\n" + i18n("Last modified: ") +KGlobal::locale()->formatDateTime(incidence->lastModified(), false); |
618 | text +="\n" + i18n("Description: ") + "\n"+ incidence->description(); | 618 | text +="\n" + i18n("Description: ") + "\n"+ incidence->description(); |
619 | ++icount; | 619 | ++icount; |
620 | 620 | ||
621 | } else { | 621 | } else { |
622 | if ( !incidence->description().isEmpty() ) { | 622 | if ( !incidence->description().isEmpty() ) { |
623 | text += "\n************************************\n"; | 623 | text += "\n************************************\n"; |
624 | if ( incidence->type() == "Todo" ) | 624 | if ( incidence->typeID() == todoID ) |
625 | text += i18n("To-Do: "); | 625 | text += i18n("To-Do: "); |
626 | text += incidence->summary(); | 626 | text += incidence->summary(); |
627 | if ( incidence->hasStartDate() ) | 627 | if ( incidence->hasStartDate() ) |
628 | text +="\n"+ i18n("Start Date: ") + incidence->dtStartStr( false ); | 628 | text +="\n"+ i18n("Start Date: ") + incidence->dtStartStr( false ); |
629 | text +="\n"+ i18n("Last modified: ") +KGlobal::locale()->formatDateTime(incidence->lastModified(), false); | 629 | text +="\n"+ i18n("Last modified: ") +KGlobal::locale()->formatDateTime(incidence->lastModified(), false); |
630 | if ( !incidence->location().isEmpty() ) | 630 | if ( !incidence->location().isEmpty() ) |
631 | text += "\n" +i18n("Location: ") + incidence->location(); | 631 | text += "\n" +i18n("Location: ") + incidence->location(); |
632 | text += "\n" + i18n("Description: ") + "\n" + incidence->description(); | 632 | text += "\n" + i18n("Description: ") + "\n" + incidence->description(); |
633 | ++icount; | 633 | ++icount; |
634 | 634 | ||
635 | } | 635 | } |
636 | } | 636 | } |
637 | incidence = delSel.next(); | 637 | incidence = delSel.next(); |
638 | } | 638 | } |
639 | QFile file( fn ); | 639 | QFile file( fn ); |
640 | if (!file.open( IO_WriteOnly ) ) { | 640 | if (!file.open( IO_WriteOnly ) ) { |
641 | topLevelWidget()->setCaption(i18n("File open error - nothing saved!") ); | 641 | topLevelWidget()->setCaption(i18n("File open error - nothing saved!") ); |
642 | return; | 642 | return; |
643 | } | 643 | } |
644 | QTextStream ts( &file ); | 644 | QTextStream ts( &file ); |
645 | ts << text; | 645 | ts << text; |
646 | file.close(); | 646 | file.close(); |
647 | //qDebug("%s ", text.latin1()); | 647 | //qDebug("%s ", text.latin1()); |
648 | mes = i18n("KO/Pi:Saved %1 descriptions/journals").arg(icount ); | 648 | mes = i18n("KO/Pi:Saved %1 descriptions/journals").arg(icount ); |
649 | KOPrefs::instance()->mLastSaveFile = fn; | 649 | KOPrefs::instance()->mLastSaveFile = fn; |
650 | topLevelWidget()->setCaption(mes); | 650 | topLevelWidget()->setCaption(mes); |
651 | } | 651 | } |
652 | } | 652 | } |
653 | } | 653 | } |
654 | void KOListView::saveToFileVCS() | 654 | void KOListView::saveToFileVCS() |
655 | { | 655 | { |
656 | writeToFile( false ); | 656 | writeToFile( false ); |
657 | } | 657 | } |
658 | void KOListView::saveToFile() | 658 | void KOListView::saveToFile() |
659 | { | 659 | { |
660 | writeToFile( true ); | 660 | writeToFile( true ); |
661 | } | 661 | } |
662 | void KOListView::writeToFile( bool iCal ) | 662 | void KOListView::writeToFile( bool iCal ) |
663 | { | 663 | { |
664 | 664 | ||
665 | int icount = 0; | 665 | int icount = 0; |
666 | QPtrList<Incidence> delSel ; | 666 | QPtrList<Incidence> delSel ; |
667 | QListViewItem *item = mListView->firstChild (); | 667 | QListViewItem *item = mListView->firstChild (); |
668 | bool journal = iCal; // warn only for vCal | 668 | bool journal = iCal; // warn only for vCal |
669 | while ( item ) { | 669 | while ( item ) { |
670 | if ( item->isSelected() ) { | 670 | if ( item->isSelected() ) { |
671 | if ( !journal ) | 671 | if ( !journal ) |
672 | if ( ((KOListViewItem *)item)->data()->type() == "Journal") | 672 | if ( ((KOListViewItem *)item)->data()->typeID() == journalID ) |
673 | journal = true; | 673 | journal = true; |
674 | delSel.append(((KOListViewItem *)item)->data()); | 674 | delSel.append(((KOListViewItem *)item)->data()); |
675 | ++icount; | 675 | ++icount; |
676 | } | 676 | } |
677 | 677 | ||
678 | item = item->nextSibling(); | 678 | item = item->nextSibling(); |
679 | } | 679 | } |
680 | if ( !iCal && journal ) { | 680 | if ( !iCal && journal ) { |
681 | int result = KMessageBox::warningContinueCancel(this, | 681 | int result = KMessageBox::warningContinueCancel(this, |
682 | i18n("The journal entries can not be\nexported to a vCalendar file."), | 682 | i18n("The journal entries can not be\nexported to a vCalendar file."), |
683 | i18n("Data Loss Warning"),i18n("Proceed"),i18n("Cancel"), | 683 | i18n("Data Loss Warning"),i18n("Proceed"),i18n("Cancel"), |
684 | true); | 684 | true); |
685 | if (result != KMessageBox::Continue) return; | 685 | if (result != KMessageBox::Continue) return; |
686 | } | 686 | } |
687 | if ( icount ) { | 687 | if ( icount ) { |
688 | QString fn = KOPrefs::instance()->mLastSaveFile; | 688 | QString fn = KOPrefs::instance()->mLastSaveFile; |
689 | QString extension; | 689 | QString extension; |
690 | if ( iCal ) { | 690 | if ( iCal ) { |
691 | if ( fn.right( 4 ).lower() == ".vcs" ) { | 691 | if ( fn.right( 4 ).lower() == ".vcs" ) { |
692 | fn = fn.left( fn.length() -3) + "ics"; | 692 | fn = fn.left( fn.length() -3) + "ics"; |
693 | } | 693 | } |
694 | } else { | 694 | } else { |
695 | if ( fn.right( 4 ).lower() == ".ics" ) { | 695 | if ( fn.right( 4 ).lower() == ".ics" ) { |
696 | fn = fn.left( fn.length() -3) + "vcs"; | 696 | fn = fn.left( fn.length() -3) + "vcs"; |
697 | } | 697 | } |
698 | } | 698 | } |
699 | fn = KFileDialog::getSaveFileName( fn, i18n("Save filename"), this ); | 699 | fn = KFileDialog::getSaveFileName( fn, i18n("Save filename"), this ); |
700 | 700 | ||
701 | if ( fn == "" ) | 701 | if ( fn == "" ) |
702 | return; | 702 | return; |
703 | QFileInfo info; | 703 | QFileInfo info; |
704 | info.setFile( fn ); | 704 | info.setFile( fn ); |
705 | QString mes; | 705 | QString mes; |
706 | bool createbup = true; | 706 | bool createbup = true; |
707 | if ( info. exists() ) { | 707 | if ( info. exists() ) { |
708 | mes = i18n("File already exists!\nOld file from:\n%1\nOverwrite?\n").arg (KGlobal::locale()->formatDateTime(info.lastModified (), true, false ) ); | 708 | mes = i18n("File already exists!\nOld file from:\n%1\nOverwrite?\n").arg (KGlobal::locale()->formatDateTime(info.lastModified (), true, false ) ); |
709 | int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"),mes, | 709 | int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"),mes, |
710 | i18n("Overwrite!"), i18n("Cancel"), 0, | 710 | i18n("Overwrite!"), i18n("Cancel"), 0, |
711 | 0, 1 ); | 711 | 0, 1 ); |
712 | if ( result != 0 ) { | 712 | if ( result != 0 ) { |
713 | createbup = false; | 713 | createbup = false; |
714 | } | 714 | } |
715 | } | 715 | } |
716 | if ( createbup ) { | 716 | if ( createbup ) { |
717 | CalendarLocal cal; | 717 | CalendarLocal cal; |
718 | cal.setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); | 718 | cal.setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); |
719 | Incidence *incidence = delSel.first(); | 719 | Incidence *incidence = delSel.first(); |
720 | while ( incidence ) { | 720 | while ( incidence ) { |
721 | cal.addIncidence( incidence->clone() ); | 721 | cal.addIncidence( incidence->clone() ); |
722 | incidence = delSel.next(); | 722 | incidence = delSel.next(); |
723 | } | 723 | } |
724 | if ( iCal ) { | 724 | if ( iCal ) { |
725 | ICalFormat format; | 725 | ICalFormat format; |
726 | format.save( &cal, fn ); | 726 | format.save( &cal, fn ); |
727 | } else { | 727 | } else { |
728 | 728 | ||
729 | VCalFormat format; | 729 | VCalFormat format; |
730 | format.save( &cal, fn ); | 730 | format.save( &cal, fn ); |
731 | } | 731 | } |
732 | mes = i18n("KO/Pi:Saved %1").arg(fn ); | 732 | mes = i18n("KO/Pi:Saved %1").arg(fn ); |
733 | KOPrefs::instance()->mLastSaveFile = fn; | 733 | KOPrefs::instance()->mLastSaveFile = fn; |
734 | topLevelWidget()->setCaption(mes); | 734 | topLevelWidget()->setCaption(mes); |
735 | } | 735 | } |
736 | } | 736 | } |
737 | QTimer::singleShot( 1, this, SLOT ( resetFocus() ) ); | 737 | QTimer::singleShot( 1, this, SLOT ( resetFocus() ) ); |
738 | } | 738 | } |
739 | void KOListView::hideAll() | 739 | void KOListView::hideAll() |
740 | { | 740 | { |
741 | QPtrList<QListViewItem> delSel ; | 741 | QPtrList<QListViewItem> delSel ; |
742 | QListViewItem *item = mListView->firstChild (); | 742 | QListViewItem *item = mListView->firstChild (); |
743 | while ( item ) { | 743 | while ( item ) { |
744 | if ( item->isSelected() ) { | 744 | if ( item->isSelected() ) { |
745 | delSel.append(item); | 745 | delSel.append(item); |
746 | } | 746 | } |
747 | item = item->nextSibling(); | 747 | item = item->nextSibling(); |
748 | } | 748 | } |
749 | item = delSel.first() ; | 749 | item = delSel.first() ; |
750 | while ( item ) { | 750 | while ( item ) { |
751 | QListViewItem * del = item; | 751 | QListViewItem * del = item; |
752 | item = delSel.next(); | 752 | item = delSel.next(); |
753 | delete del; | 753 | delete del; |
754 | } | 754 | } |
755 | } | 755 | } |
756 | void KOListView::printList() | 756 | void KOListView::printList() |
757 | { | 757 | { |
758 | mListView->printList(); | 758 | mListView->printList(); |
759 | } | 759 | } |
760 | void KOListView::deleteAll() | 760 | void KOListView::deleteAll() |
761 | { | 761 | { |
762 | int icount = 0; | 762 | int icount = 0; |
763 | QPtrList<Incidence> delSel ; | 763 | QPtrList<Incidence> delSel ; |
764 | QListViewItem *item = mListView->firstChild (); | 764 | QListViewItem *item = mListView->firstChild (); |
765 | while ( item ) { | 765 | while ( item ) { |
766 | if ( item->isSelected() ) { | 766 | if ( item->isSelected() ) { |
767 | delSel.append(((KOListViewItem *)item)->data()); | 767 | delSel.append(((KOListViewItem *)item)->data()); |
768 | ++icount; | 768 | ++icount; |
769 | } | 769 | } |
770 | 770 | ||
771 | item = item->nextSibling(); | 771 | item = item->nextSibling(); |
772 | } | 772 | } |
773 | if ( icount ) { | 773 | if ( icount ) { |
774 | Incidence *incidence = delSel.first(); | 774 | Incidence *incidence = delSel.first(); |
775 | Incidence *toDelete; | 775 | Incidence *toDelete; |
776 | KOPrefs *p = KOPrefs::instance(); | 776 | KOPrefs *p = KOPrefs::instance(); |
777 | bool confirm = p->mConfirm; | 777 | bool confirm = p->mConfirm; |
778 | QString mess; | 778 | QString mess; |
779 | mess = mess.sprintf( i18n("You have %d item(s) selected.\n"), icount ); | 779 | mess = mess.sprintf( i18n("You have %d item(s) selected.\n"), icount ); |
780 | if ( KMessageBox::Continue == KMessageBox::warningContinueCancel(this, mess + i18n("All selected items will be\npermanently deleted.\n(Deleting items will take\nsome time on a PDA)\n"), i18n("KO/Pi Confirmation"),i18n("Delete")) ) { | 780 | if ( KMessageBox::Continue == KMessageBox::warningContinueCancel(this, mess + i18n("All selected items will be\npermanently deleted.\n(Deleting items will take\nsome time on a PDA)\n"), i18n("KO/Pi Confirmation"),i18n("Delete")) ) { |
781 | p->mConfirm = false; | 781 | p->mConfirm = false; |
782 | int delCounter = 0; | 782 | int delCounter = 0; |
783 | QDialog dia ( this, "p-dialog", true ); | 783 | QDialog dia ( this, "p-dialog", true ); |
784 | QLabel lab (i18n("Close dialog to abort deletion!"), &dia ); | 784 | QLabel lab (i18n("Close dialog to abort deletion!"), &dia ); |
785 | QVBoxLayout lay( &dia ); | 785 | QVBoxLayout lay( &dia ); |
786 | lay.setMargin(7); | 786 | lay.setMargin(7); |
787 | lay.setSpacing(7); | 787 | lay.setSpacing(7); |
788 | lay.addWidget( &lab); | 788 | lay.addWidget( &lab); |
789 | QProgressBar bar( icount, &dia ); | 789 | QProgressBar bar( icount, &dia ); |
790 | lay.addWidget( &bar); | 790 | lay.addWidget( &bar); |
791 | int w = 220; | 791 | int w = 220; |
792 | int h = 50; | 792 | int h = 50; |
793 | int dw = QApplication::desktop()->width(); | 793 | int dw = QApplication::desktop()->width(); |
794 | int dh = QApplication::desktop()->height(); | 794 | int dh = QApplication::desktop()->height(); |
795 | dia.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); | 795 | dia.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); |
796 | //dia.resize( 240,50 ); | 796 | //dia.resize( 240,50 ); |
797 | dia.show(); | 797 | dia.show(); |
798 | 798 | ||
799 | while ( incidence ) { | 799 | while ( incidence ) { |
800 | bar.setProgress( delCounter ); | 800 | bar.setProgress( delCounter ); |
diff --git a/korganizer/kotodoview.cpp b/korganizer/kotodoview.cpp index 5aaf360..2602487 100644 --- a/korganizer/kotodoview.cpp +++ b/korganizer/kotodoview.cpp | |||
@@ -577,399 +577,399 @@ KOTodoView::KOTodoView(Calendar *calendar,QWidget* parent,const char* name) : | |||
577 | SLOT(selectionChanged(QListViewItem *))); | 577 | SLOT(selectionChanged(QListViewItem *))); |
578 | connect(mTodoListView,SIGNAL(pressed(QListViewItem *)), | 578 | connect(mTodoListView,SIGNAL(pressed(QListViewItem *)), |
579 | SLOT(selectionChanged(QListViewItem *))); | 579 | SLOT(selectionChanged(QListViewItem *))); |
580 | #endif | 580 | #endif |
581 | 581 | ||
582 | connect( mTodoListView, SIGNAL(reparentTodoSignal( Todo *,Todo * ) ), SIGNAL(reparentTodoSignal( Todo *,Todo * ) )); | 582 | connect( mTodoListView, SIGNAL(reparentTodoSignal( Todo *,Todo * ) ), SIGNAL(reparentTodoSignal( Todo *,Todo * ) )); |
583 | connect( mTodoListView, SIGNAL(unparentTodoSignal(Todo *) ), SIGNAL(unparentTodoSignal(Todo *) )); | 583 | connect( mTodoListView, SIGNAL(unparentTodoSignal(Todo *) ), SIGNAL(unparentTodoSignal(Todo *) )); |
584 | connect( mTodoListView, SIGNAL( deleteTodo(Todo *) ), SIGNAL(deleteTodoSignal(Todo *) )); | 584 | connect( mTodoListView, SIGNAL( deleteTodo(Todo *) ), SIGNAL(deleteTodoSignal(Todo *) )); |
585 | 585 | ||
586 | connect( mTodoListView, SIGNAL(selectionChanged() ), | 586 | connect( mTodoListView, SIGNAL(selectionChanged() ), |
587 | SLOT( processSelectionChange() ) ); | 587 | SLOT( processSelectionChange() ) ); |
588 | connect( mQuickAdd, SIGNAL( returnPressed () ), | 588 | connect( mQuickAdd, SIGNAL( returnPressed () ), |
589 | SLOT( addQuickTodo() ) ); | 589 | SLOT( addQuickTodo() ) ); |
590 | 590 | ||
591 | } | 591 | } |
592 | 592 | ||
593 | KOTodoView::~KOTodoView() | 593 | KOTodoView::~KOTodoView() |
594 | { | 594 | { |
595 | 595 | ||
596 | #if QT_VERSION >= 0x030000 | 596 | #if QT_VERSION >= 0x030000 |
597 | 597 | ||
598 | #else | 598 | #else |
599 | delete mKOTodoViewWhatsThis; | 599 | delete mKOTodoViewWhatsThis; |
600 | #endif | 600 | #endif |
601 | 601 | ||
602 | delete mDocPrefs; | 602 | delete mDocPrefs; |
603 | } | 603 | } |
604 | QString KOTodoView::getWhatsThisText(QPoint p) | 604 | QString KOTodoView::getWhatsThisText(QPoint p) |
605 | { | 605 | { |
606 | KOTodoViewItem* item = ( KOTodoViewItem* ) mTodoListView->itemAt( p ); | 606 | KOTodoViewItem* item = ( KOTodoViewItem* ) mTodoListView->itemAt( p ); |
607 | if ( item ) | 607 | if ( item ) |
608 | return KIncidenceFormatter::instance()->getFormattedText( item->todo(), | 608 | return KIncidenceFormatter::instance()->getFormattedText( item->todo(), |
609 | KOPrefs::instance()->mWTshowDetails, | 609 | KOPrefs::instance()->mWTshowDetails, |
610 | KOPrefs::instance()->mWTshowCreated, | 610 | KOPrefs::instance()->mWTshowCreated, |
611 | KOPrefs::instance()->mWTshowChanged); | 611 | KOPrefs::instance()->mWTshowChanged); |
612 | return i18n("That is the todo view" ); | 612 | return i18n("That is the todo view" ); |
613 | 613 | ||
614 | } | 614 | } |
615 | 615 | ||
616 | void KOTodoView::jumpToDate () | 616 | void KOTodoView::jumpToDate () |
617 | { | 617 | { |
618 | // if (mActiveItem) { | 618 | // if (mActiveItem) { |
619 | // mActiveItem->todo()); | 619 | // mActiveItem->todo()); |
620 | // if ( mActiveItem->todo()->hasDueDate() ) | 620 | // if ( mActiveItem->todo()->hasDueDate() ) |
621 | // emit mActiveItem->todo()jumpToTime( mTodo->dtDue().date() ); | 621 | // emit mActiveItem->todo()jumpToTime( mTodo->dtDue().date() ); |
622 | } | 622 | } |
623 | void KOTodoView::paintNeeded() | 623 | void KOTodoView::paintNeeded() |
624 | { | 624 | { |
625 | if ( mPendingUpdateBeforeRepaint ) { | 625 | if ( mPendingUpdateBeforeRepaint ) { |
626 | updateView(); | 626 | updateView(); |
627 | mPendingUpdateBeforeRepaint = false; | 627 | mPendingUpdateBeforeRepaint = false; |
628 | } | 628 | } |
629 | } | 629 | } |
630 | void KOTodoView::paintEvent(QPaintEvent * pevent) | 630 | void KOTodoView::paintEvent(QPaintEvent * pevent) |
631 | { | 631 | { |
632 | if ( mPendingUpdateBeforeRepaint ) { | 632 | if ( mPendingUpdateBeforeRepaint ) { |
633 | updateView(); | 633 | updateView(); |
634 | mPendingUpdateBeforeRepaint = false; | 634 | mPendingUpdateBeforeRepaint = false; |
635 | } | 635 | } |
636 | KOrg::BaseView::paintEvent( pevent); | 636 | KOrg::BaseView::paintEvent( pevent); |
637 | } | 637 | } |
638 | 638 | ||
639 | void KOTodoView::updateView() | 639 | void KOTodoView::updateView() |
640 | { | 640 | { |
641 | pendingSubtodo = 0; | 641 | pendingSubtodo = 0; |
642 | if ( mBlockUpdate ) { | 642 | if ( mBlockUpdate ) { |
643 | return; | 643 | return; |
644 | } | 644 | } |
645 | if ( !isVisible() ) { | 645 | if ( !isVisible() ) { |
646 | mPendingUpdateBeforeRepaint = true; | 646 | mPendingUpdateBeforeRepaint = true; |
647 | return; | 647 | return; |
648 | } | 648 | } |
649 | storeCurrentItem(); | 649 | storeCurrentItem(); |
650 | //qDebug("KOTodoView::updateView() %x", this); | 650 | //qDebug("KOTodoView::updateView() %x", this); |
651 | if ( isFlatDisplay ) { | 651 | if ( isFlatDisplay ) { |
652 | displayAllFlat(); | 652 | displayAllFlat(); |
653 | resetCurrentItem(); | 653 | resetCurrentItem(); |
654 | return; | 654 | return; |
655 | } | 655 | } |
656 | //qDebug("update "); | 656 | //qDebug("update "); |
657 | // kdDebug() << "KOTodoView::updateView()" << endl; | 657 | // kdDebug() << "KOTodoView::updateView()" << endl; |
658 | QFont fo = KOPrefs::instance()->mTodoViewFont; | 658 | QFont fo = KOPrefs::instance()->mTodoViewFont; |
659 | 659 | ||
660 | 660 | ||
661 | mTodoListView->clear(); | 661 | mTodoListView->clear(); |
662 | if ( mName == "todolistsmall" ) { | 662 | if ( mName == "todolistsmall" ) { |
663 | if ( KOPrefs::instance()->mTodoViewUsesSmallFont ) { | 663 | if ( KOPrefs::instance()->mTodoViewUsesSmallFont ) { |
664 | int ps = fo.pointSize() -2; | 664 | int ps = fo.pointSize() -2; |
665 | if ( ps > 12 ) | 665 | if ( ps > 12 ) |
666 | ps -= 2; | 666 | ps -= 2; |
667 | fo.setPointSize( ps ); | 667 | fo.setPointSize( ps ); |
668 | } | 668 | } |
669 | } | 669 | } |
670 | 670 | ||
671 | mTodoListView->setFont( fo ); | 671 | mTodoListView->setFont( fo ); |
672 | // QFontMetrics fm ( KOPrefs::instance()->mTodoViewFont ); | 672 | // QFontMetrics fm ( KOPrefs::instance()->mTodoViewFont ); |
673 | //mTodoListView->header()->setMaximumHeight(fm.height()); | 673 | //mTodoListView->header()->setMaximumHeight(fm.height()); |
674 | QPtrList<Todo> todoList = calendar()->todos(); | 674 | QPtrList<Todo> todoList = calendar()->todos(); |
675 | 675 | ||
676 | /* | 676 | /* |
677 | kdDebug() << "KOTodoView::updateView(): Todo List:" << endl; | 677 | kdDebug() << "KOTodoView::updateView(): Todo List:" << endl; |
678 | Event *t; | 678 | Event *t; |
679 | for(t = todoList.first(); t; t = todoList.next()) { | 679 | for(t = todoList.first(); t; t = todoList.next()) { |
680 | kdDebug() << " " << t->getSummary() << endl; | 680 | kdDebug() << " " << t->getSummary() << endl; |
681 | 681 | ||
682 | if (t->getRelatedTo()) { | 682 | if (t->getRelatedTo()) { |
683 | kdDebug() << " (related to " << t->getRelatedTo()->getSummary() << ")" << endl; | 683 | kdDebug() << " (related to " << t->getRelatedTo()->getSummary() << ")" << endl; |
684 | } | 684 | } |
685 | 685 | ||
686 | QPtrList<Event> l = t->getRelations(); | 686 | QPtrList<Event> l = t->getRelations(); |
687 | Event *c; | 687 | Event *c; |
688 | for(c=l.first();c;c=l.next()) { | 688 | for(c=l.first();c;c=l.next()) { |
689 | kdDebug() << " - relation: " << c->getSummary() << endl; | 689 | kdDebug() << " - relation: " << c->getSummary() << endl; |
690 | } | 690 | } |
691 | } | 691 | } |
692 | */ | 692 | */ |
693 | 693 | ||
694 | // Put for each Event a KOTodoViewItem in the list view. Don't rely on a | 694 | // Put for each Event a KOTodoViewItem in the list view. Don't rely on a |
695 | // specific order of events. That means that we have to generate parent items | 695 | // specific order of events. That means that we have to generate parent items |
696 | // recursively for proper hierarchical display of Todos. | 696 | // recursively for proper hierarchical display of Todos. |
697 | mTodoMap.clear(); | 697 | mTodoMap.clear(); |
698 | Todo *todo; | 698 | Todo *todo; |
699 | todo = todoList.first();// todo; todo = todoList.next()) { | 699 | todo = todoList.first();// todo; todo = todoList.next()) { |
700 | while ( todo ) { | 700 | while ( todo ) { |
701 | bool next = true; | 701 | bool next = true; |
702 | // qDebug("todo %s ", todo->summary().latin1()); | 702 | // qDebug("todo %s ", todo->summary().latin1()); |
703 | Incidence *incidence = todo->relatedTo(); | 703 | Incidence *incidence = todo->relatedTo(); |
704 | while ( incidence ) { | 704 | while ( incidence ) { |
705 | if ( incidence->type() == "Todo") { | 705 | if ( incidence->typeID() == todoID ) { |
706 | //qDebug("related %s ",incidence->summary().latin1() ); | 706 | //qDebug("related %s ",incidence->summary().latin1() ); |
707 | if ( !(todoList.contains ( ((Todo* )incidence ) ) )) { | 707 | if ( !(todoList.contains ( ((Todo* )incidence ) ) )) { |
708 | //qDebug("related not found "); | 708 | //qDebug("related not found "); |
709 | todoList.remove( ); | 709 | todoList.remove( ); |
710 | todo = todoList.current(); | 710 | todo = todoList.current(); |
711 | next = false; | 711 | next = false; |
712 | incidence = 0; | 712 | incidence = 0; |
713 | 713 | ||
714 | } else { | 714 | } else { |
715 | //qDebug("related found "); | 715 | //qDebug("related found "); |
716 | incidence = incidence->relatedTo(); | 716 | incidence = incidence->relatedTo(); |
717 | } | 717 | } |
718 | } else | 718 | } else |
719 | incidence = 0; | 719 | incidence = 0; |
720 | } | 720 | } |
721 | if ( next ) | 721 | if ( next ) |
722 | todo = todoList.next(); | 722 | todo = todoList.next(); |
723 | } | 723 | } |
724 | 724 | ||
725 | for(todo = todoList.first(); todo; todo = todoList.next()) { | 725 | for(todo = todoList.first(); todo; todo = todoList.next()) { |
726 | if (!mTodoMap.contains(todo) && checkTodo( todo ) ) | 726 | if (!mTodoMap.contains(todo) && checkTodo( todo ) ) |
727 | { | 727 | { |
728 | insertTodoItem(todo); | 728 | insertTodoItem(todo); |
729 | } | 729 | } |
730 | } | 730 | } |
731 | // Restore opened/closed state | 731 | // Restore opened/closed state |
732 | mTodoListView->blockSignals( true ); | 732 | mTodoListView->blockSignals( true ); |
733 | if( mDocPrefs ) restoreItemState( mTodoListView->firstChild() ); | 733 | if( mDocPrefs ) restoreItemState( mTodoListView->firstChild() ); |
734 | mTodoListView->blockSignals( false ); | 734 | mTodoListView->blockSignals( false ); |
735 | resetCurrentItem(); | 735 | resetCurrentItem(); |
736 | processSelectionChange(); | 736 | processSelectionChange(); |
737 | } | 737 | } |
738 | 738 | ||
739 | void KOTodoView::storeCurrentItem() | 739 | void KOTodoView::storeCurrentItem() |
740 | { | 740 | { |
741 | mCurItem = 0; | 741 | mCurItem = 0; |
742 | mCurItemRootParent = 0; | 742 | mCurItemRootParent = 0; |
743 | mCurItemParent = 0; | 743 | mCurItemParent = 0; |
744 | mCurItemAbove = 0; | 744 | mCurItemAbove = 0; |
745 | mActiveItem = (KOTodoViewItem*)mTodoListView->currentItem(); | 745 | mActiveItem = (KOTodoViewItem*)mTodoListView->currentItem(); |
746 | if (mActiveItem) { | 746 | if (mActiveItem) { |
747 | mCurItem = mActiveItem->todo(); | 747 | mCurItem = mActiveItem->todo(); |
748 | KOTodoViewItem* activeItemAbove = (KOTodoViewItem*)mActiveItem->itemAbove (); | 748 | KOTodoViewItem* activeItemAbove = (KOTodoViewItem*)mActiveItem->itemAbove (); |
749 | if ( activeItemAbove ) | 749 | if ( activeItemAbove ) |
750 | mCurItemAbove = activeItemAbove->todo(); | 750 | mCurItemAbove = activeItemAbove->todo(); |
751 | mCurItemRootParent = mCurItem; | 751 | mCurItemRootParent = mCurItem; |
752 | mCurItemParent = mCurItemRootParent->relatedTo(); | 752 | mCurItemParent = mCurItemRootParent->relatedTo(); |
753 | while ( mCurItemRootParent->relatedTo() != 0 ) | 753 | while ( mCurItemRootParent->relatedTo() != 0 ) |
754 | mCurItemRootParent = mCurItemRootParent->relatedTo(); | 754 | mCurItemRootParent = mCurItemRootParent->relatedTo(); |
755 | } | 755 | } |
756 | mActiveItem = 0; | 756 | mActiveItem = 0; |
757 | } | 757 | } |
758 | 758 | ||
759 | void KOTodoView::resetCurrentItem() | 759 | void KOTodoView::resetCurrentItem() |
760 | { | 760 | { |
761 | mTodoListView->setFocus(); | 761 | mTodoListView->setFocus(); |
762 | KOTodoViewItem* foundItem = 0; | 762 | KOTodoViewItem* foundItem = 0; |
763 | KOTodoViewItem* foundItemRoot = 0; | 763 | KOTodoViewItem* foundItemRoot = 0; |
764 | KOTodoViewItem* foundItemParent = 0; | 764 | KOTodoViewItem* foundItemParent = 0; |
765 | KOTodoViewItem* foundItemAbove = 0; | 765 | KOTodoViewItem* foundItemAbove = 0; |
766 | if ( mTodoListView->firstChild () ) { | 766 | if ( mTodoListView->firstChild () ) { |
767 | if ( mCurItem ) { | 767 | if ( mCurItem ) { |
768 | KOTodoViewItem* item = (KOTodoViewItem*)mTodoListView->firstChild (); | 768 | KOTodoViewItem* item = (KOTodoViewItem*)mTodoListView->firstChild (); |
769 | while ( item ) { | 769 | while ( item ) { |
770 | if ( item->todo() == mCurItem ) { | 770 | if ( item->todo() == mCurItem ) { |
771 | foundItem = item; | 771 | foundItem = item; |
772 | break; | 772 | break; |
773 | } else if ( item->todo() == mCurItemAbove ) { | 773 | } else if ( item->todo() == mCurItemAbove ) { |
774 | foundItemAbove = item; | 774 | foundItemAbove = item; |
775 | 775 | ||
776 | } | 776 | } |
777 | if ( item->todo() == mCurItemRootParent ) { | 777 | if ( item->todo() == mCurItemRootParent ) { |
778 | foundItemRoot = item; | 778 | foundItemRoot = item; |
779 | } | 779 | } |
780 | if ( item->todo() == mCurItemParent ) { | 780 | if ( item->todo() == mCurItemParent ) { |
781 | foundItemParent = item; | 781 | foundItemParent = item; |
782 | } | 782 | } |
783 | item = (KOTodoViewItem*)item->itemBelow(); | 783 | item = (KOTodoViewItem*)item->itemBelow(); |
784 | } | 784 | } |
785 | if ( ! foundItem ) { | 785 | if ( ! foundItem ) { |
786 | if ( foundItemParent ) { | 786 | if ( foundItemParent ) { |
787 | foundItem = foundItemParent; | 787 | foundItem = foundItemParent; |
788 | } else { | 788 | } else { |
789 | if ( foundItemRoot ) | 789 | if ( foundItemRoot ) |
790 | foundItem = foundItemRoot; | 790 | foundItem = foundItemRoot; |
791 | else | 791 | else |
792 | foundItem = foundItemAbove; | 792 | foundItem = foundItemAbove; |
793 | } | 793 | } |
794 | } | 794 | } |
795 | } | 795 | } |
796 | if ( foundItem ) { | 796 | if ( foundItem ) { |
797 | mTodoListView->setCurrentItem( foundItem ); | 797 | mTodoListView->setCurrentItem( foundItem ); |
798 | mTodoListView->ensureItemVisible( foundItem ); | 798 | mTodoListView->ensureItemVisible( foundItem ); |
799 | } else { | 799 | } else { |
800 | mTodoListView->setCurrentItem( mTodoListView->firstChild () ); | 800 | mTodoListView->setCurrentItem( mTodoListView->firstChild () ); |
801 | } | 801 | } |
802 | } | 802 | } |
803 | mTodoListView->setFocus(); | 803 | mTodoListView->setFocus(); |
804 | } | 804 | } |
805 | //Incidence * mCurItem, *mCurItemRootParent,*mCurItemAbove; | 805 | //Incidence * mCurItem, *mCurItemRootParent,*mCurItemAbove; |
806 | bool KOTodoView::checkTodo( Todo * todo ) | 806 | bool KOTodoView::checkTodo( Todo * todo ) |
807 | { | 807 | { |
808 | 808 | ||
809 | if ( !KOPrefs::instance()->mShowCompletedTodo && todo->isCompleted() ) | 809 | if ( !KOPrefs::instance()->mShowCompletedTodo && todo->isCompleted() ) |
810 | return false; | 810 | return false; |
811 | if ( !todo->isCompleted() ) { | 811 | if ( !todo->isCompleted() ) { |
812 | if ( todo->hasDueDate() && todo->dtDue().date() <= QDate::currentDate() ) | 812 | if ( todo->hasDueDate() && todo->dtDue().date() <= QDate::currentDate() ) |
813 | return true; | 813 | return true; |
814 | } | 814 | } |
815 | if ( KOPrefs::instance()->mHideNonStartedTodos && mNavigator ) { | 815 | if ( KOPrefs::instance()->mHideNonStartedTodos && mNavigator ) { |
816 | if ( todo->hasStartDate() ) | 816 | if ( todo->hasStartDate() ) |
817 | if ( mNavigator->selectedDates().last() < todo->dtStart().date() ) | 817 | if ( mNavigator->selectedDates().last() < todo->dtStart().date() ) |
818 | return false; | 818 | return false; |
819 | if ( todo->hasDueDate() ) | 819 | if ( todo->hasDueDate() ) |
820 | if ( mNavigator->selectedDates().first() > todo->dtDue().date() ) | 820 | if ( mNavigator->selectedDates().first() > todo->dtDue().date() ) |
821 | return false; | 821 | return false; |
822 | } | 822 | } |
823 | return true; | 823 | return true; |
824 | } | 824 | } |
825 | 825 | ||
826 | void KOTodoView::restoreItemState( QListViewItem *item ) | 826 | void KOTodoView::restoreItemState( QListViewItem *item ) |
827 | { | 827 | { |
828 | pendingSubtodo = 0; | 828 | pendingSubtodo = 0; |
829 | while( item ) { | 829 | while( item ) { |
830 | KOTodoViewItem *todoItem = (KOTodoViewItem *)item; | 830 | KOTodoViewItem *todoItem = (KOTodoViewItem *)item; |
831 | todoItem->setOpen( mDocPrefs->readBoolEntry( todoItem->todo()->uid() ) ); | 831 | todoItem->setOpen( mDocPrefs->readBoolEntry( todoItem->todo()->uid() ) ); |
832 | if( item->childCount() > 0 ) restoreItemState( item->firstChild() ); | 832 | if( item->childCount() > 0 ) restoreItemState( item->firstChild() ); |
833 | item = item->nextSibling(); | 833 | item = item->nextSibling(); |
834 | } | 834 | } |
835 | } | 835 | } |
836 | 836 | ||
837 | 837 | ||
838 | QMap<Todo *,KOTodoViewItem *>::ConstIterator | 838 | QMap<Todo *,KOTodoViewItem *>::ConstIterator |
839 | KOTodoView::insertTodoItem(Todo *todo) | 839 | KOTodoView::insertTodoItem(Todo *todo) |
840 | { | 840 | { |
841 | 841 | ||
842 | // kdDebug() << "KOTodoView::insertTodoItem(): " << todo->getSummary() << endl; | 842 | // kdDebug() << "KOTodoView::insertTodoItem(): " << todo->getSummary() << endl; |
843 | // TODO: Check, if dynmaic cast is necessary | 843 | // TODO: Check, if dynmaic cast is necessary |
844 | 844 | ||
845 | pendingSubtodo = 0; | 845 | pendingSubtodo = 0; |
846 | Incidence *incidence = todo->relatedTo(); | 846 | Incidence *incidence = todo->relatedTo(); |
847 | if (incidence && incidence->type() == "Todo") { | 847 | if (incidence && incidence->typeID() == todoID ) { |
848 | Todo *relatedTodo = static_cast<Todo *>(incidence); | 848 | Todo *relatedTodo = static_cast<Todo *>(incidence); |
849 | 849 | ||
850 | // kdDebug() << " has Related" << endl; | 850 | // kdDebug() << " has Related" << endl; |
851 | QMap<Todo *,KOTodoViewItem *>::ConstIterator itemIterator; | 851 | QMap<Todo *,KOTodoViewItem *>::ConstIterator itemIterator; |
852 | itemIterator = mTodoMap.find(relatedTodo); | 852 | itemIterator = mTodoMap.find(relatedTodo); |
853 | if (itemIterator == mTodoMap.end()) { | 853 | if (itemIterator == mTodoMap.end()) { |
854 | // kdDebug() << " related not yet in list" << endl; | 854 | // kdDebug() << " related not yet in list" << endl; |
855 | itemIterator = insertTodoItem (relatedTodo); | 855 | itemIterator = insertTodoItem (relatedTodo); |
856 | } | 856 | } |
857 | // isn't this pretty stupid? We give one Todo to the KOTodoViewItem | 857 | // isn't this pretty stupid? We give one Todo to the KOTodoViewItem |
858 | // and one into the map. Sure finding is more easy but why? -zecke | 858 | // and one into the map. Sure finding is more easy but why? -zecke |
859 | KOTodoViewItem *todoItem = new KOTodoViewItem(*itemIterator,todo,this); | 859 | KOTodoViewItem *todoItem = new KOTodoViewItem(*itemIterator,todo,this); |
860 | return mTodoMap.insert(todo,todoItem); | 860 | return mTodoMap.insert(todo,todoItem); |
861 | } else { | 861 | } else { |
862 | // kdDebug() << " no Related" << endl; | 862 | // kdDebug() << " no Related" << endl; |
863 | // see above -zecke | 863 | // see above -zecke |
864 | KOTodoViewItem *todoItem = new KOTodoViewItem(mTodoListView,todo,this); | 864 | KOTodoViewItem *todoItem = new KOTodoViewItem(mTodoListView,todo,this); |
865 | return mTodoMap.insert(todo,todoItem); | 865 | return mTodoMap.insert(todo,todoItem); |
866 | } | 866 | } |
867 | } | 867 | } |
868 | 868 | ||
869 | 869 | ||
870 | void KOTodoView::updateConfig() | 870 | void KOTodoView::updateConfig() |
871 | { | 871 | { |
872 | updateView(); | 872 | updateView(); |
873 | mTodoListView->repaintContents(); | 873 | mTodoListView->repaintContents(); |
874 | } | 874 | } |
875 | 875 | ||
876 | QPtrList<Incidence> KOTodoView::selectedIncidences() | 876 | QPtrList<Incidence> KOTodoView::selectedIncidences() |
877 | { | 877 | { |
878 | QPtrList<Incidence> selected; | 878 | QPtrList<Incidence> selected; |
879 | 879 | ||
880 | KOTodoViewItem *item = (KOTodoViewItem *)(mTodoListView->selectedItem()); | 880 | KOTodoViewItem *item = (KOTodoViewItem *)(mTodoListView->selectedItem()); |
881 | // if (!item) item = mActiveItem; | 881 | // if (!item) item = mActiveItem; |
882 | if (item) selected.append(item->todo()); | 882 | if (item) selected.append(item->todo()); |
883 | 883 | ||
884 | return selected; | 884 | return selected; |
885 | } | 885 | } |
886 | 886 | ||
887 | QPtrList<Todo> KOTodoView::selectedTodos() | 887 | QPtrList<Todo> KOTodoView::selectedTodos() |
888 | { | 888 | { |
889 | QPtrList<Todo> selected; | 889 | QPtrList<Todo> selected; |
890 | 890 | ||
891 | KOTodoViewItem *item = (KOTodoViewItem *)(mTodoListView->selectedItem()); | 891 | KOTodoViewItem *item = (KOTodoViewItem *)(mTodoListView->selectedItem()); |
892 | // if (!item) item = mActiveItem; | 892 | // if (!item) item = mActiveItem; |
893 | if (item) selected.append(item->todo()); | 893 | if (item) selected.append(item->todo()); |
894 | 894 | ||
895 | return selected; | 895 | return selected; |
896 | } | 896 | } |
897 | 897 | ||
898 | void KOTodoView::changeEventDisplay(Event *, int) | 898 | void KOTodoView::changeEventDisplay(Event *, int) |
899 | { | 899 | { |
900 | updateView(); | 900 | updateView(); |
901 | } | 901 | } |
902 | 902 | ||
903 | void KOTodoView::showDates(const QDate &, const QDate &) | 903 | void KOTodoView::showDates(const QDate &, const QDate &) |
904 | { | 904 | { |
905 | } | 905 | } |
906 | 906 | ||
907 | void KOTodoView::showEvents(QPtrList<Event>) | 907 | void KOTodoView::showEvents(QPtrList<Event>) |
908 | { | 908 | { |
909 | kdDebug() << "KOTodoView::selectEvents(): not yet implemented" << endl; | 909 | kdDebug() << "KOTodoView::selectEvents(): not yet implemented" << endl; |
910 | } | 910 | } |
911 | 911 | ||
912 | void KOTodoView::printPreview(CalPrinter *calPrinter, const QDate &fd, | 912 | void KOTodoView::printPreview(CalPrinter *calPrinter, const QDate &fd, |
913 | const QDate &td) | 913 | const QDate &td) |
914 | { | 914 | { |
915 | #ifndef KORG_NOPRINTER | 915 | #ifndef KORG_NOPRINTER |
916 | calPrinter->preview(CalPrinter::Todolist, fd, td); | 916 | calPrinter->preview(CalPrinter::Todolist, fd, td); |
917 | #endif | 917 | #endif |
918 | } | 918 | } |
919 | 919 | ||
920 | void KOTodoView::editItem(QListViewItem *item ) | 920 | void KOTodoView::editItem(QListViewItem *item ) |
921 | { | 921 | { |
922 | emit editTodoSignal(((KOTodoViewItem *)item)->todo()); | 922 | emit editTodoSignal(((KOTodoViewItem *)item)->todo()); |
923 | } | 923 | } |
924 | 924 | ||
925 | void KOTodoView::showItem(QListViewItem *item,const QPoint &,int) | 925 | void KOTodoView::showItem(QListViewItem *item,const QPoint &,int) |
926 | { | 926 | { |
927 | emit showTodoSignal(((KOTodoViewItem *)item)->todo()); | 927 | emit showTodoSignal(((KOTodoViewItem *)item)->todo()); |
928 | } | 928 | } |
929 | 929 | ||
930 | void KOTodoView::popupMenu(QListViewItem *item,const QPoint &p,int column) | 930 | void KOTodoView::popupMenu(QListViewItem *item,const QPoint &p,int column) |
931 | { | 931 | { |
932 | pendingSubtodo = 0; | 932 | pendingSubtodo = 0; |
933 | mActiveItem = (KOTodoViewItem *)item; | 933 | mActiveItem = (KOTodoViewItem *)item; |
934 | if (item) { | 934 | if (item) { |
935 | switch (column){ | 935 | switch (column){ |
936 | case 1: | 936 | case 1: |
937 | mPriorityPopupMenu->popup(QCursor::pos ()); break; | 937 | mPriorityPopupMenu->popup(QCursor::pos ()); break; |
938 | case 2: | 938 | case 2: |
939 | mPercentageCompletedPopupMenu->popup(QCursor::pos ()); break; | 939 | mPercentageCompletedPopupMenu->popup(QCursor::pos ()); break; |
940 | case 3: | 940 | case 3: |
941 | moveTodo(); | 941 | moveTodo(); |
942 | break; | 942 | break; |
943 | case 8: | 943 | case 8: |
944 | getCategoryPopupMenu((KOTodoViewItem *)item)->popup(QCursor::pos ()); break; | 944 | getCategoryPopupMenu((KOTodoViewItem *)item)->popup(QCursor::pos ()); break; |
945 | default: | 945 | default: |
946 | mItemPopupMenu->popup(QCursor::pos()); | 946 | mItemPopupMenu->popup(QCursor::pos()); |
947 | } | 947 | } |
948 | } else mPopupMenu->popup(QCursor::pos()); | 948 | } else mPopupMenu->popup(QCursor::pos()); |
949 | } | 949 | } |
950 | void KOTodoView::newTodo() | 950 | void KOTodoView::newTodo() |
951 | { | 951 | { |
952 | emit newTodoSignal(); | 952 | emit newTodoSignal(); |
953 | } | 953 | } |
954 | 954 | ||
955 | void KOTodoView::newSubTodo() | 955 | void KOTodoView::newSubTodo() |
956 | { | 956 | { |
957 | if (mActiveItem) { | 957 | if (mActiveItem) { |
958 | emit newSubTodoSignal(mActiveItem->todo()); | 958 | emit newSubTodoSignal(mActiveItem->todo()); |
959 | } | 959 | } |
960 | } | 960 | } |
961 | void KOTodoView::unparentTodo() | 961 | void KOTodoView::unparentTodo() |
962 | { | 962 | { |
963 | if (mActiveItem) { | 963 | if (mActiveItem) { |
964 | emit unparentTodoSignal(mActiveItem->todo()); | 964 | emit unparentTodoSignal(mActiveItem->todo()); |
965 | } | 965 | } |
966 | } | 966 | } |
967 | 967 | ||
968 | void KOTodoView::reparentTodo() | 968 | void KOTodoView::reparentTodo() |
969 | { | 969 | { |
970 | if (mActiveItem) { | 970 | if (mActiveItem) { |
971 | topLevelWidget()->setCaption(i18n("Click on new parent item")); | 971 | topLevelWidget()->setCaption(i18n("Click on new parent item")); |
972 | pendingSubtodo = mActiveItem; | 972 | pendingSubtodo = mActiveItem; |
973 | } | 973 | } |
974 | } | 974 | } |
975 | void KOTodoView::editTodo() | 975 | void KOTodoView::editTodo() |
diff --git a/korganizer/kowhatsnextview.cpp b/korganizer/kowhatsnextview.cpp index 62d7ede..e8574a0 100644 --- a/korganizer/kowhatsnextview.cpp +++ b/korganizer/kowhatsnextview.cpp | |||
@@ -364,399 +364,399 @@ void KOWhatsNextView::updateView() | |||
364 | } | 364 | } |
365 | } | 365 | } |
366 | ev = events.next(); | 366 | ev = events.next(); |
367 | } | 367 | } |
368 | } | 368 | } |
369 | todos = calendar()->todos(); | 369 | todos = calendar()->todos(); |
370 | if (todos.count() > 0) { | 370 | if (todos.count() > 0) { |
371 | Todo *to = todos.first(); | 371 | Todo *to = todos.first(); |
372 | while(to) { | 372 | while(to) { |
373 | if ( !to->isCompleted() ){ | 373 | if ( !to->isCompleted() ){ |
374 | Attendee *me = to->attendeeByMails(KOPrefs::instance()->mAdditionalMails,KOPrefs::instance()->email()); | 374 | Attendee *me = to->attendeeByMails(KOPrefs::instance()->mAdditionalMails,KOPrefs::instance()->email()); |
375 | if (me!=0) { | 375 | if (me!=0) { |
376 | if (me->status()==Attendee::NeedsAction && me->RSVP()) { | 376 | if (me->status()==Attendee::NeedsAction && me->RSVP()) { |
377 | if (replys == 0) { | 377 | if (replys == 0) { |
378 | mText +="<h2><em><font color=\"#000080\">" + i18n("Events and To-Dos that need a reply:") + "</font></em></h2>\n"; | 378 | mText +="<h2><em><font color=\"#000080\">" + i18n("Events and To-Dos that need a reply:") + "</font></em></h2>\n"; |
379 | mText += "<table>\n"; | 379 | mText += "<table>\n"; |
380 | } | 380 | } |
381 | replys++; | 381 | replys++; |
382 | appendEvent(to, true); | 382 | appendEvent(to, true); |
383 | } | 383 | } |
384 | } | 384 | } |
385 | } | 385 | } |
386 | to = todos.next(); | 386 | to = todos.next(); |
387 | } | 387 | } |
388 | } | 388 | } |
389 | if (replys > 0 ) mText += "</table>\n"; | 389 | if (replys > 0 ) mText += "</table>\n"; |
390 | 390 | ||
391 | 391 | ||
392 | mText += "</td></tr>\n</table>\n"; | 392 | mText += "</td></tr>\n</table>\n"; |
393 | 393 | ||
394 | mView->setText(mText); | 394 | mView->setText(mText); |
395 | mView->setFocus(); | 395 | mView->setFocus(); |
396 | 396 | ||
397 | // QPixmap bPix = SmallIcon( "back" ); | 397 | // QPixmap bPix = SmallIcon( "back" ); |
398 | // qDebug("xxxxxxxxxxxxxxxxxxxxx "); | 398 | // qDebug("xxxxxxxxxxxxxxxxxxxxx "); |
399 | // QWidget* test = new QWidget(); | 399 | // QWidget* test = new QWidget(); |
400 | // test->setBackgroundMode(FixedPixmap ); | 400 | // test->setBackgroundMode(FixedPixmap ); |
401 | // test->setBackgroundPixmap ( bPix ); | 401 | // test->setBackgroundPixmap ( bPix ); |
402 | // test->resize( 300, 400 ); | 402 | // test->resize( 300, 400 ); |
403 | // test->show(); | 403 | // test->show(); |
404 | // mView->setBackgroundMode(FixedPixmap ); | 404 | // mView->setBackgroundMode(FixedPixmap ); |
405 | // mView->setBackgroundPixmap ( bPix ); | 405 | // mView->setBackgroundPixmap ( bPix ); |
406 | // qDebug("%s ",mText.latin1()); | 406 | // qDebug("%s ",mText.latin1()); |
407 | } | 407 | } |
408 | 408 | ||
409 | void KOWhatsNextView::appendDay( int i, QDate eventDate ) | 409 | void KOWhatsNextView::appendDay( int i, QDate eventDate ) |
410 | { | 410 | { |
411 | QString date; | 411 | QString date; |
412 | QString day = KGlobal::locale()->formatDate( eventDate , KOPrefs::instance()->mShortDateInViewer); | 412 | QString day = KGlobal::locale()->formatDate( eventDate , KOPrefs::instance()->mShortDateInViewer); |
413 | if ( ! KOPrefs::instance()->mShortDateInViewer && QApplication::desktop()->width() < 320 ) { | 413 | if ( ! KOPrefs::instance()->mShortDateInViewer && QApplication::desktop()->width() < 320 ) { |
414 | if ( i == 0 ) { | 414 | if ( i == 0 ) { |
415 | //mText += "<table>\n"; | 415 | //mText += "<table>\n"; |
416 | return;//date = "<em><font color=\"#008000\"><em>" + day+"</font></em>"; | 416 | return;//date = "<em><font color=\"#008000\"><em>" + day+"</font></em>"; |
417 | } | 417 | } |
418 | else if ( i == 1 ) | 418 | else if ( i == 1 ) |
419 | date = "<em><font color=\"#000080\">" + day + "</font></em>" ; | 419 | date = "<em><font color=\"#000080\">" + day + "</font></em>" ; |
420 | else date = "<em><font color=\"#000080\">" + day + "</font></em>"; | 420 | else date = "<em><font color=\"#000080\">" + day + "</font></em>"; |
421 | mText += "<h2>" + date + "</h2>\n"; | 421 | mText += "<h2>" + date + "</h2>\n"; |
422 | //mText += "<big><big><strong>" + date + "</strong></big></big>\n"; | 422 | //mText += "<big><big><strong>" + date + "</strong></big></big>\n"; |
423 | mText += "<table>\n"; | 423 | mText += "<table>\n"; |
424 | 424 | ||
425 | 425 | ||
426 | 426 | ||
427 | } else { | 427 | } else { |
428 | if ( i == 0 ) { | 428 | if ( i == 0 ) { |
429 | //mText += "<table>\n"; | 429 | //mText += "<table>\n"; |
430 | return;// date = "<font color=\"#008000\"><em>" +i18n("Today: ") +"</em>" + day+"</font>"; | 430 | return;// date = "<font color=\"#008000\"><em>" +i18n("Today: ") +"</em>" + day+"</font>"; |
431 | } | 431 | } |
432 | 432 | ||
433 | #ifdef DESKTOP_VERSION | 433 | #ifdef DESKTOP_VERSION |
434 | else if ( i == 1 ) { | 434 | else if ( i == 1 ) { |
435 | date = "<h2><em><font color=\"#000080\">" + i18n("Tomorrow: ") + day +"</font></em></h2>" ; | 435 | date = "<h2><em><font color=\"#000080\">" + i18n("Tomorrow: ") + day +"</font></em></h2>" ; |
436 | } | 436 | } |
437 | else date = "<h2><em><font color=\"#000080\">" + i18n("In %1 days: ").arg( i ) +day + "</font></em></h2>"; | 437 | else date = "<h2><em><font color=\"#000080\">" + i18n("In %1 days: ").arg( i ) +day + "</font></em></h2>"; |
438 | #else | 438 | #else |
439 | else if ( i == 1 ) { | 439 | else if ( i == 1 ) { |
440 | date = "<em><font color=\"#000080\">" + i18n("Tomorrow: ") + day +"</font></em>" ; | 440 | date = "<em><font color=\"#000080\">" + i18n("Tomorrow: ") + day +"</font></em>" ; |
441 | } | 441 | } |
442 | else date = "<em><font color=\"#000080\">" + i18n("In %1 days: ").arg( i ) +day + "</font></em>"; | 442 | else date = "<em><font color=\"#000080\">" + i18n("In %1 days: ").arg( i ) +day + "</font></em>"; |
443 | 443 | ||
444 | #endif | 444 | #endif |
445 | mText += "<h2>" + date + "</h2>\n"; | 445 | mText += "<h2>" + date + "</h2>\n"; |
446 | //mText += "<big><big><strong>" + date + "</strong></big></big>\n"; | 446 | //mText += "<big><big><strong>" + date + "</strong></big></big>\n"; |
447 | mText += "<table>\n"; | 447 | mText += "<table>\n"; |
448 | } | 448 | } |
449 | } | 449 | } |
450 | 450 | ||
451 | 451 | ||
452 | void KOWhatsNextView::showDates(const QDate &, const QDate &) | 452 | void KOWhatsNextView::showDates(const QDate &, const QDate &) |
453 | { | 453 | { |
454 | updateView(); | 454 | updateView(); |
455 | } | 455 | } |
456 | 456 | ||
457 | void KOWhatsNextView::showEvents(QPtrList<Event>) | 457 | void KOWhatsNextView::showEvents(QPtrList<Event>) |
458 | { | 458 | { |
459 | } | 459 | } |
460 | 460 | ||
461 | void KOWhatsNextView::changeEventDisplay(Event *, int action) | 461 | void KOWhatsNextView::changeEventDisplay(Event *, int action) |
462 | { | 462 | { |
463 | switch(action) { | 463 | switch(action) { |
464 | case KOGlobals::EVENTADDED: | 464 | case KOGlobals::EVENTADDED: |
465 | updateView(); | 465 | updateView(); |
466 | break; | 466 | break; |
467 | case KOGlobals::EVENTEDITED: | 467 | case KOGlobals::EVENTEDITED: |
468 | updateView(); | 468 | updateView(); |
469 | break; | 469 | break; |
470 | case KOGlobals::EVENTDELETED: | 470 | case KOGlobals::EVENTDELETED: |
471 | updateView(); | 471 | updateView(); |
472 | break; | 472 | break; |
473 | default: | 473 | default: |
474 | updateView(); | 474 | updateView(); |
475 | kdDebug() << "KOWhatsNextView::changeEventDisplay(): Illegal action " << action << endl; | 475 | kdDebug() << "KOWhatsNextView::changeEventDisplay(): Illegal action " << action << endl; |
476 | } | 476 | } |
477 | } | 477 | } |
478 | 478 | ||
479 | bool KOWhatsNextView::appendEvent(Incidence *ev, bool reply, bool notRed, bool appendTable ) | 479 | bool KOWhatsNextView::appendEvent(Incidence *ev, bool reply, bool notRed, bool appendTable ) |
480 | { | 480 | { |
481 | if ( !KOPrefs::instance()->mShowSyncEvents && ev->uid().left(15) == QString("last-syncEvent-") ) | 481 | if ( !KOPrefs::instance()->mShowSyncEvents && ev->uid().left(15) == QString("last-syncEvent-") ) |
482 | return false; | 482 | return false; |
483 | QDateTime cdt = QDateTime::currentDateTime(); | 483 | QDateTime cdt = QDateTime::currentDateTime(); |
484 | QDateTime noc; | 484 | QDateTime noc; |
485 | QString tempText; | 485 | QString tempText; |
486 | if ( appendTable && !notRed ) { | 486 | if ( appendTable && !notRed ) { |
487 | tempText = "<table>"; | 487 | tempText = "<table>"; |
488 | } | 488 | } |
489 | bool ok = true; | 489 | bool ok = true; |
490 | if ( reply ) { | 490 | if ( reply ) { |
491 | noc = ev->getNextOccurence( cdt, &ok ); | 491 | noc = ev->getNextOccurence( cdt, &ok ); |
492 | if (! ok && ev->type() == "Event") | 492 | if (! ok && ev->typeID() == eventID) |
493 | return false; | 493 | return false; |
494 | } | 494 | } |
495 | bool bDay = false; | 495 | bool bDay = false; |
496 | if ( ev->isBirthday() || ev->isAnniversary() ) | 496 | if ( ev->isBirthday() || ev->isAnniversary() ) |
497 | bDay = true; | 497 | bDay = true; |
498 | tempText += "<tr><td><b>"; | 498 | tempText += "<tr><td><b>"; |
499 | if (ev->type()=="Event") { | 499 | if (ev->typeID() == eventID ) { |
500 | if (reply) { | 500 | if (reply) { |
501 | if (!ev->doesFloat()) | 501 | if (!ev->doesFloat()) |
502 | tempText += KGlobal::locale()->formatDateTime( noc , KOPrefs::instance()->mShortDateInViewer) +": "; | 502 | tempText += KGlobal::locale()->formatDateTime( noc , KOPrefs::instance()->mShortDateInViewer) +": "; |
503 | else | 503 | else |
504 | tempText += KGlobal::locale()->formatDate( noc.date() , KOPrefs::instance()->mShortDateInViewer) +": "; | 504 | tempText += KGlobal::locale()->formatDate( noc.date() , KOPrefs::instance()->mShortDateInViewer) +": "; |
505 | 505 | ||
506 | } else { | 506 | } else { |
507 | if (!ev->doesFloat()) { | 507 | if (!ev->doesFloat()) { |
508 | Event *event = static_cast<Event *>(ev); | 508 | Event *event = static_cast<Event *>(ev); |
509 | QDateTime st,end; | 509 | QDateTime st,end; |
510 | if ( event->recurrence()->doesRecur() ) { | 510 | if ( event->recurrence()->doesRecur() ) { |
511 | QDate recDate= mEventDate; | 511 | QDate recDate= mEventDate; |
512 | int days = event->dtStart().date().daysTo (event->dtEnd().date() ); | 512 | int days = event->dtStart().date().daysTo (event->dtEnd().date() ); |
513 | while ( ! event->recursOn( recDate ) ) { | 513 | while ( ! event->recursOn( recDate ) ) { |
514 | recDate = recDate.addDays( -1 ); | 514 | recDate = recDate.addDays( -1 ); |
515 | 515 | ||
516 | } | 516 | } |
517 | st = QDateTime ( recDate, event->dtStart().time() ); | 517 | st = QDateTime ( recDate, event->dtStart().time() ); |
518 | end = QDateTime ( recDate.addDays( days ), event->dtEnd().time() ); | 518 | end = QDateTime ( recDate.addDays( days ), event->dtEnd().time() ); |
519 | } | 519 | } |
520 | else { | 520 | else { |
521 | st = event->dtStart(); | 521 | st = event->dtStart(); |
522 | end = event->dtEnd(); | 522 | end = event->dtEnd(); |
523 | } | 523 | } |
524 | 524 | ||
525 | 525 | ||
526 | QString dateText; | 526 | QString dateText; |
527 | // qDebug("%s %s %s %s ", mEventDate.toString().latin1(),event->summary().latin1(), st .toString().latin1(),end.toString().latin1() ); | 527 | // qDebug("%s %s %s %s ", mEventDate.toString().latin1(),event->summary().latin1(), st .toString().latin1(),end.toString().latin1() ); |
528 | if ( st.date() < mEventDate ) | 528 | if ( st.date() < mEventDate ) |
529 | dateText = "++:++-"; | 529 | dateText = "++:++-"; |
530 | else | 530 | else |
531 | dateText = event->dtStartTimeStr() + "-"; | 531 | dateText = event->dtStartTimeStr() + "-"; |
532 | if ( end.date() > mEventDate ) | 532 | if ( end.date() > mEventDate ) |
533 | dateText += "++:++"; | 533 | dateText += "++:++"; |
534 | else | 534 | else |
535 | dateText += event->dtEndTimeStr(); | 535 | dateText += event->dtEndTimeStr(); |
536 | if ( notRed ) | 536 | if ( notRed ) |
537 | tempText += dateText; | 537 | tempText += dateText; |
538 | else { | 538 | else { |
539 | if ( end < cdt ) { | 539 | if ( end < cdt ) { |
540 | if ( !KOPrefs::instance()->mWNViewShowsPast ) | 540 | if ( !KOPrefs::instance()->mWNViewShowsPast ) |
541 | return false; | 541 | return false; |
542 | tempText += "<font color=\"#F00000\">" + dateText + "</font>"; | 542 | tempText += "<font color=\"#F00000\">" + dateText + "</font>"; |
543 | } | 543 | } |
544 | else if ( st < cdt ) | 544 | else if ( st < cdt ) |
545 | tempText += "<font color=\"#008000\">" + dateText + "</font>"; | 545 | tempText += "<font color=\"#008000\">" + dateText + "</font>"; |
546 | else | 546 | else |
547 | tempText += dateText; | 547 | tempText += dateText; |
548 | 548 | ||
549 | } | 549 | } |
550 | 550 | ||
551 | } else { | 551 | } else { |
552 | if ( bDay ) { | 552 | if ( bDay ) { |
553 | 553 | ||
554 | if ( ev->isBirthday()) | 554 | if ( ev->isBirthday()) |
555 | tempText += "<font color=\"#00B000\">" + i18n("Birthday") +":</font>"; | 555 | tempText += "<font color=\"#00B000\">" + i18n("Birthday") +":</font>"; |
556 | else | 556 | else |
557 | tempText += "<font color=\"#00B0000\">" + i18n("Anniversary")+":</font>"; | 557 | tempText += "<font color=\"#00B0000\">" + i18n("Anniversary")+":</font>"; |
558 | } else { | 558 | } else { |
559 | tempText += i18n("Allday:"); | 559 | tempText += i18n("Allday:"); |
560 | } | 560 | } |
561 | 561 | ||
562 | } | 562 | } |
563 | } | 563 | } |
564 | } else { | 564 | } else { |
565 | mTodos.append( ev ); | 565 | mTodos.append( ev ); |
566 | tempText += i18n("ToDo:"); | 566 | tempText += i18n("ToDo:"); |
567 | if (reply) { | 567 | if (reply) { |
568 | tempText += " "; | 568 | tempText += " "; |
569 | if ( noc != cdt ) { | 569 | if ( noc != cdt ) { |
570 | tempText += KGlobal::locale()->formatDate( noc.date() , KOPrefs::instance()->mShortDateInViewer) +": "; | 570 | tempText += KGlobal::locale()->formatDate( noc.date() , KOPrefs::instance()->mShortDateInViewer) +": "; |
571 | } | 571 | } |
572 | } else { | 572 | } else { |
573 | if ( ((Todo*)ev)->dtDue().date() < QDate::currentDate() ) { | 573 | if ( ((Todo*)ev)->dtDue().date() < QDate::currentDate() ) { |
574 | // tempText +="<font color=\"#F00000\">" + i18n("O-due!") + "</font>"; | 574 | // tempText +="<font color=\"#F00000\">" + i18n("O-due!") + "</font>"; |
575 | QString dfs = KGlobal::locale()->dateFormatShort(); | 575 | QString dfs = KGlobal::locale()->dateFormatShort(); |
576 | KGlobal::locale()->setDateFormatShort("%d.%b"); | 576 | KGlobal::locale()->setDateFormatShort("%d.%b"); |
577 | tempText +="<font color=\"#F00000\">" + KGlobal::locale()->formatDate(((Todo*)ev)->dtDue().date(), true, KLocale::Userdefined) + "</font>"; | 577 | tempText +="<font color=\"#F00000\">" + KGlobal::locale()->formatDate(((Todo*)ev)->dtDue().date(), true, KLocale::Userdefined) + "</font>"; |
578 | KGlobal::locale()->setDateFormatShort(dfs); | 578 | KGlobal::locale()->setDateFormatShort(dfs); |
579 | } else { | 579 | } else { |
580 | if (!ev->doesFloat() ) | 580 | if (!ev->doesFloat() ) |
581 | if( ( (Todo*)ev)->dtDue() < cdt ) { | 581 | if( ( (Todo*)ev)->dtDue() < cdt ) { |
582 | tempText +="<font color=\"#F00000\">" + ((Todo*)ev)->dtDueTimeStr() + "</font>"; | 582 | tempText +="<font color=\"#F00000\">" + ((Todo*)ev)->dtDueTimeStr() + "</font>"; |
583 | 583 | ||
584 | 584 | ||
585 | } else | 585 | } else |
586 | tempText +=((Todo*)ev)->dtDueTimeStr(); | 586 | tempText +=((Todo*)ev)->dtDueTimeStr(); |
587 | mTodos.append( ev ); | 587 | mTodos.append( ev ); |
588 | } | 588 | } |
589 | } | 589 | } |
590 | } | 590 | } |
591 | tempText += "</b></td><td>"; | 591 | tempText += "</b></td><td>"; |
592 | bool needClose = false; | 592 | bool needClose = false; |
593 | if ( ev->cancelled() ) { | 593 | if ( ev->cancelled() ) { |
594 | tempText += "<font color=\"#F00000\">[c"; | 594 | tempText += "<font color=\"#F00000\">[c"; |
595 | needClose =true; | 595 | needClose =true; |
596 | 596 | ||
597 | } | 597 | } |
598 | if ( ev->isAlarmEnabled() ) { | 598 | if ( ev->isAlarmEnabled() ) { |
599 | if ( !needClose) | 599 | if ( !needClose) |
600 | tempText +="["; | 600 | tempText +="["; |
601 | tempText += "a"; | 601 | tempText += "a"; |
602 | needClose =true; | 602 | needClose =true; |
603 | 603 | ||
604 | } | 604 | } |
605 | if ( ev->description().length() > 0 ) { | 605 | if ( ev->description().length() > 0 ) { |
606 | if ( !needClose) | 606 | if ( !needClose) |
607 | tempText +="["; | 607 | tempText +="["; |
608 | tempText += "i"; | 608 | tempText += "i"; |
609 | needClose =true; | 609 | needClose =true; |
610 | } | 610 | } |
611 | if ( ev->recurrence()->doesRecur() ) { | 611 | if ( ev->recurrence()->doesRecur() ) { |
612 | if ( !needClose) | 612 | if ( !needClose) |
613 | tempText +="["; | 613 | tempText +="["; |
614 | tempText += "r"; | 614 | tempText += "r"; |
615 | needClose =true; | 615 | needClose =true; |
616 | } | 616 | } |
617 | if ( needClose ) { | 617 | if ( needClose ) { |
618 | tempText += "] "; | 618 | tempText += "] "; |
619 | } | 619 | } |
620 | if ( ev->cancelled() ) | 620 | if ( ev->cancelled() ) |
621 | tempText += "</font>"; | 621 | tempText += "</font>"; |
622 | tempText += "<a "; | 622 | tempText += "<a "; |
623 | if (ev->type()=="Event") tempText += "href=\"event:"; | 623 | if (ev->typeID() == eventID ) tempText += "href=\"event:"; |
624 | if (ev->type()=="Todo") tempText += "href=\"todo:"; | 624 | if (ev->typeID() == todoID ) tempText += "href=\"todo:"; |
625 | tempText += ev->uid() + "\">"; | 625 | tempText += ev->uid() + "\">"; |
626 | if ( ev->summary().length() > 0 ) | 626 | if ( ev->summary().length() > 0 ) |
627 | tempText += ev->summary(); | 627 | tempText += ev->summary(); |
628 | else | 628 | else |
629 | tempText += i18n("-no summary-"); | 629 | tempText += i18n("-no summary-"); |
630 | if ( bDay ) { | 630 | if ( bDay ) { |
631 | noc = ev->getNextOccurence( cdt.addDays(-1), &ok ); | 631 | noc = ev->getNextOccurence( cdt.addDays(-1), &ok ); |
632 | if ( ok ) { | 632 | if ( ok ) { |
633 | int years = 0; | 633 | int years = 0; |
634 | if ( ev->type() =="Todo" ) { | 634 | if ( ev->typeID() == todoID ) { |
635 | years = noc.date().year() -((Todo*)ev)->dtDue().date().year(); | 635 | years = noc.date().year() -((Todo*)ev)->dtDue().date().year(); |
636 | } else | 636 | } else |
637 | years = noc.date().year() - ev->dtStart().date().year(); | 637 | years = noc.date().year() - ev->dtStart().date().year(); |
638 | tempText += i18n(" (%1 y.)"). arg( years ); | 638 | tempText += i18n(" (%1 y.)"). arg( years ); |
639 | } | 639 | } |
640 | } | 640 | } |
641 | 641 | ||
642 | tempText += "</a>"; | 642 | tempText += "</a>"; |
643 | if ( KOPrefs::instance()->mWNViewShowLocation ) | 643 | if ( KOPrefs::instance()->mWNViewShowLocation ) |
644 | if ( !ev->location().isEmpty() ) | 644 | if ( !ev->location().isEmpty() ) |
645 | tempText += " ("+ev->location() +")"; | 645 | tempText += " ("+ev->location() +")"; |
646 | if ( ev->relatedTo() && KOPrefs::instance()->mWNViewShowsParents) | 646 | if ( ev->relatedTo() && KOPrefs::instance()->mWNViewShowsParents) |
647 | tempText += " ["+ev->relatedTo()->summary() +"]"; | 647 | tempText += " ["+ev->relatedTo()->summary() +"]"; |
648 | tempText += "</td></tr>\n"; | 648 | tempText += "</td></tr>\n"; |
649 | mText += tempText; | 649 | mText += tempText; |
650 | return true; | 650 | return true; |
651 | } | 651 | } |
652 | 652 | ||
653 | bool KOWhatsNextView::appendTodo(Incidence *ev, QString ind , bool isSub ) | 653 | bool KOWhatsNextView::appendTodo(Incidence *ev, QString ind , bool isSub ) |
654 | { | 654 | { |
655 | if ( mTodos.find( ev ) != mTodos.end() ) return false; | 655 | if ( mTodos.find( ev ) != mTodos.end() ) return false; |
656 | 656 | ||
657 | mTodos.append( ev ); | 657 | mTodos.append( ev ); |
658 | if ( !isSub ) | 658 | if ( !isSub ) |
659 | mText += "<p>"; | 659 | mText += "<p>"; |
660 | else | 660 | else |
661 | mText += "<li>"; | 661 | mText += "<li>"; |
662 | mText += "[" +QString::number(ev->priority()) + "/" + QString::number(((Todo*)ev)->percentComplete())+"%] "; | 662 | mText += "[" +QString::number(ev->priority()) + "/" + QString::number(((Todo*)ev)->percentComplete())+"%] "; |
663 | 663 | ||
664 | 664 | ||
665 | mText += ind; | 665 | mText += ind; |
666 | bool needClose = false; | 666 | bool needClose = false; |
667 | if ( ev->cancelled() ) { | 667 | if ( ev->cancelled() ) { |
668 | mText += "<font color=\"#F00000\">[c"; | 668 | mText += "<font color=\"#F00000\">[c"; |
669 | needClose =true; | 669 | needClose =true; |
670 | 670 | ||
671 | } | 671 | } |
672 | if ( ev->isAlarmEnabled() ) { | 672 | if ( ev->isAlarmEnabled() ) { |
673 | if ( !needClose) | 673 | if ( !needClose) |
674 | mText +="["; | 674 | mText +="["; |
675 | mText += "a"; | 675 | mText += "a"; |
676 | needClose =true; | 676 | needClose =true; |
677 | 677 | ||
678 | } | 678 | } |
679 | 679 | ||
680 | if ( ev->description().length() > 0 ) { | 680 | if ( ev->description().length() > 0 ) { |
681 | if ( !needClose) | 681 | if ( !needClose) |
682 | mText +="["; | 682 | mText +="["; |
683 | mText += "i"; | 683 | mText += "i"; |
684 | needClose =true; | 684 | needClose =true; |
685 | } | 685 | } |
686 | if ( ev->doesRecur() ) { | 686 | if ( ev->doesRecur() ) { |
687 | if ( !needClose) | 687 | if ( !needClose) |
688 | mText +="["; | 688 | mText +="["; |
689 | mText += "r"; | 689 | mText += "r"; |
690 | needClose =true; | 690 | needClose =true; |
691 | } | 691 | } |
692 | // if ( ev->recurrence()->doesRecur() ) { | 692 | // if ( ev->recurrence()->doesRecur() ) { |
693 | // if ( !needClose) | 693 | // if ( !needClose) |
694 | // mText +="("; | 694 | // mText +="("; |
695 | // mText += "r"; | 695 | // mText += "r"; |
696 | // needClose =true; | 696 | // needClose =true; |
697 | // } | 697 | // } |
698 | if ( needClose ) | 698 | if ( needClose ) |
699 | mText += "] "; | 699 | mText += "] "; |
700 | if ( ev->cancelled() ) | 700 | if ( ev->cancelled() ) |
701 | mText += "</font>"; | 701 | mText += "</font>"; |
702 | mText += "<a href=\"todo:" + ev->uid() + "\">"; | 702 | mText += "<a href=\"todo:" + ev->uid() + "\">"; |
703 | if ( ev->summary().length() > 0 ) | 703 | if ( ev->summary().length() > 0 ) |
704 | mText += ev->summary(); | 704 | mText += ev->summary(); |
705 | else | 705 | else |
706 | mText += i18n("-no summary-"); | 706 | mText += i18n("-no summary-"); |
707 | mText += "</a>"; | 707 | mText += "</a>"; |
708 | if ( ((Todo*)ev)->hasDueDate () ) { | 708 | if ( ((Todo*)ev)->hasDueDate () ) { |
709 | QString year = ""; | 709 | QString year = ""; |
710 | int ye = ((Todo*)ev)->dtDue().date().year(); | 710 | int ye = ((Todo*)ev)->dtDue().date().year(); |
711 | if ( QDateTime::currentDateTime().date().year() != ye ) | 711 | if ( QDateTime::currentDateTime().date().year() != ye ) |
712 | year = QString::number( ye ); | 712 | year = QString::number( ye ); |
713 | QString dfs = KGlobal::locale()->dateFormatShort(); | 713 | QString dfs = KGlobal::locale()->dateFormatShort(); |
714 | KGlobal::locale()->setDateFormatShort("%d.%b"); | 714 | KGlobal::locale()->setDateFormatShort("%d.%b"); |
715 | mText +="<font color=\"#00A000\"> [" + KGlobal::locale()->formatDate(((Todo*)ev)->dtDue().date(), true, KLocale::Userdefined) + "."+ year +"]</font>"; | 715 | mText +="<font color=\"#00A000\"> [" + KGlobal::locale()->formatDate(((Todo*)ev)->dtDue().date(), true, KLocale::Userdefined) + "."+ year +"]</font>"; |
716 | KGlobal::locale()->setDateFormatShort(dfs); | 716 | KGlobal::locale()->setDateFormatShort(dfs); |
717 | } | 717 | } |
718 | if ( KOPrefs::instance()->mWNViewShowLocation ) | 718 | if ( KOPrefs::instance()->mWNViewShowLocation ) |
719 | if ( !ev->location().isEmpty() ) | 719 | if ( !ev->location().isEmpty() ) |
720 | mText += " ("+ev->location() +")"; | 720 | mText += " ("+ev->location() +")"; |
721 | if ( !isSub ) { | 721 | if ( !isSub ) { |
722 | if ( ((Todo*)ev)->relatedTo()&& KOPrefs::instance()->mWNViewShowsParents) | 722 | if ( ((Todo*)ev)->relatedTo()&& KOPrefs::instance()->mWNViewShowsParents) |
723 | mText += " ["+ev->relatedTo()->summary() +"]"; | 723 | mText += " ["+ev->relatedTo()->summary() +"]"; |
724 | mText += "</p>\n"; | 724 | mText += "</p>\n"; |
725 | } | 725 | } |
726 | else { | 726 | else { |
727 | ind += "-"; | 727 | ind += "-"; |
728 | mText += "</li>\n"; | 728 | mText += "</li>\n"; |
729 | } | 729 | } |
730 | QPtrList<Incidence> Relations = ev->relations(); | 730 | QPtrList<Incidence> Relations = ev->relations(); |
731 | Incidence *to; | 731 | Incidence *to; |
732 | for (to=Relations.first();to;to=Relations.next()) { | 732 | for (to=Relations.first();to;to=Relations.next()) { |
733 | if (!((Todo*)to)->isCompleted() && ((Todo*)to)->priority() <= mCurrentMaxPrio ) | 733 | if (!((Todo*)to)->isCompleted() && ((Todo*)to)->priority() <= mCurrentMaxPrio ) |
734 | appendTodo( to, ind , true ); | 734 | appendTodo( to, ind , true ); |
735 | } | 735 | } |
736 | 736 | ||
737 | return true; | 737 | return true; |
738 | } | 738 | } |
739 | 739 | ||
740 | /* | 740 | /* |
741 | void KOWhatsNextView::createEventViewer() | 741 | void KOWhatsNextView::createEventViewer() |
742 | { | 742 | { |
743 | if (!mEventViewer) { | 743 | if (!mEventViewer) { |
744 | 744 | ||
745 | mEventViewer = new KOEventViewerDialog(this); | 745 | mEventViewer = new KOEventViewerDialog(this); |
746 | } | 746 | } |
747 | } | 747 | } |
748 | */ | 748 | */ |
749 | void KOWhatsNextView::setEventViewer(KOEventViewerDialog* v ) | 749 | void KOWhatsNextView::setEventViewer(KOEventViewerDialog* v ) |
750 | { | 750 | { |
751 | mEventViewer = v; | 751 | mEventViewer = v; |
752 | } | 752 | } |
753 | 753 | ||
754 | // TODO: Create this function in CalendarView and remove it from here | 754 | // TODO: Create this function in CalendarView and remove it from here |
755 | void KOWhatsNextView::showIncidence(const QString &uid) | 755 | void KOWhatsNextView::showIncidence(const QString &uid) |
756 | { | 756 | { |
757 | 757 | ||
758 | if ( !mEventViewer ) { | 758 | if ( !mEventViewer ) { |
759 | qDebug("KOWhatsNextView::showIncidence::sorry, no event viewer set "); | 759 | qDebug("KOWhatsNextView::showIncidence::sorry, no event viewer set "); |
760 | return; | 760 | return; |
761 | } | 761 | } |
762 | //kdDebug() << "KOWhatsNextView::showIncidence(): " << uid << endl; | 762 | //kdDebug() << "KOWhatsNextView::showIncidence(): " << uid << endl; |
diff --git a/korganizer/mainwindow.cpp b/korganizer/mainwindow.cpp index 53b65b2..481eab4 100644 --- a/korganizer/mainwindow.cpp +++ b/korganizer/mainwindow.cpp | |||
@@ -1207,261 +1207,261 @@ void MainWindow::initActions() | |||
1207 | connect( action, SIGNAL( activated() ), | 1207 | connect( action, SIGNAL( activated() ), |
1208 | mView, SLOT( goNext() ) ); | 1208 | mView, SLOT( goNext() ) ); |
1209 | action->addTo( navigatorToolBar ); | 1209 | action->addTo( navigatorToolBar ); |
1210 | } | 1210 | } |
1211 | icon = loadPixmap( pathString + "2rightarrowB" ); | 1211 | icon = loadPixmap( pathString + "2rightarrowB" ); |
1212 | configureToolBarMenu->insertItem(icon, i18n("Next month"), 230); | 1212 | configureToolBarMenu->insertItem(icon, i18n("Next month"), 230); |
1213 | if (p-> mShowIconForwardFast) { | 1213 | if (p-> mShowIconForwardFast) { |
1214 | action = new QAction( i18n("Next month"), icon, i18n("Next month"),0 , this ); | 1214 | action = new QAction( i18n("Next month"), icon, i18n("Next month"),0 , this ); |
1215 | connect( action, SIGNAL( activated() ), | 1215 | connect( action, SIGNAL( activated() ), |
1216 | mView, SLOT( goNextMonth() ) ); | 1216 | mView, SLOT( goNextMonth() ) ); |
1217 | action->addTo( navigatorToolBar ); | 1217 | action->addTo( navigatorToolBar ); |
1218 | } | 1218 | } |
1219 | 1219 | ||
1220 | 1220 | ||
1221 | configureToolBarMenu->insertItem(i18n("What's This?"), 300, 6); | 1221 | configureToolBarMenu->insertItem(i18n("What's This?"), 300, 6); |
1222 | 1222 | ||
1223 | 1223 | ||
1224 | if ( p->mShowIconNavigator ) configureToolBarMenu->setItemChecked( 22 , true); | 1224 | if ( p->mShowIconNavigator ) configureToolBarMenu->setItemChecked( 22 , true); |
1225 | if ( p->mShowIconAllday ) configureToolBarMenu->setItemChecked( 24 , true); | 1225 | if ( p->mShowIconAllday ) configureToolBarMenu->setItemChecked( 24 , true); |
1226 | if ( p->mShowIconFilterview ) configureToolBarMenu->setItemChecked( 26 , true); | 1226 | if ( p->mShowIconFilterview ) configureToolBarMenu->setItemChecked( 26 , true); |
1227 | if ( p->mShowIconToggleFull ) configureToolBarMenu->setItemChecked( 28 , true); | 1227 | if ( p->mShowIconToggleFull ) configureToolBarMenu->setItemChecked( 28 , true); |
1228 | 1228 | ||
1229 | if (p-> mShowIconNewEvent) | 1229 | if (p-> mShowIconNewEvent) |
1230 | configureToolBarMenu->setItemChecked( 10, true ); | 1230 | configureToolBarMenu->setItemChecked( 10, true ); |
1231 | if (p->mShowIconNewTodo ) | 1231 | if (p->mShowIconNewTodo ) |
1232 | configureToolBarMenu->setItemChecked( 20, true ); | 1232 | configureToolBarMenu->setItemChecked( 20, true ); |
1233 | if (p-> mShowIconSearch) | 1233 | if (p-> mShowIconSearch) |
1234 | configureToolBarMenu->setItemChecked( 120, true ); | 1234 | configureToolBarMenu->setItemChecked( 120, true ); |
1235 | if (p-> mShowIconList) | 1235 | if (p-> mShowIconList) |
1236 | configureToolBarMenu->setItemChecked( 30, true ); | 1236 | configureToolBarMenu->setItemChecked( 30, true ); |
1237 | if (p-> mShowIconDay1) | 1237 | if (p-> mShowIconDay1) |
1238 | configureToolBarMenu->setItemChecked( 40, true ); | 1238 | configureToolBarMenu->setItemChecked( 40, true ); |
1239 | if (p-> mShowIconDay5) | 1239 | if (p-> mShowIconDay5) |
1240 | configureToolBarMenu->setItemChecked( 50, true ); | 1240 | configureToolBarMenu->setItemChecked( 50, true ); |
1241 | if (p-> mShowIconDay6) | 1241 | if (p-> mShowIconDay6) |
1242 | configureToolBarMenu->setItemChecked( 75, true ); | 1242 | configureToolBarMenu->setItemChecked( 75, true ); |
1243 | if (p-> mShowIconDay7) | 1243 | if (p-> mShowIconDay7) |
1244 | configureToolBarMenu->setItemChecked( 60, true ); | 1244 | configureToolBarMenu->setItemChecked( 60, true ); |
1245 | if (p-> mShowIconMonth) | 1245 | if (p-> mShowIconMonth) |
1246 | configureToolBarMenu->setItemChecked( 70, true ); | 1246 | configureToolBarMenu->setItemChecked( 70, true ); |
1247 | if (p-> mShowIconTodoview) | 1247 | if (p-> mShowIconTodoview) |
1248 | configureToolBarMenu->setItemChecked( 80, true ); | 1248 | configureToolBarMenu->setItemChecked( 80, true ); |
1249 | if (p-> mShowIconBackFast) | 1249 | if (p-> mShowIconBackFast) |
1250 | configureToolBarMenu->setItemChecked( 200, true ); | 1250 | configureToolBarMenu->setItemChecked( 200, true ); |
1251 | if (p-> mShowIconBack) | 1251 | if (p-> mShowIconBack) |
1252 | configureToolBarMenu->setItemChecked( 210, true ); | 1252 | configureToolBarMenu->setItemChecked( 210, true ); |
1253 | if (p-> mShowIconToday) | 1253 | if (p-> mShowIconToday) |
1254 | configureToolBarMenu->setItemChecked( 130, true ); | 1254 | configureToolBarMenu->setItemChecked( 130, true ); |
1255 | if (p-> mShowIconForward) | 1255 | if (p-> mShowIconForward) |
1256 | configureToolBarMenu->setItemChecked( 220, true ); | 1256 | configureToolBarMenu->setItemChecked( 220, true ); |
1257 | if (p-> mShowIconForwardFast) | 1257 | if (p-> mShowIconForwardFast) |
1258 | configureToolBarMenu->setItemChecked( 230, true ); | 1258 | configureToolBarMenu->setItemChecked( 230, true ); |
1259 | if (p-> mShowIconNextDays) | 1259 | if (p-> mShowIconNextDays) |
1260 | configureToolBarMenu->setItemChecked( 100, true ); | 1260 | configureToolBarMenu->setItemChecked( 100, true ); |
1261 | if (p-> mShowIconNext) | 1261 | if (p-> mShowIconNext) |
1262 | configureToolBarMenu->setItemChecked( 110, true ); | 1262 | configureToolBarMenu->setItemChecked( 110, true ); |
1263 | if (p-> mShowIconJournal) | 1263 | if (p-> mShowIconJournal) |
1264 | configureToolBarMenu->setItemChecked( 90, true ); | 1264 | configureToolBarMenu->setItemChecked( 90, true ); |
1265 | if (p-> mShowIconWhatsThis) | 1265 | if (p-> mShowIconWhatsThis) |
1266 | configureToolBarMenu->setItemChecked( 300, true ); | 1266 | configureToolBarMenu->setItemChecked( 300, true ); |
1267 | if (p-> mShowIconWeekNum) | 1267 | if (p-> mShowIconWeekNum) |
1268 | configureToolBarMenu->setItemChecked( 400, true ); | 1268 | configureToolBarMenu->setItemChecked( 400, true ); |
1269 | if (!p-> mShowIconStretch) { | 1269 | if (!p-> mShowIconStretch) { |
1270 | QLabel* dummy = new QLabel( iconToolBar ); | 1270 | QLabel* dummy = new QLabel( iconToolBar ); |
1271 | dummy->setBackgroundColor( iconToolBar->backgroundColor() ); | 1271 | dummy->setBackgroundColor( iconToolBar->backgroundColor() ); |
1272 | dummy->setMinimumWidth( 0 ); | 1272 | dummy->setMinimumWidth( 0 ); |
1273 | iconToolBar->setStretchableWidget ( dummy ) ; | 1273 | iconToolBar->setStretchableWidget ( dummy ) ; |
1274 | } | 1274 | } |
1275 | else { | 1275 | else { |
1276 | iconToolBar->setHorizontalStretchable (true ); | 1276 | iconToolBar->setHorizontalStretchable (true ); |
1277 | viewToolBar->setHorizontalStretchable (true ); | 1277 | viewToolBar->setHorizontalStretchable (true ); |
1278 | navigatorToolBar->setHorizontalStretchable (true ); | 1278 | navigatorToolBar->setHorizontalStretchable (true ); |
1279 | iconToolBar->setVerticalStretchable (true ); | 1279 | iconToolBar->setVerticalStretchable (true ); |
1280 | viewToolBar->setVerticalStretchable (true ); | 1280 | viewToolBar->setVerticalStretchable (true ); |
1281 | navigatorToolBar->setVerticalStretchable (true ); | 1281 | navigatorToolBar->setVerticalStretchable (true ); |
1282 | configureToolBarMenu->setItemChecked( 5, true ); | 1282 | configureToolBarMenu->setItemChecked( 5, true ); |
1283 | } | 1283 | } |
1284 | if (p-> mShowIconFilter) | 1284 | if (p-> mShowIconFilter) |
1285 | configureToolBarMenu->setItemChecked( 7, true ); | 1285 | configureToolBarMenu->setItemChecked( 7, true ); |
1286 | if (p-> mShowIconOnetoolbar) | 1286 | if (p-> mShowIconOnetoolbar) |
1287 | configureToolBarMenu->setItemChecked( 6, true ); | 1287 | configureToolBarMenu->setItemChecked( 6, true ); |
1288 | 1288 | ||
1289 | 1289 | ||
1290 | if ( filterMenubar ) { | 1290 | if ( filterMenubar ) { |
1291 | filterMenubar->reparent(filterToolBar,0,QPoint(0,0) ); | 1291 | filterMenubar->reparent(filterToolBar,0,QPoint(0,0) ); |
1292 | connect( mView->filterView(), SIGNAL( filterChanged() ), SLOT( updateFilterToolbar() ) ); | 1292 | connect( mView->filterView(), SIGNAL( filterChanged() ), SLOT( updateFilterToolbar() ) ); |
1293 | } | 1293 | } |
1294 | connect( configureToolBarMenu, SIGNAL( activated( int ) ),this, SLOT(configureToolBar( int ) ) ); | 1294 | connect( configureToolBarMenu, SIGNAL( activated( int ) ),this, SLOT(configureToolBar( int ) ) ); |
1295 | configureAgenda( p->mHourSize ); | 1295 | configureAgenda( p->mHourSize ); |
1296 | connect( configureAgendaMenu, SIGNAL( activated( int ) ),this, SLOT(configureAgenda( int ) ) ); | 1296 | connect( configureAgendaMenu, SIGNAL( activated( int ) ),this, SLOT(configureAgenda( int ) ) ); |
1297 | } | 1297 | } |
1298 | 1298 | ||
1299 | void MainWindow::exportToPhone( int mode ) | 1299 | void MainWindow::exportToPhone( int mode ) |
1300 | { | 1300 | { |
1301 | 1301 | ||
1302 | //ex2phone->insertItem(i18n("Complete calendar..."), 1 ); | 1302 | //ex2phone->insertItem(i18n("Complete calendar..."), 1 ); |
1303 | //ex2phone->insertItem(i18n("Filtered calendar..."), 2 ); | 1303 | //ex2phone->insertItem(i18n("Filtered calendar..."), 2 ); |
1304 | KOex2phonePrefs ex2phone; | 1304 | KOex2phonePrefs ex2phone; |
1305 | 1305 | ||
1306 | ex2phone.mPhoneConnection->setText( KPimGlobalPrefs::instance()->mEx2PhoneConnection ); | 1306 | ex2phone.mPhoneConnection->setText( KPimGlobalPrefs::instance()->mEx2PhoneConnection ); |
1307 | ex2phone.mPhoneDevice->setText( KPimGlobalPrefs::instance()->mEx2PhoneDevice ); | 1307 | ex2phone.mPhoneDevice->setText( KPimGlobalPrefs::instance()->mEx2PhoneDevice ); |
1308 | ex2phone.mPhoneModel->setText( KPimGlobalPrefs::instance()->mEx2PhoneModel ); | 1308 | ex2phone.mPhoneModel->setText( KPimGlobalPrefs::instance()->mEx2PhoneModel ); |
1309 | if ( mode == 1 ) | 1309 | if ( mode == 1 ) |
1310 | ex2phone.setCaption(i18n("Export complete calendar")); | 1310 | ex2phone.setCaption(i18n("Export complete calendar")); |
1311 | if ( mode == 2 ) | 1311 | if ( mode == 2 ) |
1312 | ex2phone.setCaption(i18n("Export filtered calendar")); | 1312 | ex2phone.setCaption(i18n("Export filtered calendar")); |
1313 | 1313 | ||
1314 | if ( !ex2phone.exec() ) { | 1314 | if ( !ex2phone.exec() ) { |
1315 | return; | 1315 | return; |
1316 | } | 1316 | } |
1317 | KPimGlobalPrefs::instance()->mEx2PhoneConnection = ex2phone.mPhoneConnection->text(); | 1317 | KPimGlobalPrefs::instance()->mEx2PhoneConnection = ex2phone.mPhoneConnection->text(); |
1318 | KPimGlobalPrefs::instance()->mEx2PhoneDevice = ex2phone.mPhoneDevice->text(); | 1318 | KPimGlobalPrefs::instance()->mEx2PhoneDevice = ex2phone.mPhoneDevice->text(); |
1319 | KPimGlobalPrefs::instance()->mEx2PhoneModel = ex2phone.mPhoneModel->text(); | 1319 | KPimGlobalPrefs::instance()->mEx2PhoneModel = ex2phone.mPhoneModel->text(); |
1320 | 1320 | ||
1321 | int inFuture = 0; | 1321 | int inFuture = 0; |
1322 | if ( ex2phone.mWriteBackFuture->isChecked() ) | 1322 | if ( ex2phone.mWriteBackFuture->isChecked() ) |
1323 | inFuture = ex2phone.mWriteBackFutureWeeks->value(); | 1323 | inFuture = ex2phone.mWriteBackFutureWeeks->value(); |
1324 | QPtrList<Incidence> delSel; | 1324 | QPtrList<Incidence> delSel; |
1325 | if ( mode == 1 ) | 1325 | if ( mode == 1 ) |
1326 | delSel = mCalendar->rawIncidences(); | 1326 | delSel = mCalendar->rawIncidences(); |
1327 | if ( mode == 2 ) | 1327 | if ( mode == 2 ) |
1328 | delSel = mCalendar->incidences(); | 1328 | delSel = mCalendar->incidences(); |
1329 | CalendarLocal* cal = new CalendarLocal(); | 1329 | CalendarLocal* cal = new CalendarLocal(); |
1330 | cal->setLocalTime(); | 1330 | cal->setLocalTime(); |
1331 | Incidence *incidence = delSel.first(); | 1331 | Incidence *incidence = delSel.first(); |
1332 | QDateTime cur = QDateTime::currentDateTime().addDays( -7 ); | 1332 | QDateTime cur = QDateTime::currentDateTime().addDays( -7 ); |
1333 | QDateTime end = cur.addDays( ( inFuture +1 ) *7 ); | 1333 | QDateTime end = cur.addDays( ( inFuture +1 ) *7 ); |
1334 | while ( incidence ) { | 1334 | while ( incidence ) { |
1335 | if ( incidence->type() != "Journal" ) { | 1335 | if ( incidence->typeID() != journalID ) { |
1336 | bool add = true; | 1336 | bool add = true; |
1337 | if ( inFuture ) { | 1337 | if ( inFuture ) { |
1338 | QDateTime dt; | 1338 | QDateTime dt; |
1339 | if ( incidence->type() == "Todo" ) { | 1339 | if ( incidence->typeID() == todoID ) { |
1340 | Todo * t = (Todo*)incidence; | 1340 | Todo * t = (Todo*)incidence; |
1341 | if ( t->hasDueDate() ) | 1341 | if ( t->hasDueDate() ) |
1342 | dt = t->dtDue(); | 1342 | dt = t->dtDue(); |
1343 | else | 1343 | else |
1344 | dt = cur.addSecs( 62 ); | 1344 | dt = cur.addSecs( 62 ); |
1345 | } | 1345 | } |
1346 | else { | 1346 | else { |
1347 | bool ok; | 1347 | bool ok; |
1348 | dt = incidence->getNextOccurence( cur, &ok ); | 1348 | dt = incidence->getNextOccurence( cur, &ok ); |
1349 | if ( !ok ) | 1349 | if ( !ok ) |
1350 | dt = cur.addSecs( -62 ); | 1350 | dt = cur.addSecs( -62 ); |
1351 | } | 1351 | } |
1352 | if ( dt < cur || dt > end ) { | 1352 | if ( dt < cur || dt > end ) { |
1353 | add = false; | 1353 | add = false; |
1354 | } | 1354 | } |
1355 | } | 1355 | } |
1356 | if ( add ) { | 1356 | if ( add ) { |
1357 | Incidence *in = incidence->clone(); | 1357 | Incidence *in = incidence->clone(); |
1358 | cal->addIncidence( in ); | 1358 | cal->addIncidence( in ); |
1359 | } | 1359 | } |
1360 | } | 1360 | } |
1361 | incidence = delSel.next(); | 1361 | incidence = delSel.next(); |
1362 | } | 1362 | } |
1363 | PhoneAccess::writeConfig( KPimGlobalPrefs::instance()->mEx2PhoneDevice, | 1363 | PhoneAccess::writeConfig( KPimGlobalPrefs::instance()->mEx2PhoneDevice, |
1364 | KPimGlobalPrefs::instance()->mEx2PhoneConnection, | 1364 | KPimGlobalPrefs::instance()->mEx2PhoneConnection, |
1365 | KPimGlobalPrefs::instance()->mEx2PhoneModel ); | 1365 | KPimGlobalPrefs::instance()->mEx2PhoneModel ); |
1366 | 1366 | ||
1367 | setCaption( i18n("Writing to phone...")); | 1367 | setCaption( i18n("Writing to phone...")); |
1368 | if ( PhoneFormat::writeToPhone( cal ) ) | 1368 | if ( PhoneFormat::writeToPhone( cal ) ) |
1369 | setCaption( i18n("Export to phone successful!")); | 1369 | setCaption( i18n("Export to phone successful!")); |
1370 | else | 1370 | else |
1371 | setCaption( i18n("Error exporting to phone!")); | 1371 | setCaption( i18n("Error exporting to phone!")); |
1372 | delete cal; | 1372 | delete cal; |
1373 | } | 1373 | } |
1374 | 1374 | ||
1375 | 1375 | ||
1376 | void MainWindow::setDefaultPreferences() | 1376 | void MainWindow::setDefaultPreferences() |
1377 | { | 1377 | { |
1378 | KOPrefs *p = KOPrefs::instance(); | 1378 | KOPrefs *p = KOPrefs::instance(); |
1379 | 1379 | ||
1380 | p->mCompactDialogs = true; | 1380 | p->mCompactDialogs = true; |
1381 | p->mConfirm = true; | 1381 | p->mConfirm = true; |
1382 | // p->mEnableQuickTodo = false; | 1382 | // p->mEnableQuickTodo = false; |
1383 | 1383 | ||
1384 | } | 1384 | } |
1385 | 1385 | ||
1386 | QString MainWindow::resourcePath() | 1386 | QString MainWindow::resourcePath() |
1387 | { | 1387 | { |
1388 | return KGlobal::iconLoader()->iconPath(); | 1388 | return KGlobal::iconLoader()->iconPath(); |
1389 | } | 1389 | } |
1390 | 1390 | ||
1391 | void MainWindow::displayText( QString text ,QString cap ) | 1391 | void MainWindow::displayText( QString text ,QString cap ) |
1392 | { | 1392 | { |
1393 | QDialog dia( this, "name", true ); ; | 1393 | QDialog dia( this, "name", true ); ; |
1394 | dia.setCaption( cap ); | 1394 | dia.setCaption( cap ); |
1395 | QVBoxLayout* lay = new QVBoxLayout( &dia ); | 1395 | QVBoxLayout* lay = new QVBoxLayout( &dia ); |
1396 | lay->setSpacing( 3 ); | 1396 | lay->setSpacing( 3 ); |
1397 | lay->setMargin( 3 ); | 1397 | lay->setMargin( 3 ); |
1398 | QTextBrowser tb ( &dia ); | 1398 | QTextBrowser tb ( &dia ); |
1399 | lay->addWidget( &tb ); | 1399 | lay->addWidget( &tb ); |
1400 | tb.setText( text ); | 1400 | tb.setText( text ); |
1401 | #ifdef DESKTOP_VERSION | 1401 | #ifdef DESKTOP_VERSION |
1402 | dia.resize( 640, 480); | 1402 | dia.resize( 640, 480); |
1403 | #else | 1403 | #else |
1404 | dia.showMaximized(); | 1404 | dia.showMaximized(); |
1405 | #endif | 1405 | #endif |
1406 | dia.exec(); | 1406 | dia.exec(); |
1407 | } | 1407 | } |
1408 | 1408 | ||
1409 | void MainWindow::features() | 1409 | void MainWindow::features() |
1410 | { | 1410 | { |
1411 | 1411 | ||
1412 | KApplication::showFile( i18n("KO/Pi Features and hints"), "kdepim/korganizer/featuresKOPI.txt" ); | 1412 | KApplication::showFile( i18n("KO/Pi Features and hints"), "kdepim/korganizer/featuresKOPI.txt" ); |
1413 | } | 1413 | } |
1414 | 1414 | ||
1415 | void MainWindow::usertrans() | 1415 | void MainWindow::usertrans() |
1416 | { | 1416 | { |
1417 | 1417 | ||
1418 | KApplication::showFile( i18n("KO/Pi User translation HowTo"), "kdepim/korganizer/usertranslationHOWTO.txt" ); | 1418 | KApplication::showFile( i18n("KO/Pi User translation HowTo"), "kdepim/korganizer/usertranslationHOWTO.txt" ); |
1419 | } | 1419 | } |
1420 | 1420 | ||
1421 | void MainWindow::storagehowto() | 1421 | void MainWindow::storagehowto() |
1422 | { | 1422 | { |
1423 | KApplication::showFile( "KDE-Pim/Pi Storage HowTo", "kdepim/storagehowto.txt" ); | 1423 | KApplication::showFile( "KDE-Pim/Pi Storage HowTo", "kdepim/storagehowto.txt" ); |
1424 | } | 1424 | } |
1425 | void MainWindow::timetrackinghowto() | 1425 | void MainWindow::timetrackinghowto() |
1426 | { | 1426 | { |
1427 | KApplication::showFile( "KO/Pi Timetracking HowTo", "kdepim/timetrackerhowto.txt" ); | 1427 | KApplication::showFile( "KO/Pi Timetracking HowTo", "kdepim/timetrackerhowto.txt" ); |
1428 | } | 1428 | } |
1429 | void MainWindow::kdesynchowto() | 1429 | void MainWindow::kdesynchowto() |
1430 | { | 1430 | { |
1431 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/Zaurus-KDE_syncHowTo.txt" ); | 1431 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/Zaurus-KDE_syncHowTo.txt" ); |
1432 | } | 1432 | } |
1433 | void MainWindow::multisynchowto() | 1433 | void MainWindow::multisynchowto() |
1434 | { | 1434 | { |
1435 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/MultiSyncHowTo.txt" ); | 1435 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/MultiSyncHowTo.txt" ); |
1436 | } | 1436 | } |
1437 | void MainWindow::synchowto() | 1437 | void MainWindow::synchowto() |
1438 | { | 1438 | { |
1439 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/SyncHowto.txt" ); | 1439 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/SyncHowto.txt" ); |
1440 | } | 1440 | } |
1441 | void MainWindow::faq() | 1441 | void MainWindow::faq() |
1442 | { | 1442 | { |
1443 | KApplication::showFile( i18n("KO/Pi FAQ"), "kdepim/korganizer/kopiFAQ.txt" ); | 1443 | KApplication::showFile( i18n("KO/Pi FAQ"), "kdepim/korganizer/kopiFAQ.txt" ); |
1444 | 1444 | ||
1445 | } | 1445 | } |
1446 | void MainWindow::whatsNew() | 1446 | void MainWindow::whatsNew() |
1447 | { | 1447 | { |
1448 | KApplication::showFile( "KDE-Pim/Pi Version Info", "kdepim/WhatsNew.txt" ); | 1448 | KApplication::showFile( "KDE-Pim/Pi Version Info", "kdepim/WhatsNew.txt" ); |
1449 | 1449 | ||
1450 | } | 1450 | } |
1451 | void MainWindow::licence() | 1451 | void MainWindow::licence() |
1452 | { | 1452 | { |
1453 | KApplication::showLicence(); | 1453 | KApplication::showLicence(); |
1454 | 1454 | ||
1455 | } | 1455 | } |
1456 | void MainWindow::about() | 1456 | void MainWindow::about() |
1457 | { | 1457 | { |
1458 | QString version; | 1458 | QString version; |
1459 | #include <../version> | 1459 | #include <../version> |
1460 | QMessageBox::about( this, i18n("About KOrganizer/Pi"), | 1460 | QMessageBox::about( this, i18n("About KOrganizer/Pi"), |
1461 | i18n("KOrganizer/Platform-independent\n") + | 1461 | i18n("KOrganizer/Platform-independent\n") + |
1462 | "(KO/Pi) " + version + " - " + | 1462 | "(KO/Pi) " + version + " - " + |
1463 | 1463 | ||
1464 | #ifdef DESKTOP_VERSION | 1464 | #ifdef DESKTOP_VERSION |
1465 | i18n("Desktop Edition\n") + | 1465 | i18n("Desktop Edition\n") + |
1466 | #else | 1466 | #else |
1467 | i18n("PDA-Edition\nfor: Zaurus 5x00/7x0/860/3000/6000\n") + | 1467 | i18n("PDA-Edition\nfor: Zaurus 5x00/7x0/860/3000/6000\n") + |
@@ -1471,301 +1471,301 @@ void MainWindow::about() | |||
1471 | void MainWindow::keyBindings() | 1471 | void MainWindow::keyBindings() |
1472 | { | 1472 | { |
1473 | QString cap = i18n("KO/Pi Keys + Colors"); | 1473 | QString cap = i18n("KO/Pi Keys + Colors"); |
1474 | QString text = i18n("<p><h2>KO/Pi key shortcuts:</h2></p>\n") + | 1474 | QString text = i18n("<p><h2>KO/Pi key shortcuts:</h2></p>\n") + |
1475 | i18n("<p><b>H</b>: This help dialog | <b>S</b>: Search dialog</p>\n")+ | 1475 | i18n("<p><b>H</b>: This help dialog | <b>S</b>: Search dialog</p>\n")+ |
1476 | i18n("<p><b>N</b>: Switch to next view which has a toolbar icon</p>\n") + | 1476 | i18n("<p><b>N</b>: Switch to next view which has a toolbar icon</p>\n") + |
1477 | i18n("<p><b>A+(shift or ctrl)</b>: Show occurence of next alarm</p>\n") + | 1477 | i18n("<p><b>A+(shift or ctrl)</b>: Show occurence of next alarm</p>\n") + |
1478 | i18n("<p><b>I</b>: Show info for selected event/todo</p>\n") + | 1478 | i18n("<p><b>I</b>: Show info for selected event/todo</p>\n") + |
1479 | i18n("<p><b>Space</b>: Toggle fullscreen | <b>P</b>: Date picker</p>\n")+ | 1479 | i18n("<p><b>Space</b>: Toggle fullscreen | <b>P</b>: Date picker</p>\n")+ |
1480 | i18n("<p><b>F</b>: Toggle filterview |<b>F+ctrl</b>: Edit filter </p>\n")+ | 1480 | i18n("<p><b>F</b>: Toggle filterview |<b>F+ctrl</b>: Edit filter </p>\n")+ |
1481 | i18n("<p><b>O</b>: Filter On/Off | <b>J</b>: Journal view</p>\n")+ | 1481 | i18n("<p><b>O</b>: Filter On/Off | <b>J</b>: Journal view</p>\n")+ |
1482 | i18n("<p><b>1-0</b> (+<b>ctrl</b>): Select filter 1-10 (11-20)</p>\n")+ | 1482 | i18n("<p><b>1-0</b> (+<b>ctrl</b>): Select filter 1-10 (11-20)</p>\n")+ |
1483 | i18n("<p><b>X</b>: Next X days view| <b>W</b>: What's next view\n ")+ | 1483 | i18n("<p><b>X</b>: Next X days view| <b>W</b>: What's next view\n ")+ |
1484 | i18n("<p><b>V</b>: Todo view | <b>L</b>: Event list view</p>\n")+ | 1484 | i18n("<p><b>V</b>: Todo view | <b>L</b>: Event list view</p>\n")+ |
1485 | i18n("<p><b>Z,Y</b>: Work week view | <b>U</b>: Week view</p>\n")+ | 1485 | i18n("<p><b>Z,Y</b>: Work week view | <b>U</b>: Week view</p>\n")+ |
1486 | i18n("<p><b>D</b>: One day view | <b>M</b>: Month view</p>\n")+ | 1486 | i18n("<p><b>D</b>: One day view | <b>M</b>: Month view</p>\n")+ |
1487 | i18n("<p><b>K</b>: Week view in Month view syle</p>\n")+ | 1487 | i18n("<p><b>K</b>: Week view in Month view syle</p>\n")+ |
1488 | i18n("<p><b>E</b>: Edit selected item |<b> E+ctrl</b>: New Event</p>\n")+ | 1488 | i18n("<p><b>E</b>: Edit selected item |<b> E+ctrl</b>: New Event</p>\n")+ |
1489 | i18n("<p><b>T</b>: Goto today | <b>T+ctrl</b>: New Todo</p>\n")+ | 1489 | i18n("<p><b>T</b>: Goto today | <b>T+ctrl</b>: New Todo</p>\n")+ |
1490 | i18n("<p><b>S+ctrl</b>: Add sub-todo | <b>X+ctrl</b>: Toggle datenavigator</p>\n")+ | 1490 | i18n("<p><b>S+ctrl</b>: Add sub-todo | <b>X+ctrl</b>: Toggle datenavigator</p>\n")+ |
1491 | i18n("<p><b>+,-</b> : Zoom in/out agenda | <b>A</b>: Toggle allday agenda height</p>\n")+ | 1491 | i18n("<p><b>+,-</b> : Zoom in/out agenda | <b>A</b>: Toggle allday agenda height</p>\n")+ |
1492 | i18n("<p><b>C</b>: Show current time in agenda view</p>\n")+ | 1492 | i18n("<p><b>C</b>: Show current time in agenda view</p>\n")+ |
1493 | i18n("<p><b>B</b>: Edit description (details) of selected item</p>\n")+ | 1493 | i18n("<p><b>B</b>: Edit description (details) of selected item</p>\n")+ |
1494 | i18n("<p><b>right</b>: Next week | <b>right+ctrl</b>: Next month</p>\n")+ | 1494 | i18n("<p><b>right</b>: Next week | <b>right+ctrl</b>: Next month</p>\n")+ |
1495 | i18n("<p><b>left</b>: Prev. week | <b>left+ctrl</b>: Prev. month</p>\n")+ | 1495 | i18n("<p><b>left</b>: Prev. week | <b>left+ctrl</b>: Prev. month</p>\n")+ |
1496 | i18n("<p><b>del,backspace</b>: Delete selected item</p>\n")+ | 1496 | i18n("<p><b>del,backspace</b>: Delete selected item</p>\n")+ |
1497 | i18n("<p><h3>In agenda view:</h3></p>\n") + | 1497 | i18n("<p><h3>In agenda view:</h3></p>\n") + |
1498 | i18n("<p><b>up/down</b>: Scroll agenda view</p>\n")+ | 1498 | i18n("<p><b>up/down</b>: Scroll agenda view</p>\n")+ |
1499 | i18n("<p><b>ctrl+up/down</b>: Scroll small todo view</p>\n")+ | 1499 | i18n("<p><b>ctrl+up/down</b>: Scroll small todo view</p>\n")+ |
1500 | i18n("<p><h3>In todo view:</h3></p>\n") + | 1500 | i18n("<p><h3>In todo view:</h3></p>\n") + |
1501 | i18n("<p><b>shift+U</b>: <b>U</b>nparent todo (make root todo)</p>\n")+ | 1501 | i18n("<p><b>shift+U</b>: <b>U</b>nparent todo (make root todo)</p>\n")+ |
1502 | i18n("<p><b>shift+S</b>: Make <b>S</b>ubtodo (reparent todo)</p>\n")+ | 1502 | i18n("<p><b>shift+S</b>: Make <b>S</b>ubtodo (reparent todo)</p>\n")+ |
1503 | i18n("<p><b>shift+P</b>: Make new <b>P</b>arent for todo selected with shift+S</p>\n")+ | 1503 | i18n("<p><b>shift+P</b>: Make new <b>P</b>arent for todo selected with shift+S</p>\n")+ |
1504 | i18n("<p><b>Q</b>: Toggle quick todo line edit.</p>\n")+ | 1504 | i18n("<p><b>Q</b>: Toggle quick todo line edit.</p>\n")+ |
1505 | i18n("<p><b>I</b>: Show info of current item+one step down.</p>\n")+ | 1505 | i18n("<p><b>I</b>: Show info of current item+one step down.</p>\n")+ |
1506 | i18n("<p><b>return</b>: Mark item as completed+one step down.</p>\n")+ | 1506 | i18n("<p><b>return</b>: Mark item as completed+one step down.</p>\n")+ |
1507 | i18n("<p><b>return+shift</b>: Mark item as not completed+one step down</p>\n")+ | 1507 | i18n("<p><b>return+shift</b>: Mark item as not completed+one step down</p>\n")+ |
1508 | i18n("<p><h3>In list view:</h3></p>\n") + | 1508 | i18n("<p><h3>In list view:</h3></p>\n") + |
1509 | i18n("<p><b>I</b>: Show info of current item+one step down.</p>\n")+ | 1509 | i18n("<p><b>I</b>: Show info of current item+one step down.</p>\n")+ |
1510 | i18n("<p><b>return</b>: Select item+one step down</p>\n")+ | 1510 | i18n("<p><b>return</b>: Select item+one step down</p>\n")+ |
1511 | i18n("<p><b>return+shift</b>: Deselect item+one step down</p>\n")+ | 1511 | i18n("<p><b>return+shift</b>: Deselect item+one step down</p>\n")+ |
1512 | i18n("<p><b>up/down</b>: Next/prev item</p>\n")+ | 1512 | i18n("<p><b>up/down</b>: Next/prev item</p>\n")+ |
1513 | i18n("<p><b>ctrl+up/down</b>: Goto up/down by 20% of items</p>\n")+ | 1513 | i18n("<p><b>ctrl+up/down</b>: Goto up/down by 20% of items</p>\n")+ |
1514 | i18n("<p><b>shift+up/down</b>: Goto first/last item</p>\n")+ | 1514 | i18n("<p><b>shift+up/down</b>: Goto first/last item</p>\n")+ |
1515 | i18n("<p><h3>In event/todo viewer:</h3></p>\n") + | 1515 | i18n("<p><h3>In event/todo viewer:</h3></p>\n") + |
1516 | i18n("<p><b>I,C</b>: Close dialog.</p>\n")+ | 1516 | i18n("<p><b>I,C</b>: Close dialog.</p>\n")+ |
1517 | i18n("<p><b>A</b>: Show agenda view.</p>\n")+ | 1517 | i18n("<p><b>A</b>: Show agenda view.</p>\n")+ |
1518 | i18n("<p><b>E</b>: Edit item</p>\n") + | 1518 | i18n("<p><b>E</b>: Edit item</p>\n") + |
1519 | i18n("<p><h2>KO/Pi icon colors:</h2></p>\n") + | 1519 | i18n("<p><h2>KO/Pi icon colors:</h2></p>\n") + |
1520 | i18n("<p><b>(for square icons in agenda and month view)</b></p>\n") + | 1520 | i18n("<p><b>(for square icons in agenda and month view)</b></p>\n") + |
1521 | i18n("<p><b>Cross</b>: Item cancelled.([c] in Whats'Next view)</p>\n")+ | 1521 | i18n("<p><b>Cross</b>: Item cancelled.([c] in Whats'Next view)</p>\n")+ |
1522 | i18n("<p><b>Red</b>: Alarm set.([a] in Whats'Next view)</p>\n")+ | 1522 | i18n("<p><b>Red</b>: Alarm set.([a] in Whats'Next view)</p>\n")+ |
1523 | i18n("<p><b>Blue</b>: Recurrent event.([r] in Whats'Next view)</p>\n")+ | 1523 | i18n("<p><b>Blue</b>: Recurrent event.([r] in Whats'Next view)</p>\n")+ |
1524 | i18n("<p><b>Dark green</b>: Information(description) available.([i] in WN view)</p>\n")+ | 1524 | i18n("<p><b>Dark green</b>: Information(description) available.([i] in WN view)</p>\n")+ |
1525 | i18n("<p><b>Black</b>: Event/todo with attendees. You are the organizer!</p>\n")+ | 1525 | i18n("<p><b>Black</b>: Event/todo with attendees. You are the organizer!</p>\n")+ |
1526 | i18n("<p><b>Dark yellow</b>: Event/todo with attendees.</p>\n") + | 1526 | i18n("<p><b>Dark yellow</b>: Event/todo with attendees.</p>\n") + |
1527 | i18n("<p><b>White</b>: Item readonly</p>\n"); | 1527 | i18n("<p><b>White</b>: Item readonly</p>\n"); |
1528 | displayText( text, cap); | 1528 | displayText( text, cap); |
1529 | } | 1529 | } |
1530 | void MainWindow::aboutAutoSaving() | 1530 | void MainWindow::aboutAutoSaving() |
1531 | { | 1531 | { |
1532 | QString text = i18n("After changing something, the data is\nautomatically saved to the file\n~/kdepim/apps/korganizer/mycalendar.ics\nafter (configurable) three minutes.\nFor safety reasons there is one autosaving\nafter 10 minutes (of idle time) again. The \ndata is saved automatically when closing KO/Pi\nYou can create a backup file \nwith: File - Save Calendar Backup\n"); | 1532 | QString text = i18n("After changing something, the data is\nautomatically saved to the file\n~/kdepim/apps/korganizer/mycalendar.ics\nafter (configurable) three minutes.\nFor safety reasons there is one autosaving\nafter 10 minutes (of idle time) again. The \ndata is saved automatically when closing KO/Pi\nYou can create a backup file \nwith: File - Save Calendar Backup\n"); |
1533 | 1533 | ||
1534 | KApplication::showText( i18n("Auto Saving in KOrganizer/Pi"), text); | 1534 | KApplication::showText( i18n("Auto Saving in KOrganizer/Pi"), text); |
1535 | 1535 | ||
1536 | } | 1536 | } |
1537 | void MainWindow::aboutKnownBugs() | 1537 | void MainWindow::aboutKnownBugs() |
1538 | { | 1538 | { |
1539 | QMessageBox* msg; | 1539 | QMessageBox* msg; |
1540 | msg = new QMessageBox( i18n("Known Problems in KOrganizer/Pi"), | 1540 | msg = new QMessageBox( i18n("Known Problems in KOrganizer/Pi"), |
1541 | i18n("1) Importing *.vcs or *.ics files from\nother applications may not work properly,\nif there are events with properties\nKO/Pi does not support.\n")+ | 1541 | i18n("1) Importing *.vcs or *.ics files from\nother applications may not work properly,\nif there are events with properties\nKO/Pi does not support.\n")+ |
1542 | i18n("2) Audio alarm daemon\nfor Zaurus is available!\nas an additional small application\n")+ | 1542 | i18n("2) Audio alarm daemon\nfor Zaurus is available!\nas an additional small application\n")+ |
1543 | i18n("\nPlease report unexpected behaviour to\nlutz@pi-sync.info\n") + | 1543 | i18n("\nPlease report unexpected behaviour to\nlutz@pi-sync.info\n") + |
1544 | i18n("\nor report them in the bugtracker on\n") + | 1544 | i18n("\nor report them in the bugtracker on\n") + |
1545 | i18n("\nhttp://sourceforge.net/projects/kdepimpi\n"), | 1545 | i18n("\nhttp://sourceforge.net/projects/kdepimpi\n"), |
1546 | QMessageBox::NoIcon, | 1546 | QMessageBox::NoIcon, |
1547 | QMessageBox::Ok, | 1547 | QMessageBox::Ok, |
1548 | QMessageBox::NoButton, | 1548 | QMessageBox::NoButton, |
1549 | QMessageBox::NoButton); | 1549 | QMessageBox::NoButton); |
1550 | msg->exec(); | 1550 | msg->exec(); |
1551 | delete msg; | 1551 | delete msg; |
1552 | 1552 | ||
1553 | } | 1553 | } |
1554 | 1554 | ||
1555 | QString MainWindow::defaultFileName() | 1555 | QString MainWindow::defaultFileName() |
1556 | { | 1556 | { |
1557 | return locateLocal( "data", "korganizer/mycalendar.ics" ); | 1557 | return locateLocal( "data", "korganizer/mycalendar.ics" ); |
1558 | } | 1558 | } |
1559 | QString MainWindow::syncFileName() | 1559 | QString MainWindow::syncFileName() |
1560 | { | 1560 | { |
1561 | #ifdef DESKTOP_VERSION | 1561 | #ifdef DESKTOP_VERSION |
1562 | return locateLocal( "tmp", "synccalendar.ics" ); | 1562 | return locateLocal( "tmp", "synccalendar.ics" ); |
1563 | #else | 1563 | #else |
1564 | return QString( "/tmp/synccalendar.ics" ); | 1564 | return QString( "/tmp/synccalendar.ics" ); |
1565 | #endif | 1565 | #endif |
1566 | } | 1566 | } |
1567 | #include "koglobals.h" | 1567 | #include "koglobals.h" |
1568 | #include <kcalendarsystem.h> | 1568 | #include <kcalendarsystem.h> |
1569 | void MainWindow::updateWeek(QDate seda) | 1569 | void MainWindow::updateWeek(QDate seda) |
1570 | { | 1570 | { |
1571 | int weekNum = KGlobal::locale()->weekNum ( seda ); | 1571 | int weekNum = KGlobal::locale()->weekNum ( seda ); |
1572 | mWeekPixmap.fill( mWeekBgColor ); | 1572 | mWeekPixmap.fill( mWeekBgColor ); |
1573 | QPainter p ( &mWeekPixmap ); | 1573 | QPainter p ( &mWeekPixmap ); |
1574 | p.setFont( mWeekFont ); | 1574 | p.setFont( mWeekFont ); |
1575 | p.drawText( 0,0,mWeekPixmap.width(), mWeekPixmap.height(),AlignCenter, QString::number( weekNum) ); | 1575 | p.drawText( 0,0,mWeekPixmap.width(), mWeekPixmap.height(),AlignCenter, QString::number( weekNum) ); |
1576 | p.end(); | 1576 | p.end(); |
1577 | QIconSet icon3 ( mWeekPixmap ); | 1577 | QIconSet icon3 ( mWeekPixmap ); |
1578 | mWeekAction->setIconSet ( icon3 ); | 1578 | mWeekAction->setIconSet ( icon3 ); |
1579 | 1579 | ||
1580 | } | 1580 | } |
1581 | void MainWindow::updateWeekNum(const DateList &selectedDates) | 1581 | void MainWindow::updateWeekNum(const DateList &selectedDates) |
1582 | { | 1582 | { |
1583 | updateWeek( selectedDates.first() ); | 1583 | updateWeek( selectedDates.first() ); |
1584 | } | 1584 | } |
1585 | void MainWindow::processIncidenceSelection( Incidence *incidence ) | 1585 | void MainWindow::processIncidenceSelection( Incidence *incidence ) |
1586 | { | 1586 | { |
1587 | 1587 | ||
1588 | if ( !incidence ) { | 1588 | if ( !incidence ) { |
1589 | enableIncidenceActions( false ); | 1589 | enableIncidenceActions( false ); |
1590 | 1590 | ||
1591 | mNewSubTodoAction->setEnabled( false ); | 1591 | mNewSubTodoAction->setEnabled( false ); |
1592 | setCaptionToDates(); | 1592 | setCaptionToDates(); |
1593 | return; | 1593 | return; |
1594 | 1594 | ||
1595 | } | 1595 | } |
1596 | 1596 | ||
1597 | //KGlobal::locale()->formatDateTime(nextA, true); | 1597 | //KGlobal::locale()->formatDateTime(nextA, true); |
1598 | QString startString = ""; | 1598 | QString startString = ""; |
1599 | if ( incidence->type() != "Todo" ) { | 1599 | if ( incidence->typeID() != todoID ) { |
1600 | if ( incidence->dtStart().date() < incidence->dtEnd().date() ) { | 1600 | if ( incidence->dtStart().date() < incidence->dtEnd().date() ) { |
1601 | if ( incidence->doesFloat() ) { | 1601 | if ( incidence->doesFloat() ) { |
1602 | startString += ": "+incidence->dtStartDateStr( true ); | 1602 | startString += ": "+incidence->dtStartDateStr( true ); |
1603 | startString += " --- "+((Event*)incidence)->dtEndDateStr( true ); | 1603 | startString += " --- "+((Event*)incidence)->dtEndDateStr( true ); |
1604 | 1604 | ||
1605 | } else { | 1605 | } else { |
1606 | startString = ": "+incidence->dtStartStr(true); | 1606 | startString = ": "+incidence->dtStartStr(true); |
1607 | startString += " --- "+((Event*)incidence)->dtEndStr(true); | 1607 | startString += " --- "+((Event*)incidence)->dtEndStr(true); |
1608 | 1608 | ||
1609 | } | 1609 | } |
1610 | 1610 | ||
1611 | } else { | 1611 | } else { |
1612 | if ( incidence->dtStart().time() != incidence->dtEnd().time() ) | 1612 | if ( incidence->dtStart().time() != incidence->dtEnd().time() ) |
1613 | startString = ": "+KGlobal::locale()->formatTime(incidence->dtStart().time())+ | 1613 | startString = ": "+KGlobal::locale()->formatTime(incidence->dtStart().time())+ |
1614 | "-"+KGlobal::locale()->formatTime(incidence->dtEnd().time()); | 1614 | "-"+KGlobal::locale()->formatTime(incidence->dtEnd().time()); |
1615 | 1615 | ||
1616 | if ( incidence->isBirthday() || incidence->isAnniversary() ) { | 1616 | if ( incidence->isBirthday() || incidence->isAnniversary() ) { |
1617 | bool ok; | 1617 | bool ok; |
1618 | QDateTime noc = incidence->getNextOccurence( mView->startDate().addDays(-1), &ok ); | 1618 | QDateTime noc = incidence->getNextOccurence( mView->startDate().addDays(-1), &ok ); |
1619 | if ( ok ) { | 1619 | if ( ok ) { |
1620 | int years = noc.date().year() - incidence->dtStart().date().year(); | 1620 | int years = noc.date().year() - incidence->dtStart().date().year(); |
1621 | startString += i18n(" (%1 y.)"). arg( years ); | 1621 | startString += i18n(" (%1 y.)"). arg( years ); |
1622 | } | 1622 | } |
1623 | } | 1623 | } |
1624 | else | 1624 | else |
1625 | startString +=" "+KGlobal::locale()->formatDate( incidence->dtStart().date(), true); | 1625 | startString +=" "+KGlobal::locale()->formatDate( incidence->dtStart().date(), true); |
1626 | } | 1626 | } |
1627 | 1627 | ||
1628 | } | 1628 | } |
1629 | else | 1629 | else |
1630 | startString = i18n(": (Prio ") +QString::number( (( KCal::Todo*)incidence)->priority() ) +") "+QString::number( (( KCal::Todo*)incidence)->percentComplete() ) +i18n("\% completed"); | 1630 | startString = i18n(": (Prio ") +QString::number( (( KCal::Todo*)incidence)->priority() ) +") "+QString::number( (( KCal::Todo*)incidence)->percentComplete() ) +i18n("\% completed"); |
1631 | if ( !incidence->location().isEmpty() ) | 1631 | if ( !incidence->location().isEmpty() ) |
1632 | startString += " (" +incidence->location()+")"; | 1632 | startString += " (" +incidence->location()+")"; |
1633 | setCaption( incidence->summary()+startString); | 1633 | setCaption( incidence->summary()+startString); |
1634 | 1634 | ||
1635 | enableIncidenceActions( true ); | 1635 | enableIncidenceActions( true ); |
1636 | 1636 | ||
1637 | if ( incidence->type() == "Event" ) { | 1637 | if ( incidence->typeID() == eventID ) { |
1638 | mShowAction->setText( i18n("Show Event...") ); | 1638 | mShowAction->setText( i18n("Show Event...") ); |
1639 | mEditAction->setText( i18n("Edit Event...") ); | 1639 | mEditAction->setText( i18n("Edit Event...") ); |
1640 | mDeleteAction->setText( i18n("Delete Event...") ); | 1640 | mDeleteAction->setText( i18n("Delete Event...") ); |
1641 | 1641 | ||
1642 | mNewSubTodoAction->setEnabled( false ); | 1642 | mNewSubTodoAction->setEnabled( false ); |
1643 | } else if ( incidence->type() == "Todo" ) { | 1643 | } else if ( incidence->typeID() == todoID ) { |
1644 | mShowAction->setText( i18n("Show Todo...") ); | 1644 | mShowAction->setText( i18n("Show Todo...") ); |
1645 | mEditAction->setText( i18n("Edit Todo...") ); | 1645 | mEditAction->setText( i18n("Edit Todo...") ); |
1646 | mDeleteAction->setText( i18n("Delete Todo...") ); | 1646 | mDeleteAction->setText( i18n("Delete Todo...") ); |
1647 | 1647 | ||
1648 | mNewSubTodoAction->setEnabled( true ); | 1648 | mNewSubTodoAction->setEnabled( true ); |
1649 | } else { | 1649 | } else { |
1650 | mShowAction->setText( i18n("Show...") ); | 1650 | mShowAction->setText( i18n("Show...") ); |
1651 | mShowAction->setText( i18n("Edit...") ); | 1651 | mShowAction->setText( i18n("Edit...") ); |
1652 | mShowAction->setText( i18n("Delete...") ); | 1652 | mShowAction->setText( i18n("Delete...") ); |
1653 | 1653 | ||
1654 | mNewSubTodoAction->setEnabled( false ); | 1654 | mNewSubTodoAction->setEnabled( false ); |
1655 | } | 1655 | } |
1656 | } | 1656 | } |
1657 | 1657 | ||
1658 | void MainWindow::enableIncidenceActions( bool enabled ) | 1658 | void MainWindow::enableIncidenceActions( bool enabled ) |
1659 | { | 1659 | { |
1660 | mShowAction->setEnabled( enabled ); | 1660 | mShowAction->setEnabled( enabled ); |
1661 | mEditAction->setEnabled( enabled ); | 1661 | mEditAction->setEnabled( enabled ); |
1662 | mDeleteAction->setEnabled( enabled ); | 1662 | mDeleteAction->setEnabled( enabled ); |
1663 | 1663 | ||
1664 | mCloneAction->setEnabled( enabled ); | 1664 | mCloneAction->setEnabled( enabled ); |
1665 | mMoveAction->setEnabled( enabled ); | 1665 | mMoveAction->setEnabled( enabled ); |
1666 | mBeamAction->setEnabled( enabled ); | 1666 | mBeamAction->setEnabled( enabled ); |
1667 | mCancelAction->setEnabled( enabled ); | 1667 | mCancelAction->setEnabled( enabled ); |
1668 | } | 1668 | } |
1669 | 1669 | ||
1670 | void MainWindow::importOL() | 1670 | void MainWindow::importOL() |
1671 | { | 1671 | { |
1672 | #ifdef _OL_IMPORT_ | 1672 | #ifdef _OL_IMPORT_ |
1673 | mView->clearAllViews(); | 1673 | mView->clearAllViews(); |
1674 | KOImportOLdialog *id = new KOImportOLdialog("Import from OL - select folder!" , mView->calendar(),this ); | 1674 | KOImportOLdialog *id = new KOImportOLdialog("Import from OL - select folder!" , mView->calendar(),this ); |
1675 | id->exec(); | 1675 | id->exec(); |
1676 | delete id; | 1676 | delete id; |
1677 | mView->calendar()->checkAlarmForIncidence( 0, true ); | 1677 | mView->calendar()->checkAlarmForIncidence( 0, true ); |
1678 | mView->updateView(); | 1678 | mView->updateView(); |
1679 | #endif | 1679 | #endif |
1680 | } | 1680 | } |
1681 | void MainWindow::importBday() | 1681 | void MainWindow::importBday() |
1682 | { | 1682 | { |
1683 | int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"), | 1683 | int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"), |
1684 | i18n("When importing birthdays twice\nduplicated events will be ignored,\nif the event has not been\nchanged in KO/Pi!\n"), | 1684 | i18n("When importing birthdays twice\nduplicated events will be ignored,\nif the event has not been\nchanged in KO/Pi!\n"), |
1685 | i18n("Import!"), i18n("Cancel"), 0, | 1685 | i18n("Import!"), i18n("Cancel"), 0, |
1686 | 0, 1 ); | 1686 | 0, 1 ); |
1687 | if ( result == 0 ) { | 1687 | if ( result == 0 ) { |
1688 | mView->importBday(); | 1688 | mView->importBday(); |
1689 | 1689 | ||
1690 | } | 1690 | } |
1691 | 1691 | ||
1692 | 1692 | ||
1693 | } | 1693 | } |
1694 | void MainWindow::importQtopia() | 1694 | void MainWindow::importQtopia() |
1695 | { | 1695 | { |
1696 | //#ifndef DESKTOP_VERSION | 1696 | //#ifndef DESKTOP_VERSION |
1697 | QString mess = i18n("When importing a calendar twice\nduplicated events will be ignored!\nYou can create a backup file with\nFile - Save Calendar Backup\nto revert importing"); | 1697 | QString mess = i18n("When importing a calendar twice\nduplicated events will be ignored!\nYou can create a backup file with\nFile - Save Calendar Backup\nto revert importing"); |
1698 | #ifdef DESKTOP_VERSION | 1698 | #ifdef DESKTOP_VERSION |
1699 | mess += i18n("The content of the following files will be\nimported (located in your home directory (hd)):\n(hd)/Applications/datebook/datebook.xml\n(hd)/Applications/todolist/todolist.xml\nThe following category file will be used:\n(hd)/Settings/Categories.xml"); | 1699 | mess += i18n("The content of the following files will be\nimported (located in your home directory (hd)):\n(hd)/Applications/datebook/datebook.xml\n(hd)/Applications/todolist/todolist.xml\nThe following category file will be used:\n(hd)/Settings/Categories.xml"); |
1700 | #endif | 1700 | #endif |
1701 | int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"),mess, | 1701 | int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"),mess, |
1702 | i18n("Import!"), i18n("Cancel"), 0, | 1702 | i18n("Import!"), i18n("Cancel"), 0, |
1703 | 0, 1 ); | 1703 | 0, 1 ); |
1704 | if ( result == 0 ) { | 1704 | if ( result == 0 ) { |
1705 | #ifndef DESKTOP_VERSION | 1705 | #ifndef DESKTOP_VERSION |
1706 | QString datebook = Global::applicationFileName( "datebook", "datebook.xml"); | 1706 | QString datebook = Global::applicationFileName( "datebook", "datebook.xml"); |
1707 | QString todolist = Global::applicationFileName( "todolist", "todolist.xml"); | 1707 | QString todolist = Global::applicationFileName( "todolist", "todolist.xml"); |
1708 | QString categories = QString( getenv( "HOME" ) ) + "/Settings/Categories.xml"; | 1708 | QString categories = QString( getenv( "HOME" ) ) + "/Settings/Categories.xml"; |
1709 | #else | 1709 | #else |
1710 | QString datebook = QDir::homeDirPath()+ "/Applications/datebook/datebook.xml"; | 1710 | QString datebook = QDir::homeDirPath()+ "/Applications/datebook/datebook.xml"; |
1711 | QString todolist = QDir::homeDirPath()+ "/Applications/todolist/todolist.xml"; | 1711 | QString todolist = QDir::homeDirPath()+ "/Applications/todolist/todolist.xml"; |
1712 | QString categories = QDir::homeDirPath()+ "/Settings/Categories.xml"; | 1712 | QString categories = QDir::homeDirPath()+ "/Settings/Categories.xml"; |
1713 | #endif | 1713 | #endif |
1714 | mView->importQtopia( categories, datebook, todolist ); | 1714 | mView->importQtopia( categories, datebook, todolist ); |
1715 | } | 1715 | } |
1716 | mView->calendar()->reInitAlarmSettings(); | 1716 | mView->calendar()->reInitAlarmSettings(); |
1717 | #if 0 | 1717 | #if 0 |
1718 | int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"), | 1718 | int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"), |
1719 | i18n("Not supported \non desktop!\n"), | 1719 | i18n("Not supported \non desktop!\n"), |
1720 | i18n("Ok"), i18n("Cancel"), 0, | 1720 | i18n("Ok"), i18n("Cancel"), 0, |
1721 | 0, 1 ); | 1721 | 0, 1 ); |
1722 | 1722 | ||
1723 | #endif | 1723 | #endif |
1724 | } | 1724 | } |
1725 | 1725 | ||
1726 | void MainWindow::saveOnClose() | 1726 | void MainWindow::saveOnClose() |
1727 | { | 1727 | { |
1728 | KOPrefs *p = KOPrefs::instance(); | 1728 | KOPrefs *p = KOPrefs::instance(); |
1729 | p->mToolBarHor = ( iconToolBar->orientation () == Qt:: Horizontal ); | 1729 | p->mToolBarHor = ( iconToolBar->orientation () == Qt:: Horizontal ); |
1730 | p->mToolBarHorV = ( viewToolBar->orientation () == Qt:: Horizontal ); | 1730 | p->mToolBarHorV = ( viewToolBar->orientation () == Qt:: Horizontal ); |
1731 | p->mToolBarHorN = ( navigatorToolBar->orientation () == Qt:: Horizontal ); | 1731 | p->mToolBarHorN = ( navigatorToolBar->orientation () == Qt:: Horizontal ); |
1732 | if ( filterToolBar ) { | 1732 | if ( filterToolBar ) { |
1733 | p->mToolBarHorF = ( filterToolBar->orientation () == Qt:: Horizontal ); | 1733 | p->mToolBarHorF = ( filterToolBar->orientation () == Qt:: Horizontal ); |
1734 | } | 1734 | } |
1735 | #ifdef DESKTOP_VERSION | 1735 | #ifdef DESKTOP_VERSION |
1736 | 1736 | ||
1737 | QPoint myP; | 1737 | QPoint myP; |
1738 | myP = mapFromGlobal( iconToolBar->mapToGlobal( QPoint( 0,0) ) ); | 1738 | myP = mapFromGlobal( iconToolBar->mapToGlobal( QPoint( 0,0) ) ); |
1739 | if ( p->mToolBarHor ) | 1739 | if ( p->mToolBarHor ) |
1740 | p->mToolBarUp = myP.y() > height()/2; | 1740 | p->mToolBarUp = myP.y() > height()/2; |
1741 | else | 1741 | else |
1742 | p->mToolBarUp = myP.x() > width()/2; | 1742 | p->mToolBarUp = myP.x() > width()/2; |
1743 | myP = mapFromGlobal( viewToolBar->mapToGlobal( QPoint( 0,0) ) ); | 1743 | myP = mapFromGlobal( viewToolBar->mapToGlobal( QPoint( 0,0) ) ); |
1744 | if ( p->mToolBarHorV ) | 1744 | if ( p->mToolBarHorV ) |
1745 | p->mToolBarUpV = myP.y() > height()/2; | 1745 | p->mToolBarUpV = myP.y() > height()/2; |
1746 | else | 1746 | else |
1747 | p->mToolBarUpV = myP.x() > width()/2 ; | 1747 | p->mToolBarUpV = myP.x() > width()/2 ; |
1748 | myP = mapFromGlobal( navigatorToolBar->mapToGlobal( QPoint( 0,0) ) ); | 1748 | myP = mapFromGlobal( navigatorToolBar->mapToGlobal( QPoint( 0,0) ) ); |
1749 | if ( p->mToolBarHorN ) | 1749 | if ( p->mToolBarHorN ) |
1750 | p->mToolBarUpN = myP.y() > height()/2; | 1750 | p->mToolBarUpN = myP.y() > height()/2; |
1751 | else | 1751 | else |
1752 | p->mToolBarUpN = myP.x() > width()/2 ; | 1752 | p->mToolBarUpN = myP.x() > width()/2 ; |
1753 | if ( filterToolBar ) { | 1753 | if ( filterToolBar ) { |
1754 | myP = mapFromGlobal( filterToolBar->mapToGlobal( QPoint( 0,0) ) ); | 1754 | myP = mapFromGlobal( filterToolBar->mapToGlobal( QPoint( 0,0) ) ); |
1755 | if ( p->mToolBarHorF ) | 1755 | if ( p->mToolBarHorF ) |
1756 | p->mToolBarUpF = myP.y() > height()/2; | 1756 | p->mToolBarUpF = myP.y() > height()/2; |
1757 | else | 1757 | else |
1758 | p->mToolBarUpF = myP.x() > width()/2 ; | 1758 | p->mToolBarUpF = myP.x() > width()/2 ; |
1759 | } | 1759 | } |
1760 | #else | 1760 | #else |
1761 | if ( p->mToolBarHor ) | 1761 | if ( p->mToolBarHor ) |
1762 | p->mToolBarUp = iconToolBar->y() > height()/2; | 1762 | p->mToolBarUp = iconToolBar->y() > height()/2; |
1763 | else | 1763 | else |
1764 | p->mToolBarUp = iconToolBar->x() > width()/2; | 1764 | p->mToolBarUp = iconToolBar->x() > width()/2; |
1765 | if ( p->mToolBarHorV ) | 1765 | if ( p->mToolBarHorV ) |
1766 | p->mToolBarUpV = viewToolBar->y() > height()/2; | 1766 | p->mToolBarUpV = viewToolBar->y() > height()/2; |
1767 | else | 1767 | else |
1768 | p->mToolBarUpV = viewToolBar->x() > width()/2 ; | 1768 | p->mToolBarUpV = viewToolBar->x() > width()/2 ; |
1769 | 1769 | ||
1770 | if ( p->mToolBarHorN ) | 1770 | if ( p->mToolBarHorN ) |
1771 | p->mToolBarUpN = navigatorToolBar->y() > height()/2; | 1771 | p->mToolBarUpN = navigatorToolBar->y() > height()/2; |