-rw-r--r-- | libopie/pim/oevent.cpp | 20 | ||||
-rw-r--r-- | libopie/pim/otodo.cpp | 12 | ||||
-rw-r--r-- | libopie2/opiepim/oevent.cpp | 20 | ||||
-rw-r--r-- | libopie2/opiepim/otodo.cpp | 12 |
4 files changed, 46 insertions, 18 deletions
diff --git a/libopie/pim/oevent.cpp b/libopie/pim/oevent.cpp index cda12f9..2b138c0 100644 --- a/libopie/pim/oevent.cpp +++ b/libopie/pim/oevent.cpp | |||
@@ -151,138 +151,148 @@ void OEvent::setNote( const QString& note ) { | |||
151 | } | 151 | } |
152 | QDateTime OEvent::createdDateTime()const { | 152 | QDateTime OEvent::createdDateTime()const { |
153 | return data->created; | 153 | return data->created; |
154 | } | 154 | } |
155 | void OEvent::setCreatedDateTime( const QDateTime& time ) { | 155 | void OEvent::setCreatedDateTime( const QDateTime& time ) { |
156 | changeOrModify(); | 156 | changeOrModify(); |
157 | data->created = time; | 157 | data->created = time; |
158 | } | 158 | } |
159 | QDateTime OEvent::startDateTime()const { | 159 | QDateTime OEvent::startDateTime()const { |
160 | if ( data->isAllDay ) | 160 | if ( data->isAllDay ) |
161 | return QDateTime( data->start.date(), QTime(0, 0, 0 ) ); | 161 | return QDateTime( data->start.date(), QTime(0, 0, 0 ) ); |
162 | return data->start; | 162 | return data->start; |
163 | } | 163 | } |
164 | QDateTime OEvent::startDateTimeInZone()const { | 164 | QDateTime OEvent::startDateTimeInZone()const { |
165 | /* if no timezone, or all day event or if the current and this timeZone match... */ | 165 | /* if no timezone, or all day event or if the current and this timeZone match... */ |
166 | if (data->timezone.isEmpty() || data->isAllDay || data->timezone == OTimeZone::current().timeZone() ) return startDateTime(); | 166 | if (data->timezone.isEmpty() || data->isAllDay || data->timezone == OTimeZone::current().timeZone() ) return startDateTime(); |
167 | 167 | ||
168 | OTimeZone zone(data->timezone ); | 168 | OTimeZone zone(data->timezone ); |
169 | return zone.toDateTime( data->start, OTimeZone::current() ); | 169 | return zone.toDateTime( data->start, OTimeZone::current() ); |
170 | } | 170 | } |
171 | void OEvent::setStartDateTime( const QDateTime& dt ) { | 171 | void OEvent::setStartDateTime( const QDateTime& dt ) { |
172 | changeOrModify(); | 172 | changeOrModify(); |
173 | data->start = dt; | 173 | data->start = dt; |
174 | } | 174 | } |
175 | QDateTime OEvent::endDateTime()const { | 175 | QDateTime OEvent::endDateTime()const { |
176 | /* | 176 | /* |
177 | * if all Day event the end time needs | 177 | * if all Day event the end time needs |
178 | * to be on the same day as the start | 178 | * to be on the same day as the start |
179 | */ | 179 | */ |
180 | if ( data->isAllDay ) | 180 | if ( data->isAllDay ) |
181 | return QDateTime( data->start.date(), QTime(23, 59, 59 ) ); | 181 | return QDateTime( data->start.date(), QTime(23, 59, 59 ) ); |
182 | return data->end; | 182 | return data->end; |
183 | } | 183 | } |
184 | QDateTime OEvent::endDateTimeInZone()const { | 184 | QDateTime OEvent::endDateTimeInZone()const { |
185 | /* if no timezone, or all day event or if the current and this timeZone match... */ | 185 | /* if no timezone, or all day event or if the current and this timeZone match... */ |
186 | if (data->timezone.isEmpty() || data->isAllDay || data->timezone == OTimeZone::current().timeZone() ) return endDateTime(); | 186 | if (data->timezone.isEmpty() || data->isAllDay || data->timezone == OTimeZone::current().timeZone() ) return endDateTime(); |
187 | 187 | ||
188 | OTimeZone zone(data->timezone ); | 188 | OTimeZone zone(data->timezone ); |
189 | return zone.toDateTime( data->end, OTimeZone::current() ); | 189 | return zone.toDateTime( data->end, OTimeZone::current() ); |
190 | } | 190 | } |
191 | void OEvent::setEndDateTime( const QDateTime& dt ) { | 191 | void OEvent::setEndDateTime( const QDateTime& dt ) { |
192 | changeOrModify(); | 192 | changeOrModify(); |
193 | data->end = dt; | 193 | data->end = dt; |
194 | } | 194 | } |
195 | bool OEvent::isMultipleDay()const { | 195 | bool OEvent::isMultipleDay()const { |
196 | return data->end.date().day() - data->start.date().day(); | 196 | return data->end.date().day() - data->start.date().day(); |
197 | } | 197 | } |
198 | bool OEvent::isAllDay()const { | 198 | bool OEvent::isAllDay()const { |
199 | return data->isAllDay; | 199 | return data->isAllDay; |
200 | } | 200 | } |
201 | void OEvent::setAllDay( bool allDay ) { | 201 | void OEvent::setAllDay( bool allDay ) { |
202 | changeOrModify(); | 202 | changeOrModify(); |
203 | data->isAllDay = allDay; | 203 | data->isAllDay = allDay; |
204 | if (allDay ) data->timezone = "UTC"; | 204 | if (allDay ) data->timezone = "UTC"; |
205 | } | 205 | } |
206 | void OEvent::setTimeZone( const QString& tz ) { | 206 | void OEvent::setTimeZone( const QString& tz ) { |
207 | changeOrModify(); | 207 | changeOrModify(); |
208 | data->timezone = tz; | 208 | data->timezone = tz; |
209 | } | 209 | } |
210 | QString OEvent::timeZone()const { | 210 | QString OEvent::timeZone()const { |
211 | if (data->isAllDay ) return QString::fromLatin1("UTC"); | 211 | if (data->isAllDay ) return QString::fromLatin1("UTC"); |
212 | return data->timezone; | 212 | return data->timezone; |
213 | } | 213 | } |
214 | bool OEvent::match( const QRegExp& re )const { | 214 | bool OEvent::match( const QRegExp& re )const { |
215 | if ( re.match( data->description ) != -1 ) | 215 | if ( re.match( data->description ) != -1 ){ |
216 | setLastHitField( DatebookDescription ); | ||
216 | return true; | 217 | return true; |
217 | if ( re.match( data->note ) != -1 ) | 218 | } |
219 | if ( re.match( data->note ) != -1 ){ | ||
220 | setLastHitField( Note ); | ||
218 | return true; | 221 | return true; |
219 | if ( re.match( data->location ) != -1 ) | 222 | } |
223 | if ( re.match( data->location ) != -1 ){ | ||
224 | setLastHitField( Location ); | ||
220 | return true; | 225 | return true; |
221 | if ( re.match( data->start.toString() ) != -1 ) | 226 | } |
227 | if ( re.match( data->start.toString() ) != -1 ){ | ||
228 | setLastHitField( StartDateTime ); | ||
222 | return true; | 229 | return true; |
223 | if ( re.match( data->end.toString() ) != -1 ) | 230 | } |
231 | if ( re.match( data->end.toString() ) != -1 ){ | ||
232 | setLastHitField( EndDateTime ); | ||
224 | return true; | 233 | return true; |
234 | } | ||
225 | return false; | 235 | return false; |
226 | } | 236 | } |
227 | QString OEvent::toRichText()const { | 237 | QString OEvent::toRichText()const { |
228 | QString text; | 238 | QString text; |
229 | if ( !description().isEmpty() ) { | 239 | if ( !description().isEmpty() ) { |
230 | text += "<b>" + QObject::tr( "Description:") + "</b><br>"; | 240 | text += "<b>" + QObject::tr( "Description:") + "</b><br>"; |
231 | text += Qtopia::escapeString(description() ). | 241 | text += Qtopia::escapeString(description() ). |
232 | replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; | 242 | replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; |
233 | } | 243 | } |
234 | if ( startDateTime().isValid() ) { | 244 | if ( startDateTime().isValid() ) { |
235 | text += "<b>" + QObject::tr( "Start:") + "</b> "; | 245 | text += "<b>" + QObject::tr( "Start:") + "</b> "; |
236 | text += Qtopia::escapeString(startDateTime().toString() ). | 246 | text += Qtopia::escapeString(startDateTime().toString() ). |
237 | replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; | 247 | replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; |
238 | } | 248 | } |
239 | if ( endDateTime().isValid() ) { | 249 | if ( endDateTime().isValid() ) { |
240 | text += "<b>" + QObject::tr( "End:") + "</b> "; | 250 | text += "<b>" + QObject::tr( "End:") + "</b> "; |
241 | text += Qtopia::escapeString(endDateTime().toString() ). | 251 | text += Qtopia::escapeString(endDateTime().toString() ). |
242 | replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; | 252 | replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; |
243 | } | 253 | } |
244 | if ( !note().isEmpty() ) { | 254 | if ( !note().isEmpty() ) { |
245 | text += "<b>" + QObject::tr( "Note:") + "</b><br>"; | 255 | text += "<b>" + QObject::tr( "Note:") + "</b><br>"; |
246 | text += note(); | 256 | text += note(); |
247 | // text += Qtopia::escapeString(note() ). | 257 | // text += Qtopia::escapeString(note() ). |
248 | // replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; | 258 | // replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; |
249 | } | 259 | } |
250 | return text; | 260 | return text; |
251 | } | 261 | } |
252 | QString OEvent::toShortText()const { | 262 | QString OEvent::toShortText()const { |
253 | QString text; | 263 | QString text; |
254 | text += QString::number( startDateTime().date().day() ); | 264 | text += QString::number( startDateTime().date().day() ); |
255 | text += "."; | 265 | text += "."; |
256 | text += QString::number( startDateTime().date().month() ); | 266 | text += QString::number( startDateTime().date().month() ); |
257 | text += "."; | 267 | text += "."; |
258 | text += QString::number( startDateTime().date().year() ); | 268 | text += QString::number( startDateTime().date().year() ); |
259 | text += " "; | 269 | text += " "; |
260 | text += QString::number( startDateTime().time().hour() ); | 270 | text += QString::number( startDateTime().time().hour() ); |
261 | text += ":"; | 271 | text += ":"; |
262 | text += QString::number( startDateTime().time().minute() ); | 272 | text += QString::number( startDateTime().time().minute() ); |
263 | text += " - "; | 273 | text += " - "; |
264 | text += description(); | 274 | text += description(); |
265 | return text; | 275 | return text; |
266 | } | 276 | } |
267 | QString OEvent::type()const { | 277 | QString OEvent::type()const { |
268 | return QString::fromLatin1("OEvent"); | 278 | return QString::fromLatin1("OEvent"); |
269 | } | 279 | } |
270 | QString OEvent::recordField( int /*id */ )const { | 280 | QString OEvent::recordField( int /*id */ )const { |
271 | return QString::null; | 281 | return QString::null; |
272 | } | 282 | } |
273 | int OEvent::rtti() { | 283 | int OEvent::rtti() { |
274 | return OPimResolver::DateBook; | 284 | return OPimResolver::DateBook; |
275 | } | 285 | } |
276 | bool OEvent::loadFromStream( QDataStream& ) { | 286 | bool OEvent::loadFromStream( QDataStream& ) { |
277 | return true; | 287 | return true; |
278 | } | 288 | } |
279 | bool OEvent::saveToStream( QDataStream& )const { | 289 | bool OEvent::saveToStream( QDataStream& )const { |
280 | return true; | 290 | return true; |
281 | } | 291 | } |
282 | void OEvent::changeOrModify() { | 292 | void OEvent::changeOrModify() { |
283 | if ( data->count != 1 ) { | 293 | if ( data->count != 1 ) { |
284 | data->deref(); | 294 | data->deref(); |
285 | Data* d2 = new Data; | 295 | Data* d2 = new Data; |
286 | d2->description = data->description; | 296 | d2->description = data->description; |
287 | d2->location = data->location; | 297 | d2->location = data->location; |
288 | 298 | ||
diff --git a/libopie/pim/otodo.cpp b/libopie/pim/otodo.cpp index a29d88e..e087a00 100644 --- a/libopie/pim/otodo.cpp +++ b/libopie/pim/otodo.cpp | |||
@@ -44,135 +44,139 @@ struct OTodo::OTodoData : public QShared { | |||
44 | QDate completed; | 44 | QDate completed; |
45 | OPimNotifyManager *notifiers; | 45 | OPimNotifyManager *notifiers; |
46 | }; | 46 | }; |
47 | 47 | ||
48 | OTodo::OTodo(const OTodo &event ) | 48 | OTodo::OTodo(const OTodo &event ) |
49 | : OPimRecord( event ), data( event.data ) | 49 | : OPimRecord( event ), data( event.data ) |
50 | { | 50 | { |
51 | data->ref(); | 51 | data->ref(); |
52 | // qWarning("ref up"); | 52 | // qWarning("ref up"); |
53 | } | 53 | } |
54 | OTodo::~OTodo() { | 54 | OTodo::~OTodo() { |
55 | 55 | ||
56 | // qWarning("~OTodo " ); | 56 | // qWarning("~OTodo " ); |
57 | if ( data->deref() ) { | 57 | if ( data->deref() ) { |
58 | // qWarning("OTodo::dereffing"); | 58 | // qWarning("OTodo::dereffing"); |
59 | delete data; | 59 | delete data; |
60 | data = 0l; | 60 | data = 0l; |
61 | } | 61 | } |
62 | } | 62 | } |
63 | OTodo::OTodo(bool completed, int priority, | 63 | OTodo::OTodo(bool completed, int priority, |
64 | const QArray<int> &category, | 64 | const QArray<int> &category, |
65 | const QString& summary, | 65 | const QString& summary, |
66 | const QString &description, | 66 | const QString &description, |
67 | ushort progress, | 67 | ushort progress, |
68 | bool hasDate, QDate date, int uid ) | 68 | bool hasDate, QDate date, int uid ) |
69 | : OPimRecord( uid ) | 69 | : OPimRecord( uid ) |
70 | { | 70 | { |
71 | // qWarning("OTodoData " + summary); | 71 | // qWarning("OTodoData " + summary); |
72 | setCategories( category ); | 72 | setCategories( category ); |
73 | 73 | ||
74 | data = new OTodoData; | 74 | data = new OTodoData; |
75 | 75 | ||
76 | data->date = date; | 76 | data->date = date; |
77 | data->isCompleted = completed; | 77 | data->isCompleted = completed; |
78 | data->hasDate = hasDate; | 78 | data->hasDate = hasDate; |
79 | data->priority = priority; | 79 | data->priority = priority; |
80 | data->sum = summary; | 80 | data->sum = summary; |
81 | data->prog = progress; | 81 | data->prog = progress; |
82 | data->desc = Qtopia::simplifyMultiLineSpace(description ); | 82 | data->desc = Qtopia::simplifyMultiLineSpace(description ); |
83 | } | 83 | } |
84 | OTodo::OTodo(bool completed, int priority, | 84 | OTodo::OTodo(bool completed, int priority, |
85 | const QStringList &category, | 85 | const QStringList &category, |
86 | const QString& summary, | 86 | const QString& summary, |
87 | const QString &description, | 87 | const QString &description, |
88 | ushort progress, | 88 | ushort progress, |
89 | bool hasDate, QDate date, int uid ) | 89 | bool hasDate, QDate date, int uid ) |
90 | : OPimRecord( uid ) | 90 | : OPimRecord( uid ) |
91 | { | 91 | { |
92 | // qWarning("OTodoData" + summary); | 92 | // qWarning("OTodoData" + summary); |
93 | setCategories( idsFromString( category.join(";") ) ); | 93 | setCategories( idsFromString( category.join(";") ) ); |
94 | 94 | ||
95 | data = new OTodoData; | 95 | data = new OTodoData; |
96 | 96 | ||
97 | data->date = date; | 97 | data->date = date; |
98 | data->isCompleted = completed; | 98 | data->isCompleted = completed; |
99 | data->hasDate = hasDate; | 99 | data->hasDate = hasDate; |
100 | data->priority = priority; | 100 | data->priority = priority; |
101 | data->sum = summary; | 101 | data->sum = summary; |
102 | data->prog = progress; | 102 | data->prog = progress; |
103 | data->desc = Qtopia::simplifyMultiLineSpace(description ); | 103 | data->desc = Qtopia::simplifyMultiLineSpace(description ); |
104 | } | 104 | } |
105 | bool OTodo::match( const QRegExp ®Exp )const | 105 | bool OTodo::match( const QRegExp ®Exp )const |
106 | { | 106 | { |
107 | if( QString::number( data->priority ).find( regExp ) != -1 ){ | 107 | if( QString::number( data->priority ).find( regExp ) != -1 ){ |
108 | return true; | 108 | setLastHitField( Priority ); |
109 | return true; | ||
109 | }else if( data->hasDate && data->date.toString().find( regExp) != -1 ){ | 110 | }else if( data->hasDate && data->date.toString().find( regExp) != -1 ){ |
110 | return true; | 111 | setLastHitField( HasDate ); |
112 | return true; | ||
111 | }else if(data->desc.find( regExp ) != -1 ){ | 113 | }else if(data->desc.find( regExp ) != -1 ){ |
112 | return true; | 114 | setLastHitField( Description ); |
115 | return true; | ||
113 | }else if(data->sum.find( regExp ) != -1 ) { | 116 | }else if(data->sum.find( regExp ) != -1 ) { |
114 | return true; | 117 | setLastHitField( Summary ); |
118 | return true; | ||
115 | } | 119 | } |
116 | return false; | 120 | return false; |
117 | } | 121 | } |
118 | bool OTodo::isCompleted() const | 122 | bool OTodo::isCompleted() const |
119 | { | 123 | { |
120 | return data->isCompleted; | 124 | return data->isCompleted; |
121 | } | 125 | } |
122 | bool OTodo::hasDueDate() const | 126 | bool OTodo::hasDueDate() const |
123 | { | 127 | { |
124 | return data->hasDate; | 128 | return data->hasDate; |
125 | } | 129 | } |
126 | bool OTodo::hasStartDate()const { | 130 | bool OTodo::hasStartDate()const { |
127 | return data->start.isValid(); | 131 | return data->start.isValid(); |
128 | } | 132 | } |
129 | bool OTodo::hasCompletedDate()const { | 133 | bool OTodo::hasCompletedDate()const { |
130 | return data->completed.isValid(); | 134 | return data->completed.isValid(); |
131 | } | 135 | } |
132 | int OTodo::priority()const | 136 | int OTodo::priority()const |
133 | { | 137 | { |
134 | return data->priority; | 138 | return data->priority; |
135 | } | 139 | } |
136 | QString OTodo::summary() const | 140 | QString OTodo::summary() const |
137 | { | 141 | { |
138 | return data->sum; | 142 | return data->sum; |
139 | } | 143 | } |
140 | ushort OTodo::progress() const | 144 | ushort OTodo::progress() const |
141 | { | 145 | { |
142 | return data->prog; | 146 | return data->prog; |
143 | } | 147 | } |
144 | QDate OTodo::dueDate()const | 148 | QDate OTodo::dueDate()const |
145 | { | 149 | { |
146 | return data->date; | 150 | return data->date; |
147 | } | 151 | } |
148 | QDate OTodo::startDate()const { | 152 | QDate OTodo::startDate()const { |
149 | return data->start; | 153 | return data->start; |
150 | } | 154 | } |
151 | QDate OTodo::completedDate()const { | 155 | QDate OTodo::completedDate()const { |
152 | return data->completed; | 156 | return data->completed; |
153 | } | 157 | } |
154 | QString OTodo::description()const | 158 | QString OTodo::description()const |
155 | { | 159 | { |
156 | return data->desc; | 160 | return data->desc; |
157 | } | 161 | } |
158 | bool OTodo::hasState() const{ | 162 | bool OTodo::hasState() const{ |
159 | if (!data->state ) return false; | 163 | if (!data->state ) return false; |
160 | return ( data->state->state() != OPimState::Undefined ); | 164 | return ( data->state->state() != OPimState::Undefined ); |
161 | } | 165 | } |
162 | OPimState OTodo::state()const { | 166 | OPimState OTodo::state()const { |
163 | if (!data->state ) { | 167 | if (!data->state ) { |
164 | OPimState state; | 168 | OPimState state; |
165 | return state; | 169 | return state; |
166 | } | 170 | } |
167 | 171 | ||
168 | return (*data->state); | 172 | return (*data->state); |
169 | } | 173 | } |
170 | bool OTodo::hasRecurrence()const { | 174 | bool OTodo::hasRecurrence()const { |
171 | if (!data->recur) return false; | 175 | if (!data->recur) return false; |
172 | return data->recur->doesRecur(); | 176 | return data->recur->doesRecur(); |
173 | } | 177 | } |
174 | ORecur OTodo::recurrence()const { | 178 | ORecur OTodo::recurrence()const { |
175 | if (!data->recur) return ORecur(); | 179 | if (!data->recur) return ORecur(); |
176 | 180 | ||
177 | return (*data->recur); | 181 | return (*data->recur); |
178 | } | 182 | } |
diff --git a/libopie2/opiepim/oevent.cpp b/libopie2/opiepim/oevent.cpp index cda12f9..2b138c0 100644 --- a/libopie2/opiepim/oevent.cpp +++ b/libopie2/opiepim/oevent.cpp | |||
@@ -151,138 +151,148 @@ void OEvent::setNote( const QString& note ) { | |||
151 | } | 151 | } |
152 | QDateTime OEvent::createdDateTime()const { | 152 | QDateTime OEvent::createdDateTime()const { |
153 | return data->created; | 153 | return data->created; |
154 | } | 154 | } |
155 | void OEvent::setCreatedDateTime( const QDateTime& time ) { | 155 | void OEvent::setCreatedDateTime( const QDateTime& time ) { |
156 | changeOrModify(); | 156 | changeOrModify(); |
157 | data->created = time; | 157 | data->created = time; |
158 | } | 158 | } |
159 | QDateTime OEvent::startDateTime()const { | 159 | QDateTime OEvent::startDateTime()const { |
160 | if ( data->isAllDay ) | 160 | if ( data->isAllDay ) |
161 | return QDateTime( data->start.date(), QTime(0, 0, 0 ) ); | 161 | return QDateTime( data->start.date(), QTime(0, 0, 0 ) ); |
162 | return data->start; | 162 | return data->start; |
163 | } | 163 | } |
164 | QDateTime OEvent::startDateTimeInZone()const { | 164 | QDateTime OEvent::startDateTimeInZone()const { |
165 | /* if no timezone, or all day event or if the current and this timeZone match... */ | 165 | /* if no timezone, or all day event or if the current and this timeZone match... */ |
166 | if (data->timezone.isEmpty() || data->isAllDay || data->timezone == OTimeZone::current().timeZone() ) return startDateTime(); | 166 | if (data->timezone.isEmpty() || data->isAllDay || data->timezone == OTimeZone::current().timeZone() ) return startDateTime(); |
167 | 167 | ||
168 | OTimeZone zone(data->timezone ); | 168 | OTimeZone zone(data->timezone ); |
169 | return zone.toDateTime( data->start, OTimeZone::current() ); | 169 | return zone.toDateTime( data->start, OTimeZone::current() ); |
170 | } | 170 | } |
171 | void OEvent::setStartDateTime( const QDateTime& dt ) { | 171 | void OEvent::setStartDateTime( const QDateTime& dt ) { |
172 | changeOrModify(); | 172 | changeOrModify(); |
173 | data->start = dt; | 173 | data->start = dt; |
174 | } | 174 | } |
175 | QDateTime OEvent::endDateTime()const { | 175 | QDateTime OEvent::endDateTime()const { |
176 | /* | 176 | /* |
177 | * if all Day event the end time needs | 177 | * if all Day event the end time needs |
178 | * to be on the same day as the start | 178 | * to be on the same day as the start |
179 | */ | 179 | */ |
180 | if ( data->isAllDay ) | 180 | if ( data->isAllDay ) |
181 | return QDateTime( data->start.date(), QTime(23, 59, 59 ) ); | 181 | return QDateTime( data->start.date(), QTime(23, 59, 59 ) ); |
182 | return data->end; | 182 | return data->end; |
183 | } | 183 | } |
184 | QDateTime OEvent::endDateTimeInZone()const { | 184 | QDateTime OEvent::endDateTimeInZone()const { |
185 | /* if no timezone, or all day event or if the current and this timeZone match... */ | 185 | /* if no timezone, or all day event or if the current and this timeZone match... */ |
186 | if (data->timezone.isEmpty() || data->isAllDay || data->timezone == OTimeZone::current().timeZone() ) return endDateTime(); | 186 | if (data->timezone.isEmpty() || data->isAllDay || data->timezone == OTimeZone::current().timeZone() ) return endDateTime(); |
187 | 187 | ||
188 | OTimeZone zone(data->timezone ); | 188 | OTimeZone zone(data->timezone ); |
189 | return zone.toDateTime( data->end, OTimeZone::current() ); | 189 | return zone.toDateTime( data->end, OTimeZone::current() ); |
190 | } | 190 | } |
191 | void OEvent::setEndDateTime( const QDateTime& dt ) { | 191 | void OEvent::setEndDateTime( const QDateTime& dt ) { |
192 | changeOrModify(); | 192 | changeOrModify(); |
193 | data->end = dt; | 193 | data->end = dt; |
194 | } | 194 | } |
195 | bool OEvent::isMultipleDay()const { | 195 | bool OEvent::isMultipleDay()const { |
196 | return data->end.date().day() - data->start.date().day(); | 196 | return data->end.date().day() - data->start.date().day(); |
197 | } | 197 | } |
198 | bool OEvent::isAllDay()const { | 198 | bool OEvent::isAllDay()const { |
199 | return data->isAllDay; | 199 | return data->isAllDay; |
200 | } | 200 | } |
201 | void OEvent::setAllDay( bool allDay ) { | 201 | void OEvent::setAllDay( bool allDay ) { |
202 | changeOrModify(); | 202 | changeOrModify(); |
203 | data->isAllDay = allDay; | 203 | data->isAllDay = allDay; |
204 | if (allDay ) data->timezone = "UTC"; | 204 | if (allDay ) data->timezone = "UTC"; |
205 | } | 205 | } |
206 | void OEvent::setTimeZone( const QString& tz ) { | 206 | void OEvent::setTimeZone( const QString& tz ) { |
207 | changeOrModify(); | 207 | changeOrModify(); |
208 | data->timezone = tz; | 208 | data->timezone = tz; |
209 | } | 209 | } |
210 | QString OEvent::timeZone()const { | 210 | QString OEvent::timeZone()const { |
211 | if (data->isAllDay ) return QString::fromLatin1("UTC"); | 211 | if (data->isAllDay ) return QString::fromLatin1("UTC"); |
212 | return data->timezone; | 212 | return data->timezone; |
213 | } | 213 | } |
214 | bool OEvent::match( const QRegExp& re )const { | 214 | bool OEvent::match( const QRegExp& re )const { |
215 | if ( re.match( data->description ) != -1 ) | 215 | if ( re.match( data->description ) != -1 ){ |
216 | setLastHitField( DatebookDescription ); | ||
216 | return true; | 217 | return true; |
217 | if ( re.match( data->note ) != -1 ) | 218 | } |
219 | if ( re.match( data->note ) != -1 ){ | ||
220 | setLastHitField( Note ); | ||
218 | return true; | 221 | return true; |
219 | if ( re.match( data->location ) != -1 ) | 222 | } |
223 | if ( re.match( data->location ) != -1 ){ | ||
224 | setLastHitField( Location ); | ||
220 | return true; | 225 | return true; |
221 | if ( re.match( data->start.toString() ) != -1 ) | 226 | } |
227 | if ( re.match( data->start.toString() ) != -1 ){ | ||
228 | setLastHitField( StartDateTime ); | ||
222 | return true; | 229 | return true; |
223 | if ( re.match( data->end.toString() ) != -1 ) | 230 | } |
231 | if ( re.match( data->end.toString() ) != -1 ){ | ||
232 | setLastHitField( EndDateTime ); | ||
224 | return true; | 233 | return true; |
234 | } | ||
225 | return false; | 235 | return false; |
226 | } | 236 | } |
227 | QString OEvent::toRichText()const { | 237 | QString OEvent::toRichText()const { |
228 | QString text; | 238 | QString text; |
229 | if ( !description().isEmpty() ) { | 239 | if ( !description().isEmpty() ) { |
230 | text += "<b>" + QObject::tr( "Description:") + "</b><br>"; | 240 | text += "<b>" + QObject::tr( "Description:") + "</b><br>"; |
231 | text += Qtopia::escapeString(description() ). | 241 | text += Qtopia::escapeString(description() ). |
232 | replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; | 242 | replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; |
233 | } | 243 | } |
234 | if ( startDateTime().isValid() ) { | 244 | if ( startDateTime().isValid() ) { |
235 | text += "<b>" + QObject::tr( "Start:") + "</b> "; | 245 | text += "<b>" + QObject::tr( "Start:") + "</b> "; |
236 | text += Qtopia::escapeString(startDateTime().toString() ). | 246 | text += Qtopia::escapeString(startDateTime().toString() ). |
237 | replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; | 247 | replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; |
238 | } | 248 | } |
239 | if ( endDateTime().isValid() ) { | 249 | if ( endDateTime().isValid() ) { |
240 | text += "<b>" + QObject::tr( "End:") + "</b> "; | 250 | text += "<b>" + QObject::tr( "End:") + "</b> "; |
241 | text += Qtopia::escapeString(endDateTime().toString() ). | 251 | text += Qtopia::escapeString(endDateTime().toString() ). |
242 | replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; | 252 | replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; |
243 | } | 253 | } |
244 | if ( !note().isEmpty() ) { | 254 | if ( !note().isEmpty() ) { |
245 | text += "<b>" + QObject::tr( "Note:") + "</b><br>"; | 255 | text += "<b>" + QObject::tr( "Note:") + "</b><br>"; |
246 | text += note(); | 256 | text += note(); |
247 | // text += Qtopia::escapeString(note() ). | 257 | // text += Qtopia::escapeString(note() ). |
248 | // replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; | 258 | // replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; |
249 | } | 259 | } |
250 | return text; | 260 | return text; |
251 | } | 261 | } |
252 | QString OEvent::toShortText()const { | 262 | QString OEvent::toShortText()const { |
253 | QString text; | 263 | QString text; |
254 | text += QString::number( startDateTime().date().day() ); | 264 | text += QString::number( startDateTime().date().day() ); |
255 | text += "."; | 265 | text += "."; |
256 | text += QString::number( startDateTime().date().month() ); | 266 | text += QString::number( startDateTime().date().month() ); |
257 | text += "."; | 267 | text += "."; |
258 | text += QString::number( startDateTime().date().year() ); | 268 | text += QString::number( startDateTime().date().year() ); |
259 | text += " "; | 269 | text += " "; |
260 | text += QString::number( startDateTime().time().hour() ); | 270 | text += QString::number( startDateTime().time().hour() ); |
261 | text += ":"; | 271 | text += ":"; |
262 | text += QString::number( startDateTime().time().minute() ); | 272 | text += QString::number( startDateTime().time().minute() ); |
263 | text += " - "; | 273 | text += " - "; |
264 | text += description(); | 274 | text += description(); |
265 | return text; | 275 | return text; |
266 | } | 276 | } |
267 | QString OEvent::type()const { | 277 | QString OEvent::type()const { |
268 | return QString::fromLatin1("OEvent"); | 278 | return QString::fromLatin1("OEvent"); |
269 | } | 279 | } |
270 | QString OEvent::recordField( int /*id */ )const { | 280 | QString OEvent::recordField( int /*id */ )const { |
271 | return QString::null; | 281 | return QString::null; |
272 | } | 282 | } |
273 | int OEvent::rtti() { | 283 | int OEvent::rtti() { |
274 | return OPimResolver::DateBook; | 284 | return OPimResolver::DateBook; |
275 | } | 285 | } |
276 | bool OEvent::loadFromStream( QDataStream& ) { | 286 | bool OEvent::loadFromStream( QDataStream& ) { |
277 | return true; | 287 | return true; |
278 | } | 288 | } |
279 | bool OEvent::saveToStream( QDataStream& )const { | 289 | bool OEvent::saveToStream( QDataStream& )const { |
280 | return true; | 290 | return true; |
281 | } | 291 | } |
282 | void OEvent::changeOrModify() { | 292 | void OEvent::changeOrModify() { |
283 | if ( data->count != 1 ) { | 293 | if ( data->count != 1 ) { |
284 | data->deref(); | 294 | data->deref(); |
285 | Data* d2 = new Data; | 295 | Data* d2 = new Data; |
286 | d2->description = data->description; | 296 | d2->description = data->description; |
287 | d2->location = data->location; | 297 | d2->location = data->location; |
288 | 298 | ||
diff --git a/libopie2/opiepim/otodo.cpp b/libopie2/opiepim/otodo.cpp index a29d88e..e087a00 100644 --- a/libopie2/opiepim/otodo.cpp +++ b/libopie2/opiepim/otodo.cpp | |||
@@ -44,135 +44,139 @@ struct OTodo::OTodoData : public QShared { | |||
44 | QDate completed; | 44 | QDate completed; |
45 | OPimNotifyManager *notifiers; | 45 | OPimNotifyManager *notifiers; |
46 | }; | 46 | }; |
47 | 47 | ||
48 | OTodo::OTodo(const OTodo &event ) | 48 | OTodo::OTodo(const OTodo &event ) |
49 | : OPimRecord( event ), data( event.data ) | 49 | : OPimRecord( event ), data( event.data ) |
50 | { | 50 | { |
51 | data->ref(); | 51 | data->ref(); |
52 | // qWarning("ref up"); | 52 | // qWarning("ref up"); |
53 | } | 53 | } |
54 | OTodo::~OTodo() { | 54 | OTodo::~OTodo() { |
55 | 55 | ||
56 | // qWarning("~OTodo " ); | 56 | // qWarning("~OTodo " ); |
57 | if ( data->deref() ) { | 57 | if ( data->deref() ) { |
58 | // qWarning("OTodo::dereffing"); | 58 | // qWarning("OTodo::dereffing"); |
59 | delete data; | 59 | delete data; |
60 | data = 0l; | 60 | data = 0l; |
61 | } | 61 | } |
62 | } | 62 | } |
63 | OTodo::OTodo(bool completed, int priority, | 63 | OTodo::OTodo(bool completed, int priority, |
64 | const QArray<int> &category, | 64 | const QArray<int> &category, |
65 | const QString& summary, | 65 | const QString& summary, |
66 | const QString &description, | 66 | const QString &description, |
67 | ushort progress, | 67 | ushort progress, |
68 | bool hasDate, QDate date, int uid ) | 68 | bool hasDate, QDate date, int uid ) |
69 | : OPimRecord( uid ) | 69 | : OPimRecord( uid ) |
70 | { | 70 | { |
71 | // qWarning("OTodoData " + summary); | 71 | // qWarning("OTodoData " + summary); |
72 | setCategories( category ); | 72 | setCategories( category ); |
73 | 73 | ||
74 | data = new OTodoData; | 74 | data = new OTodoData; |
75 | 75 | ||
76 | data->date = date; | 76 | data->date = date; |
77 | data->isCompleted = completed; | 77 | data->isCompleted = completed; |
78 | data->hasDate = hasDate; | 78 | data->hasDate = hasDate; |
79 | data->priority = priority; | 79 | data->priority = priority; |
80 | data->sum = summary; | 80 | data->sum = summary; |
81 | data->prog = progress; | 81 | data->prog = progress; |
82 | data->desc = Qtopia::simplifyMultiLineSpace(description ); | 82 | data->desc = Qtopia::simplifyMultiLineSpace(description ); |
83 | } | 83 | } |
84 | OTodo::OTodo(bool completed, int priority, | 84 | OTodo::OTodo(bool completed, int priority, |
85 | const QStringList &category, | 85 | const QStringList &category, |
86 | const QString& summary, | 86 | const QString& summary, |
87 | const QString &description, | 87 | const QString &description, |
88 | ushort progress, | 88 | ushort progress, |
89 | bool hasDate, QDate date, int uid ) | 89 | bool hasDate, QDate date, int uid ) |
90 | : OPimRecord( uid ) | 90 | : OPimRecord( uid ) |
91 | { | 91 | { |
92 | // qWarning("OTodoData" + summary); | 92 | // qWarning("OTodoData" + summary); |
93 | setCategories( idsFromString( category.join(";") ) ); | 93 | setCategories( idsFromString( category.join(";") ) ); |
94 | 94 | ||
95 | data = new OTodoData; | 95 | data = new OTodoData; |
96 | 96 | ||
97 | data->date = date; | 97 | data->date = date; |
98 | data->isCompleted = completed; | 98 | data->isCompleted = completed; |
99 | data->hasDate = hasDate; | 99 | data->hasDate = hasDate; |
100 | data->priority = priority; | 100 | data->priority = priority; |
101 | data->sum = summary; | 101 | data->sum = summary; |
102 | data->prog = progress; | 102 | data->prog = progress; |
103 | data->desc = Qtopia::simplifyMultiLineSpace(description ); | 103 | data->desc = Qtopia::simplifyMultiLineSpace(description ); |
104 | } | 104 | } |
105 | bool OTodo::match( const QRegExp ®Exp )const | 105 | bool OTodo::match( const QRegExp ®Exp )const |
106 | { | 106 | { |
107 | if( QString::number( data->priority ).find( regExp ) != -1 ){ | 107 | if( QString::number( data->priority ).find( regExp ) != -1 ){ |
108 | return true; | 108 | setLastHitField( Priority ); |
109 | return true; | ||
109 | }else if( data->hasDate && data->date.toString().find( regExp) != -1 ){ | 110 | }else if( data->hasDate && data->date.toString().find( regExp) != -1 ){ |
110 | return true; | 111 | setLastHitField( HasDate ); |
112 | return true; | ||
111 | }else if(data->desc.find( regExp ) != -1 ){ | 113 | }else if(data->desc.find( regExp ) != -1 ){ |
112 | return true; | 114 | setLastHitField( Description ); |
115 | return true; | ||
113 | }else if(data->sum.find( regExp ) != -1 ) { | 116 | }else if(data->sum.find( regExp ) != -1 ) { |
114 | return true; | 117 | setLastHitField( Summary ); |
118 | return true; | ||
115 | } | 119 | } |
116 | return false; | 120 | return false; |
117 | } | 121 | } |
118 | bool OTodo::isCompleted() const | 122 | bool OTodo::isCompleted() const |
119 | { | 123 | { |
120 | return data->isCompleted; | 124 | return data->isCompleted; |
121 | } | 125 | } |
122 | bool OTodo::hasDueDate() const | 126 | bool OTodo::hasDueDate() const |
123 | { | 127 | { |
124 | return data->hasDate; | 128 | return data->hasDate; |
125 | } | 129 | } |
126 | bool OTodo::hasStartDate()const { | 130 | bool OTodo::hasStartDate()const { |
127 | return data->start.isValid(); | 131 | return data->start.isValid(); |
128 | } | 132 | } |
129 | bool OTodo::hasCompletedDate()const { | 133 | bool OTodo::hasCompletedDate()const { |
130 | return data->completed.isValid(); | 134 | return data->completed.isValid(); |
131 | } | 135 | } |
132 | int OTodo::priority()const | 136 | int OTodo::priority()const |
133 | { | 137 | { |
134 | return data->priority; | 138 | return data->priority; |
135 | } | 139 | } |
136 | QString OTodo::summary() const | 140 | QString OTodo::summary() const |
137 | { | 141 | { |
138 | return data->sum; | 142 | return data->sum; |
139 | } | 143 | } |
140 | ushort OTodo::progress() const | 144 | ushort OTodo::progress() const |
141 | { | 145 | { |
142 | return data->prog; | 146 | return data->prog; |
143 | } | 147 | } |
144 | QDate OTodo::dueDate()const | 148 | QDate OTodo::dueDate()const |
145 | { | 149 | { |
146 | return data->date; | 150 | return data->date; |
147 | } | 151 | } |
148 | QDate OTodo::startDate()const { | 152 | QDate OTodo::startDate()const { |
149 | return data->start; | 153 | return data->start; |
150 | } | 154 | } |
151 | QDate OTodo::completedDate()const { | 155 | QDate OTodo::completedDate()const { |
152 | return data->completed; | 156 | return data->completed; |
153 | } | 157 | } |
154 | QString OTodo::description()const | 158 | QString OTodo::description()const |
155 | { | 159 | { |
156 | return data->desc; | 160 | return data->desc; |
157 | } | 161 | } |
158 | bool OTodo::hasState() const{ | 162 | bool OTodo::hasState() const{ |
159 | if (!data->state ) return false; | 163 | if (!data->state ) return false; |
160 | return ( data->state->state() != OPimState::Undefined ); | 164 | return ( data->state->state() != OPimState::Undefined ); |
161 | } | 165 | } |
162 | OPimState OTodo::state()const { | 166 | OPimState OTodo::state()const { |
163 | if (!data->state ) { | 167 | if (!data->state ) { |
164 | OPimState state; | 168 | OPimState state; |
165 | return state; | 169 | return state; |
166 | } | 170 | } |
167 | 171 | ||
168 | return (*data->state); | 172 | return (*data->state); |
169 | } | 173 | } |
170 | bool OTodo::hasRecurrence()const { | 174 | bool OTodo::hasRecurrence()const { |
171 | if (!data->recur) return false; | 175 | if (!data->recur) return false; |
172 | return data->recur->doesRecur(); | 176 | return data->recur->doesRecur(); |
173 | } | 177 | } |
174 | ORecur OTodo::recurrence()const { | 178 | ORecur OTodo::recurrence()const { |
175 | if (!data->recur) return ORecur(); | 179 | if (!data->recur) return ORecur(); |
176 | 180 | ||
177 | return (*data->recur); | 181 | return (*data->recur); |
178 | } | 182 | } |