author | zautrix <zautrix> | 2005-07-28 17:20:12 (UTC) |
---|---|---|
committer | zautrix <zautrix> | 2005-07-28 17:20:12 (UTC) |
commit | 21e3b4936180fe45ba9545cb3fe28b574f86f1b5 (patch) (unidiff) | |
tree | 59667b0b2738776f69206209c4653dc2e4487d3f | |
parent | 1f1a6829b042c804e5b547b181dc50c4539d5551 (diff) | |
download | kdepimpi-21e3b4936180fe45ba9545cb3fe28b574f86f1b5.zip kdepimpi-21e3b4936180fe45ba9545cb3fe28b574f86f1b5.tar.gz kdepimpi-21e3b4936180fe45ba9545cb3fe28b574f86f1b5.tar.bz2 |
rec fix
-rw-r--r-- | libkcal/incidence.cpp | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/libkcal/incidence.cpp b/libkcal/incidence.cpp index 201f593..52d94fb 100644 --- a/libkcal/incidence.cpp +++ b/libkcal/incidence.cpp | |||
@@ -1,840 +1,841 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of libkcal. | 2 | This file is part of libkcal. |
3 | Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org> | 3 | Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org> |
4 | 4 | ||
5 | This library is free software; you can redistribute it and/or | 5 | This library is free software; you can redistribute it and/or |
6 | modify it under the terms of the GNU Library General Public | 6 | modify it under the terms of the GNU Library General Public |
7 | License as published by the Free Software Foundation; either | 7 | License as published by the Free Software Foundation; either |
8 | version 2 of the License, or (at your option) any later version. | 8 | version 2 of the License, or (at your option) any later version. |
9 | 9 | ||
10 | This library is distributed in the hope that it will be useful, | 10 | This library 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 GNU | 12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
13 | Library General Public License for more details. | 13 | Library General Public License for more details. |
14 | 14 | ||
15 | You should have received a copy of the GNU Library General Public License | 15 | You should have received a copy of the GNU Library General Public License |
16 | along with this library; see the file COPYING.LIB. If not, write to | 16 | along with this library; see the file COPYING.LIB. If not, write to |
17 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | 17 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
18 | Boston, MA 02111-1307, USA. | 18 | Boston, MA 02111-1307, USA. |
19 | */ | 19 | */ |
20 | 20 | ||
21 | #include <kglobal.h> | 21 | #include <kglobal.h> |
22 | #include <klocale.h> | 22 | #include <klocale.h> |
23 | #include <kdebug.h> | 23 | #include <kdebug.h> |
24 | 24 | ||
25 | #include "calformat.h" | 25 | #include "calformat.h" |
26 | 26 | ||
27 | #include "incidence.h" | 27 | #include "incidence.h" |
28 | #include "todo.h" | 28 | #include "todo.h" |
29 | 29 | ||
30 | using namespace KCal; | 30 | using namespace KCal; |
31 | 31 | ||
32 | Incidence::Incidence() : | 32 | Incidence::Incidence() : |
33 | IncidenceBase(), | 33 | IncidenceBase(), |
34 | mRelatedTo(0), mSecrecy(SecrecyPublic), mPriority(3) | 34 | mRelatedTo(0), mSecrecy(SecrecyPublic), mPriority(3) |
35 | { | 35 | { |
36 | mRecurrence = 0;//new Recurrence(this); | 36 | mRecurrence = 0;//new Recurrence(this); |
37 | mCancelled = false; | 37 | mCancelled = false; |
38 | recreate(); | 38 | recreate(); |
39 | mHasStartDate = true; | 39 | mHasStartDate = true; |
40 | mAlarms.setAutoDelete(true); | 40 | mAlarms.setAutoDelete(true); |
41 | mAttachments.setAutoDelete(true); | 41 | mAttachments.setAutoDelete(true); |
42 | mHasRecurrenceID = false; | 42 | mHasRecurrenceID = false; |
43 | mHoliday = false; | 43 | mHoliday = false; |
44 | mBirthday = false; | 44 | mBirthday = false; |
45 | mAnniversary = false; | 45 | mAnniversary = false; |
46 | 46 | ||
47 | } | 47 | } |
48 | 48 | ||
49 | Incidence::Incidence( const Incidence &i ) : IncidenceBase( i ) | 49 | Incidence::Incidence( const Incidence &i ) : IncidenceBase( i ) |
50 | { | 50 | { |
51 | // TODO: reenable attributes currently commented out. | 51 | // TODO: reenable attributes currently commented out. |
52 | mRevision = i.mRevision; | 52 | mRevision = i.mRevision; |
53 | mCreated = i.mCreated; | 53 | mCreated = i.mCreated; |
54 | mDescription = i.mDescription; | 54 | mDescription = i.mDescription; |
55 | mSummary = i.mSummary; | 55 | mSummary = i.mSummary; |
56 | mCategories = i.mCategories; | 56 | mCategories = i.mCategories; |
57 | // Incidence *mRelatedTo; Incidence *mRelatedTo; | 57 | // Incidence *mRelatedTo; Incidence *mRelatedTo; |
58 | mRelatedTo = 0; | 58 | mRelatedTo = 0; |
59 | mRelatedToUid = i.mRelatedToUid; | 59 | mRelatedToUid = i.mRelatedToUid; |
60 | // QPtrList<Incidence> mRelations; QPtrList<Incidence> mRelations; | 60 | // QPtrList<Incidence> mRelations; QPtrList<Incidence> mRelations; |
61 | mExDates = i.mExDates; | 61 | mExDates = i.mExDates; |
62 | mAttachments = i.mAttachments; | 62 | mAttachments = i.mAttachments; |
63 | mResources = i.mResources; | 63 | mResources = i.mResources; |
64 | mSecrecy = i.mSecrecy; | 64 | mSecrecy = i.mSecrecy; |
65 | mPriority = i.mPriority; | 65 | mPriority = i.mPriority; |
66 | mLocation = i.mLocation; | 66 | mLocation = i.mLocation; |
67 | mCancelled = i.mCancelled; | 67 | mCancelled = i.mCancelled; |
68 | mHasStartDate = i.mHasStartDate; | 68 | mHasStartDate = i.mHasStartDate; |
69 | QPtrListIterator<Alarm> it( i.mAlarms ); | 69 | QPtrListIterator<Alarm> it( i.mAlarms ); |
70 | const Alarm *a; | 70 | const Alarm *a; |
71 | while( (a = it.current()) ) { | 71 | while( (a = it.current()) ) { |
72 | Alarm *b = new Alarm( *a ); | 72 | Alarm *b = new Alarm( *a ); |
73 | b->setParent( this ); | 73 | b->setParent( this ); |
74 | mAlarms.append( b ); | 74 | mAlarms.append( b ); |
75 | 75 | ||
76 | ++it; | 76 | ++it; |
77 | } | 77 | } |
78 | mAlarms.setAutoDelete(true); | 78 | mAlarms.setAutoDelete(true); |
79 | mHasRecurrenceID = i.mHasRecurrenceID; | 79 | mHasRecurrenceID = i.mHasRecurrenceID; |
80 | mRecurrenceID = i.mRecurrenceID; | 80 | mRecurrenceID = i.mRecurrenceID; |
81 | if ( i.mRecurrence ) | 81 | if ( i.mRecurrence ) |
82 | mRecurrence = new Recurrence( *(i.mRecurrence), this ); | 82 | mRecurrence = new Recurrence( *(i.mRecurrence), this ); |
83 | else | 83 | else |
84 | mRecurrence = 0; | 84 | mRecurrence = 0; |
85 | mHoliday = i.mHoliday ; | 85 | mHoliday = i.mHoliday ; |
86 | mBirthday = i.mBirthday; | 86 | mBirthday = i.mBirthday; |
87 | mAnniversary = i.mAnniversary; | 87 | mAnniversary = i.mAnniversary; |
88 | } | 88 | } |
89 | 89 | ||
90 | Incidence::~Incidence() | 90 | Incidence::~Incidence() |
91 | { | 91 | { |
92 | 92 | ||
93 | Incidence *ev; | 93 | Incidence *ev; |
94 | QPtrList<Incidence> Relations = relations(); | 94 | QPtrList<Incidence> Relations = relations(); |
95 | for (ev=Relations.first();ev;ev=Relations.next()) { | 95 | for (ev=Relations.first();ev;ev=Relations.next()) { |
96 | if (ev->relatedTo() == this) ev->setRelatedTo(0); | 96 | if (ev->relatedTo() == this) ev->setRelatedTo(0); |
97 | } | 97 | } |
98 | if (relatedTo()) relatedTo()->removeRelation(this); | 98 | if (relatedTo()) relatedTo()->removeRelation(this); |
99 | if ( mRecurrence ) | 99 | if ( mRecurrence ) |
100 | delete mRecurrence; | 100 | delete mRecurrence; |
101 | 101 | ||
102 | } | 102 | } |
103 | QString Incidence::durationText() | 103 | QString Incidence::durationText() |
104 | { | 104 | { |
105 | return "---"; | 105 | return "---"; |
106 | } | 106 | } |
107 | QString Incidence::durationText4Time( int offset ) | 107 | QString Incidence::durationText4Time( int offset ) |
108 | { | 108 | { |
109 | int min = offset/60; | 109 | int min = offset/60; |
110 | int hours = min /60; | 110 | int hours = min /60; |
111 | min = min % 60; | 111 | min = min % 60; |
112 | int days = hours /24; | 112 | int days = hours /24; |
113 | hours = hours % 24; | 113 | hours = hours % 24; |
114 | 114 | ||
115 | if ( doesFloat() || ( min == 0 && hours == 0 ) ) { | 115 | if ( doesFloat() || ( min == 0 && hours == 0 ) ) { |
116 | if ( days == 1 ) | 116 | if ( days == 1 ) |
117 | return "1" + i18n(" day"); | 117 | return "1" + i18n(" day"); |
118 | else | 118 | else |
119 | return QString::number( days )+ i18n(" days"); | 119 | return QString::number( days )+ i18n(" days"); |
120 | 120 | ||
121 | } | 121 | } |
122 | QString message = QString::number ( hours ) +":"; | 122 | QString message = QString::number ( hours ) +":"; |
123 | if ( min < 10 ) message += "0"; | 123 | if ( min < 10 ) message += "0"; |
124 | message += QString::number ( min ); | 124 | message += QString::number ( min ); |
125 | if ( days > 0 ) { | 125 | if ( days > 0 ) { |
126 | if ( days == 1 ) | 126 | if ( days == 1 ) |
127 | message = "1" + i18n(" day") + " "+message; | 127 | message = "1" + i18n(" day") + " "+message; |
128 | else | 128 | else |
129 | message = QString::number( days )+ i18n(" days") + " "+message; | 129 | message = QString::number( days )+ i18n(" days") + " "+message; |
130 | } | 130 | } |
131 | return message; | 131 | return message; |
132 | } | 132 | } |
133 | bool Incidence::isHoliday() const | 133 | bool Incidence::isHoliday() const |
134 | { | 134 | { |
135 | return mHoliday; | 135 | return mHoliday; |
136 | } | 136 | } |
137 | bool Incidence::isBirthday() const | 137 | bool Incidence::isBirthday() const |
138 | { | 138 | { |
139 | 139 | ||
140 | return mBirthday ; | 140 | return mBirthday ; |
141 | } | 141 | } |
142 | bool Incidence::isAnniversary() const | 142 | bool Incidence::isAnniversary() const |
143 | { | 143 | { |
144 | return mAnniversary ; | 144 | return mAnniversary ; |
145 | 145 | ||
146 | } | 146 | } |
147 | 147 | ||
148 | bool Incidence::hasRecurrenceID() const | 148 | bool Incidence::hasRecurrenceID() const |
149 | { | 149 | { |
150 | return mHasRecurrenceID; | 150 | return mHasRecurrenceID; |
151 | } | 151 | } |
152 | 152 | ||
153 | void Incidence::setHasRecurrenceID( bool b ) | 153 | void Incidence::setHasRecurrenceID( bool b ) |
154 | { | 154 | { |
155 | mHasRecurrenceID = b; | 155 | mHasRecurrenceID = b; |
156 | } | 156 | } |
157 | 157 | ||
158 | void Incidence::setRecurrenceID(QDateTime d) | 158 | void Incidence::setRecurrenceID(QDateTime d) |
159 | { | 159 | { |
160 | mRecurrenceID = d; | 160 | mRecurrenceID = d; |
161 | mHasRecurrenceID = true; | 161 | mHasRecurrenceID = true; |
162 | updated(); | 162 | updated(); |
163 | } | 163 | } |
164 | QDateTime Incidence::recurrenceID () const | 164 | QDateTime Incidence::recurrenceID () const |
165 | { | 165 | { |
166 | return mRecurrenceID; | 166 | return mRecurrenceID; |
167 | } | 167 | } |
168 | 168 | ||
169 | bool Incidence::cancelled() const | 169 | bool Incidence::cancelled() const |
170 | { | 170 | { |
171 | return mCancelled; | 171 | return mCancelled; |
172 | } | 172 | } |
173 | void Incidence::setCancelled( bool b ) | 173 | void Incidence::setCancelled( bool b ) |
174 | { | 174 | { |
175 | mCancelled = b; | 175 | mCancelled = b; |
176 | updated(); | 176 | updated(); |
177 | } | 177 | } |
178 | bool Incidence::hasStartDate() const | 178 | bool Incidence::hasStartDate() const |
179 | { | 179 | { |
180 | return mHasStartDate; | 180 | return mHasStartDate; |
181 | } | 181 | } |
182 | 182 | ||
183 | void Incidence::setHasStartDate(bool f) | 183 | void Incidence::setHasStartDate(bool f) |
184 | { | 184 | { |
185 | if (mReadOnly) return; | 185 | if (mReadOnly) return; |
186 | mHasStartDate = f; | 186 | mHasStartDate = f; |
187 | updated(); | 187 | updated(); |
188 | } | 188 | } |
189 | 189 | ||
190 | // A string comparison that considers that null and empty are the same | 190 | // A string comparison that considers that null and empty are the same |
191 | static bool stringCompare( const QString& s1, const QString& s2 ) | 191 | static bool stringCompare( const QString& s1, const QString& s2 ) |
192 | { | 192 | { |
193 | if ( s1.isEmpty() && s2.isEmpty() ) | 193 | if ( s1.isEmpty() && s2.isEmpty() ) |
194 | return true; | 194 | return true; |
195 | return s1 == s2; | 195 | return s1 == s2; |
196 | } | 196 | } |
197 | 197 | ||
198 | bool KCal::operator==( const Incidence& i1, const Incidence& i2 ) | 198 | bool KCal::operator==( const Incidence& i1, const Incidence& i2 ) |
199 | { | 199 | { |
200 | 200 | ||
201 | if( i1.alarms().count() != i2.alarms().count() ) { | 201 | if( i1.alarms().count() != i2.alarms().count() ) { |
202 | return false; // no need to check further | 202 | return false; // no need to check further |
203 | } | 203 | } |
204 | if ( i1.alarms().count() > 0 ) { | 204 | if ( i1.alarms().count() > 0 ) { |
205 | if ( !( *(i1.alarms().first()) == *(i2.alarms().first())) ) | 205 | if ( !( *(i1.alarms().first()) == *(i2.alarms().first())) ) |
206 | { | 206 | { |
207 | qDebug("alarm not equal "); | 207 | qDebug("alarm not equal "); |
208 | return false; | 208 | return false; |
209 | } | 209 | } |
210 | } | 210 | } |
211 | #if 0 | 211 | #if 0 |
212 | QPtrListIterator<Alarm> a1( i1.alarms() ); | 212 | QPtrListIterator<Alarm> a1( i1.alarms() ); |
213 | QPtrListIterator<Alarm> a2( i2.alarms() ); | 213 | QPtrListIterator<Alarm> a2( i2.alarms() ); |
214 | for( ; a1.current() && a2.current(); ++a1, ++a2 ) { | 214 | for( ; a1.current() && a2.current(); ++a1, ++a2 ) { |
215 | if( *a1.current() == *a2.current() ) { | 215 | if( *a1.current() == *a2.current() ) { |
216 | continue; | 216 | continue; |
217 | } | 217 | } |
218 | else { | 218 | else { |
219 | return false; | 219 | return false; |
220 | } | 220 | } |
221 | } | 221 | } |
222 | #endif | 222 | #endif |
223 | 223 | ||
224 | if ( i1.hasRecurrenceID() == i2.hasRecurrenceID() ) { | 224 | if ( i1.hasRecurrenceID() == i2.hasRecurrenceID() ) { |
225 | if ( i1.hasRecurrenceID() ) { | 225 | if ( i1.hasRecurrenceID() ) { |
226 | if ( i1.recurrenceID() != i2.recurrenceID() ) | 226 | if ( i1.recurrenceID() != i2.recurrenceID() ) |
227 | return false; | 227 | return false; |
228 | } | 228 | } |
229 | 229 | ||
230 | } else { | 230 | } else { |
231 | return false; | 231 | return false; |
232 | } | 232 | } |
233 | 233 | ||
234 | if ( ! operator==( (const IncidenceBase&)i1, (const IncidenceBase&)i2 ) ) | 234 | if ( ! operator==( (const IncidenceBase&)i1, (const IncidenceBase&)i2 ) ) |
235 | return false; | 235 | return false; |
236 | if ( i1.hasStartDate() == i2.hasStartDate() ) { | 236 | if ( i1.hasStartDate() == i2.hasStartDate() ) { |
237 | if ( i1.hasStartDate() ) { | 237 | if ( i1.hasStartDate() ) { |
238 | if ( i1.dtStart() != i2.dtStart() ) | 238 | if ( i1.dtStart() != i2.dtStart() ) |
239 | return false; | 239 | return false; |
240 | } | 240 | } |
241 | } else { | 241 | } else { |
242 | return false; | 242 | return false; |
243 | } | 243 | } |
244 | if ( i1.mRecurrence != 0 && i2.mRecurrence != 0 ) { | 244 | if ( i1.mRecurrence != 0 && i2.mRecurrence != 0 ) { |
245 | if (!( *i1.mRecurrence == *i2.mRecurrence) ) { | 245 | if (!( *i1.mRecurrence == *i2.mRecurrence) ) { |
246 | //qDebug("recurrence is NOT equal "); | 246 | //qDebug("recurrence is NOT equal "); |
247 | return false; | 247 | return false; |
248 | } | 248 | } |
249 | } else { | 249 | } else { |
250 | // one ( or both ) recurrence is 0 | 250 | // one ( or both ) recurrence is 0 |
251 | if ( i1.mRecurrence == 0 ) { | 251 | if ( i1.mRecurrence == 0 ) { |
252 | if ( i2.mRecurrence != 0 && i2.mRecurrence->doesRecur() != Recurrence::rNone ) | 252 | if ( i2.mRecurrence != 0 && i2.mRecurrence->doesRecur() != Recurrence::rNone ) |
253 | return false; | 253 | return false; |
254 | } else { | 254 | } else { |
255 | // i1.mRecurrence != 0 | 255 | // i1.mRecurrence != 0 |
256 | // i2.mRecurrence == 0 | 256 | // i2.mRecurrence == 0 |
257 | if ( i1.mRecurrence->doesRecur() != Recurrence::rNone ) | 257 | if ( i1.mRecurrence->doesRecur() != Recurrence::rNone ) |
258 | return false; | 258 | return false; |
259 | } | 259 | } |
260 | } | 260 | } |
261 | 261 | ||
262 | return | 262 | return |
263 | // i1.created() == i2.created() && | 263 | // i1.created() == i2.created() && |
264 | stringCompare( i1.description(), i2.description() ) && | 264 | stringCompare( i1.description(), i2.description() ) && |
265 | stringCompare( i1.summary(), i2.summary() ) && | 265 | stringCompare( i1.summary(), i2.summary() ) && |
266 | i1.categories() == i2.categories() && | 266 | i1.categories() == i2.categories() && |
267 | // no need to compare mRelatedTo | 267 | // no need to compare mRelatedTo |
268 | stringCompare( i1.relatedToUid(), i2.relatedToUid() ) && | 268 | stringCompare( i1.relatedToUid(), i2.relatedToUid() ) && |
269 | // i1.relations() == i2.relations() && | 269 | // i1.relations() == i2.relations() && |
270 | i1.exDates() == i2.exDates() && | 270 | i1.exDates() == i2.exDates() && |
271 | i1.attachments() == i2.attachments() && | 271 | i1.attachments() == i2.attachments() && |
272 | i1.resources() == i2.resources() && | 272 | i1.resources() == i2.resources() && |
273 | i1.secrecy() == i2.secrecy() && | 273 | i1.secrecy() == i2.secrecy() && |
274 | i1.priority() == i2.priority() && | 274 | i1.priority() == i2.priority() && |
275 | i1.cancelled() == i2.cancelled() && | 275 | i1.cancelled() == i2.cancelled() && |
276 | stringCompare( i1.location(), i2.location() ); | 276 | stringCompare( i1.location(), i2.location() ); |
277 | } | 277 | } |
278 | 278 | ||
279 | Incidence* Incidence::recreateCloneException( QDate d ) | 279 | Incidence* Incidence::recreateCloneException( QDate d ) |
280 | { | 280 | { |
281 | Incidence* newInc = clone(); | 281 | Incidence* newInc = clone(); |
282 | newInc->recreate(); | 282 | newInc->recreate(); |
283 | if ( doesRecur() ) { | 283 | if ( doesRecur() ) { |
284 | addExDate( d ); | 284 | addExDate( d ); |
285 | newInc->recurrence()->unsetRecurs(); | 285 | newInc->recurrence()->unsetRecurs(); |
286 | if ( typeID() == eventID ) { | 286 | if ( typeID() == eventID ) { |
287 | int len = dtStart().secsTo( ((Event*)this)->dtEnd()); | 287 | int len = dtStart().secsTo( ((Event*)this)->dtEnd()); |
288 | QTime tim = dtStart().time(); | 288 | QTime tim = dtStart().time(); |
289 | newInc->setDtStart( QDateTime(d, tim) ); | 289 | newInc->setDtStart( QDateTime(d, tim) ); |
290 | ((Event*)newInc)->setDtEnd( newInc->dtStart().addSecs( len ) ); | 290 | ((Event*)newInc)->setDtEnd( newInc->dtStart().addSecs( len ) ); |
291 | } else { | 291 | } else { |
292 | int len = dtStart().secsTo( ((Todo*)this)->dtDue()); | 292 | int len = dtStart().secsTo( ((Todo*)this)->dtDue()); |
293 | QTime tim = ((Todo*)this)->dtDue().time(); | 293 | QTime tim = ((Todo*)this)->dtDue().time(); |
294 | ((Todo*)newInc)->setDtDue( QDateTime(d, tim) ); | 294 | ((Todo*)newInc)->setDtDue( QDateTime(d, tim) ); |
295 | ((Todo*)newInc)->setDtStart( ((Todo*)newInc)->dtDue().addSecs( -len ) ); | 295 | ((Todo*)newInc)->setDtStart( ((Todo*)newInc)->dtDue().addSecs( -len ) ); |
296 | ((Todo*)this)->setRecurDates(); | 296 | ((Todo*)this)->setRecurDates(); |
297 | } | 297 | } |
298 | newInc->setExDates( DateList () ); | 298 | newInc->setExDates( DateList () ); |
299 | } | 299 | } |
300 | return newInc; | 300 | return newInc; |
301 | } | 301 | } |
302 | 302 | ||
303 | void Incidence::recreate() | 303 | void Incidence::recreate() |
304 | { | 304 | { |
305 | setCreated(QDateTime::currentDateTime()); | 305 | setCreated(QDateTime::currentDateTime()); |
306 | 306 | ||
307 | setUid(CalFormat::createUniqueId()); | 307 | setUid(CalFormat::createUniqueId()); |
308 | 308 | ||
309 | setRevision(0); | 309 | setRevision(0); |
310 | setIDStr( ":" ); | 310 | setIDStr( ":" ); |
311 | setLastModified(QDateTime::currentDateTime()); | 311 | setLastModified(QDateTime::currentDateTime()); |
312 | } | 312 | } |
313 | void Incidence::cloneRelations( Incidence * newInc ) | 313 | void Incidence::cloneRelations( Incidence * newInc ) |
314 | { | 314 | { |
315 | // newInc is already a clone of this incidence | 315 | // newInc is already a clone of this incidence |
316 | Incidence * inc; | 316 | Incidence * inc; |
317 | Incidence * cloneInc; | 317 | Incidence * cloneInc; |
318 | QPtrList<Incidence> Relations = relations(); | 318 | QPtrList<Incidence> Relations = relations(); |
319 | for (inc=Relations.first();inc;inc=Relations.next()) { | 319 | for (inc=Relations.first();inc;inc=Relations.next()) { |
320 | cloneInc = inc->clone(); | 320 | cloneInc = inc->clone(); |
321 | cloneInc->recreate(); | 321 | cloneInc->recreate(); |
322 | cloneInc->setRelatedTo( newInc ); | 322 | cloneInc->setRelatedTo( newInc ); |
323 | inc->cloneRelations( cloneInc ); | 323 | inc->cloneRelations( cloneInc ); |
324 | } | 324 | } |
325 | } | 325 | } |
326 | void Incidence::setReadOnly( bool readOnly ) | 326 | void Incidence::setReadOnly( bool readOnly ) |
327 | { | 327 | { |
328 | IncidenceBase::setReadOnly( readOnly ); | 328 | IncidenceBase::setReadOnly( readOnly ); |
329 | if ( mRecurrence ) | 329 | if ( mRecurrence ) |
330 | mRecurrence->setRecurReadOnly( readOnly); | 330 | mRecurrence->setRecurReadOnly( readOnly); |
331 | } | 331 | } |
332 | void Incidence::setLastModifiedSubInvalid() | 332 | void Incidence::setLastModifiedSubInvalid() |
333 | { | 333 | { |
334 | mLastModifiedSub = QDateTime(); | 334 | mLastModifiedSub = QDateTime(); |
335 | if ( mRelatedTo ) | 335 | if ( mRelatedTo ) |
336 | mRelatedTo->setLastModifiedSubInvalid(); | 336 | mRelatedTo->setLastModifiedSubInvalid(); |
337 | } | 337 | } |
338 | QDateTime Incidence::lastModifiedSub() | 338 | QDateTime Incidence::lastModifiedSub() |
339 | { | 339 | { |
340 | if ( !mRelations.count() ) | 340 | if ( !mRelations.count() ) |
341 | return lastModified(); | 341 | return lastModified(); |
342 | if ( mLastModifiedSub.isValid() ) | 342 | if ( mLastModifiedSub.isValid() ) |
343 | return mLastModifiedSub; | 343 | return mLastModifiedSub; |
344 | mLastModifiedSub = lastModified(); | 344 | mLastModifiedSub = lastModified(); |
345 | Incidence * inc; | 345 | Incidence * inc; |
346 | QPtrList<Incidence> Relations = relations(); | 346 | QPtrList<Incidence> Relations = relations(); |
347 | for (inc=Relations.first();inc;inc=Relations.next()) { | 347 | for (inc=Relations.first();inc;inc=Relations.next()) { |
348 | if ( inc->lastModifiedSub() > mLastModifiedSub ) | 348 | if ( inc->lastModifiedSub() > mLastModifiedSub ) |
349 | mLastModifiedSub = inc->lastModifiedSub(); | 349 | mLastModifiedSub = inc->lastModifiedSub(); |
350 | } | 350 | } |
351 | return mLastModifiedSub; | 351 | return mLastModifiedSub; |
352 | } | 352 | } |
353 | void Incidence::setCreated(QDateTime created) | 353 | void Incidence::setCreated(QDateTime created) |
354 | { | 354 | { |
355 | if (mReadOnly) return; | 355 | if (mReadOnly) return; |
356 | mCreated = getEvenTime(created); | 356 | mCreated = getEvenTime(created); |
357 | } | 357 | } |
358 | 358 | ||
359 | QDateTime Incidence::created() const | 359 | QDateTime Incidence::created() const |
360 | { | 360 | { |
361 | return mCreated; | 361 | return mCreated; |
362 | } | 362 | } |
363 | 363 | ||
364 | void Incidence::setRevision(int rev) | 364 | void Incidence::setRevision(int rev) |
365 | { | 365 | { |
366 | if (mReadOnly) return; | 366 | if (mReadOnly) return; |
367 | mRevision = rev; | 367 | mRevision = rev; |
368 | 368 | ||
369 | updated(); | 369 | updated(); |
370 | } | 370 | } |
371 | 371 | ||
372 | int Incidence::revision() const | 372 | int Incidence::revision() const |
373 | { | 373 | { |
374 | return mRevision; | 374 | return mRevision; |
375 | } | 375 | } |
376 | 376 | ||
377 | void Incidence::setDtStart(const QDateTime &dtStart) | 377 | void Incidence::setDtStart(const QDateTime &dtStart) |
378 | { | 378 | { |
379 | 379 | ||
380 | QDateTime dt = getEvenTime(dtStart); | 380 | QDateTime dt = getEvenTime(dtStart); |
381 | 381 | ||
382 | if ( mRecurrence ) | 382 | if ( mRecurrence ) |
383 | mRecurrence->setRecurStart( dt); | 383 | mRecurrence->setRecurStart( dt); |
384 | IncidenceBase::setDtStart( dt ); | 384 | IncidenceBase::setDtStart( dt ); |
385 | } | 385 | } |
386 | 386 | ||
387 | void Incidence::setDescription(const QString &description) | 387 | void Incidence::setDescription(const QString &description) |
388 | { | 388 | { |
389 | if (mReadOnly) return; | 389 | if (mReadOnly) return; |
390 | mDescription = description; | 390 | mDescription = description; |
391 | updated(); | 391 | updated(); |
392 | } | 392 | } |
393 | 393 | ||
394 | QString Incidence::description() const | 394 | QString Incidence::description() const |
395 | { | 395 | { |
396 | return mDescription; | 396 | return mDescription; |
397 | } | 397 | } |
398 | 398 | ||
399 | 399 | ||
400 | void Incidence::setSummary(const QString &summary) | 400 | void Incidence::setSummary(const QString &summary) |
401 | { | 401 | { |
402 | if (mReadOnly) return; | 402 | if (mReadOnly) return; |
403 | mSummary = summary; | 403 | mSummary = summary; |
404 | updated(); | 404 | updated(); |
405 | } | 405 | } |
406 | 406 | ||
407 | QString Incidence::summary() const | 407 | QString Incidence::summary() const |
408 | { | 408 | { |
409 | return mSummary; | 409 | return mSummary; |
410 | } | 410 | } |
411 | void Incidence::checkCategories() | 411 | void Incidence::checkCategories() |
412 | { | 412 | { |
413 | mHoliday = mCategories.contains("Holiday") || mCategories.contains(i18n("Holiday")); | 413 | mHoliday = mCategories.contains("Holiday") || mCategories.contains(i18n("Holiday")); |
414 | mBirthday = mCategories.contains("Birthday") || mCategories.contains(i18n("Birthday")); | 414 | mBirthday = mCategories.contains("Birthday") || mCategories.contains(i18n("Birthday")); |
415 | mAnniversary = mCategories.contains("Anniversary") || mCategories.contains(i18n("Anniversary")); | 415 | mAnniversary = mCategories.contains("Anniversary") || mCategories.contains(i18n("Anniversary")); |
416 | } | 416 | } |
417 | 417 | ||
418 | void Incidence::addCategories(const QStringList &categories, bool addToRelations ) //addToRelations = false | 418 | void Incidence::addCategories(const QStringList &categories, bool addToRelations ) //addToRelations = false |
419 | { | 419 | { |
420 | if (mReadOnly) return; | 420 | if (mReadOnly) return; |
421 | int i; | 421 | int i; |
422 | for( i = 0; i < categories.count(); ++i ) { | 422 | for( i = 0; i < categories.count(); ++i ) { |
423 | if ( !mCategories.contains (categories[i])) | 423 | if ( !mCategories.contains (categories[i])) |
424 | mCategories.append( categories[i] ); | 424 | mCategories.append( categories[i] ); |
425 | } | 425 | } |
426 | checkCategories(); | 426 | checkCategories(); |
427 | updated(); | 427 | updated(); |
428 | if ( addToRelations ) { | 428 | if ( addToRelations ) { |
429 | Incidence * inc; | 429 | Incidence * inc; |
430 | QPtrList<Incidence> Relations = relations(); | 430 | QPtrList<Incidence> Relations = relations(); |
431 | for (inc=Relations.first();inc;inc=Relations.next()) { | 431 | for (inc=Relations.first();inc;inc=Relations.next()) { |
432 | inc->addCategories( categories, true ); | 432 | inc->addCategories( categories, true ); |
433 | } | 433 | } |
434 | } | 434 | } |
435 | } | 435 | } |
436 | 436 | ||
437 | void Incidence::setCategories(const QStringList &categories, bool setForRelations ) //setForRelations = false | 437 | void Incidence::setCategories(const QStringList &categories, bool setForRelations ) //setForRelations = false |
438 | { | 438 | { |
439 | if (mReadOnly) return; | 439 | if (mReadOnly) return; |
440 | mCategories = categories; | 440 | mCategories = categories; |
441 | checkCategories(); | 441 | checkCategories(); |
442 | updated(); | 442 | updated(); |
443 | if ( setForRelations ) { | 443 | if ( setForRelations ) { |
444 | Incidence * inc; | 444 | Incidence * inc; |
445 | QPtrList<Incidence> Relations = relations(); | 445 | QPtrList<Incidence> Relations = relations(); |
446 | for (inc=Relations.first();inc;inc=Relations.next()) { | 446 | for (inc=Relations.first();inc;inc=Relations.next()) { |
447 | inc->setCategories( categories, true ); | 447 | inc->setCategories( categories, true ); |
448 | } | 448 | } |
449 | } | 449 | } |
450 | } | 450 | } |
451 | 451 | ||
452 | // TODO: remove setCategories(QString) function | 452 | // TODO: remove setCategories(QString) function |
453 | void Incidence::setCategories(const QString &catStr) | 453 | void Incidence::setCategories(const QString &catStr) |
454 | { | 454 | { |
455 | if (mReadOnly) return; | 455 | if (mReadOnly) return; |
456 | mCategories.clear(); | 456 | mCategories.clear(); |
457 | 457 | ||
458 | if (catStr.isEmpty()) return; | 458 | if (catStr.isEmpty()) return; |
459 | 459 | ||
460 | mCategories = QStringList::split(",",catStr); | 460 | mCategories = QStringList::split(",",catStr); |
461 | 461 | ||
462 | QStringList::Iterator it; | 462 | QStringList::Iterator it; |
463 | for(it = mCategories.begin();it != mCategories.end(); ++it) { | 463 | for(it = mCategories.begin();it != mCategories.end(); ++it) { |
464 | *it = (*it).stripWhiteSpace(); | 464 | *it = (*it).stripWhiteSpace(); |
465 | } | 465 | } |
466 | checkCategories(); | 466 | checkCategories(); |
467 | updated(); | 467 | updated(); |
468 | } | 468 | } |
469 | // using this makes filtering 3 times faster | 469 | // using this makes filtering 3 times faster |
470 | QStringList* Incidence::categoriesP() | 470 | QStringList* Incidence::categoriesP() |
471 | { | 471 | { |
472 | return &mCategories; | 472 | return &mCategories; |
473 | } | 473 | } |
474 | 474 | ||
475 | QStringList Incidence::categories() const | 475 | QStringList Incidence::categories() const |
476 | { | 476 | { |
477 | return mCategories; | 477 | return mCategories; |
478 | } | 478 | } |
479 | 479 | ||
480 | QString Incidence::categoriesStr() | 480 | QString Incidence::categoriesStr() |
481 | { | 481 | { |
482 | return mCategories.join(","); | 482 | return mCategories.join(","); |
483 | } | 483 | } |
484 | QString Incidence::categoriesStrWithSpace() | 484 | QString Incidence::categoriesStrWithSpace() |
485 | { | 485 | { |
486 | return mCategories.join(", "); | 486 | return mCategories.join(", "); |
487 | } | 487 | } |
488 | 488 | ||
489 | void Incidence::setRelatedToUid(const QString &relatedToUid) | 489 | void Incidence::setRelatedToUid(const QString &relatedToUid) |
490 | { | 490 | { |
491 | if (mReadOnly) return; | 491 | if (mReadOnly) return; |
492 | mRelatedToUid = relatedToUid; | 492 | mRelatedToUid = relatedToUid; |
493 | } | 493 | } |
494 | 494 | ||
495 | QString Incidence::relatedToUid() const | 495 | QString Incidence::relatedToUid() const |
496 | { | 496 | { |
497 | return mRelatedToUid; | 497 | return mRelatedToUid; |
498 | } | 498 | } |
499 | 499 | ||
500 | void Incidence::setRelatedTo(Incidence *relatedTo) | 500 | void Incidence::setRelatedTo(Incidence *relatedTo) |
501 | { | 501 | { |
502 | //qDebug("Incidence::setRelatedTo %d ", relatedTo); | 502 | //qDebug("Incidence::setRelatedTo %d ", relatedTo); |
503 | //qDebug("setRelatedTo(Incidence *relatedTo) %s %s", summary().latin1(), relatedTo->summary().latin1() ); | 503 | //qDebug("setRelatedTo(Incidence *relatedTo) %s %s", summary().latin1(), relatedTo->summary().latin1() ); |
504 | if (mReadOnly || mRelatedTo == relatedTo) return; | 504 | if (mReadOnly || mRelatedTo == relatedTo) return; |
505 | if(mRelatedTo) { | 505 | if(mRelatedTo) { |
506 | // updated(); | 506 | // updated(); |
507 | mRelatedTo->removeRelation(this); | 507 | mRelatedTo->removeRelation(this); |
508 | } | 508 | } |
509 | mRelatedTo = relatedTo; | 509 | mRelatedTo = relatedTo; |
510 | if (mRelatedTo) { | 510 | if (mRelatedTo) { |
511 | mRelatedTo->addRelation(this); | 511 | mRelatedTo->addRelation(this); |
512 | mRelatedToUid = mRelatedTo->uid(); | 512 | mRelatedToUid = mRelatedTo->uid(); |
513 | } else { | 513 | } else { |
514 | mRelatedToUid = ""; | 514 | mRelatedToUid = ""; |
515 | } | 515 | } |
516 | } | 516 | } |
517 | 517 | ||
518 | Incidence *Incidence::relatedTo() const | 518 | Incidence *Incidence::relatedTo() const |
519 | { | 519 | { |
520 | return mRelatedTo; | 520 | return mRelatedTo; |
521 | } | 521 | } |
522 | 522 | ||
523 | QPtrList<Incidence> Incidence::relations() const | 523 | QPtrList<Incidence> Incidence::relations() const |
524 | { | 524 | { |
525 | return mRelations; | 525 | return mRelations; |
526 | } | 526 | } |
527 | 527 | ||
528 | void Incidence::addRelationsToList(QPtrList<Incidence> *rel) | 528 | void Incidence::addRelationsToList(QPtrList<Incidence> *rel) |
529 | { | 529 | { |
530 | Incidence* inc; | 530 | Incidence* inc; |
531 | QPtrList<Incidence> Relations = relations(); | 531 | QPtrList<Incidence> Relations = relations(); |
532 | for (inc=Relations.first();inc;inc=Relations.next()) { | 532 | for (inc=Relations.first();inc;inc=Relations.next()) { |
533 | inc->addRelationsToList( rel ); | 533 | inc->addRelationsToList( rel ); |
534 | } | 534 | } |
535 | if ( rel->findRef( this ) == -1 ) | 535 | if ( rel->findRef( this ) == -1 ) |
536 | rel->append( this ); | 536 | rel->append( this ); |
537 | } | 537 | } |
538 | 538 | ||
539 | void Incidence::addRelation(Incidence *event) | 539 | void Incidence::addRelation(Incidence *event) |
540 | { | 540 | { |
541 | setLastModifiedSubInvalid(); | 541 | setLastModifiedSubInvalid(); |
542 | if( mRelations.findRef( event ) == -1 ) { | 542 | if( mRelations.findRef( event ) == -1 ) { |
543 | mRelations.append(event); | 543 | mRelations.append(event); |
544 | //updated(); | 544 | //updated(); |
545 | } | 545 | } |
546 | } | 546 | } |
547 | 547 | ||
548 | void Incidence::removeRelation(Incidence *event) | 548 | void Incidence::removeRelation(Incidence *event) |
549 | { | 549 | { |
550 | setLastModifiedSubInvalid(); | 550 | setLastModifiedSubInvalid(); |
551 | mRelations.removeRef(event); | 551 | mRelations.removeRef(event); |
552 | // if (event->getRelatedTo() == this) event->setRelatedTo(0); | 552 | // if (event->getRelatedTo() == this) event->setRelatedTo(0); |
553 | } | 553 | } |
554 | 554 | ||
555 | bool Incidence::recursOn(const QDate &qd) const | 555 | bool Incidence::recursOn(const QDate &qd) const |
556 | { | 556 | { |
557 | if (mRecurrence && mRecurrence->recursOnPure(qd) && !isException(qd)) return true; | 557 | if (mRecurrence && mRecurrence->recursOnPure(qd) && !isException(qd)) return true; |
558 | else return false; | 558 | else return false; |
559 | } | 559 | } |
560 | 560 | ||
561 | void Incidence::setExDates(const DateList &exDates) | 561 | void Incidence::setExDates(const DateList &exDates) |
562 | { | 562 | { |
563 | if (mReadOnly) return; | 563 | if (mReadOnly) return; |
564 | mExDates = exDates; | 564 | mExDates = exDates; |
565 | recurrence()->setRecurExDatesCount(mExDates.count()); | 565 | recurrence()->setRecurExDatesCount(mExDates.count()); |
566 | 566 | ||
567 | updated(); | 567 | updated(); |
568 | } | 568 | } |
569 | 569 | ||
570 | void Incidence::addExDate(const QDate &date) | 570 | void Incidence::addExDate(const QDate &date) |
571 | { | 571 | { |
572 | if (mReadOnly) return; | 572 | if (mReadOnly) return; |
573 | mExDates.append(date); | 573 | mExDates.append(date); |
574 | 574 | ||
575 | recurrence()->setRecurExDatesCount(mExDates.count()); | 575 | recurrence()->setRecurExDatesCount(mExDates.count()); |
576 | 576 | ||
577 | updated(); | 577 | updated(); |
578 | } | 578 | } |
579 | 579 | ||
580 | DateList Incidence::exDates() const | 580 | DateList Incidence::exDates() const |
581 | { | 581 | { |
582 | return mExDates; | 582 | return mExDates; |
583 | } | 583 | } |
584 | 584 | ||
585 | bool Incidence::isException(const QDate &date) const | 585 | bool Incidence::isException(const QDate &date) const |
586 | { | 586 | { |
587 | DateList::ConstIterator it; | 587 | DateList::ConstIterator it; |
588 | for( it = mExDates.begin(); it != mExDates.end(); ++it ) { | 588 | for( it = mExDates.begin(); it != mExDates.end(); ++it ) { |
589 | if ( (*it) == date ) { | 589 | if ( (*it) == date ) { |
590 | return true; | 590 | return true; |
591 | } | 591 | } |
592 | } | 592 | } |
593 | 593 | ||
594 | return false; | 594 | return false; |
595 | } | 595 | } |
596 | 596 | ||
597 | void Incidence::addAttachment(Attachment *attachment) | 597 | void Incidence::addAttachment(Attachment *attachment) |
598 | { | 598 | { |
599 | if (mReadOnly || !attachment) return; | 599 | if (mReadOnly || !attachment) return; |
600 | mAttachments.append(attachment); | 600 | mAttachments.append(attachment); |
601 | updated(); | 601 | updated(); |
602 | } | 602 | } |
603 | 603 | ||
604 | void Incidence::deleteAttachment(Attachment *attachment) | 604 | void Incidence::deleteAttachment(Attachment *attachment) |
605 | { | 605 | { |
606 | mAttachments.removeRef(attachment); | 606 | mAttachments.removeRef(attachment); |
607 | } | 607 | } |
608 | 608 | ||
609 | void Incidence::deleteAttachments(const QString& mime) | 609 | void Incidence::deleteAttachments(const QString& mime) |
610 | { | 610 | { |
611 | Attachment *at = mAttachments.first(); | 611 | Attachment *at = mAttachments.first(); |
612 | while (at) { | 612 | while (at) { |
613 | if (at->mimeType() == mime) | 613 | if (at->mimeType() == mime) |
614 | mAttachments.remove(); | 614 | mAttachments.remove(); |
615 | else | 615 | else |
616 | at = mAttachments.next(); | 616 | at = mAttachments.next(); |
617 | } | 617 | } |
618 | } | 618 | } |
619 | 619 | ||
620 | QPtrList<Attachment> Incidence::attachments() const | 620 | QPtrList<Attachment> Incidence::attachments() const |
621 | { | 621 | { |
622 | return mAttachments; | 622 | return mAttachments; |
623 | } | 623 | } |
624 | 624 | ||
625 | QPtrList<Attachment> Incidence::attachments(const QString& mime) const | 625 | QPtrList<Attachment> Incidence::attachments(const QString& mime) const |
626 | { | 626 | { |
627 | QPtrList<Attachment> attachments; | 627 | QPtrList<Attachment> attachments; |
628 | QPtrListIterator<Attachment> it( mAttachments ); | 628 | QPtrListIterator<Attachment> it( mAttachments ); |
629 | Attachment *at; | 629 | Attachment *at; |
630 | while ( (at = it.current()) ) { | 630 | while ( (at = it.current()) ) { |
631 | if (at->mimeType() == mime) | 631 | if (at->mimeType() == mime) |
632 | attachments.append(at); | 632 | attachments.append(at); |
633 | ++it; | 633 | ++it; |
634 | } | 634 | } |
635 | 635 | ||
636 | return attachments; | 636 | return attachments; |
637 | } | 637 | } |
638 | 638 | ||
639 | void Incidence::setResources(const QStringList &resources) | 639 | void Incidence::setResources(const QStringList &resources) |
640 | { | 640 | { |
641 | if (mReadOnly) return; | 641 | if (mReadOnly) return; |
642 | mResources = resources; | 642 | mResources = resources; |
643 | updated(); | 643 | updated(); |
644 | } | 644 | } |
645 | 645 | ||
646 | QStringList Incidence::resources() const | 646 | QStringList Incidence::resources() const |
647 | { | 647 | { |
648 | return mResources; | 648 | return mResources; |
649 | } | 649 | } |
650 | 650 | ||
651 | 651 | ||
652 | void Incidence::setPriority(int priority) | 652 | void Incidence::setPriority(int priority) |
653 | { | 653 | { |
654 | if (mReadOnly) return; | 654 | if (mReadOnly) return; |
655 | mPriority = priority; | 655 | mPriority = priority; |
656 | updated(); | 656 | updated(); |
657 | } | 657 | } |
658 | 658 | ||
659 | int Incidence::priority() const | 659 | int Incidence::priority() const |
660 | { | 660 | { |
661 | return mPriority; | 661 | return mPriority; |
662 | } | 662 | } |
663 | 663 | ||
664 | void Incidence::setSecrecy(int sec) | 664 | void Incidence::setSecrecy(int sec) |
665 | { | 665 | { |
666 | if (mReadOnly) return; | 666 | if (mReadOnly) return; |
667 | mSecrecy = sec; | 667 | mSecrecy = sec; |
668 | updated(); | 668 | updated(); |
669 | } | 669 | } |
670 | 670 | ||
671 | int Incidence::secrecy() const | 671 | int Incidence::secrecy() const |
672 | { | 672 | { |
673 | return mSecrecy; | 673 | return mSecrecy; |
674 | } | 674 | } |
675 | 675 | ||
676 | QString Incidence::secrecyStr() const | 676 | QString Incidence::secrecyStr() const |
677 | { | 677 | { |
678 | return secrecyName(mSecrecy); | 678 | return secrecyName(mSecrecy); |
679 | } | 679 | } |
680 | 680 | ||
681 | QString Incidence::secrecyName(int secrecy) | 681 | QString Incidence::secrecyName(int secrecy) |
682 | { | 682 | { |
683 | switch (secrecy) { | 683 | switch (secrecy) { |
684 | case SecrecyPublic: | 684 | case SecrecyPublic: |
685 | return i18n("Public"); | 685 | return i18n("Public"); |
686 | break; | 686 | break; |
687 | case SecrecyPrivate: | 687 | case SecrecyPrivate: |
688 | return i18n("Private"); | 688 | return i18n("Private"); |
689 | break; | 689 | break; |
690 | case SecrecyConfidential: | 690 | case SecrecyConfidential: |
691 | return i18n("Confidential"); | 691 | return i18n("Confidential"); |
692 | break; | 692 | break; |
693 | default: | 693 | default: |
694 | return i18n("Undefined"); | 694 | return i18n("Undefined"); |
695 | break; | 695 | break; |
696 | } | 696 | } |
697 | } | 697 | } |
698 | 698 | ||
699 | QStringList Incidence::secrecyList() | 699 | QStringList Incidence::secrecyList() |
700 | { | 700 | { |
701 | QStringList list; | 701 | QStringList list; |
702 | list << secrecyName(SecrecyPublic); | 702 | list << secrecyName(SecrecyPublic); |
703 | list << secrecyName(SecrecyPrivate); | 703 | list << secrecyName(SecrecyPrivate); |
704 | list << secrecyName(SecrecyConfidential); | 704 | list << secrecyName(SecrecyConfidential); |
705 | 705 | ||
706 | return list; | 706 | return list; |
707 | } | 707 | } |
708 | 708 | ||
709 | 709 | ||
710 | QPtrList<Alarm> Incidence::alarms() const | 710 | QPtrList<Alarm> Incidence::alarms() const |
711 | { | 711 | { |
712 | return mAlarms; | 712 | return mAlarms; |
713 | } | 713 | } |
714 | 714 | ||
715 | Alarm* Incidence::newAlarm() | 715 | Alarm* Incidence::newAlarm() |
716 | { | 716 | { |
717 | Alarm* alarm = new Alarm(this); | 717 | Alarm* alarm = new Alarm(this); |
718 | mAlarms.append(alarm); | 718 | mAlarms.append(alarm); |
719 | // updated(); | 719 | // updated(); |
720 | return alarm; | 720 | return alarm; |
721 | } | 721 | } |
722 | 722 | ||
723 | void Incidence::addAlarm(Alarm *alarm) | 723 | void Incidence::addAlarm(Alarm *alarm) |
724 | { | 724 | { |
725 | mAlarms.append(alarm); | 725 | mAlarms.append(alarm); |
726 | updated(); | 726 | updated(); |
727 | } | 727 | } |
728 | 728 | ||
729 | void Incidence::removeAlarm(Alarm *alarm) | 729 | void Incidence::removeAlarm(Alarm *alarm) |
730 | { | 730 | { |
731 | mAlarms.removeRef(alarm); | 731 | mAlarms.removeRef(alarm); |
732 | updated(); | 732 | updated(); |
733 | } | 733 | } |
734 | 734 | ||
735 | void Incidence::clearAlarms() | 735 | void Incidence::clearAlarms() |
736 | { | 736 | { |
737 | mAlarms.clear(); | 737 | mAlarms.clear(); |
738 | updated(); | 738 | updated(); |
739 | } | 739 | } |
740 | 740 | ||
741 | bool Incidence::isAlarmEnabled() const | 741 | bool Incidence::isAlarmEnabled() const |
742 | { | 742 | { |
743 | Alarm* alarm; | 743 | Alarm* alarm; |
744 | for (QPtrListIterator<Alarm> it(mAlarms); (alarm = it.current()) != 0; ++it) { | 744 | for (QPtrListIterator<Alarm> it(mAlarms); (alarm = it.current()) != 0; ++it) { |
745 | if (alarm->enabled()) | 745 | if (alarm->enabled()) |
746 | return true; | 746 | return true; |
747 | } | 747 | } |
748 | return false; | 748 | return false; |
749 | } | 749 | } |
750 | #include <stdlib.h> | 750 | #include <stdlib.h> |
751 | Recurrence *Incidence::recurrence() | 751 | Recurrence *Incidence::recurrence() |
752 | { | 752 | { |
753 | if ( ! mRecurrence ) { | 753 | if ( ! mRecurrence ) { |
754 | mRecurrence = new Recurrence(this); | 754 | mRecurrence = new Recurrence(this); |
755 | qDebug("creating new recurence "); | 755 | mRecurrence->setRecurStart( dtStart() ); |
756 | //qDebug("creating new recurence "); | ||
756 | //abort(); | 757 | //abort(); |
757 | } | 758 | } |
758 | return mRecurrence; | 759 | return mRecurrence; |
759 | } | 760 | } |
760 | void Incidence::setRecurrence( Recurrence * r) | 761 | void Incidence::setRecurrence( Recurrence * r) |
761 | { | 762 | { |
762 | if ( mRecurrence ) | 763 | if ( mRecurrence ) |
763 | delete mRecurrence; | 764 | delete mRecurrence; |
764 | mRecurrence = r; | 765 | mRecurrence = r; |
765 | } | 766 | } |
766 | 767 | ||
767 | void Incidence::setLocation(const QString &location) | 768 | void Incidence::setLocation(const QString &location) |
768 | { | 769 | { |
769 | if (mReadOnly) return; | 770 | if (mReadOnly) return; |
770 | mLocation = location; | 771 | mLocation = location; |
771 | updated(); | 772 | updated(); |
772 | } | 773 | } |
773 | 774 | ||
774 | QString Incidence::location() const | 775 | QString Incidence::location() const |
775 | { | 776 | { |
776 | return mLocation; | 777 | return mLocation; |
777 | } | 778 | } |
778 | QString Incidence::recurrenceText() const | 779 | QString Incidence::recurrenceText() const |
779 | { | 780 | { |
780 | if ( mRecurrence ) return mRecurrence->recurrenceText(); | 781 | if ( mRecurrence ) return mRecurrence->recurrenceText(); |
781 | return i18n("No"); | 782 | return i18n("No"); |
782 | } | 783 | } |
783 | 784 | ||
784 | ushort Incidence::doesRecur() const | 785 | ushort Incidence::doesRecur() const |
785 | { | 786 | { |
786 | if ( mRecurrence ) return mRecurrence->doesRecur(); | 787 | if ( mRecurrence ) return mRecurrence->doesRecur(); |
787 | else return Recurrence::rNone; | 788 | else return Recurrence::rNone; |
788 | } | 789 | } |
789 | 790 | ||
790 | QDateTime Incidence::getNextOccurence( const QDateTime& dt, bool* ok ) const | 791 | QDateTime Incidence::getNextOccurence( const QDateTime& dt, bool* ok ) const |
791 | { | 792 | { |
792 | QDateTime incidenceStart = dt; | 793 | QDateTime incidenceStart = dt; |
793 | *ok = false; | 794 | *ok = false; |
794 | if ( doesRecur() ) { | 795 | if ( doesRecur() ) { |
795 | bool last; | 796 | bool last; |
796 | mRecurrence->getPreviousDateTime( incidenceStart , &last ); | 797 | mRecurrence->getPreviousDateTime( incidenceStart , &last ); |
797 | int count = 0; | 798 | int count = 0; |
798 | if ( !last ) { | 799 | if ( !last ) { |
799 | while ( !last ) { | 800 | while ( !last ) { |
800 | ++count; | 801 | ++count; |
801 | incidenceStart = mRecurrence->getNextDateTime( incidenceStart, &last ); | 802 | incidenceStart = mRecurrence->getNextDateTime( incidenceStart, &last ); |
802 | if ( recursOn( incidenceStart.date() ) ) { | 803 | if ( recursOn( incidenceStart.date() ) ) { |
803 | last = true; // exit while llop | 804 | last = true; // exit while llop |
804 | } else { | 805 | } else { |
805 | if ( last ) { // no alarm on last recurrence | 806 | if ( last ) { // no alarm on last recurrence |
806 | return QDateTime (); | 807 | return QDateTime (); |
807 | } | 808 | } |
808 | int year = incidenceStart.date().year(); | 809 | int year = incidenceStart.date().year(); |
809 | // workaround for bug in recurrence | 810 | // workaround for bug in recurrence |
810 | if ( count == 100 || year < 1000 || year > 5000 ) { | 811 | if ( count == 100 || year < 1000 || year > 5000 ) { |
811 | return QDateTime (); | 812 | return QDateTime (); |
812 | } | 813 | } |
813 | incidenceStart = incidenceStart.addSecs( 1 ); | 814 | incidenceStart = incidenceStart.addSecs( 1 ); |
814 | } | 815 | } |
815 | } | 816 | } |
816 | } else { | 817 | } else { |
817 | return QDateTime (); | 818 | return QDateTime (); |
818 | } | 819 | } |
819 | } else { | 820 | } else { |
820 | if ( hasStartDate () ) { | 821 | if ( hasStartDate () ) { |
821 | incidenceStart = dtStart(); | 822 | incidenceStart = dtStart(); |
822 | } | 823 | } |
823 | if ( typeID() == todoID ) { | 824 | if ( typeID() == todoID ) { |
824 | if ( ((Todo*)this)->hasDueDate() ) | 825 | if ( ((Todo*)this)->hasDueDate() ) |
825 | incidenceStart = ((Todo*)this)->dtDue(); | 826 | incidenceStart = ((Todo*)this)->dtDue(); |
826 | } | 827 | } |
827 | } | 828 | } |
828 | if ( incidenceStart > dt ) | 829 | if ( incidenceStart > dt ) |
829 | *ok = true; | 830 | *ok = true; |
830 | return incidenceStart; | 831 | return incidenceStart; |
831 | } | 832 | } |
832 | QDateTime Incidence::dtStart() const | 833 | QDateTime Incidence::dtStart() const |
833 | { | 834 | { |
834 | if ( doesRecur() ) { | 835 | if ( doesRecur() ) { |
835 | if ( typeID() == todoID ) { | 836 | if ( typeID() == todoID ) { |
836 | ((Todo*)this)->checkSetCompletedFalse(); | 837 | ((Todo*)this)->checkSetCompletedFalse(); |
837 | } | 838 | } |
838 | } | 839 | } |
839 | return mDtStart; | 840 | return mDtStart; |
840 | } | 841 | } |