-rw-r--r-- | core/pim/todo/tableview.cpp | 39 | ||||
-rw-r--r-- | core/pim/todo/tableview.h | 3 |
2 files changed, 36 insertions, 6 deletions
diff --git a/core/pim/todo/tableview.cpp b/core/pim/todo/tableview.cpp index 34b8b3c..c4165db 100644 --- a/core/pim/todo/tableview.cpp +++ b/core/pim/todo/tableview.cpp | |||
@@ -1,456 +1,483 @@ | |||
1 | /* | 1 | /* |
2 | =. This file is part of the OPIE Project | 2 | =. This file is part of the OPIE Project |
3 | .=l. Copyright (c) 2002 <> | 3 | .=l. Copyright (c) 2002 <> |
4 | .>+-= | 4 | .>+-= |
5 | _;:, .> :=|. This program is free software; you can | 5 | _;:, .> :=|. This program is free software; you can |
6 | .> <`_, > . <= redistribute it and/or modify it under | 6 | .> <`_, > . <= redistribute it and/or modify it under |
7 | :`=1 )Y*s>-.-- : the terms of the GNU General Public | 7 | :`=1 )Y*s>-.-- : the terms of the GNU General Public |
8 | .="- .-=="i, .._ License as published by the Free Software | 8 | .="- .-=="i, .._ License as published by the Free Software |
9 | - . .-<_> .<> Foundation; either version 2 of the License, | 9 | - . .-<_> .<> Foundation; either version 2 of the License, |
10 | ._= =} : or (at your option) any later version. | 10 | ._= =} : or (at your option) any later version. |
11 | .%`+i> _;_. | 11 | .%`+i> _;_. |
12 | .i_,=:_. -<s. This program is distributed in the hope that | 12 | .i_,=:_. -<s. This program is distributed in the hope that |
13 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 13 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
14 | : .. .:, . . . without even the implied warranty of | 14 | : .. .:, . . . without even the implied warranty of |
15 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 15 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
16 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU | 16 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU |
17 | ..}^=.= = ; Library General Public License for more | 17 | ..}^=.= = ; Library General Public License for more |
18 | ++= -. .` .: details. | 18 | ++= -. .` .: details. |
19 | : = ...= . :.=- | 19 | : = ...= . :.=- |
20 | -. .:....=;==+<; You should have received a copy of the GNU | 20 | -. .:....=;==+<; You should have received a copy of the GNU |
21 | -_. . . )=. = Library General Public License along with | 21 | -_. . . )=. = Library General Public License along with |
22 | -- :-=` this library; see the file COPYING.LIB. | 22 | -- :-=` this library; see the file COPYING.LIB. |
23 | If not, write to the Free Software Foundation, | 23 | If not, write to the Free Software Foundation, |
24 | Inc., 59 Temple Place - Suite 330, | 24 | Inc., 59 Temple Place - Suite 330, |
25 | Boston, MA 02111-1307, USA. | 25 | Boston, MA 02111-1307, USA. |
26 | 26 | ||
27 | */ | 27 | */ |
28 | #include <stdlib.h> | ||
28 | 29 | ||
29 | #include <qtimer.h> | 30 | #include <qtimer.h> |
30 | #include <qpoint.h> | 31 | #include <qpoint.h> |
31 | #include <qpopupmenu.h> | 32 | #include <qpopupmenu.h> |
32 | 33 | ||
33 | #include "mainwindow.h" | 34 | #include "mainwindow.h" |
34 | //#include "tableitems.h" | 35 | //#include "tableitems.h" |
35 | #include "tableview.h" | 36 | #include "tableview.h" |
36 | 37 | ||
37 | using namespace Todo; | 38 | using namespace Todo; |
38 | 39 | ||
39 | namespace { | 40 | namespace { |
40 | static const int BoxSize = 14; | 41 | static const int BoxSize = 14; |
41 | static const int RowHeight = 20; | 42 | static const int RowHeight = 20; |
42 | } | 43 | } |
43 | 44 | ||
44 | 45 | ||
45 | TableView::TableView( MainWindow* window, QWidget* wid ) | 46 | TableView::TableView( MainWindow* window, QWidget* wid ) |
46 | : QTable( wid ), TodoView( window ) { | 47 | : QTable( wid ), TodoView( window ) { |
47 | setUpdatesEnabled( false ); | 48 | setUpdatesEnabled( false ); |
48 | viewport()->setUpdatesEnabled( false ); | 49 | viewport()->setUpdatesEnabled( false ); |
49 | m_enablePaint = false; | 50 | m_enablePaint = false; |
50 | setNumRows(0); | 51 | setNumRows(0); |
51 | setNumCols(4); | 52 | setNumCols(4); |
52 | 53 | ||
53 | setSorting( TRUE ); | 54 | setSorting( TRUE ); |
54 | setSelectionMode( NoSelection ); | 55 | setSelectionMode( NoSelection ); |
55 | setColumnStretchable( 2, TRUE ); | 56 | setColumnStretchable( 2, TRUE ); |
56 | setColumnWidth(0, 20 ); | 57 | setColumnWidth(0, 20 ); |
57 | setColumnWidth(1, 35 ); | 58 | setColumnWidth(1, 35 ); |
58 | 59 | ||
59 | setLeftMargin( 0 ); | 60 | setLeftMargin( 0 ); |
60 | verticalHeader()->hide(); | 61 | verticalHeader()->hide(); |
61 | 62 | ||
62 | horizontalHeader()->setLabel(0, tr("C.") ); | 63 | horizontalHeader()->setLabel(0, tr("C.") ); |
63 | horizontalHeader()->setLabel(1, tr("Prior.") ); | 64 | horizontalHeader()->setLabel(1, tr("Prior.") ); |
64 | horizontalHeader()->setLabel(2, tr("Description" ) ); | 65 | horizontalHeader()->setLabel(2, tr("Description" ) ); |
65 | 66 | ||
66 | setColumnStretchable(3, FALSE ); | 67 | setColumnStretchable(3, FALSE ); |
67 | setColumnWidth(3, 20 ); | 68 | setColumnWidth(3, 20 ); |
68 | horizontalHeader()->setLabel(3, tr("Deadline") ); | 69 | horizontalHeader()->setLabel(3, tr("Deadline") ); |
69 | 70 | ||
70 | if ( todoWindow()->showDeadline() ) | 71 | if ( todoWindow()->showDeadline() ) |
71 | showColumn( 3); | 72 | showColumn( 3); |
72 | else | 73 | else |
73 | hideColumn(3 ); | 74 | hideColumn(3 ); |
74 | 75 | ||
75 | connect((QTable*)this, SIGNAL( clicked( int, int, int, const QPoint& ) ), | 76 | connect((QTable*)this, SIGNAL( clicked( int, int, int, const QPoint& ) ), |
76 | this, SLOT( slotClicked(int, int, int, const QPoint& ) ) ); | 77 | this, SLOT( slotClicked(int, int, int, const QPoint& ) ) ); |
77 | connect((QTable*)this, SIGNAL( pressed( int, int, int, const QPoint& ) ), | 78 | connect((QTable*)this, SIGNAL( pressed( int, int, int, const QPoint& ) ), |
78 | this, SLOT( slotPressed(int, int, int, const QPoint& ) ) ); | 79 | this, SLOT( slotPressed(int, int, int, const QPoint& ) ) ); |
79 | connect((QTable*)this, SIGNAL(valueChanged(int, int) ), | 80 | connect((QTable*)this, SIGNAL(valueChanged(int, int) ), |
80 | this, SLOT( slotValueChanged(int, int) ) ); | 81 | this, SLOT( slotValueChanged(int, int) ) ); |
81 | connect((QTable*)this, SIGNAL(currentChanged(int, int) ), | 82 | connect((QTable*)this, SIGNAL(currentChanged(int, int) ), |
82 | this, SLOT( slotCurrentChanged(int, int) ) ); | 83 | this, SLOT( slotCurrentChanged(int, int) ) ); |
83 | 84 | ||
84 | m_menuTimer = new QTimer( this ); | 85 | m_menuTimer = new QTimer( this ); |
85 | connect( m_menuTimer, SIGNAL(timeout()), | 86 | connect( m_menuTimer, SIGNAL(timeout()), |
86 | this, SLOT(slotShowMenu()) ); | 87 | this, SLOT(slotShowMenu()) ); |
87 | 88 | ||
88 | m_enablePaint = true; | 89 | m_enablePaint = true; |
89 | setUpdatesEnabled( true ); | 90 | setUpdatesEnabled( true ); |
90 | viewport()->setUpdatesEnabled( true ); | 91 | viewport()->setUpdatesEnabled( true ); |
91 | viewport()->update(); | 92 | viewport()->update(); |
92 | setSortOrder( 0 ); | 93 | setSortOrder( 0 ); |
93 | setAscending( TRUE ); | 94 | setAscending( TRUE ); |
94 | m_first = true; | 95 | m_first = true; |
95 | } | 96 | } |
96 | /* a new day has started | 97 | /* a new day has started |
97 | * update the day | 98 | * update the day |
98 | */ | 99 | */ |
99 | void TableView::newDay() { | 100 | void TableView::newDay() { |
100 | clear(); | 101 | clear(); |
101 | updateView(); | 102 | updateView(); |
102 | } | 103 | } |
103 | TableView::~TableView() { | 104 | TableView::~TableView() { |
104 | 105 | ||
105 | } | 106 | } |
106 | void TableView::slotShowMenu() { | 107 | void TableView::slotShowMenu() { |
107 | QPopupMenu *menu = todoWindow()->contextMenu( current() ); | 108 | QPopupMenu *menu = todoWindow()->contextMenu( current() ); |
108 | menu->exec(QCursor::pos() ); | 109 | menu->exec(QCursor::pos() ); |
109 | delete menu; | 110 | delete menu; |
110 | } | 111 | } |
111 | QString TableView::type() const { | 112 | QString TableView::type() const { |
112 | return QString::fromLatin1( tr("Table View") ); | 113 | return QString::fromLatin1( tr("Table View") ); |
113 | } | 114 | } |
114 | int TableView::current() { | 115 | int TableView::current() { |
115 | int uid = sorted().uidAt(currentRow() ); | 116 | int uid = sorted().uidAt(currentRow() ); |
116 | qWarning("uid %d", uid ); | 117 | qWarning("uid %d", uid ); |
117 | return uid; | 118 | return uid; |
118 | } | 119 | } |
119 | QString TableView::currentRepresentation() { | 120 | QString TableView::currentRepresentation() { |
120 | return text( currentRow(), 2); | 121 | return text( currentRow(), 2); |
121 | } | 122 | } |
122 | /* show overdue */ | 123 | /* show overdue */ |
123 | void TableView::showOverDue( bool ) { | 124 | void TableView::showOverDue( bool ) { |
124 | clear(); | 125 | clear(); |
125 | updateView(); | 126 | updateView(); |
126 | } | 127 | } |
127 | 128 | ||
128 | void TableView::updateView( ) { | 129 | void TableView::updateView( ) { |
129 | qWarning("update view"); | 130 | qWarning("update view"); |
130 | m_row = false; | 131 | m_row = false; |
131 | static int id; | 132 | static int id; |
132 | id = startTimer(2000 ); | 133 | id = startTimer(2000 ); |
133 | /* FIXME we want one page to be read! | 134 | /* FIXME we want one page to be read! |
134 | * | 135 | * |
135 | * Calculate that screensize | 136 | * Calculate that screensize |
136 | */ | 137 | */ |
137 | todoWindow()->setReadAhead( 4 ); | 138 | todoWindow()->setReadAhead( 4 ); |
138 | sort(); | 139 | sort(); |
139 | OTodoAccess::List::Iterator it, end; | 140 | OTodoAccess::List::Iterator it, end; |
140 | it = sorted().begin(); | 141 | it = sorted().begin(); |
141 | end = sorted().end(); | 142 | end = sorted().end(); |
142 | 143 | ||
143 | qWarning("setTodos"); | 144 | qWarning("setTodos"); |
144 | QTime time; | 145 | QTime time; |
145 | time.start(); | 146 | time.start(); |
146 | m_enablePaint = false; | 147 | m_enablePaint = false; |
147 | setUpdatesEnabled( false ); | 148 | setUpdatesEnabled( false ); |
148 | viewport()->setUpdatesEnabled( false ); | 149 | viewport()->setUpdatesEnabled( false ); |
149 | 150 | ||
150 | QTime t; | ||
151 | t.start(); | ||
152 | setNumRows( it.count() ); | 151 | setNumRows( it.count() ); |
153 | if ( it.count() == 0 ) | 152 | if ( it.count() == 0 ) |
154 | killTimer(id); | 153 | killTimer(id); |
154 | |||
155 | int elc = time.elapsed(); | 155 | int elc = time.elapsed(); |
156 | qWarning("Adding took %d", elc/1000 ); | ||
157 | setUpdatesEnabled( true ); | 156 | setUpdatesEnabled( true ); |
158 | viewport()->setUpdatesEnabled( true ); | 157 | viewport()->setUpdatesEnabled( true ); |
159 | viewport()->update(); | 158 | viewport()->update(); |
160 | 159 | ||
161 | m_enablePaint = true; | 160 | m_enablePaint = true; |
162 | int el = time.elapsed(); | 161 | int el = time.elapsed(); |
163 | qWarning("adding took %d", el/1000 ); | ||
164 | } | 162 | } |
165 | void TableView::setTodo( int, const OTodo&) { | 163 | void TableView::setTodo( int, const OTodo&) { |
166 | sort(); | 164 | sort(); |
167 | 165 | ||
168 | /* repaint */ | 166 | /* repaint */ |
169 | repaint(); | 167 | repaint(); |
170 | } | 168 | } |
171 | void TableView::addEvent( const OTodo&) { | 169 | void TableView::addEvent( const OTodo&) { |
172 | 170 | ||
173 | /* fix problems of not showing the 'Haken' */ | 171 | /* fix problems of not showing the 'Haken' */ |
174 | updateView(); | 172 | updateView(); |
175 | } | 173 | } |
176 | /* | 174 | /* |
177 | * find the event | 175 | * find the event |
178 | * and then replace the complete row | 176 | * and then replace the complete row |
179 | */ | 177 | */ |
180 | void TableView::replaceEvent( const OTodo& ev) { | 178 | void TableView::replaceEvent( const OTodo& ev) { |
181 | addEvent( ev ); | 179 | addEvent( ev ); |
182 | } | 180 | } |
183 | /* | 181 | /* |
184 | * re aligning table can be slow too | 182 | * re aligning table can be slow too |
185 | * FIXME: look what performs better | 183 | * FIXME: look what performs better |
186 | * either this or the old align table | 184 | * either this or the old align table |
187 | */ | 185 | */ |
188 | void TableView::removeEvent( int ) { | 186 | void TableView::removeEvent( int ) { |
189 | updateView(); | 187 | updateView(); |
190 | } | 188 | } |
191 | void TableView::setShowCompleted( bool b) { | 189 | void TableView::setShowCompleted( bool b) { |
192 | qWarning("Show Completed %d" + b ); | 190 | qWarning("Show Completed %d" + b ); |
193 | updateView(); | 191 | updateView(); |
194 | } | 192 | } |
195 | void TableView::setShowDeadline( bool b) { | 193 | void TableView::setShowDeadline( bool b) { |
196 | qWarning("Show DeadLine %d" + b ); | 194 | qWarning("Show DeadLine %d" + b ); |
197 | if (b) | 195 | if (b) |
198 | showColumn(3 ); | 196 | showColumn(3 ); |
199 | else | 197 | else |
200 | hideColumn(3 ); | 198 | hideColumn(3 ); |
201 | } | 199 | } |
202 | void TableView::setShowCategory( const QString& str) { | 200 | void TableView::setShowCategory( const QString& str) { |
203 | qWarning("setShowCategory"); | 201 | qWarning("setShowCategory"); |
204 | if ( str != m_oleCat || m_first ) | 202 | if ( str != m_oleCat || m_first ) |
205 | updateView(); | 203 | updateView(); |
206 | 204 | ||
207 | m_oleCat = str; | 205 | m_oleCat = str; |
208 | m_first = false; | 206 | m_first = false; |
209 | 207 | ||
210 | } | 208 | } |
211 | void TableView::clear() { | 209 | void TableView::clear() { |
212 | setNumRows(0); | 210 | setNumRows(0); |
213 | } | 211 | } |
214 | void TableView::slotClicked(int row, int col, int, | 212 | void TableView::slotClicked(int row, int col, int, |
215 | const QPoint& point) { | 213 | const QPoint& point) { |
216 | if ( !cellGeometry(row, col ).contains(point ) ) | 214 | if ( !cellGeometry(row, col ).contains(point ) ) |
217 | return; | 215 | return; |
218 | 216 | ||
219 | int ui= sorted().uidAt( row ); | 217 | int ui= sorted().uidAt( row ); |
220 | 218 | ||
221 | 219 | ||
222 | switch( col ) { | 220 | switch( col ) { |
223 | case 0:{ | 221 | case 0:{ |
224 | int x = point.x() -columnPos( col ); | 222 | int x = point.x() -columnPos( col ); |
225 | int y = point.y() -rowPos( row ); | 223 | int y = point.y() -rowPos( row ); |
226 | int w = columnWidth( col ); | 224 | int w = columnWidth( col ); |
227 | int h = rowHeight( row ); | 225 | int h = rowHeight( row ); |
228 | if ( x >= ( w - BoxSize ) / 2 && | 226 | if ( x >= ( w - BoxSize ) / 2 && |
229 | x <= ( w - BoxSize ) / 2 + BoxSize && | 227 | x <= ( w - BoxSize ) / 2 + BoxSize && |
230 | y >= ( h - BoxSize ) / 2 && | 228 | y >= ( h - BoxSize ) / 2 && |
231 | y <= ( h - BoxSize ) / 2 + BoxSize ) { | 229 | y <= ( h - BoxSize ) / 2 + BoxSize ) { |
232 | OTodo todo = sorted()[row]; | 230 | OTodo todo = sorted()[row]; |
233 | todo.setCompleted( !todo.isCompleted() ); | 231 | todo.setCompleted( !todo.isCompleted() ); |
234 | TodoView::update( todo.uid(), todo ); | 232 | TodoView::update( todo.uid(), todo ); |
235 | updateView(); | 233 | updateView(); |
236 | } | 234 | } |
237 | } | 235 | } |
238 | break; | 236 | break; |
239 | 237 | ||
240 | case 1: | 238 | case 1: |
241 | break; | 239 | break; |
242 | 240 | ||
243 | case 2: { | 241 | case 2: { |
244 | m_menuTimer->stop(); | 242 | m_menuTimer->stop(); |
245 | showTodo( ui ); | 243 | showTodo( ui ); |
246 | break; | 244 | break; |
247 | } | 245 | } |
248 | case 3: { | 246 | case 3: { |
249 | m_menuTimer->stop(); | 247 | m_menuTimer->stop(); |
250 | TodoView::edit( ui ); | 248 | TodoView::edit( ui ); |
251 | break; | 249 | break; |
252 | } | 250 | } |
253 | } | 251 | } |
254 | 252 | ||
255 | 253 | ||
256 | } | 254 | } |
257 | void TableView::slotPressed(int row, int col, int, | 255 | void TableView::slotPressed(int row, int col, int, |
258 | const QPoint& point) { | 256 | const QPoint& point) { |
259 | 257 | ||
258 | m_prevP = point; | ||
260 | /* TextColumn column */ | 259 | /* TextColumn column */ |
261 | if ( col == 2 && cellGeometry( row, col ).contains( point ) ) | 260 | if ( col == 2 && cellGeometry( row, col ).contains( point ) ) |
262 | m_menuTimer->start( 750, TRUE ); | 261 | m_menuTimer->start( 750, TRUE ); |
263 | } | 262 | } |
264 | void TableView::slotValueChanged( int, int ) { | 263 | void TableView::slotValueChanged( int, int ) { |
265 | qWarning("Value Changed"); | 264 | qWarning("Value Changed"); |
266 | } | 265 | } |
267 | void TableView::slotCurrentChanged(int, int ) { | 266 | void TableView::slotCurrentChanged(int, int ) { |
268 | m_menuTimer->stop(); | 267 | m_menuTimer->stop(); |
269 | } | 268 | } |
270 | QWidget* TableView::widget() { | 269 | QWidget* TableView::widget() { |
271 | return this; | 270 | return this; |
272 | } | 271 | } |
273 | /* | 272 | /* |
274 | * We need to overwrite sortColumn | 273 | * We need to overwrite sortColumn |
275 | * because we want to sort whole row | 274 | * because we want to sort whole row |
276 | * based | 275 | * based |
277 | * We event want to set the setOrder | 276 | * We event want to set the setOrder |
278 | * to a sort() and update() | 277 | * to a sort() and update() |
279 | */ | 278 | */ |
280 | void TableView::sortColumn( int col, bool asc, bool ) { | 279 | void TableView::sortColumn( int col, bool asc, bool ) { |
281 | qWarning("bool %d", asc ); | 280 | qWarning("bool %d", asc ); |
282 | setSortOrder( col ); | 281 | setSortOrder( col ); |
283 | setAscending( asc ); | 282 | setAscending( asc ); |
284 | updateView(); | 283 | updateView(); |
285 | } | 284 | } |
286 | void TableView::viewportPaintEvent( QPaintEvent* e) { | 285 | void TableView::viewportPaintEvent( QPaintEvent* e) { |
287 | qWarning("Paint event" ); | ||
288 | if (m_enablePaint ) | 286 | if (m_enablePaint ) |
289 | QTable::viewportPaintEvent( e ); | 287 | QTable::viewportPaintEvent( e ); |
290 | } | 288 | } |
291 | /* | 289 | /* |
292 | * This segment is copyrighted by TT | 290 | * This segment is copyrighted by TT |
293 | * it was taken from their todolist | 291 | * it was taken from their todolist |
294 | * application this code is GPL | 292 | * application this code is GPL |
295 | */ | 293 | */ |
296 | void TableView::paintCell(QPainter* p, int row, int col, const QRect& cr, bool ) { | 294 | void TableView::paintCell(QPainter* p, int row, int col, const QRect& cr, bool ) { |
297 | const QColorGroup &cg = colorGroup(); | 295 | const QColorGroup &cg = colorGroup(); |
298 | 296 | ||
299 | p->save(); | 297 | p->save(); |
300 | 298 | ||
301 | OTodo task = sorted()[row]; | 299 | OTodo task = sorted()[row]; |
302 | 300 | ||
303 | p->fillRect( 0, 0, cr.width(), cr.height(), cg.brush( QColorGroup::Base ) ); | 301 | p->fillRect( 0, 0, cr.width(), cr.height(), cg.brush( QColorGroup::Base ) ); |
304 | 302 | ||
305 | QPen op = p->pen(); | 303 | QPen op = p->pen(); |
306 | p->setPen(cg.mid()); | 304 | p->setPen(cg.mid()); |
307 | p->drawLine( 0, cr.height() - 1, cr.width() - 1, cr.height() - 1 ); | 305 | p->drawLine( 0, cr.height() - 1, cr.width() - 1, cr.height() - 1 ); |
308 | p->drawLine( cr.width() - 1, 0, cr.width() - 1, cr.height() - 1 ); | 306 | p->drawLine( cr.width() - 1, 0, cr.width() - 1, cr.height() - 1 ); |
309 | p->setPen(op); | 307 | p->setPen(op); |
310 | 308 | ||
311 | QFont f = p->font(); | 309 | QFont f = p->font(); |
312 | QFontMetrics fm(f); | 310 | QFontMetrics fm(f); |
313 | 311 | ||
314 | switch(col) { | 312 | switch(col) { |
315 | case 0: | 313 | case 0: |
316 | { | 314 | { |
317 | // completed field | 315 | // completed field |
318 | int marg = ( cr.width() - BoxSize ) / 2; | 316 | int marg = ( cr.width() - BoxSize ) / 2; |
319 | int x = 0; | 317 | int x = 0; |
320 | int y = ( cr.height() - BoxSize ) / 2; | 318 | int y = ( cr.height() - BoxSize ) / 2; |
321 | p->setPen( QPen( cg.text() ) ); | 319 | p->setPen( QPen( cg.text() ) ); |
322 | p->drawRect( x + marg, y, BoxSize, BoxSize ); | 320 | p->drawRect( x + marg, y, BoxSize, BoxSize ); |
323 | p->drawRect( x + marg+1, y+1, BoxSize-2, BoxSize-2 ); | 321 | p->drawRect( x + marg+1, y+1, BoxSize-2, BoxSize-2 ); |
324 | p->setPen( darkGreen ); | 322 | p->setPen( darkGreen ); |
325 | x += 1; | 323 | x += 1; |
326 | y += 1; | 324 | y += 1; |
327 | if ( task.isCompleted() ) { | 325 | if ( task.isCompleted() ) { |
328 | QPointArray a( 9*2 ); | 326 | QPointArray a( 9*2 ); |
329 | int i, xx, yy; | 327 | int i, xx, yy; |
330 | xx = x+2+marg; | 328 | xx = x+2+marg; |
331 | yy = y+4; | 329 | yy = y+4; |
332 | for ( i=0; i<4; i++ ) { | 330 | for ( i=0; i<4; i++ ) { |
333 | a.setPoint( 2*i, xx, yy ); | 331 | a.setPoint( 2*i, xx, yy ); |
334 | a.setPoint( 2*i+1, xx, yy+2 ); | 332 | a.setPoint( 2*i+1, xx, yy+2 ); |
335 | xx++; yy++; | 333 | xx++; yy++; |
336 | } | 334 | } |
337 | yy -= 2; | 335 | yy -= 2; |
338 | for ( i=4; i<9; i++ ) { | 336 | for ( i=4; i<9; i++ ) { |
339 | a.setPoint( 2*i, xx, yy ); | 337 | a.setPoint( 2*i, xx, yy ); |
340 | a.setPoint( 2*i+1, xx, yy+2 ); | 338 | a.setPoint( 2*i+1, xx, yy+2 ); |
341 | xx++; yy--; | 339 | xx++; yy--; |
342 | } | 340 | } |
343 | p->drawLineSegments( a ); | 341 | p->drawLineSegments( a ); |
344 | } | 342 | } |
345 | } | 343 | } |
346 | break; | 344 | break; |
347 | case 1: | 345 | case 1: |
348 | // priority field | 346 | // priority field |
349 | { | 347 | { |
350 | QString text = QString::number(task.priority()); | 348 | QString text = QString::number(task.priority()); |
351 | p->drawText(2,2 + fm.ascent(), text); | 349 | p->drawText(2,2 + fm.ascent(), text); |
352 | } | 350 | } |
353 | break; | 351 | break; |
354 | case 2: | 352 | case 2: |
355 | // description field | 353 | // description field |
356 | { | 354 | { |
357 | QString text = task.summary().isEmpty() ? | 355 | QString text = task.summary().isEmpty() ? |
358 | task.description() : | 356 | task.description() : |
359 | task.summary(); | 357 | task.summary(); |
360 | p->drawText(2,2 + fm.ascent(), text); | 358 | p->drawText(2,2 + fm.ascent(), text); |
361 | } | 359 | } |
362 | break; | 360 | break; |
363 | case 3: | 361 | case 3: |
364 | { | 362 | { |
365 | QString text; | 363 | QString text; |
366 | if (task.hasDueDate()) { | 364 | if (task.hasDueDate()) { |
367 | int off = QDate::currentDate().daysTo( task.dueDate() ); | 365 | int off = QDate::currentDate().daysTo( task.dueDate() ); |
368 | text = QString::number(off) + tr(" day(s)"); | 366 | text = QString::number(off) + tr(" day(s)"); |
369 | /* | 367 | /* |
370 | * set color if not completed | 368 | * set color if not completed |
371 | */ | 369 | */ |
372 | if (!task.isCompleted() ) { | 370 | if (!task.isCompleted() ) { |
373 | QColor color = Qt::black; | 371 | QColor color = Qt::black; |
374 | if ( off < 0 ) | 372 | if ( off < 0 ) |
375 | color = Qt::red; | 373 | color = Qt::red; |
376 | else if ( off == 0 ) | 374 | else if ( off == 0 ) |
377 | color = Qt::yellow; | 375 | color = Qt::yellow; |
378 | else if ( off > 0 ) | 376 | else if ( off > 0 ) |
379 | color = Qt::green; | 377 | color = Qt::green; |
380 | p->setPen(color ); | 378 | p->setPen(color ); |
381 | } | 379 | } |
382 | } else { | 380 | } else { |
383 | text = tr("None"); | 381 | text = tr("None"); |
384 | } | 382 | } |
385 | p->drawText(2,2 + fm.ascent(), text); | 383 | p->drawText(2,2 + fm.ascent(), text); |
386 | } | 384 | } |
387 | break; | 385 | break; |
388 | } | 386 | } |
389 | p->restore(); | 387 | p->restore(); |
390 | } | 388 | } |
391 | QWidget* TableView::createEditor(int row, int col, bool )const { | 389 | QWidget* TableView::createEditor(int row, int col, bool )const { |
392 | switch( col ) { | 390 | switch( col ) { |
393 | case 1: { | 391 | case 1: { |
394 | /* the priority stuff */ | 392 | /* the priority stuff */ |
395 | QComboBox* combo = new QComboBox( viewport() ); | 393 | QComboBox* combo = new QComboBox( viewport() ); |
396 | combo->insertItem( "1" ); | 394 | combo->insertItem( "1" ); |
397 | combo->insertItem( "2" ); | 395 | combo->insertItem( "2" ); |
398 | combo->insertItem( "3" ); | 396 | combo->insertItem( "3" ); |
399 | combo->insertItem( "4" ); | 397 | combo->insertItem( "4" ); |
400 | combo->insertItem( "5" ); | 398 | combo->insertItem( "5" ); |
401 | combo->setCurrentItem( sorted()[row].priority()-1 ); | 399 | combo->setCurrentItem( sorted()[row].priority()-1 ); |
402 | return combo; | 400 | return combo; |
403 | } | 401 | } |
404 | case 0: | 402 | case 0: |
405 | default: | 403 | default: |
406 | return 0l; | 404 | return 0l; |
407 | } | 405 | } |
408 | } | 406 | } |
409 | void TableView::setCellContentFromEditor(int row, int col ) { | 407 | void TableView::setCellContentFromEditor(int row, int col ) { |
410 | if ( col == 1 ) { | 408 | if ( col == 1 ) { |
411 | QWidget* wid = cellWidget(row, 1 ); | 409 | QWidget* wid = cellWidget(row, 1 ); |
412 | if ( wid->inherits("QComboBox") ) { | 410 | if ( wid->inherits("QComboBox") ) { |
413 | int pri = ((QComboBox*)wid)->currentItem() + 1; | 411 | int pri = ((QComboBox*)wid)->currentItem() + 1; |
414 | OTodo todo = sorted()[row]; | 412 | OTodo todo = sorted()[row]; |
415 | if ( todo.priority() != pri ) { | 413 | if ( todo.priority() != pri ) { |
416 | todo.setPriority( pri ); | 414 | todo.setPriority( pri ); |
417 | TodoView::update( todo.uid(), todo ); | 415 | TodoView::update( todo.uid(), todo ); |
418 | updateView(); | 416 | updateView(); |
419 | } | 417 | } |
420 | } | 418 | } |
421 | } | 419 | } |
422 | } | 420 | } |
423 | void TableView::slotPriority() { | 421 | void TableView::slotPriority() { |
424 | setCellContentFromEditor( currentRow(), currentColumn() ); | 422 | setCellContentFromEditor( currentRow(), currentColumn() ); |
425 | } | 423 | } |
426 | /* | 424 | /* |
427 | * We'll use the TimerEvent to read ahead or to keep the cahce always | 425 | * We'll use the TimerEvent to read ahead or to keep the cahce always |
428 | * filled enough. | 426 | * filled enough. |
429 | * We will try to read ahead 4 items in both ways | 427 | * We will try to read ahead 4 items in both ways |
430 | * up and down. On odd or even we will currentRow()+-4 or +-9 | 428 | * up and down. On odd or even we will currentRow()+-4 or +-9 |
431 | * | 429 | * |
432 | */ | 430 | */ |
433 | void TableView::timerEvent( QTimerEvent* ev ) { | 431 | void TableView::timerEvent( QTimerEvent* ev ) { |
434 | if (sorted().count() == 0 ) | 432 | if (sorted().count() == 0 ) |
435 | return; | 433 | return; |
436 | 434 | ||
437 | int row = currentRow(); | 435 | int row = currentRow(); |
438 | qWarning("TimerEvent %d", row); | ||
439 | if ( m_row ) { | 436 | if ( m_row ) { |
440 | int ro = row-4; | 437 | int ro = row-4; |
441 | if (ro < 0 ) ro = 0; | 438 | if (ro < 0 ) ro = 0; |
442 | sorted()[ro]; | 439 | sorted()[ro]; |
443 | 440 | ||
444 | ro = row+4; | 441 | ro = row+4; |
445 | sorted()[ro]; | 442 | sorted()[ro]; |
446 | } else { | 443 | } else { |
447 | int ro = row + 8; | 444 | int ro = row + 8; |
448 | sorted()[ro]; | 445 | sorted()[ro]; |
449 | 446 | ||
450 | ro = row-8; | 447 | ro = row-8; |
451 | if (ro < 0 ) ro = 0; | 448 | if (ro < 0 ) ro = 0; |
452 | sorted()[ro]; | 449 | sorted()[ro]; |
453 | } | 450 | } |
454 | 451 | ||
455 | m_row = !m_row; | 452 | m_row = !m_row; |
456 | } | 453 | } |
454 | |||
455 | // We want a strike through completed ;) | ||
456 | // durchstreichen to complete | ||
457 | /* | ||
458 | * MouseTracking is off this mean we only receive | ||
459 | * these events if the mouse button is pressed | ||
460 | * We've the previous point saved | ||
461 | * We check if the previous and current Point are | ||
462 | * in the same row. | ||
463 | * Then we check if they're some pixel horizontal away | ||
464 | * if the distance between the two points is greater than | ||
465 | * 8 we mark the underlying todo as completed and do a repaint | ||
466 | */ | ||
467 | void TableView::contentsMouseReleaseEvent( QMouseEvent* e) { | ||
468 | int row = rowAt(m_prevP.y()); | ||
469 | if ( row == rowAt( e->y() ) ) { | ||
470 | if ( abs( m_prevP.x() - e->x() ) >= 8 ) { | ||
471 | OTodo todo = sorted()[row]; | ||
472 | todo.setCompleted( !todo.isCompleted() ); | ||
473 | TodoView::update( todo.uid(), todo ); | ||
474 | updateView(); | ||
475 | return; | ||
476 | } | ||
477 | } | ||
478 | QTable::contentsMouseReleaseEvent( e ); | ||
479 | } | ||
480 | void TableView::contentsMouseMoveEvent( QMouseEvent* e ) { | ||
481 | m_menuTimer->stop(); | ||
482 | QTable::contentsMouseMoveEvent( e ); | ||
483 | } | ||
diff --git a/core/pim/todo/tableview.h b/core/pim/todo/tableview.h index fe65ca9..0c3e865 100644 --- a/core/pim/todo/tableview.h +++ b/core/pim/todo/tableview.h | |||
@@ -1,103 +1,106 @@ | |||
1 | /* | 1 | /* |
2 | =. This file is part of the OPIE Project | 2 | =. This file is part of the OPIE Project |
3 | .=l. Copyright (c) 2002 <> | 3 | .=l. Copyright (c) 2002 <> |
4 | .>+-= | 4 | .>+-= |
5 | _;:, .> :=|. This program is free software; you can | 5 | _;:, .> :=|. This program is free software; you can |
6 | .> <`_, > . <= redistribute it and/or modify it under | 6 | .> <`_, > . <= redistribute it and/or modify it under |
7 | :`=1 )Y*s>-.-- : the terms of the GNU General Public | 7 | :`=1 )Y*s>-.-- : the terms of the GNU General Public |
8 | .="- .-=="i, .._ License as published by the Free Software | 8 | .="- .-=="i, .._ License as published by the Free Software |
9 | - . .-<_> .<> Foundation; either version 2 of the License, | 9 | - . .-<_> .<> Foundation; either version 2 of the License, |
10 | ._= =} : or (at your option) any later version. | 10 | ._= =} : or (at your option) any later version. |
11 | .%`+i> _;_. | 11 | .%`+i> _;_. |
12 | .i_,=:_. -<s. This program is distributed in the hope that | 12 | .i_,=:_. -<s. This program is distributed in the hope that |
13 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 13 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
14 | : .. .:, . . . without even the implied warranty of | 14 | : .. .:, . . . without even the implied warranty of |
15 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 15 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
16 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU | 16 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU |
17 | ..}^=.= = ; Library General Public License for more | 17 | ..}^=.= = ; Library General Public License for more |
18 | ++= -. .` .: details. | 18 | ++= -. .` .: details. |
19 | : = ...= . :.=- | 19 | : = ...= . :.=- |
20 | -. .:....=;==+<; You should have received a copy of the GNU | 20 | -. .:....=;==+<; You should have received a copy of the GNU |
21 | -_. . . )=. = Library General Public License along with | 21 | -_. . . )=. = Library General Public License along with |
22 | -- :-=` this library; see the file COPYING.LIB. | 22 | -- :-=` this library; see the file COPYING.LIB. |
23 | If not, write to the Free Software Foundation, | 23 | If not, write to the Free Software Foundation, |
24 | Inc., 59 Temple Place - Suite 330, | 24 | Inc., 59 Temple Place - Suite 330, |
25 | Boston, MA 02111-1307, USA. | 25 | Boston, MA 02111-1307, USA. |
26 | 26 | ||
27 | */ | 27 | */ |
28 | 28 | ||
29 | #ifndef OPIE_TABLE_VIEW_H | 29 | #ifndef OPIE_TABLE_VIEW_H |
30 | #define OPIE_TABLE_VIEW_H | 30 | #define OPIE_TABLE_VIEW_H |
31 | 31 | ||
32 | #include <qtable.h> | 32 | #include <qtable.h> |
33 | #include <qmap.h> | 33 | #include <qmap.h> |
34 | 34 | ||
35 | #include "tableitems.h" | 35 | #include "tableitems.h" |
36 | #include "todoview.h" | 36 | #include "todoview.h" |
37 | 37 | ||
38 | class QTimer; | 38 | class QTimer; |
39 | 39 | ||
40 | namespace Todo { | 40 | namespace Todo { |
41 | class CheckItem; | 41 | class CheckItem; |
42 | class DueTextItem; | 42 | class DueTextItem; |
43 | class TableView : public QTable, public TodoView { | 43 | class TableView : public QTable, public TodoView { |
44 | Q_OBJECT | 44 | Q_OBJECT |
45 | public: | 45 | public: |
46 | TableView( MainWindow*, QWidget* parent ); | 46 | TableView( MainWindow*, QWidget* parent ); |
47 | ~TableView(); | 47 | ~TableView(); |
48 | 48 | ||
49 | 49 | ||
50 | QString type()const; | 50 | QString type()const; |
51 | int current(); | 51 | int current(); |
52 | QString currentRepresentation(); | 52 | QString currentRepresentation(); |
53 | 53 | ||
54 | void clear(); | 54 | void clear(); |
55 | void showOverDue( bool ); | 55 | void showOverDue( bool ); |
56 | void updateView(); | 56 | void updateView(); |
57 | void setTodo( int uid, const OTodo& ); | 57 | void setTodo( int uid, const OTodo& ); |
58 | void addEvent( const OTodo& event ); | 58 | void addEvent( const OTodo& event ); |
59 | void replaceEvent( const OTodo& ); | 59 | void replaceEvent( const OTodo& ); |
60 | void removeEvent( int uid ); | 60 | void removeEvent( int uid ); |
61 | void setShowCompleted( bool ); | 61 | void setShowCompleted( bool ); |
62 | void setShowDeadline( bool ); | 62 | void setShowDeadline( bool ); |
63 | 63 | ||
64 | void setShowCategory(const QString& =QString::null ); | 64 | void setShowCategory(const QString& =QString::null ); |
65 | void newDay(); | 65 | void newDay(); |
66 | QWidget* widget(); | 66 | QWidget* widget(); |
67 | void sortColumn(int, bool, bool ); | 67 | void sortColumn(int, bool, bool ); |
68 | 68 | ||
69 | /* | 69 | /* |
70 | * we do our drawing ourselves | 70 | * we do our drawing ourselves |
71 | * because we don't want to have | 71 | * because we don't want to have |
72 | * 40.000 QTableItems for 10.000 | 72 | * 40.000 QTableItems for 10.000 |
73 | * OTodos where we only show 10 at a time! | 73 | * OTodos where we only show 10 at a time! |
74 | */ | 74 | */ |
75 | void paintCell(QPainter* p, int row, int col, const QRect&, bool ); | 75 | void paintCell(QPainter* p, int row, int col, const QRect&, bool ); |
76 | private: | 76 | private: |
77 | /* reimplented for internal reasons */ | 77 | /* reimplented for internal reasons */ |
78 | void viewportPaintEvent( QPaintEvent* ); | 78 | void viewportPaintEvent( QPaintEvent* ); |
79 | QTimer *m_menuTimer; | 79 | QTimer *m_menuTimer; |
80 | bool m_enablePaint:1; | 80 | bool m_enablePaint:1; |
81 | QString m_oleCat; | 81 | QString m_oleCat; |
82 | bool m_first : 1; | 82 | bool m_first : 1; |
83 | 83 | ||
84 | protected: | 84 | protected: |
85 | void contentsMouseReleaseEvent( QMouseEvent* ); | ||
86 | void contentsMouseMoveEvent( QMouseEvent* ); | ||
85 | void timerEvent( QTimerEvent* e ); | 87 | void timerEvent( QTimerEvent* e ); |
86 | QWidget* createEditor(int row, int col, bool initFromCell )const; | 88 | QWidget* createEditor(int row, int col, bool initFromCell )const; |
87 | void setCellContentFromEditor( int row, int col ); | 89 | void setCellContentFromEditor( int row, int col ); |
88 | 90 | ||
89 | private slots: | 91 | private slots: |
90 | void slotShowMenu(); | 92 | void slotShowMenu(); |
91 | void slotClicked(int, int, int, | 93 | void slotClicked(int, int, int, |
92 | const QPoint& ); | 94 | const QPoint& ); |
93 | void slotPressed(int, int, int, | 95 | void slotPressed(int, int, int, |
94 | const QPoint& ); | 96 | const QPoint& ); |
95 | void slotValueChanged(int, int); | 97 | void slotValueChanged(int, int); |
96 | void slotCurrentChanged(int, int ); | 98 | void slotCurrentChanged(int, int ); |
97 | void slotPriority(); | 99 | void slotPriority(); |
98 | private: | 100 | private: |
99 | bool m_row : 1; | 101 | bool m_row : 1; |
102 | QPoint m_prevP; | ||
100 | }; | 103 | }; |
101 | }; | 104 | }; |
102 | 105 | ||
103 | #endif | 106 | #endif |