-rw-r--r-- | libopie/todoevent.cpp | 21 |
1 files changed, 17 insertions, 4 deletions
diff --git a/libopie/todoevent.cpp b/libopie/todoevent.cpp index fb7073c..b35ac9d 100644 --- a/libopie/todoevent.cpp +++ b/libopie/todoevent.cpp | |||
@@ -16,24 +16,26 @@ ToDoEvent::ToDoEvent(const ToDoEvent &event ) | |||
16 | { | 16 | { |
17 | *this = event; | 17 | *this = event; |
18 | } | 18 | } |
19 | 19 | ||
20 | ToDoEvent::ToDoEvent(bool completed, int priority, | 20 | ToDoEvent::ToDoEvent(bool completed, int priority, |
21 | const QStringList &category, | 21 | const QStringList &category, |
22 | const QString& summary, | 22 | const QString& summary, |
23 | const QString &description, | 23 | const QString &description, |
24 | ushort progress, | ||
24 | bool hasDate, QDate date, int uid ) | 25 | bool hasDate, QDate date, int uid ) |
25 | { | 26 | { |
26 | m_date = date; | 27 | m_date = date; |
27 | m_isCompleted = completed; | 28 | m_isCompleted = completed; |
28 | m_hasDate = hasDate; | 29 | m_hasDate = hasDate; |
29 | m_priority = priority; | 30 | m_priority = priority; |
30 | m_category = category; | 31 | m_category = category; |
31 | m_sum = summary; | 32 | m_sum = summary; |
33 | m_prog = progress; | ||
32 | m_desc = Qtopia::simplifyMultiLineSpace(description ); | 34 | m_desc = Qtopia::simplifyMultiLineSpace(description ); |
33 | if (uid == -1 ) { | 35 | if (uid == -1 ) { |
34 | Qtopia::UidGen *uidgen = new Qtopia::UidGen(); | 36 | Qtopia::UidGen *uidgen = new Qtopia::UidGen(); |
35 | uid = uidgen->generate(); | 37 | uid = uidgen->generate(); |
36 | delete uidgen; | 38 | delete uidgen; |
37 | }// generate the ids | 39 | }// generate the ids |
38 | m_uid = uid; | 40 | m_uid = uid; |
39 | } | 41 | } |
@@ -73,16 +75,20 @@ QStringList ToDoEvent::allCategories()const | |||
73 | QString ToDoEvent::extra(const QString& )const | 75 | QString ToDoEvent::extra(const QString& )const |
74 | { | 76 | { |
75 | return QString::null; | 77 | return QString::null; |
76 | } | 78 | } |
77 | QString ToDoEvent::summary() const | 79 | QString ToDoEvent::summary() const |
78 | { | 80 | { |
79 | return m_sum; | 81 | return m_sum; |
80 | } | 82 | } |
83 | ushort ToDoEvent::progress() const | ||
84 | { | ||
85 | return m_prog; | ||
86 | } | ||
81 | void ToDoEvent::insertCategory(const QString &str ) | 87 | void ToDoEvent::insertCategory(const QString &str ) |
82 | { | 88 | { |
83 | m_category.append( str ); | 89 | m_category.append( str ); |
84 | } | 90 | } |
85 | void ToDoEvent::clearCategories() | 91 | void ToDoEvent::clearCategories() |
86 | { | 92 | { |
87 | m_category.clear(); | 93 | m_category.clear(); |
88 | } | 94 | } |
@@ -134,34 +140,39 @@ void ToDoEvent::setDate( QDate date ) | |||
134 | m_date = date; | 140 | m_date = date; |
135 | } | 141 | } |
136 | bool ToDoEvent::isOverdue( ) | 142 | bool ToDoEvent::isOverdue( ) |
137 | { | 143 | { |
138 | if( m_hasDate ) | 144 | if( m_hasDate ) |
139 | return QDate::currentDate() > m_date; | 145 | return QDate::currentDate() > m_date; |
140 | return false; | 146 | return false; |
141 | } | 147 | } |
142 | 148 | void ToDoEvent::setProgress(ushort progress ) | |
149 | { | ||
150 | m_prog = progress; | ||
151 | } | ||
143 | /*! | 152 | /*! |
144 | Returns a richt text string | 153 | Returns a richt text string |
145 | */ | 154 | */ |
146 | QString ToDoEvent::richText() const | 155 | QString ToDoEvent::richText() const |
147 | { | 156 | { |
148 | QString text; | 157 | QString text; |
149 | QStringList catlist; | 158 | QStringList catlist; |
150 | 159 | ||
151 | // Description of the todo | 160 | // Description of the todo |
152 | if ( !description().isEmpty() ){ | 161 | if ( !description().isEmpty() ){ |
153 | text += "<b>" + QObject::tr( "Summary:") + "</b><br>"; | 162 | text += "<b>" + QObject::tr( "Summary:") + "</b><br>"; |
154 | text += Qtopia::escapeString(summary() ).replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; | 163 | text += Qtopia::escapeString(summary() ).replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; |
155 | text += "<b>" + QObject::tr( "Description:" ) + "</b><br>"; | 164 | text += "<b>" + QObject::tr( "Description:" ) + "</b><br>"; |
156 | text += Qtopia::escapeString(description() ).replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; | 165 | text += Qtopia::escapeString(description() ).replace(QRegExp( "[\n]"), "<br>" ) + "<br><br><br>"; |
157 | } | 166 | } |
158 | text += "<b>" + QObject::tr( "Priority:") +" </b>" | 167 | text += "<b>" + QObject::tr( "Priority:") +" </b>" |
159 | + QString::number( priority() ) + "<br>"; | 168 | + QString::number( priority() ) + " <br>"; |
169 | text += "<b>" + QObject::tr( "Progress:") + " </b>" | ||
170 | + QString::number( progress() ) + " %<br>"; | ||
160 | if (hasDate() ){ | 171 | if (hasDate() ){ |
161 | text += "<b>" + QObject::tr( "Deadline:") + " </b>"; | 172 | text += "<b>" + QObject::tr( "Deadline:") + " </b>"; |
162 | text += date().toString(); | 173 | text += date().toString(); |
163 | text += "<br>"; | 174 | text += "<br>"; |
164 | } | 175 | } |
165 | 176 | ||
166 | // Open database of all categories and get the list of | 177 | // Open database of all categories and get the list of |
167 | // the categories this todoevent belongs to. | 178 | // the categories this todoevent belongs to. |
@@ -181,17 +192,17 @@ QString ToDoEvent::richText() const | |||
181 | text += catdb.label ("todo", (*it).toInt()); | 192 | text += catdb.label ("todo", (*it).toInt()); |
182 | } | 193 | } |
183 | text += "<br>"; | 194 | text += "<br>"; |
184 | return text; | 195 | return text; |
185 | } | 196 | } |
186 | 197 | ||
187 | bool ToDoEvent::operator<( const ToDoEvent &toDoEvent )const{ | 198 | bool ToDoEvent::operator<( const ToDoEvent &toDoEvent )const{ |
188 | if( !hasDate() && !toDoEvent.hasDate() ) return true; | 199 | if( !hasDate() && !toDoEvent.hasDate() ) return true; |
189 | if( !hasDate() && toDoEvent.hasDate() ) return true; | 200 | if( !hasDate() && toDoEvent.hasDate() ) return false; |
190 | if( hasDate() && toDoEvent.hasDate() ){ | 201 | if( hasDate() && toDoEvent.hasDate() ){ |
191 | if( date() == toDoEvent.date() ){ // let's the priority decide | 202 | if( date() == toDoEvent.date() ){ // let's the priority decide |
192 | return priority() < toDoEvent.priority(); | 203 | return priority() < toDoEvent.priority(); |
193 | }else{ | 204 | }else{ |
194 | return date() < toDoEvent.date(); | 205 | return date() < toDoEvent.date(); |
195 | } | 206 | } |
196 | } | 207 | } |
197 | return false; | 208 | return false; |
@@ -233,16 +244,17 @@ bool ToDoEvent::operator>=(const ToDoEvent &toDoEvent )const | |||
233 | return date() > toDoEvent.date(); | 244 | return date() > toDoEvent.date(); |
234 | } | 245 | } |
235 | } | 246 | } |
236 | return true; | 247 | return true; |
237 | } | 248 | } |
238 | bool ToDoEvent::operator==(const ToDoEvent &toDoEvent )const | 249 | bool ToDoEvent::operator==(const ToDoEvent &toDoEvent )const |
239 | { | 250 | { |
240 | if( m_priority == toDoEvent.m_priority && | 251 | if( m_priority == toDoEvent.m_priority && |
252 | m_priority == toDoEvent.m_prog && | ||
241 | m_isCompleted == toDoEvent.m_isCompleted && | 253 | m_isCompleted == toDoEvent.m_isCompleted && |
242 | m_hasDate == toDoEvent.m_hasDate && | 254 | m_hasDate == toDoEvent.m_hasDate && |
243 | m_date == toDoEvent.m_date && | 255 | m_date == toDoEvent.m_date && |
244 | m_category == toDoEvent.m_category && | 256 | m_category == toDoEvent.m_category && |
245 | m_sum == toDoEvent.m_sum && | 257 | m_sum == toDoEvent.m_sum && |
246 | m_desc == toDoEvent.m_desc ) | 258 | m_desc == toDoEvent.m_desc ) |
247 | return true; | 259 | return true; |
248 | return false; | 260 | return false; |
@@ -252,16 +264,17 @@ ToDoEvent &ToDoEvent::operator=(const ToDoEvent &item ) | |||
252 | m_date = item.m_date; | 264 | m_date = item.m_date; |
253 | m_isCompleted = item.m_isCompleted; | 265 | m_isCompleted = item.m_isCompleted; |
254 | m_hasDate = item.m_hasDate; | 266 | m_hasDate = item.m_hasDate; |
255 | m_priority = item.m_priority; | 267 | m_priority = item.m_priority; |
256 | m_category = item.m_category; | 268 | m_category = item.m_category; |
257 | m_desc = item.m_desc; | 269 | m_desc = item.m_desc; |
258 | m_uid = item.m_uid; | 270 | m_uid = item.m_uid; |
259 | m_sum = item.m_sum; | 271 | m_sum = item.m_sum; |
272 | m_prog = item.m_prog; | ||
260 | return *this; | 273 | return *this; |
261 | } | 274 | } |
262 | 275 | ||
263 | 276 | ||
264 | 277 | ||
265 | 278 | ||
266 | 279 | ||
267 | 280 | ||