summaryrefslogtreecommitdiffabout
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--korganizer/komonthview.cpp12
-rw-r--r--korganizer/komonthview.h3
2 files changed, 10 insertions, 5 deletions
diff --git a/korganizer/komonthview.cpp b/korganizer/komonthview.cpp
index 4aeb20c..8d06040 100644
--- a/korganizer/komonthview.cpp
+++ b/korganizer/komonthview.cpp
@@ -1,2330 +1,2334 @@
1/* 1/*
2 This file is part of KOrganizer. 2 This file is part of KOrganizer.
3 Copyright (c) 2000,2001 Cornelius Schumacher <schumacher@kde.org> 3 Copyright (c) 2000,2001 Cornelius Schumacher <schumacher@kde.org>
4 4
5 This program is free software; you can redistribute it and/or modify 5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by 6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or 7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version. 8 (at your option) any later version.
9 9
10 This program is distributed in the hope that it will be useful, 10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details. 13 GNU General Public License for more details.
14 14
15 You should have received a copy of the GNU General Public License 15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software 16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18*/ 18*/
19 19
20#include <qpopupmenu.h> 20#include <qpopupmenu.h>
21#include <qfont.h> 21#include <qfont.h>
22#include <qfontmetrics.h> 22#include <qfontmetrics.h>
23#include <qkeycode.h> 23#include <qkeycode.h>
24#include <qhbox.h> 24#include <qhbox.h>
25#include <qvbox.h> 25#include <qvbox.h>
26#include <qwidgetstack.h> 26#include <qwidgetstack.h>
27#include <qpushbutton.h> 27#include <qpushbutton.h>
28#include <qtooltip.h> 28#include <qtooltip.h>
29#include <qpainter.h> 29#include <qpainter.h>
30#include <qtimer.h> 30#include <qtimer.h>
31#include <qwhatsthis.h> 31#include <qwhatsthis.h>
32#ifndef DESKTOP_VERSION 32#ifndef DESKTOP_VERSION
33#include <qpe/qpeapplication.h> 33#include <qpe/qpeapplication.h>
34#else 34#else
35#include <qapplication.h> 35#include <qapplication.h>
36#endif 36#endif
37 37
38#include <kdebug.h> 38#include <kdebug.h>
39#include <klocale.h> 39#include <klocale.h>
40#include <kglobal.h> 40#include <kglobal.h>
41#include <kconfig.h> 41#include <kconfig.h>
42#include <kiconloader.h> 42#include <kiconloader.h>
43 43
44#include <kcalendarsystem.h> 44#include <kcalendarsystem.h>
45 45
46#ifndef KORG_NOPRINTER 46#ifndef KORG_NOPRINTER
47#include "calprinter.h" 47#include "calprinter.h"
48#endif 48#endif
49#include "koprefs.h" 49#include "koprefs.h"
50#ifndef KORG_NOPLUGINS 50#ifndef KORG_NOPLUGINS
51#include "kocore.h" 51#include "kocore.h"
52#endif 52#endif
53#include "koglobals.h" 53#include "koglobals.h"
54#include <libkcal/kincidenceformatter.h> 54#include <libkcal/kincidenceformatter.h>
55 55
56#include "komonthview.h" 56#include "komonthview.h"
57 57
58#define PIXMAP_SIZE 5 58#define PIXMAP_SIZE 5
59#ifdef DESKTOP_VERSION 59#ifdef DESKTOP_VERSION
60QToolTipGroup *MonthViewCell::mToolTipGroup = 0; 60QToolTipGroup *MonthViewCell::mToolTipGroup = 0;
61#endif 61#endif
62class KNOWhatsThis :public QWhatsThis 62class KNOWhatsThis :public QWhatsThis
63{ 63{
64public: 64public:
65 KNOWhatsThis( KNoScrollListBox* sbox ) : QWhatsThis( sbox ), _wid( sbox) { }; 65 KNOWhatsThis( KNoScrollListBox* sbox ) : QWhatsThis( sbox ), _wid( sbox) { };
66 //~KNOWhatsThis( ) {qDebug("~KNOWhatsThis( ) "); }; 66 //~KNOWhatsThis( ) {qDebug("~KNOWhatsThis( ) "); };
67 67
68protected: 68protected:
69 virtual QString text( const QPoint& p) 69 virtual QString text( const QPoint& p)
70 { 70 {
71 return _wid->getWhatsThisText(p) ; 71 return _wid->getWhatsThisText(p) ;
72 }; 72 };
73private: 73private:
74 KNoScrollListBox* _wid; 74 KNoScrollListBox* _wid;
75 75
76}; 76};
77 77
78 78
79KNoScrollListBox::KNoScrollListBox(QWidget *parent,const char *name) 79KNoScrollListBox::KNoScrollListBox(QWidget *parent,const char *name)
80 : QListBox(parent, name, WRepaintNoErase) 80 : QListBox(parent, name, WRepaintNoErase)
81{ 81{
82#ifndef DESKTOP_VERSION 82#ifndef DESKTOP_VERSION
83 QPEApplication::setStylusOperation( viewport(), QPEApplication::RightOnHold ); 83 QPEApplication::setStylusOperation( viewport(), QPEApplication::RightOnHold );
84#endif 84#endif
85 mBlockDeselect = false;
85 mWT = new KNOWhatsThis(this); 86 mWT = new KNOWhatsThis(this);
86 resetOnFocusIn = true; 87 resetOnFocusIn = true;
87 setVScrollBarMode(QScrollView::AlwaysOff); 88 setVScrollBarMode(QScrollView::AlwaysOff);
88 setHScrollBarMode(QScrollView::AlwaysOff); 89 setHScrollBarMode(QScrollView::AlwaysOff);
89} 90}
90KNoScrollListBox::~KNoScrollListBox() 91KNoScrollListBox::~KNoScrollListBox()
91{ 92{
92#if QT_VERSION >= 0x030000 93#if QT_VERSION >= 0x030000
93 94
94#else 95#else
95 delete mWT; 96 delete mWT;
96#endif 97#endif
97} 98}
98 99
99 100
100void KNoScrollListBox::focusInEvent ( QFocusEvent * e ) 101void KNoScrollListBox::focusInEvent ( QFocusEvent * e )
101{ 102{
102 QListBox::focusInEvent ( e ); 103 QListBox::focusInEvent ( e );
103 if ( count() ){ 104 if ( count() ){
104 int ci = currentItem(); 105 int ci = currentItem();
105 if ( ci < 0 ) ci = 0; 106 if ( ci < 0 ) ci = 0;
106 107
107 setCurrentItem( ci ); 108 setCurrentItem( ci );
108 setSelected ( ci, true ); 109 setSelected ( ci, true );
109 emit highlighted( item ( ci ) ); 110 emit highlighted( item ( ci ) );
110 111
111 resetOnFocusIn = true; 112 resetOnFocusIn = true;
112 113
113 if ( KOPrefs::instance()->mEnableMonthScroll || KOPrefs::instance()->mMonthViewWeek ) { 114 if ( KOPrefs::instance()->mEnableMonthScroll || KOPrefs::instance()->mMonthViewWeek ) {
114 QListBoxItem *fi = firstItem (); 115 QListBoxItem *fi = firstItem ();
115 if (fi ) { 116 if (fi ) {
116 int ihei = fi->height( this ); 117 int ihei = fi->height( this );
117 int hei = numRows () * ihei; 118 int hei = numRows () * ihei;
118 if ( hei < height() - horizontalScrollBar()->height () ) { 119 if ( hei < height() - horizontalScrollBar()->height () ) {
119 setVScrollBarMode(QScrollView::AlwaysOff); 120 setVScrollBarMode(QScrollView::AlwaysOff);
120 } 121 }
121 else 122 else
122 setVScrollBarMode(QScrollView::Auto); 123 setVScrollBarMode(QScrollView::Auto);
123 if ( ihei *3 > height() ) { 124 if ( ihei *3 > height() ) {
124 setHScrollBarMode(QScrollView::AlwaysOff); 125 setHScrollBarMode(QScrollView::AlwaysOff);
125 } 126 }
126 else { 127 else {
127 setHScrollBarMode(QScrollView::Auto); 128 setHScrollBarMode(QScrollView::Auto);
128 } 129 }
129 } else { 130 } else {
130 setVScrollBarMode(QScrollView::Auto); 131 setVScrollBarMode(QScrollView::Auto);
131 setHScrollBarMode(QScrollView::Auto); 132 setHScrollBarMode(QScrollView::Auto);
132 } 133 }
133 } 134 }
134 } 135 }
135} 136}
136void KNoScrollListBox::focusOutEvent ( QFocusEvent * e ) 137void KNoScrollListBox::focusOutEvent ( QFocusEvent * e )
137{ 138{
139 if ( ! mBlockDeselect ) {
138 int i = currentItem (); 140 int i = currentItem ();
139 if ( i >= 0 ) { 141 if ( i >= 0 ) {
140 setSelected ( i, false ); 142 setSelected ( i, false );
141 } 143 }
142 QListBox::focusOutEvent ( e ); 144 QListBox::focusOutEvent ( e );
145 }
143 setVScrollBarMode(QScrollView::AlwaysOff); 146 setVScrollBarMode(QScrollView::AlwaysOff);
144 setHScrollBarMode(QScrollView::AlwaysOff); 147 setHScrollBarMode(QScrollView::AlwaysOff);
145 emit highlightIncidence( 0, (MonthViewCell*)this, 0 ); 148 if ( ! mBlockDeselect )
149 emit highlightIncidence( 0, (MonthViewCell*)this, 0 );
150 mBlockDeselect = false;
146} 151}
147 152
148QString KNoScrollListBox::getWhatsThisText(QPoint p) 153QString KNoScrollListBox::getWhatsThisText(QPoint p)
149{ 154{
150 QListBoxItem* item = itemAt ( p ); 155 QListBoxItem* item = itemAt ( p );
151 if ( ! item ) { 156 if ( ! item ) {
152 return i18n("Click in the cell\nto add an event!"); 157 return i18n("Click in the cell\nto add an event!");
153 } 158 }
154 return KIncidenceFormatter::instance()->getFormattedText(((MonthViewItem*) item)->incidence(), 159 return KIncidenceFormatter::instance()->getFormattedText(((MonthViewItem*) item)->incidence(),
155 KOPrefs::instance()->mWTshowDetails, 160 KOPrefs::instance()->mWTshowDetails,
156 KOPrefs::instance()->mWTshowCreated, 161 KOPrefs::instance()->mWTshowCreated,
157 KOPrefs::instance()->mWTshowChanged); 162 KOPrefs::instance()->mWTshowChanged);
158} 163}
159void KNoScrollListBox::keyPressEvent(QKeyEvent *e) 164void KNoScrollListBox::keyPressEvent(QKeyEvent *e)
160{ 165{
161 //qDebug("KNoScrollListBox::keyPressEvent "); 166 //qDebug("KNoScrollListBox::keyPressEvent ");
162 switch(e->key()) { 167 switch(e->key()) {
163 case Key_Right: 168 case Key_Right:
164 if ( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton ) 169 if ( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton )
165 { 170 {
166 e->ignore(); 171 e->ignore();
167 return; 172 return;
168 } 173 }
169 scrollBy(10,0); 174 scrollBy(10,0);
170 break; 175 break;
171 case Key_Left: 176 case Key_Left:
172 if (e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton ) 177 if (e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton )
173 { 178 {
174 e->ignore(); 179 e->ignore();
175 return; 180 return;
176 } 181 }
177 scrollBy(-10,0); 182 scrollBy(-10,0);
178 break; 183 break;
179 case Key_Up: 184 case Key_Up:
180 if( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton) { 185 if( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton) {
181 e->ignore(); 186 e->ignore();
182 break; 187 break;
183 } 188 }
184 if ( count() ) { 189 if ( count() ) {
185 if ( currentItem() == 0 ) { 190 if ( currentItem() == 0 ) {
186 emit prevCell(); 191 emit prevCell();
187 } else { 192 } else {
188 setCurrentItem((currentItem()+count()-1)%count()); 193 setCurrentItem((currentItem()+count()-1)%count());
189 if(!itemVisible(currentItem())) { 194 if(!itemVisible(currentItem())) {
190 if((unsigned int) currentItem() == (count()-1)) { 195 if((unsigned int) currentItem() == (count()-1)) {
191 setTopItem(currentItem()-numItemsVisible()+1); 196 setTopItem(currentItem()-numItemsVisible()+1);
192 } else { 197 } else {
193 setTopItem(topItem()-1); 198 setTopItem(topItem()-1);
194 } 199 }
195 } 200 }
196 } 201 }
197 } 202 }
198 break; 203 break;
199 case Key_Down: 204 case Key_Down:
200 if(e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton) { 205 if(e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton) {
201 e->ignore(); 206 e->ignore();
202 break; 207 break;
203 } 208 }
204 if ( count () ) { 209 if ( count () ) {
205 if ( ((uint)currentItem()+1) == count () ) { 210 if ( ((uint)currentItem()+1) == count () ) {
206 emit nextCell(); 211 emit nextCell();
207 } else { 212 } else {
208 setCurrentItem((currentItem()+1)%count()); 213 setCurrentItem((currentItem()+1)%count());
209 if(!itemVisible(currentItem())) { 214 if(!itemVisible(currentItem())) {
210 if(currentItem() == 0) { 215 if(currentItem() == 0) {
211 setTopItem(0); 216 setTopItem(0);
212 } else { 217 } else {
213 setTopItem(topItem()+1); 218 setTopItem(topItem()+1);
214 } 219 }
215 } 220 }
216 } 221 }
217 } 222 }
218 break; 223 break;
219 case Key_I: 224 case Key_I:
220 QTimer::singleShot( 1, this, SLOT ( oneDown() ) ); 225 QTimer::singleShot( 1, this, SLOT ( oneDown() ) );
221 e->ignore(); 226 e->ignore();
222 break; 227 break;
223 case Key_Return: 228 case Key_Return:
224 case Key_Enter: 229 case Key_Enter:
225 { 230 {
226 if ( currentItem() >= 0 ) { 231 if ( currentItem() >= 0 ) {
227 emit doubleClicked( item( currentItem() ) ); 232 emit doubleClicked( item( currentItem() ) );
228 e->accept(); 233 e->accept();
229 } else { 234 } else {
230 e->ignore(); 235 e->ignore();
231 } 236 }
232 } 237 }
233 break; 238 break;
234 case Key_Shift: 239 case Key_Shift:
235 emit shiftDown(); 240 emit shiftDown();
236 break; 241 break;
237 default: 242 default:
238 e->ignore(); 243 e->ignore();
239 break; 244 break;
240 } 245 }
241} 246}
242 247
243void KNoScrollListBox::oneDown() 248void KNoScrollListBox::oneDown()
244{ 249{
245 if ( count () ) { 250 if ( count () ) {
246 if ( ((uint)currentItem()+1) == count () ) { 251 if ( ((uint)currentItem()+1) == count () ) {
247 emit nextCell(); 252 emit nextCell();
248 } else { 253 } else {
249 resetOnFocusIn = false; 254 resetOnFocusIn = false;
250 setCurrentItem((currentItem()+1)%count()); 255 setCurrentItem((currentItem()+1)%count());
251 if(!itemVisible(currentItem())) { 256 if(!itemVisible(currentItem())) {
252 if(currentItem() == 0) { 257 if(currentItem() == 0) {
253 setTopItem(0); 258 setTopItem(0);
254 } else { 259 } else {
255 setTopItem(topItem()+1); 260 setTopItem(topItem()+1);
256 } 261 }
257 } 262 }
258 } 263 }
259 } 264 }
260} 265}
261void KNoScrollListBox::keyReleaseEvent(QKeyEvent *e) 266void KNoScrollListBox::keyReleaseEvent(QKeyEvent *e)
262{ 267{
263 switch(e->key()) { 268 switch(e->key()) {
264 case Key_Shift: 269 case Key_Shift:
265 emit shiftUp(); 270 emit shiftUp();
266 break; 271 break;
267 default: 272 default:
268 break; 273 break;
269 } 274 }
270} 275}
271 276
272void KNoScrollListBox::mousePressEvent(QMouseEvent *e) 277void KNoScrollListBox::mousePressEvent(QMouseEvent *e)
273{ 278{
274 QListBox::mousePressEvent(e); 279 QListBox::mousePressEvent(e);
275 280
276 if(e->button() == RightButton) { 281 if(e->button() == RightButton) {
277 emit rightClick(); 282 emit rightClick();
278 } 283 }
279} 284}
280 285
281MonthViewItem::MonthViewItem( Incidence *incidence, const QString & s) 286MonthViewItem::MonthViewItem( Incidence *incidence, const QString & s)
282 : QListBoxItem() 287 : QListBoxItem()
283{ 288{
284 mblockRepaint = true; 289 mblockRepaint = true;
285 isWeekItem = KOPrefs::instance()->mMonthViewWeek; 290 isWeekItem = KOPrefs::instance()->mMonthViewWeek;
286 recycle( incidence, s ); 291 recycle( incidence, s );
287} 292}
288void MonthViewItem::recycle( Incidence *incidence, const QString & s) 293void MonthViewItem::recycle( Incidence *incidence, const QString & s)
289{ 294{
290 mDisplayHighlighted = false; 295 mDisplayHighlighted = false;
291 setText( s ); 296 setText( s );
292 mMultiday = 0; 297 mMultiday = 0;
293 mIncidence = incidence; 298 mIncidence = incidence;
294 mRecur = false; 299 mRecur = false;
295 mAlarm = false; 300 mAlarm = false;
296 mReply = false; 301 mReply = false;
297 mInfo = false; 302 mInfo = false;
298 mdayPos = 0; 303 mdayPos = 0;
299} 304}
300 305
301bool MonthViewItem::setHighlightedFalse() 306bool MonthViewItem::setHighlightedFalse()
302{ 307{
303 if ( !mDisplayHighlighted ) 308 if ( !mDisplayHighlighted )
304 return false; 309 return false;
305 mDisplayHighlighted = false; 310 mDisplayHighlighted = false;
306 return true; 311 return true;
307} 312}
308 313
309bool MonthViewItem::setHighlighted( Incidence * inc ) 314bool MonthViewItem::setHighlighted( Incidence * inc )
310{ 315{
311 if ( inc == mIncidence ) { 316 if ( inc == mIncidence ) {
312 if ( mDisplayHighlighted ) 317 if ( mDisplayHighlighted )
313 return false; 318 return false;
314 mDisplayHighlighted = true; 319 mDisplayHighlighted = true;
315 return true; 320 return true;
316 } else { 321 } else {
317 if ( !mDisplayHighlighted ) 322 if ( !mDisplayHighlighted )
318 return false; 323 return false;
319 mDisplayHighlighted = false; 324 mDisplayHighlighted = false;
320 return true; 325 return true;
321 } 326 }
322 return false; 327 return false;
323} 328}
324void MonthViewItem::paint(QPainter *p) 329void MonthViewItem::paint(QPainter *p)
325{ 330{
326 if ( mblockRepaint || !mIncidence ) { 331 if ( mblockRepaint || !mIncidence ) {
327 return; 332 return;
328 } 333 }
329#if QT_VERSION >= 0x030000 334#if QT_VERSION >= 0x030000
330 bool sel = isSelected(); 335 bool sel = isSelected();
331#else 336#else
332 bool sel = selected(); 337 bool sel = selected();
333#endif 338#endif
334 int heihei = height( listBox () ); 339 int heihei = height( listBox () );
335 int x = 1; 340 int x = 1;
336 if (KOPrefs::instance()->mMonthViewUsesCategoryColor || mDisplayHighlighted || sel ) 341 if (KOPrefs::instance()->mMonthViewUsesCategoryColor || mDisplayHighlighted || sel )
337 { 342 {
338 343
339 p->setBackgroundColor( palette().color( QPalette::Normal, \ 344 p->setBackgroundColor( palette().color( QPalette::Normal, \
340 sel ||mDisplayHighlighted ? QColorGroup::Highlight : QColorGroup::Background ) ); 345 sel ||mDisplayHighlighted ? QColorGroup::Highlight : QColorGroup::Background ) );
341 p->eraseRect( 0, 0, listBox()->maxItemWidth(), heihei ); 346 p->eraseRect( 0, 0, listBox()->maxItemWidth(), heihei );
342 } 347 }
343 348
344 //int y = 3;//(height() - mRecurPixmap.height()) /2; 349 //int y = 3;//(height() - mRecurPixmap.height()) /2;
345 int size = PIXMAP_SIZE; 350 int size = PIXMAP_SIZE;
346 if ( QApplication::desktop()->width() < 300 ) 351 if ( QApplication::desktop()->width() < 300 )
347 size = 3; 352 size = 3;
348 int y = (heihei - size -1 ) /2; 353 int y = (heihei - size -1 ) /2;
349 354
350 if ( mIncidence->calID() > 1 ) { 355 if ( mIncidence->calID() > 1 ) {
351 p->fillRect ( x, y-2,size,size+4, KOPrefs::instance()->defaultColor( mIncidence->calID() ) ); 356 p->fillRect ( x, y-2,size,size+4, KOPrefs::instance()->defaultColor( mIncidence->calID() ) );
352 p->drawRect ( x, y-2,size,size+4); 357 p->drawRect ( x, y-2,size,size+4);
353 x += size + 1; 358 x += size + 1;
354 } 359 }
355 if ( KOPrefs::instance()->mMonthShowIcons ) { 360 if ( KOPrefs::instance()->mMonthShowIcons ) {
356 if ( mInfo ) { 361 if ( mInfo ) {
357 p->fillRect ( x, y,size,size, Qt::darkGreen ); 362 p->fillRect ( x, y,size,size, Qt::darkGreen );
358 x += size + 1; 363 x += size + 1;
359 } 364 }
360 if ( mRecur ) { 365 if ( mRecur ) {
361 p->fillRect ( x, y,size,size, Qt::blue ); 366 p->fillRect ( x, y,size,size, Qt::blue );
362 x += size + 1; 367 x += size + 1;
363 } 368 }
364 if ( mAlarm ) { 369 if ( mAlarm ) {
365 p->fillRect ( x, y,size,size, Qt::red ); 370 p->fillRect ( x, y,size,size, Qt::red );
366 x += size + 1; 371 x += size + 1;
367 } 372 }
368 if ( mReply ) { 373 if ( mReply ) {
369 p->fillRect ( x, y,size,size, Qt::yellow ); 374 p->fillRect ( x, y,size,size, Qt::yellow );
370 x += size + 1; 375 x += size + 1;
371 } 376 }
372 } 377 }
373 378
374 379
375 380
376 381
377 if ( sel ) p->setPen( Qt::white ); 382 if ( sel ) p->setPen( Qt::white );
378 else p->setPen( palette().color( QPalette::Normal,QColorGroup::Foreground ) ); 383 else p->setPen( palette().color( QPalette::Normal,QColorGroup::Foreground ) );
379 384
380#if 0 385#if 0
381 p->setPen( palette().color( QPalette::Normal, sel ? \ 386 p->setPen( palette().color( QPalette::Normal, sel ? \
382 QColorGroup::HighlightedText : QColorGroup::Foreground ) ); 387 QColorGroup::HighlightedText : QColorGroup::Foreground ) );
383#endif 388#endif
384 QColor textColor = p->pen().color(); 389 QColor textColor = p->pen().color();
385 390
386 391
387 if ( mMultiday ) { 392 if ( mMultiday ) {
388 int yyy = y+(size/2); 393 int yyy = y+(size/2);
389 int sizeM = size+2; 394 int sizeM = size+2;
390 p->setBrush( QBrush( textColor ) ); 395 p->setBrush( QBrush( textColor ) );
391 p->drawLine ( x+1, yyy, x +sizeM +sizeM/2-1, yyy ) ; 396 p->drawLine ( x+1, yyy, x +sizeM +sizeM/2-1, yyy ) ;
392 if ( mMultiday == 2 || mMultiday == 3 ) { 397 if ( mMultiday == 2 || mMultiday == 3 ) {
393 QPointArray pa ( 3 ); 398 QPointArray pa ( 3 );
394 pa.setPoint (0, x, yyy ); 399 pa.setPoint (0, x, yyy );
395 pa.setPoint (1, x+sizeM/2, yyy+sizeM/2 ); 400 pa.setPoint (1, x+sizeM/2, yyy+sizeM/2 );
396 pa.setPoint (2, x+sizeM/2, yyy-sizeM/2 ); 401 pa.setPoint (2, x+sizeM/2, yyy-sizeM/2 );
397 p->drawPolygon( pa ); 402 p->drawPolygon( pa );
398 } 403 }
399 if ( mMultiday == 2 || mMultiday == 1 ) { 404 if ( mMultiday == 2 || mMultiday == 1 ) {
400 QPointArray pa ( 3 ); 405 QPointArray pa ( 3 );
401 pa.setPoint (0, x+sizeM +sizeM/2, yyy ); 406 pa.setPoint (0, x+sizeM +sizeM/2, yyy );
402 pa.setPoint (1, x+sizeM, yyy+sizeM/2 ); 407 pa.setPoint (1, x+sizeM, yyy+sizeM/2 );
403 pa.setPoint (2, x+sizeM, yyy-sizeM/2 ); 408 pa.setPoint (2, x+sizeM, yyy-sizeM/2 );
404 p->drawPolygon( pa ); 409 p->drawPolygon( pa );
405 } 410 }
406 if ( mMultiday == 1 ) { 411 if ( mMultiday == 1 ) {
407 // p->fillRect ( x, yyy-sizeM/2+1, sizeM/2, size, QBrush ( QBrush::SolidPattern ) ); 412 // p->fillRect ( x, yyy-sizeM/2+1, sizeM/2, size, QBrush ( QBrush::SolidPattern ) );
408 p->drawLine ( x+1, yyy-sizeM/2, x+1, yyy+sizeM/2 ); 413 p->drawLine ( x+1, yyy-sizeM/2, x+1, yyy+sizeM/2 );
409 } 414 }
410 if ( mMultiday == 3 ) { 415 if ( mMultiday == 3 ) {
411 // p->fillRect ( x+sizeM, yyy-sizeM/2+1, sizeM/2, size, QBrush ( QBrush::SolidPattern ) ); 416 // p->fillRect ( x+sizeM, yyy-sizeM/2+1, sizeM/2, size, QBrush ( QBrush::SolidPattern ) );
412 p->drawLine ( x+sizeM +sizeM/2-1, yyy-sizeM/2, x+sizeM +sizeM/2-1, yyy+sizeM/2 ); 417 p->drawLine ( x+sizeM +sizeM/2-1, yyy-sizeM/2, x+sizeM +sizeM/2-1, yyy+sizeM/2 );
413 418
414 } 419 }
415 x += sizeM/2 + 1; 420 x += sizeM/2 + 1;
416 x += sizeM + 1; 421 x += sizeM + 1;
417 } 422 }
418 423
419 if ( mIncidence->typeID() == todoID ){ 424 if ( mIncidence->typeID() == todoID ){
420 Todo* td = ( Todo* ) mIncidence; 425 Todo* td = ( Todo* ) mIncidence;
421 if ( td->isCompleted() ) { 426 if ( td->isCompleted() ) {
422 int half = size/2; 427 int half = size/2;
423 p->drawLine ( x, heihei/2, x +half , heihei/2 +half ) ; 428 p->drawLine ( x, heihei/2, x +half , heihei/2 +half ) ;
424 p->drawLine ( x +half , heihei/2 +half , x +half+half +2 , heihei/2 -2 ) ; 429 p->drawLine ( x +half , heihei/2 +half , x +half+half +2 , heihei/2 -2 ) ;
425 x += half+half + 4; 430 x += half+half + 4;
426 431
427 } else { 432 } else {
428 int val = td->percentComplete()/20; 433 int val = td->percentComplete()/20;
429 p->fillRect ( x+1, y-2, val ,size+4,textColor ); 434 p->fillRect ( x+1, y-2, val ,size+4,textColor );
430 p->drawRect ( x, y-2,7,size+4); 435 p->drawRect ( x, y-2,7,size+4);
431 x += size + 3; 436 x += size + 3;
432 } 437 }
433 } 438 }
434 QFontMetrics fm = p->fontMetrics(); 439 QFontMetrics fm = p->fontMetrics();
435 int yPos; 440 int yPos;
436 int pmheight = size; 441 int pmheight = size;
437 if( pmheight < fm.height() ) 442 if( pmheight < fm.height() )
438 yPos = fm.ascent() + fm.leading()/2; 443 yPos = fm.ascent() + fm.leading()/2;
439 else 444 else
440 yPos = pmheight/2 - fm.height()/2 + fm.ascent(); 445 yPos = pmheight/2 - fm.height()/2 + fm.ascent();
441 446
442 if ( KOPrefs::instance()->mMonthShowTimes || isWeekItem) { 447 if ( KOPrefs::instance()->mMonthShowTimes || isWeekItem) {
443 p->drawText( x, yPos, text() ); 448 p->drawText( x, yPos, text() );
444 if ( mIncidence->cancelled() ) { 449 if ( mIncidence->cancelled() ) {
445 int wid = fm.width( text() ); 450 int wid = fm.width( text() );
446 p->drawLine( x, heihei/2 ,x+wid, heihei/2 ); 451 p->drawLine( x, heihei/2 ,x+wid, heihei/2 );
447 } 452 }
448 } else { 453 } else {
449 QString pText = text(); 454 QString pText = text();
450 if( pText.mid(2,1) == ":" ) 455 if( pText.mid(2,1) == ":" )
451 pText = pText.mid( 6 ); 456 pText = pText.mid( 6 );
452 p->drawText( x, yPos, pText ); 457 p->drawText( x, yPos, pText );
453 if ( mIncidence->cancelled() ) { 458 if ( mIncidence->cancelled() ) {
454 int wid = fm.width( pText ); 459 int wid = fm.width( pText );
455 p->drawLine( x, heihei/2 ,x+wid, heihei/2 ); 460 p->drawLine( x, heihei/2 ,x+wid, heihei/2 );
456 } 461 }
457 } 462 }
458} 463}
459 464
460int MonthViewItem::height(const QListBox *lb) const 465int MonthViewItem::height(const QListBox *lb) const
461{ 466{
462 int ret = 10; 467 int ret = 10;
463 if ( lb ) 468 if ( lb )
464 ret = lb->fontMetrics().lineSpacing()+1; 469 ret = lb->fontMetrics().lineSpacing()+1;
465 return ret; 470 return ret;
466} 471}
467 472
468int MonthViewItem::width(const QListBox *lb) const 473int MonthViewItem::width(const QListBox *lb) const
469{ 474{
470 if( KOPrefs::instance()->mEnableMonthScroll || isWeekItem ) { 475 if( KOPrefs::instance()->mEnableMonthScroll || isWeekItem ) {
471 int size = PIXMAP_SIZE; 476 int size = PIXMAP_SIZE;
472 if ( QApplication::desktop()->width() < 300 ) 477 if ( QApplication::desktop()->width() < 300 )
473 size = 3; 478 size = 3;
474 int x = 1; 479 int x = 1;
475 if ( KOPrefs::instance()->mMonthShowIcons ) { 480 if ( KOPrefs::instance()->mMonthShowIcons ) {
476 if ( mInfo ) { 481 if ( mInfo ) {
477 x += size + 1; 482 x += size + 1;
478 } 483 }
479 if( mRecur ) { 484 if( mRecur ) {
480 x += size+1; 485 x += size+1;
481 } 486 }
482 if( mAlarm ) { 487 if( mAlarm ) {
483 x += size+1; 488 x += size+1;
484 } 489 }
485 if( mReply ) { 490 if( mReply ) {
486 x += size+1; 491 x += size+1;
487 } 492 }
488 } 493 }
489 if( mMultiday ) { 494 if( mMultiday ) {
490 x += size+1+2+size/2; 495 x += size+1+2+size/2;
491 } 496 }
492 return( x + lb->fontMetrics().width( text() ) + 1 ); 497 return( x + lb->fontMetrics().width( text() ) + 1 );
493 } 498 }
494 if ( ! lb ) 499 if ( ! lb )
495 return 10; 500 return 10;
496 return lb->width(); 501 return lb->width();
497} 502}
498 503
499 504
500MonthViewCell::MonthViewCell( KOMonthView *parent,QWidget* par ) 505MonthViewCell::MonthViewCell( KOMonthView *parent,QWidget* par )
501 : KNoScrollListBox( par ), 506 : KNoScrollListBox( par ),
502 mMonthView( parent ) 507 mMonthView( parent )
503{ 508{
504 //QVBoxLayout *topLayout = new QVBoxLayout( this ); 509 //QVBoxLayout *topLayout = new QVBoxLayout( this );
505 currentPalette = 0; 510 currentPalette = 0;
506 // mLabel = new QLabel( this );QPushButton 511 // mLabel = new QLabel( this );QPushButton
507 mLabel = new QPushButton( this ); 512 mLabel = new QPushButton( this );
508 //mLabel->setFrameStyle( QFrame::Panel | QFrame::Plain ); 513 //mLabel->setFrameStyle( QFrame::Panel | QFrame::Plain );
509 //mLabel->setLineWidth( 1 ); 514 //mLabel->setLineWidth( 1 );
510 //mLabel->setAlignment( AlignCenter ); 515 //mLabel->setAlignment( AlignCenter );
511 mLabel->setFlat( true ); 516 mLabel->setFlat( true );
512 mLabel->setFocusPolicy(NoFocus); 517 mLabel->setFocusPolicy(NoFocus);
513 //mItemList = new KNoScrollListBox( this ); 518 //mItemList = new KNoScrollListBox( this );
514 setMinimumSize( 10, 10 ); 519 setMinimumSize( 10, 10 );
515 setFrameStyle( QFrame::Panel | QFrame::Plain ); 520 setFrameStyle( QFrame::Panel | QFrame::Plain );
516 setLineWidth( 1 ); 521 setLineWidth( 1 );
517 //topLayout->addWidget( mItemList ); 522 //topLayout->addWidget( mItemList );
518 mLabel->raise(); 523 mLabel->raise();
519 // QColor( 0,0,255 ) QColor( 160,1600,255 ) 524 // QColor( 0,0,255 ) QColor( 160,1600,255 )
520 mStandardPalette = palette(); 525 mStandardPalette = palette();
521 mStandardPalette.setColor(QColorGroup::Base, mStandardPalette.color( QPalette::Normal, QColorGroup::Background ) ); 526 mStandardPalette.setColor(QColorGroup::Base, mStandardPalette.color( QPalette::Normal, QColorGroup::Background ) );
522 527
523 enableScrollBars( false ); 528 enableScrollBars( false );
524 updateConfig(); 529 updateConfig();
525 //connect( mLabel, SIGNAL( clicked( )), SLOT( newEvent() )); 530 //connect( mLabel, SIGNAL( clicked( )), SLOT( newEvent() ));
526 connect( mLabel, SIGNAL( clicked( )), SLOT( showDay() )); 531 connect( mLabel, SIGNAL( clicked( )), SLOT( showDay() ));
527 connect( this , SIGNAL( doubleClicked( QListBoxItem *) ), 532 connect( this , SIGNAL( doubleClicked( QListBoxItem *) ),
528 SLOT( defaultAction( QListBoxItem * ) ) ); 533 SLOT( defaultAction( QListBoxItem * ) ) );
529 connect( this, SIGNAL( rightButtonPressed( QListBoxItem *, 534 connect( this, SIGNAL( rightButtonPressed( QListBoxItem *,
530 const QPoint &) ), 535 const QPoint &) ),
531 SLOT( contextMenu( QListBoxItem * ) ) ); 536 SLOT( contextMenu( QListBoxItem * ) ) );
532 connect( this, SIGNAL( highlighted( QListBoxItem *) ), 537 connect( this, SIGNAL( highlighted( QListBoxItem *) ),
533 SLOT( selection( QListBoxItem * ) ) ); 538 SLOT( selection( QListBoxItem * ) ) );
534 539
535 /* 540 /*
536 connect( this, SIGNAL( clicked( QListBoxItem * ) ), 541 connect( this, SIGNAL( clicked( QListBoxItem * ) ),
537 SLOT( selection( QListBoxItem * ) ) ); 542 SLOT( selection( QListBoxItem * ) ) );
538 */ 543 */
539} 544}
540#ifdef DESKTOP_VERSION 545#ifdef DESKTOP_VERSION
541QToolTipGroup *MonthViewCell::toolTipGroup() 546QToolTipGroup *MonthViewCell::toolTipGroup()
542{ 547{
543 if (!mToolTipGroup) mToolTipGroup = new QToolTipGroup(0); 548 if (!mToolTipGroup) mToolTipGroup = new QToolTipGroup(0);
544 return mToolTipGroup; 549 return mToolTipGroup;
545} 550}
546#endif 551#endif
547 552
548void MonthViewCell::setDate( const QDate &date ) 553void MonthViewCell::setDate( const QDate &date )
549{ 554{
550 // kdDebug() << "MonthViewCell::setDate(): " << date.toString() << endl; 555 // kdDebug() << "MonthViewCell::setDate(): " << date.toString() << endl;
551 mDate = date; 556 mDate = date;
552 557
553 558
554 559
555 //resizeEvent( 0 ); 560 //resizeEvent( 0 );
556} 561}
557 562
558QDate MonthViewCell::date() const 563QDate MonthViewCell::date() const
559{ 564{
560 return mDate; 565 return mDate;
561} 566}
562 567
563void MonthViewCell::setPrimary( bool primary ) 568void MonthViewCell::setPrimary( bool primary )
564{ 569{
565 mPrimary = primary; 570 mPrimary = primary;
566 //setMyPalette(); 571 //setMyPalette();
567} 572}
568void MonthViewCell::setMyPalette() 573void MonthViewCell::setMyPalette()
569{ 574{
570 575
571 if ( mHoliday) { 576 if ( mHoliday) {
572 if ( currentPalette == 1 ) return; 577 if ( currentPalette == 1 ) return;
573 mLabel->setPalette( QPalette ( mHolidayPalette.color( QPalette::Normal,QColorGroup::Base),mHolidayPalette.color(QPalette::Normal,QColorGroup::Base ) )); 578 mLabel->setPalette( QPalette ( mHolidayPalette.color( QPalette::Normal,QColorGroup::Base),mHolidayPalette.color(QPalette::Normal,QColorGroup::Base ) ));
574 setPalette( mHolidayPalette ); 579 setPalette( mHolidayPalette );
575 //mLabel->setPalette( mHolidayPalette ); 580 //mLabel->setPalette( mHolidayPalette );
576 currentPalette = 1; 581 currentPalette = 1;
577 582
578 } else { 583 } else {
579 if ( mPrimary ) { 584 if ( mPrimary ) {
580 if ( currentPalette == 2 ) return; 585 if ( currentPalette == 2 ) return;
581 mLabel->setPalette( QPalette ( mPrimaryPalette.color( QPalette::Normal,QColorGroup::Base),mPrimaryPalette.color(QPalette::Normal,QColorGroup::Base ) )); 586 mLabel->setPalette( QPalette ( mPrimaryPalette.color( QPalette::Normal,QColorGroup::Base),mPrimaryPalette.color(QPalette::Normal,QColorGroup::Base ) ));
582 //mLabel->setPalette( mPrimaryPalette ); 587 //mLabel->setPalette( mPrimaryPalette );
583 setPalette( mPrimaryPalette ); 588 setPalette( mPrimaryPalette );
584 currentPalette = 2; 589 currentPalette = 2;
585 590
586 } else { 591 } else {
587 if ( currentPalette == 3 ) return; 592 if ( currentPalette == 3 ) return;
588 setPalette( mNonPrimaryPalette ); 593 setPalette( mNonPrimaryPalette );
589 mLabel->setPalette( QPalette ( mNonPrimaryPalette.color( QPalette::Normal,QColorGroup::Base),mNonPrimaryPalette.color(QPalette::Normal,QColorGroup::Base ) )); 594 mLabel->setPalette( QPalette ( mNonPrimaryPalette.color( QPalette::Normal,QColorGroup::Base),mNonPrimaryPalette.color(QPalette::Normal,QColorGroup::Base ) ));
590 //mLabel->setPalette( mNonPrimaryPalette );; 595 //mLabel->setPalette( mNonPrimaryPalette );;
591 currentPalette = 3; 596 currentPalette = 3;
592 } 597 }
593 } 598 }
594 //QPalette pal = palette(); 599 //QPalette pal = palette();
595 600
596 //mLabel->setPalette( QPalette ( pal.color( QPalette::Normal,QColorGroup::Base),pal.color(QPalette::Normal,QColorGroup::Base ) )); 601 //mLabel->setPalette( QPalette ( pal.color( QPalette::Normal,QColorGroup::Base),pal.color(QPalette::Normal,QColorGroup::Base ) ));
597} 602}
598QPalette MonthViewCell::getPalette () 603QPalette MonthViewCell::getPalette ()
599{ 604{
600 if ( !KOPrefs::instance()->mMonthViewUsesDayColors ) 605 if ( !KOPrefs::instance()->mMonthViewUsesDayColors )
601 return mStandardPalette; 606 return mStandardPalette;
602 if ( mHoliday) { 607 if ( mHoliday) {
603 return mHolidayPalette ; 608 return mHolidayPalette ;
604 } else { 609 } else {
605 if ( mPrimary ) { 610 if ( mPrimary ) {
606 return mPrimaryPalette ; 611 return mPrimaryPalette ;
607 } 612 }
608 } 613 }
609 return mNonPrimaryPalette; 614 return mNonPrimaryPalette;
610} 615}
611bool MonthViewCell::isPrimary() const 616bool MonthViewCell::isPrimary() const
612{ 617{
613 return mPrimary; 618 return mPrimary;
614} 619}
615 620
616void MonthViewCell::setHoliday( bool holiday ) 621void MonthViewCell::setHoliday( bool holiday )
617{ 622{
618 mHoliday = holiday; 623 mHoliday = holiday;
619 //setMyPalette(); 624 //setMyPalette();
620} 625}
621 626
622void MonthViewCell::setHoliday( const QString &holiday ) 627void MonthViewCell::setHoliday( const QString &holiday )
623{ 628{
624 mHolidayString = holiday; 629 mHolidayString = holiday;
625 630
626 if ( !holiday.isEmpty() ) { 631 if ( !holiday.isEmpty() ) {
627 setHoliday( true ); 632 setHoliday( true );
628 } 633 }
629} 634}
630 635
631void MonthViewCell::startUpdateCell() 636void MonthViewCell::startUpdateCell()
632{ 637{
633 blockSignals( true ); 638 blockSignals( true );
634 mdayCount = 0; 639 mdayCount = 0;
635 setFocusPolicy(NoFocus); 640 setFocusPolicy(NoFocus);
636 if ( !mMonthView->isUpdatePossible() ) 641 if ( !mMonthView->isUpdatePossible() )
637 return; 642 return;
638 MonthViewItem *mitem = (MonthViewItem*) firstItem (); 643 MonthViewItem *mitem = (MonthViewItem*) firstItem ();
639 while ( mitem ) { 644 while ( mitem ) {
640 mitem->setBlockRepaint( true ); 645 mitem->setBlockRepaint( true );
641 mitem = (MonthViewItem *)mitem->next(); 646 mitem = (MonthViewItem *)mitem->next();
642 } 647 }
643 if ( mAvailItemList.count() > 20 ) { 648 if ( mAvailItemList.count() > 20 ) {
644 mAvailItemList.setAutoDelete( true ); 649 mAvailItemList.setAutoDelete( true );
645 mAvailItemList.clear(); 650 mAvailItemList.clear();
646 mAvailItemList.setAutoDelete( false ); 651 mAvailItemList.setAutoDelete( false );
647 clear(); 652 clear();
648 } 653 }
649 654
650 setPrimary( mDate.month()%2 ); 655 setPrimary( mDate.month()%2 );
651 setHoliday( KOGlobals::self()->calendarSystem()->dayOfWeek(mDate) == KOGlobals::self()->calendarSystem()->weekDayOfPray() || ( mDate.dayOfWeek() == 6 ) && KOPrefs::instance()-> mExcludeSaturdays); 656 setHoliday( KOGlobals::self()->calendarSystem()->dayOfWeek(mDate) == KOGlobals::self()->calendarSystem()->weekDayOfPray() || ( mDate.dayOfWeek() == 6 ) && KOPrefs::instance()-> mExcludeSaturdays);
652 if ( mDate == QDate::currentDate() ) { 657 if ( mDate == QDate::currentDate() ) {
653 setLineWidth( 3 ); 658 setLineWidth( 3 );
654 } else { 659 } else {
655 setLineWidth( 1 ); 660 setLineWidth( 1 );
656 } 661 }
657 MonthViewItem* CurrentAvailItem = (MonthViewItem*) firstItem (); 662 MonthViewItem* CurrentAvailItem = (MonthViewItem*) firstItem ();
658 //clear(); 663 //clear();
659 while ( CurrentAvailItem ) { 664 while ( CurrentAvailItem ) {
660 MonthViewItem *item = CurrentAvailItem; 665 MonthViewItem *item = CurrentAvailItem;
661 //item->setHighlightedFalse(); 666 //item->setHighlightedFalse();
662 item->recycle( 0, ""); 667 item->recycle( 0, "");
663 CurrentAvailItem = (MonthViewItem *)item->next(); 668 CurrentAvailItem = (MonthViewItem *)item->next();
664 mAvailItemList.append( item ); 669 mAvailItemList.append( item );
665 takeItem ( item ); 670 takeItem ( item );
666 } 671 }
667 672
668#ifdef DESKTOP_VERSION 673#ifdef DESKTOP_VERSION
669 QToolTip::remove(this); 674 QToolTip::remove(this);
670#endif 675#endif
671 mToolTip.clear(); 676 mToolTip.clear();
672 //qApp->processEvents(); 677 //qApp->processEvents();
673#if 0 678#if 0
674 if ( !mHolidayString.isEmpty() ) { 679 if ( !mHolidayString.isEmpty() ) {
675 MonthViewItem *item = new MonthViewItem( 0, mDate, mHolidayString ); 680 MonthViewItem *item = new MonthViewItem( 0, mDate, mHolidayString );
676 item->setPalette( mHolidayPalette ); 681 item->setPalette( mHolidayPalette );
677 insertItem( item ); 682 insertItem( item );
678 mToolTip.append ( mHolidayString ); 683 mToolTip.append ( mHolidayString );
679 } 684 }
680#endif 685#endif
681} 686}
682 687
683int MonthViewCell::insertEvent(Event *event) 688int MonthViewCell::insertEvent(Event *event)
684{ 689{
685 bool useToolTips = true; 690 bool useToolTips = true;
686#ifndef DESKTOP_VERSION 691#ifndef DESKTOP_VERSION
687 useToolTips = false; 692 useToolTips = false;
688#endif 693#endif
689 QString mToolTipText; 694 QString mToolTipText;
690 setFocusPolicy(WheelFocus); 695 setFocusPolicy(WheelFocus);
691 if ( !(event->doesRecur() == Recurrence::rNone) ) { 696 if ( !(event->doesRecur() == Recurrence::rNone) ) {
692 if ( !KOPrefs::instance()->mMonthDailyRecur && event->doesRecur() == Recurrence::rDaily ) 697 if ( !KOPrefs::instance()->mMonthDailyRecur && event->doesRecur() == Recurrence::rDaily )
693 return mdayCount; 698 return mdayCount;
694 else 699 else
695 if ( !KOPrefs::instance()->mMonthWeeklyRecur && event->doesRecur() == Recurrence::rWeekly ) 700 if ( !KOPrefs::instance()->mMonthWeeklyRecur && event->doesRecur() == Recurrence::rWeekly )
696 return mdayCount; 701 return mdayCount;
697 } 702 }
698 703
699 if ( event->isHoliday()) { 704 if ( event->isHoliday()) {
700 setHoliday( true ); 705 setHoliday( true );
701 if ( mDate.dayOfWeek() == 7 ) 706 if ( mDate.dayOfWeek() == 7 )
702 setLineWidth( 3 ); 707 setLineWidth( 3 );
703 } 708 }
704 QString text; 709 QString text;
705 int multiday = 0;// 1 = start, 2 = midddle, 3 = end day 710 int multiday = 0;// 1 = start, 2 = midddle, 3 = end day
706 if (event->isMultiDay()) { 711 if (event->isMultiDay()) {
707 QString prefix = "<->";multiday = 2; 712 QString prefix = "<->";multiday = 2;
708 QString time; 713 QString time;
709 if ( event->doesRecur() ) { 714 if ( event->doesRecur() ) {
710 if ( event->recursOn( mDate) ) { 715 if ( event->recursOn( mDate) ) {
711 prefix ="->" ;multiday = 1; 716 prefix ="->" ;multiday = 1;
712 } 717 }
713 else { 718 else {
714 int days = event->dtStart().date().daysTo ( event->dtEnd().date() ); 719 int days = event->dtStart().date().daysTo ( event->dtEnd().date() );
715 if ( event->recursOn( mDate.addDays( -days)) ) { 720 if ( event->recursOn( mDate.addDays( -days)) ) {
716 prefix ="<-" ;multiday = 3; 721 prefix ="<-" ;multiday = 3;
717 } 722 }
718 } 723 }
719 724
720 } else { 725 } else {
721 if (mDate == event->dtStart().date()) { 726 if (mDate == event->dtStart().date()) {
722 prefix ="->" ;multiday = 1; 727 prefix ="->" ;multiday = 1;
723 } else if (mDate == event->dtEnd().date()) { 728 } else if (mDate == event->dtEnd().date()) {
724 prefix ="<-" ;multiday = 3; 729 prefix ="<-" ;multiday = 3;
725 } 730 }
726 } 731 }
727 if ( !event->doesFloat() ) { 732 if ( !event->doesFloat() ) {
728 if ( mDate == event->dtStart().date () ) 733 if ( mDate == event->dtStart().date () )
729 time = KGlobal::locale()->formatTime(event->dtStart().time())+" "; 734 time = KGlobal::locale()->formatTime(event->dtStart().time())+" ";
730 else if ( mDate == event->dtEnd().date () ) 735 else if ( mDate == event->dtEnd().date () )
731 time = KGlobal::locale()->formatTime(event->dtEnd().time())+" "; 736 time = KGlobal::locale()->formatTime(event->dtEnd().time())+" ";
732 737
733 } 738 }
734 text = time + event->summary(); 739 text = time + event->summary();
735 if ( useToolTips ) 740 if ( useToolTips )
736 mToolTipText += prefix + text; 741 mToolTipText += prefix + text;
737 } else { 742 } else {
738 if (event->doesFloat()) { 743 if (event->doesFloat()) {
739 text = event->summary(); 744 text = event->summary();
740 if ( useToolTips ) 745 if ( useToolTips )
741 mToolTipText += text; 746 mToolTipText += text;
742 } 747 }
743 else { 748 else {
744 text = KGlobal::locale()->formatTime(event->dtStart().time()); 749 text = KGlobal::locale()->formatTime(event->dtStart().time());
745 text += " " + event->summary(); 750 text += " " + event->summary();
746 if ( useToolTips ) 751 if ( useToolTips )
747 mToolTipText += KGlobal::locale()->formatTime(event->dtStart().time()) +"-"+KGlobal::locale()->formatTime(event->dtEnd().time())+" " + event->summary(); 752 mToolTipText += KGlobal::locale()->formatTime(event->dtStart().time()) +"-"+KGlobal::locale()->formatTime(event->dtEnd().time())+" " + event->summary();
748 } 753 }
749 } 754 }
750 if ( useToolTips && ! event->location().isEmpty() ) { 755 if ( useToolTips && ! event->location().isEmpty() ) {
751 mToolTipText += " (" + event->location() +")"; 756 mToolTipText += " (" + event->location() +")";
752 } 757 }
753 MonthViewItem *item ; 758 MonthViewItem *item ;
754 759
755 if ( mAvailItemList.count() ) { 760 if ( mAvailItemList.count() ) {
756 item = mAvailItemList.first(); 761 item = mAvailItemList.first();
757 mAvailItemList.remove( item ); 762 mAvailItemList.remove( item );
758 item->recycle( event, text ); 763 item->recycle( event, text );
759 } else { 764 } else {
760 item = new MonthViewItem( event, text ); 765 item = new MonthViewItem( event, text );
761 } 766 }
762 767
763 QPalette pal; 768 QPalette pal;
764 if (KOPrefs::instance()->mMonthViewUsesCategoryColor) { 769 if (KOPrefs::instance()->mMonthViewUsesCategoryColor) {
765 QStringList categories = event->categories(); 770 QStringList categories = event->categories();
766 QString cat = categories.first(); 771 QString cat = categories.first();
767 if ( KOPrefs::instance()->mMonthViewUsesForegroundColor ) { 772 if ( KOPrefs::instance()->mMonthViewUsesForegroundColor ) {
768 pal = getPalette(); 773 pal = getPalette();
769 if (cat.isEmpty()) { 774 if (cat.isEmpty()) {
770 //pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->mEventColor); 775 //pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->mEventColor);
771 pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->defaultColor( event->calID() )); 776 pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->defaultColor( event->calID() ));
772 } else { 777 } else {
773 pal.setColor(QColorGroup::Foreground, *(KOPrefs::instance()->categoryColor(cat))); 778 pal.setColor(QColorGroup::Foreground, *(KOPrefs::instance()->categoryColor(cat)));
774 } 779 }
775 780
776 } else { 781 } else {
777 if (cat.isEmpty()) { 782 if (cat.isEmpty()) {
778 //pal = QPalette(KOPrefs::instance()->mEventColor, KOPrefs::instance()->mEventColor); 783 //pal = QPalette(KOPrefs::instance()->mEventColor, KOPrefs::instance()->mEventColor);
779 pal = QPalette( KOPrefs::instance()->defaultColor( event->calID() ), KOPrefs::instance()->defaultColor( event->calID() )); 784 pal = QPalette( KOPrefs::instance()->defaultColor( event->calID() ), KOPrefs::instance()->defaultColor( event->calID() ));
780 } else { 785 } else {
781 pal = QPalette(*(KOPrefs::instance()->categoryColor(cat)), *(KOPrefs::instance()->categoryColor(cat))); 786 pal = QPalette(*(KOPrefs::instance()->categoryColor(cat)), *(KOPrefs::instance()->categoryColor(cat)));
782 } 787 }
783 } 788 }
784 789
785 } else { 790 } else {
786 pal = mStandardPalette ; 791 pal = mStandardPalette ;
787 } 792 }
788 pal.setColor(QColorGroup::Highlight, KOPrefs::instance()->mHighlightColor); 793 pal.setColor(QColorGroup::Highlight, KOPrefs::instance()->mHighlightColor);
789 item->setPalette( pal ); 794 item->setPalette( pal );
790 item->setRecur( event->doesRecur() ); 795 item->setRecur( event->doesRecur() );
791 item->setAlarm( event->isAlarmEnabled() && multiday < 2 && event->alarmEnabled() ); 796 item->setAlarm( event->isAlarmEnabled() && multiday < 2 && event->alarmEnabled() );
792 item->setMoreInfo( event->description().length() > 0 ); 797 item->setMoreInfo( event->description().length() > 0 );
793#ifdef DESKTOP_VERSION 798#ifdef DESKTOP_VERSION
794 Attendee *me = event->attendeeByMails(KOPrefs::instance()->mAdditionalMails, 799 Attendee *me = event->attendeeByMails(KOPrefs::instance()->mAdditionalMails,
795 KOPrefs::instance()->email()); 800 KOPrefs::instance()->email());
796 if ( me != 0 ) { 801 if ( me != 0 ) {
797 if ( me->status() == Attendee::NeedsAction && me->RSVP()) 802 if ( me->status() == Attendee::NeedsAction && me->RSVP())
798 item->setReply(true && multiday < 2); 803 item->setReply(true && multiday < 2);
799 else 804 else
800 item->setReply(false); 805 item->setReply(false);
801 } else 806 } else
802 item->setReply(false); 807 item->setReply(false);
803#endif 808#endif
804 809
805 item->setMultiDay( multiday ); 810 item->setMultiDay( multiday );
806 if ( multiday ) { 811 if ( multiday ) {
807 insertItem( item ,mdayCount); 812 insertItem( item ,mdayCount);
808 ++mdayCount; 813 ++mdayCount;
809 } else { 814 } else {
810 uint i = mdayCount; 815 uint i = mdayCount;
811 uint pos = mdayCount; 816 uint pos = mdayCount;
812 uint itcount = count(); 817 uint itcount = count();
813 if ( itcount > 1000 ) { 818 if ( itcount > 1000 ) {
814 qDebug("KO: Bug in MonthViewCell::insertEvent %u ", itcount); 819 qDebug("KO: Bug in MonthViewCell::insertEvent %u ", itcount);
815 itcount = 0; 820 itcount = 0;
816 } 821 }
817 for ( i = pos; i < itcount;++i ) { 822 for ( i = pos; i < itcount;++i ) {
818 // qDebug("i %d mday %u count %d ",i,itcount,mdayCount ); 823 // qDebug("i %d mday %u count %d ",i,itcount,mdayCount );
819 QListBoxItem* it = this->item ( i ); 824 QListBoxItem* it = this->item ( i );
820 if ( it && text < it->text() ) { 825 if ( it && text < it->text() ) {
821 pos = i; 826 pos = i;
822 break; 827 break;
823 } 828 }
824 ++pos; 829 ++pos;
825 } 830 }
826 insertItem( item ,pos); 831 insertItem( item ,pos);
827 } 832 }
828 if ( useToolTips ) { 833 if ( useToolTips ) {
829 mToolTip.append( mToolTipText ); 834 mToolTip.append( mToolTipText );
830 } 835 }
831 return mdayCount; 836 return mdayCount;
832} 837}
833void MonthViewCell::insertTodo(Todo *todo) 838void MonthViewCell::insertTodo(Todo *todo)
834{ 839{
835 setFocusPolicy(WheelFocus); 840 setFocusPolicy(WheelFocus);
836 QString text; 841 QString text;
837 if (todo->hasDueDate()) { 842 if (todo->hasDueDate()) {
838 if (!todo->doesFloat()) { 843 if (!todo->doesFloat()) {
839 text += KGlobal::locale()->formatTime(todo->dtDue().time()); 844 text += KGlobal::locale()->formatTime(todo->dtDue().time());
840 text += " "; 845 text += " ";
841 } 846 }
842 } 847 }
843 text += todo->summary(); 848 text += todo->summary();
844 MonthViewItem *item ; 849 MonthViewItem *item ;
845 if ( mAvailItemList.count() ) { 850 if ( mAvailItemList.count() ) {
846 item = mAvailItemList.first(); 851 item = mAvailItemList.first();
847 mAvailItemList.remove( item ); 852 mAvailItemList.remove( item );
848 item->recycle( todo, text ); 853 item->recycle( todo, text );
849 } else { 854 } else {
850 item = new MonthViewItem( todo, text ); 855 item = new MonthViewItem( todo, text );
851 } 856 }
852 //MonthViewItem *item = new MonthViewItem( todo, mDate, text ); 857 //MonthViewItem *item = new MonthViewItem( todo, mDate, text );
853 //item->setPalette( mStandardPalette ); 858 //item->setPalette( mStandardPalette );
854 QPalette pal; 859 QPalette pal;
855 if (KOPrefs::instance()->mMonthViewUsesCategoryColor) { 860 if (KOPrefs::instance()->mMonthViewUsesCategoryColor) {
856 QStringList categories = todo->categories(); 861 QStringList categories = todo->categories();
857 QString cat = categories.first(); 862 QString cat = categories.first();
858 if ( KOPrefs::instance()->mMonthViewUsesForegroundColor ) { 863 if ( KOPrefs::instance()->mMonthViewUsesForegroundColor ) {
859 pal = getPalette(); 864 pal = getPalette();
860 if (cat.isEmpty()) { 865 if (cat.isEmpty()) {
861 //pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->mEventColor); 866 //pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->mEventColor);
862 pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->defaultColor( todo->calID() )); 867 pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->defaultColor( todo->calID() ));
863 } else { 868 } else {
864 pal.setColor(QColorGroup::Foreground, *(KOPrefs::instance()->categoryColor(cat))); 869 pal.setColor(QColorGroup::Foreground, *(KOPrefs::instance()->categoryColor(cat)));
865 } 870 }
866 871
867 } else { 872 } else {
868 if (cat.isEmpty()) { 873 if (cat.isEmpty()) {
869 //pal = QPalette(KOPrefs::instance()->mEventColor, KOPrefs::instance()->mEventColor); 874 //pal = QPalette(KOPrefs::instance()->mEventColor, KOPrefs::instance()->mEventColor);
870 pal = QPalette(KOPrefs::instance()->defaultColor( todo->calID() ), KOPrefs::instance()->defaultColor( todo->calID() )); 875 pal = QPalette(KOPrefs::instance()->defaultColor( todo->calID() ), KOPrefs::instance()->defaultColor( todo->calID() ));
871 } else { 876 } else {
872 pal = QPalette(*(KOPrefs::instance()->categoryColor(cat)), *(KOPrefs::instance()->categoryColor(cat))); 877 pal = QPalette(*(KOPrefs::instance()->categoryColor(cat)), *(KOPrefs::instance()->categoryColor(cat)));
873 } 878 }
874 } 879 }
875 880
876 } else { 881 } else {
877 pal = mStandardPalette ; 882 pal = mStandardPalette ;
878 } 883 }
879 pal.setColor(QColorGroup::Highlight, KOPrefs::instance()->mHighlightColor); 884 pal.setColor(QColorGroup::Highlight, KOPrefs::instance()->mHighlightColor);
880 item->setPalette( pal ); 885 item->setPalette( pal );
881 item->setRecur( todo->doesRecur() ); 886 item->setRecur( todo->doesRecur() );
882 item->setAlarm( todo->isAlarmEnabled() && todo->alarmEnabled() ); 887 item->setAlarm( todo->isAlarmEnabled() && todo->alarmEnabled() );
883 item->setMoreInfo( todo->description().length() > 0 ); 888 item->setMoreInfo( todo->description().length() > 0 );
884 insertItem( item , count()); 889 insertItem( item , count());
885#ifdef DESKTOP_VERSION 890#ifdef DESKTOP_VERSION
886 mToolTip.append( text ); 891 mToolTip.append( text );
887#endif 892#endif
888} 893}
889void MonthViewCell::repaintfinishUpdateCell() 894void MonthViewCell::repaintfinishUpdateCell()
890{ 895{
891 MonthViewItem *mitem = (MonthViewItem*) firstItem (); 896 MonthViewItem *mitem = (MonthViewItem*) firstItem ();
892 while ( mitem ) { 897 while ( mitem ) {
893 mitem->setBlockRepaint( false ); 898 mitem->setBlockRepaint( false );
894 updateItem ( mitem ); 899 updateItem ( mitem );
895 mitem = (MonthViewItem *)mitem->next(); 900 mitem = (MonthViewItem *)mitem->next();
896 } 901 }
897 blockSignals( false ); 902 blockSignals( false );
898} 903}
899void MonthViewCell::finishUpdateCell() 904void MonthViewCell::finishUpdateCell()
900{ 905{
901 906
902 907
903 908
904#ifdef DESKTOP_VERSION 909#ifdef DESKTOP_VERSION
905 if (mToolTip.count() > 0 ) { 910 if (mToolTip.count() > 0 ) {
906 mToolTip.sort(); 911 mToolTip.sort();
907 QToolTip::add(this,mToolTip.join("\n"),toolTipGroup(),""); 912 QToolTip::add(this,mToolTip.join("\n"),toolTipGroup(),"");
908 } 913 }
909#endif 914#endif
910 //sort(); 915 //sort();
911 //setMyPalette(); 916 //setMyPalette();
912 setMyPalette(); 917 setMyPalette();
913 918
914 resizeEvent( 0 ); 919 resizeEvent( 0 );
915 920
916} 921}
917void MonthViewCell::updateCell() 922void MonthViewCell::updateCell()
918{ 923{
919 if ( !mMonthView->isUpdatePossible() ) 924 if ( !mMonthView->isUpdatePossible() )
920 return; 925 return;
921 startUpdateCell(); 926 startUpdateCell();
922 //mLabel->setMaximumWidth( width() - mItemList->lineWidth()*2); 927 //mLabel->setMaximumWidth( width() - mItemList->lineWidth()*2);
923 QPtrList<Event> events = mMonthView->calendar()->events( mDate, true ); 928 QPtrList<Event> events = mMonthView->calendar()->events( mDate, true );
924 Event *event; 929 Event *event;
925 for( event = events.first(); event; event = events.next() ) { // for event 930 for( event = events.first(); event; event = events.next() ) { // for event
926 insertEvent(event); 931 insertEvent(event);
927 } 932 }
928 // insert due todos 933 // insert due todos
929 QPtrList<Todo> todos = mMonthView->calendar()->todos( mDate ); 934 QPtrList<Todo> todos = mMonthView->calendar()->todos( mDate );
930 Todo *todo; 935 Todo *todo;
931 for(todo = todos.first(); todo; todo = todos.next()) { 936 for(todo = todos.first(); todo; todo = todos.next()) {
932 insertTodo( todo ); 937 insertTodo( todo );
933 } 938 }
934 finishUpdateCell(); 939 finishUpdateCell();
935 // if ( isVisible()) 940 // if ( isVisible())
936 //qApp->processEvents(); 941 //qApp->processEvents();
937} 942}
938 943
939void MonthViewCell::updateConfig( bool bigFont ) // = false 944void MonthViewCell::updateConfig( bool bigFont ) // = false
940{ 945{
941 946
942 if ( bigFont ) { 947 if ( bigFont ) {
943 QFont fo = KOPrefs::instance()->mMonthViewFont; 948 QFont fo = KOPrefs::instance()->mMonthViewFont;
944 int ps = fo.pointSize() + 2; 949 int ps = fo.pointSize() + 2;
945 if ( ps < 18 ) 950 if ( ps < 18 )
946 ps += 2; 951 ps += 2;
947 fo.setPointSize( ps ); 952 fo.setPointSize( ps );
948 setFont( fo ); 953 setFont( fo );
949 } else 954 } else
950 setFont( KOPrefs::instance()->mMonthViewFont ); 955 setFont( KOPrefs::instance()->mMonthViewFont );
951 956
952 QFontMetrics fm( font() ); 957 QFontMetrics fm( font() );
953 mLabelSize = fm.size( 0, "30" ) + QSize( 4, 2 ); 958 mLabelSize = fm.size( 0, "30" ) + QSize( 4, 2 );
954 mLabelBigSize = fm.size( 0, "Mag 30" ) + QSize( 2, 2 ); 959 mLabelBigSize = fm.size( 0, "Mag 30" ) + QSize( 2, 2 );
955 mHolidayPalette = mStandardPalette; 960 mHolidayPalette = mStandardPalette;
956 mPrimaryPalette = mStandardPalette; 961 mPrimaryPalette = mStandardPalette;
957 mNonPrimaryPalette = mStandardPalette; 962 mNonPrimaryPalette = mStandardPalette;
958 if ( KOPrefs::instance()->mMonthViewUsesDayColors ) { 963 if ( KOPrefs::instance()->mMonthViewUsesDayColors ) {
959 mHolidayPalette.setColor(QColorGroup::Base, KOPrefs::instance()->mMonthViewHolidayColor ); 964 mHolidayPalette.setColor(QColorGroup::Base, KOPrefs::instance()->mMonthViewHolidayColor );
960 mHolidayPalette.setColor(QColorGroup::Background, KOPrefs::instance()->mMonthViewHolidayColor ); 965 mHolidayPalette.setColor(QColorGroup::Background, KOPrefs::instance()->mMonthViewHolidayColor );
961 mHolidayPalette.setColor(QColorGroup::Foreground, KOPrefs::instance()->mMonthViewHolidayColor.dark()); 966 mHolidayPalette.setColor(QColorGroup::Foreground, KOPrefs::instance()->mMonthViewHolidayColor.dark());
962 mPrimaryPalette.setColor(QColorGroup::Foreground,KOPrefs::instance()->mMonthViewOddColor.dark()); 967 mPrimaryPalette.setColor(QColorGroup::Foreground,KOPrefs::instance()->mMonthViewOddColor.dark());
963 mPrimaryPalette.setColor(QColorGroup::Base,KOPrefs::instance()->mMonthViewOddColor); 968 mPrimaryPalette.setColor(QColorGroup::Base,KOPrefs::instance()->mMonthViewOddColor);
964 mPrimaryPalette.setColor(QColorGroup::Background,KOPrefs::instance()->mMonthViewOddColor); 969 mPrimaryPalette.setColor(QColorGroup::Background,KOPrefs::instance()->mMonthViewOddColor);
965 mNonPrimaryPalette.setColor(QColorGroup::Foreground,KOPrefs::instance()->mMonthViewEvenColor.dark()); 970 mNonPrimaryPalette.setColor(QColorGroup::Foreground,KOPrefs::instance()->mMonthViewEvenColor.dark());
966 mNonPrimaryPalette.setColor(QColorGroup::Base,KOPrefs::instance()->mMonthViewEvenColor); 971 mNonPrimaryPalette.setColor(QColorGroup::Base,KOPrefs::instance()->mMonthViewEvenColor);
967 mNonPrimaryPalette.setColor(QColorGroup::Background,KOPrefs::instance()->mMonthViewEvenColor); 972 mNonPrimaryPalette.setColor(QColorGroup::Background,KOPrefs::instance()->mMonthViewEvenColor);
968 } 973 }
969 //updateCell(); 974 //updateCell();
970} 975}
971 976
972void MonthViewCell::enableScrollBars( bool enabled ) 977void MonthViewCell::enableScrollBars( bool enabled )
973{ 978{
974 979
975 return; 980 return;
976 if ( enabled ) { 981 if ( enabled ) {
977 QListBoxItem *fi = firstItem (); 982 QListBoxItem *fi = firstItem ();
978 if (fi ) { 983 if (fi ) {
979 int ihei = fi->height( this ); 984 int ihei = fi->height( this );
980 int hei = numRows () * ihei; 985 int hei = numRows () * ihei;
981 if ( hei < height() - horizontalScrollBar()->height () ) { 986 if ( hei < height() - horizontalScrollBar()->height () ) {
982 setVScrollBarMode(QScrollView::AlwaysOff); 987 setVScrollBarMode(QScrollView::AlwaysOff);
983 } 988 }
984 else 989 else
985 setVScrollBarMode(QScrollView::Auto); 990 setVScrollBarMode(QScrollView::Auto);
986 if ( ihei *3 > height() ) { 991 if ( ihei *3 > height() ) {
987 setHScrollBarMode(QScrollView::AlwaysOff); 992 setHScrollBarMode(QScrollView::AlwaysOff);
988 } 993 }
989 else { 994 else {
990 setHScrollBarMode(QScrollView::Auto); 995 setHScrollBarMode(QScrollView::Auto);
991 } 996 }
992 } else { 997 } else {
993 setVScrollBarMode(QScrollView::Auto); 998 setVScrollBarMode(QScrollView::Auto);
994 setHScrollBarMode(QScrollView::Auto); 999 setHScrollBarMode(QScrollView::Auto);
995 } 1000 }
996 } else { 1001 } else {
997 setVScrollBarMode(QScrollView::AlwaysOff); 1002 setVScrollBarMode(QScrollView::AlwaysOff);
998 setHScrollBarMode(QScrollView::AlwaysOff); 1003 setHScrollBarMode(QScrollView::AlwaysOff);
999 } 1004 }
1000} 1005}
1001 1006
1002Incidence *MonthViewCell::selectedIncidence() 1007Incidence *MonthViewCell::selectedIncidence()
1003{ 1008{
1004 int index = currentItem(); 1009 int index = currentItem();
1005 if ( index < 0 ) return 0; 1010 if ( index < 0 ) return 0;
1006 1011
1007 MonthViewItem *mitem = 1012 MonthViewItem *mitem =
1008 static_cast<MonthViewItem *>( item( index ) ); 1013 static_cast<MonthViewItem *>( item( index ) );
1009 1014
1010 if ( !mitem ) return 0; 1015 if ( !mitem ) return 0;
1011 1016
1012 return mitem->incidence(); 1017 return mitem->incidence();
1013} 1018}
1014 1019
1015QDate MonthViewCell::selectedIncidenceDate() 1020QDate MonthViewCell::selectedIncidenceDate()
1016{ 1021{
1017 QDate qd; 1022 QDate qd;
1018 int index = currentItem(); 1023 int index = currentItem();
1019 if ( index < 0 ) return qd; 1024 if ( index < 0 ) return qd;
1020 return mDate; 1025 return mDate;
1021} 1026}
1022 1027
1023void MonthViewCell::deselect() 1028void MonthViewCell::deselect()
1024{ 1029{
1025 clearSelection(); 1030 clearSelection();
1026 enableScrollBars( false ); 1031 enableScrollBars( false );
1027 // updateCell(); 1032 // updateCell();
1028} 1033}
1029void MonthViewCell::select() 1034void MonthViewCell::select()
1030{ 1035{
1031 ;// updateCell(); 1036 ;// updateCell();
1032} 1037}
1033 1038
1034void MonthViewCell::resizeEvent ( QResizeEvent * e ) 1039void MonthViewCell::resizeEvent ( QResizeEvent * e )
1035{ 1040{
1036 if ( !mMonthView->isUpdatePossible() ) 1041 if ( !mMonthView->isUpdatePossible() )
1037 return; 1042 return;
1038 //qDebug("++++++++++++++MonthViewCell::resizeEvent %d %d ", width(), height()); 1043 //qDebug("++++++++++++++MonthViewCell::resizeEvent %d %d ", width(), height());
1039 deselect(); 1044 deselect();
1040 mLabel->setMaximumHeight( height() - lineWidth()*2 ); 1045 mLabel->setMaximumHeight( height() - lineWidth()*2 );
1041 1046
1042 QString text; 1047 QString text;
1043 //mLabel->setText( text ); 1048 //mLabel->setText( text );
1044 bool smallDisplay = QApplication::desktop()->width() < 320 && KOPrefs::instance()->mMonthViewSatSunTog; 1049 bool smallDisplay = QApplication::desktop()->width() < 320 && KOPrefs::instance()->mMonthViewSatSunTog;
1045 if ( KOPrefs::instance()->mMonthViewWeek || KOGlobals::self()->calendarSystem()->day( mDate ) == 1 || (mDate.dayOfWeek() == 7 && !smallDisplay ) || KOPrefs::instance()->mMonthShowShort) { 1050 if ( KOPrefs::instance()->mMonthViewWeek || KOGlobals::self()->calendarSystem()->day( mDate ) == 1 || (mDate.dayOfWeek() == 7 && !smallDisplay ) || KOPrefs::instance()->mMonthShowShort) {
1046 text = KOGlobals::self()->calendarSystem()->monthName( mDate, true ) + " " + QString::number( mDate.day() ); 1051 text = KOGlobals::self()->calendarSystem()->monthName( mDate, true ) + " " + QString::number( mDate.day() );
1047 mLabel->resize( mLabelBigSize ); 1052 mLabel->resize( mLabelBigSize );
1048 } else { 1053 } else {
1049 mLabel->resize( mLabelSize ); 1054 mLabel->resize( mLabelSize );
1050 text = QString::number( mDate.day() ); 1055 text = QString::number( mDate.day() );
1051 } 1056 }
1052 mLabel->setText( text ); 1057 mLabel->setText( text );
1053 1058
1054 int size = height() - mLabel->height() - lineWidth()-1; 1059 int size = height() - mLabel->height() - lineWidth()-1;
1055 //qDebug("LW %d ", lineWidth()); 1060 //qDebug("LW %d ", lineWidth());
1056 if ( size > 0 ) 1061 if ( size > 0 )
1057 verticalScrollBar()->setMaximumHeight( size ); 1062 verticalScrollBar()->setMaximumHeight( size );
1058 size = width() - mLabel->width() -lineWidth()-1; 1063 size = width() - mLabel->width() -lineWidth()-1;
1059 if ( size > 0 ) 1064 if ( size > 0 )
1060 horizontalScrollBar()->setMaximumWidth( size ); 1065 horizontalScrollBar()->setMaximumWidth( size );
1061 mLabel->move( width()-lineWidth() - mLabel->width(), height()-lineWidth() - mLabel->height() ); 1066 mLabel->move( width()-lineWidth() - mLabel->width(), height()-lineWidth() - mLabel->height() );
1062 //mLabel->setMaximumWidth( width() - mItemList->lineWidth()*2); 1067 //mLabel->setMaximumWidth( width() - mItemList->lineWidth()*2);
1063 // mItemList->resize ( width(), height () ); 1068 // mItemList->resize ( width(), height () );
1064 if ( e ) 1069 if ( e )
1065 KNoScrollListBox::resizeEvent ( e ); 1070 KNoScrollListBox::resizeEvent ( e );
1066} 1071}
1067 1072
1068void MonthViewCell::defaultAction( QListBoxItem *item ) 1073void MonthViewCell::defaultAction( QListBoxItem *item )
1069{ 1074{
1070 1075
1071 if ( !item ) { 1076 if ( !item ) {
1072 QDateTime dt( date(), QTime( KOPrefs::instance()->mStartTime, 0 ) ); 1077 QDateTime dt( date(), QTime( KOPrefs::instance()->mStartTime, 0 ) );
1073 emit newEventSignal( dt ); 1078 emit newEventSignal( dt );
1074 return; 1079 return;
1075 } 1080 }
1076 1081
1077 MonthViewItem *eventItem = static_cast<MonthViewItem *>( item ); 1082 MonthViewItem *eventItem = static_cast<MonthViewItem *>( item );
1078 Incidence *incidence = eventItem->incidence(); 1083 Incidence *incidence = eventItem->incidence();
1079 if ( incidence ) mMonthView->defaultAction( incidence ); 1084 if ( incidence ) mMonthView->defaultAction( incidence );
1080} 1085}
1081void MonthViewCell::showDay() 1086void MonthViewCell::showDay()
1082{ 1087{
1083 emit showDaySignal( date() ); 1088 emit showDaySignal( date() );
1084} 1089}
1085void MonthViewCell::newEvent() 1090void MonthViewCell::newEvent()
1086{ 1091{
1087 QDateTime dt( date(), QTime( KOPrefs::instance()->mStartTime, 0 ) ); 1092 QDateTime dt( date(), QTime( KOPrefs::instance()->mStartTime, 0 ) );
1088 emit newEventSignal( dt ); 1093 emit newEventSignal( dt );
1089} 1094}
1090void MonthViewCell::cellClicked( QListBoxItem *item ) 1095void MonthViewCell::cellClicked( QListBoxItem *item )
1091{ 1096{
1092 mMonthView->setSelectedCell( this ); 1097 mMonthView->setSelectedCell( this );
1093 if ( item == 0 ) { 1098 if ( item == 0 ) {
1094 QDateTime dt( date(), QTime( KOPrefs::instance()->mStartTime, 0 ) ); 1099 QDateTime dt( date(), QTime( KOPrefs::instance()->mStartTime, 0 ) );
1095 emit newEventSignal( dt ); 1100 emit newEventSignal( dt );
1096 return; 1101 return;
1097 } 1102 }
1098 1103
1099} 1104}
1100 1105
1101void MonthViewCell::contextMenu( QListBoxItem *item ) 1106void MonthViewCell::contextMenu( QListBoxItem *item )
1102{ 1107{
1103 mMonthView->setPopupCell( this ); 1108 mMonthView->setPopupCell( this );
1104 if ( !item ) { 1109 if ( !item ) {
1105 mMonthView->showContextMenu( 0 ); 1110 mMonthView->showContextMenu( 0 );
1106 return; 1111 return;
1107 } 1112 }
1108 //selection( item ); 1113 //selection( item );
1109 //qApp->processEvents(); 1114 //qApp->processEvents();
1110 MonthViewItem *eventItem = static_cast<MonthViewItem *>( item ); 1115 MonthViewItem *eventItem = static_cast<MonthViewItem *>( item );
1111 Incidence *incidence = eventItem->incidence(); 1116 Incidence *incidence = eventItem->incidence();
1112 if ( incidence ) { 1117 if ( incidence ) {
1118 mBlockDeselect = true;
1113 mMonthView->showContextMenu( incidence ); 1119 mMonthView->showContextMenu( incidence );
1114 selection( item );
1115 doHighLight( incidence );
1116 } 1120 }
1117} 1121}
1118 1122
1119void MonthViewCell::selection( QListBoxItem *item ) 1123void MonthViewCell::selection( QListBoxItem *item )
1120{ 1124{
1121 if ( !item ) { 1125 if ( !item ) {
1122 emit highlightIncidence( 0 , this, 0 ); 1126 emit highlightIncidence( 0 , this, 0 );
1123 return; 1127 return;
1124 } 1128 }
1125 MonthViewItem * it = (static_cast<MonthViewItem *>( item )); 1129 MonthViewItem * it = (static_cast<MonthViewItem *>( item ));
1126 emit highlightIncidence( it->incidence(), this, it->multiDay() ); 1130 emit highlightIncidence( it->incidence(), this, it->multiDay() );
1127 mMonthView->setSelectedCell( this ); 1131 mMonthView->setSelectedCell( this );
1128} 1132}
1129 1133
1130void MonthViewCell::deHighLight() 1134void MonthViewCell::deHighLight()
1131{ 1135{
1132 MonthViewItem *mitem = (MonthViewItem*) firstItem (); 1136 MonthViewItem *mitem = (MonthViewItem*) firstItem ();
1133 while ( mitem ) { 1137 while ( mitem ) {
1134 if ( mitem->setHighlightedFalse() ) 1138 if ( mitem->setHighlightedFalse() )
1135 updateItem ( mitem ); 1139 updateItem ( mitem );
1136 mitem = (MonthViewItem *)mitem->next(); 1140 mitem = (MonthViewItem *)mitem->next();
1137 } 1141 }
1138} 1142}
1139// returns true if no inc found 1143// returns true if no inc found
1140bool MonthViewCell::doHighLight( Incidence * inc ) 1144bool MonthViewCell::doHighLight( Incidence * inc )
1141{ 1145{
1142 1146
1143 MonthViewItem *mitem = (MonthViewItem*) firstItem (); 1147 MonthViewItem *mitem = (MonthViewItem*) firstItem ();
1144 while ( mitem ) { 1148 while ( mitem ) {
1145 if ( mitem->incidence() == inc ) { 1149 if ( mitem->incidence() == inc ) {
1146 if ( mitem->setHighlighted( inc ) ) 1150 if ( mitem->setHighlighted( inc ) )
1147 updateItem ( mitem ); 1151 updateItem ( mitem );
1148 return false; 1152 return false;
1149 } 1153 }
1150 mitem = (MonthViewItem *)mitem->next(); 1154 mitem = (MonthViewItem *)mitem->next();
1151 } 1155 }
1152 return true; 1156 return true;
1153} 1157}
1154// ******************************************************************************* 1158// *******************************************************************************
1155// ******************************************************************************* 1159// *******************************************************************************
1156// ******************************************************************************* 1160// *******************************************************************************
1157 1161
1158 1162
1159KOMonthView::KOMonthView(Calendar *calendar, QWidget *parent, const char *name) 1163KOMonthView::KOMonthView(Calendar *calendar, QWidget *parent, const char *name)
1160 : KOEventView( calendar, parent, name ), 1164 : KOEventView( calendar, parent, name ),
1161 mDaysPerWeek( 7 ), mNumWeeks( 6 ), mNumCells( mDaysPerWeek * mNumWeeks ), 1165 mDaysPerWeek( 7 ), mNumWeeks( 6 ), mNumCells( mDaysPerWeek * mNumWeeks ),
1162 mWidthLongDayLabel( 0 ), mSelectedCell( 0 ) 1166 mWidthLongDayLabel( 0 ), mSelectedCell( 0 )
1163{ 1167{
1164 mFlagKeyPressed = false; 1168 mFlagKeyPressed = false;
1165 mShortDayLabelsM = false; 1169 mShortDayLabelsM = false;
1166 mShortDayLabelsW = false; 1170 mShortDayLabelsW = false;
1167 skipResize = false; 1171 skipResize = false;
1168 clPending = true; 1172 clPending = true;
1169 mPopupCell = 0; 1173 mPopupCell = 0;
1170 mNavigatorBar = new NavigatorBar( QDate::currentDate(), this, "useBigPixmaps" ); 1174 mNavigatorBar = new NavigatorBar( QDate::currentDate(), this, "useBigPixmaps" );
1171 mWidStack = new QWidgetStack( this ); 1175 mWidStack = new QWidgetStack( this );
1172 QVBoxLayout* hb = new QVBoxLayout( this ); 1176 QVBoxLayout* hb = new QVBoxLayout( this );
1173 mMonthView = new QWidget( mWidStack ); 1177 mMonthView = new QWidget( mWidStack );
1174 mWeekView = new QWidget( mWidStack ); 1178 mWeekView = new QWidget( mWidStack );
1175#if QT_VERSION >= 0x030000 1179#if QT_VERSION >= 0x030000
1176 mWidStack->addWidget(mMonthView ); 1180 mWidStack->addWidget(mMonthView );
1177 mWidStack->addWidget(mWeekView ); 1181 mWidStack->addWidget(mWeekView );
1178#else 1182#else
1179 mWidStack->addWidget( mMonthView, 1 ); 1183 mWidStack->addWidget( mMonthView, 1 );
1180 mWidStack->addWidget( mWeekView , 1 ); 1184 mWidStack->addWidget( mWeekView , 1 );
1181#endif 1185#endif
1182 hb->addWidget( mNavigatorBar ); 1186 hb->addWidget( mNavigatorBar );
1183 hb->addWidget( mWidStack ); 1187 hb->addWidget( mWidStack );
1184 mShowWeekView = KOPrefs::instance()->mMonthViewWeek; 1188 mShowWeekView = KOPrefs::instance()->mMonthViewWeek;
1185 updatePossible = false; 1189 updatePossible = false;
1186 //updatePossible = true; 1190 //updatePossible = true;
1187 mCells.setAutoDelete( true ); 1191 mCells.setAutoDelete( true );
1188 mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ; 1192 mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ;
1189 mDayLabels.resize( mDaysPerWeek ); 1193 mDayLabels.resize( mDaysPerWeek );
1190 mDayLabelsW.resize( mDaysPerWeek ); 1194 mDayLabelsW.resize( mDaysPerWeek );
1191 QFont bfont = font(); 1195 QFont bfont = font();
1192 if ( QApplication::desktop()->width() < 650 ) { 1196 if ( QApplication::desktop()->width() < 650 ) {
1193 bfont.setPointSize( bfont.pointSize() - 2 ); 1197 bfont.setPointSize( bfont.pointSize() - 2 );
1194 } 1198 }
1195 bfont.setBold( true ); 1199 bfont.setBold( true );
1196 int i; 1200 int i;
1197 1201
1198 for( i = 0; i < mDaysPerWeek; i++ ) { 1202 for( i = 0; i < mDaysPerWeek; i++ ) {
1199 QLabel *label = new QLabel( mMonthView ); 1203 QLabel *label = new QLabel( mMonthView );
1200 label->setFont(bfont); 1204 label->setFont(bfont);
1201 label->setFrameStyle(QFrame::Panel|QFrame::Raised); 1205 label->setFrameStyle(QFrame::Panel|QFrame::Raised);
1202 label->setLineWidth(1); 1206 label->setLineWidth(1);
1203 label->setAlignment(AlignCenter); 1207 label->setAlignment(AlignCenter);
1204 mDayLabels.insert( i, label ); 1208 mDayLabels.insert( i, label );
1205 label = new QLabel( mWeekView ); 1209 label = new QLabel( mWeekView );
1206 label->setFont(bfont); 1210 label->setFont(bfont);
1207 label->setFrameStyle(QFrame::Panel|QFrame::Raised); 1211 label->setFrameStyle(QFrame::Panel|QFrame::Raised);
1208 label->setLineWidth(1); 1212 label->setLineWidth(1);
1209 label->setAlignment(AlignCenter); 1213 label->setAlignment(AlignCenter);
1210 mDayLabelsW.insert( i, label ); 1214 mDayLabelsW.insert( i, label );
1211 } 1215 }
1212 1216
1213 bfont.setBold( false ); 1217 bfont.setBold( false );
1214 mWeekLabels.resize( mNumWeeks+1 ); 1218 mWeekLabels.resize( mNumWeeks+1 );
1215 mWeekLabelsW.resize( 2 ); 1219 mWeekLabelsW.resize( 2 );
1216 for( i = 0; i < mNumWeeks+1; i++ ) { 1220 for( i = 0; i < mNumWeeks+1; i++ ) {
1217 KOWeekButton *label = new KOWeekButton( mMonthView ); 1221 KOWeekButton *label = new KOWeekButton( mMonthView );
1218 label->setFocusPolicy(NoFocus); 1222 label->setFocusPolicy(NoFocus);
1219 label->setFont(bfont); 1223 label->setFont(bfont);
1220 connect( label, SIGNAL( selectWeekNum ( int )),this, SLOT( selectInternalWeekNum ( int )) ); 1224 connect( label, SIGNAL( selectWeekNum ( int )),this, SLOT( selectInternalWeekNum ( int )) );
1221 label->setFlat(true); 1225 label->setFlat(true);
1222 QWhatsThis::add(label,i18n("Click on the week number to\nshow week zoomed")); 1226 QWhatsThis::add(label,i18n("Click on the week number to\nshow week zoomed"));
1223 //label->setFrameStyle(QFrame::Panel|QFrame::Raised); 1227 //label->setFrameStyle(QFrame::Panel|QFrame::Raised);
1224 //label->setLineWidth(1); 1228 //label->setLineWidth(1);
1225 //label->setAlignment(AlignCenter); 1229 //label->setAlignment(AlignCenter);
1226 mWeekLabels.insert( i, label ); 1230 mWeekLabels.insert( i, label );
1227 } 1231 }
1228 mWeekLabels[mNumWeeks]->setText( i18n("W")); 1232 mWeekLabels[mNumWeeks]->setText( i18n("W"));
1229 mWeekLabels[mNumWeeks]->setFocusPolicy(WheelFocus); 1233 mWeekLabels[mNumWeeks]->setFocusPolicy(WheelFocus);
1230 QWhatsThis::add(mWeekLabels[mNumWeeks],i18n("Click on this to\nselect week number")); 1234 QWhatsThis::add(mWeekLabels[mNumWeeks],i18n("Click on this to\nselect week number"));
1231 1235
1232 for( i = 0; i < 1+1; i++ ) { 1236 for( i = 0; i < 1+1; i++ ) {
1233 KOWeekButton *label = new KOWeekButton( mWeekView ); 1237 KOWeekButton *label = new KOWeekButton( mWeekView );
1234 label->setFocusPolicy(NoFocus); 1238 label->setFocusPolicy(NoFocus);
1235 label->setFont(bfont); 1239 label->setFont(bfont);
1236 connect( label, SIGNAL( selectWeekNum ( int )),this, SLOT( selectInternalWeekNum ( int )) ); 1240 connect( label, SIGNAL( selectWeekNum ( int )),this, SLOT( selectInternalWeekNum ( int )) );
1237 label->setFlat(true); 1241 label->setFlat(true);
1238 QWhatsThis::add(label,i18n("Click on the week number to\nshow week zoomed")); 1242 QWhatsThis::add(label,i18n("Click on the week number to\nshow week zoomed"));
1239 //label->setFrameStyle(QFrame::Panel|QFrame::Raised); 1243 //label->setFrameStyle(QFrame::Panel|QFrame::Raised);
1240 //label->setLineWidth(1); 1244 //label->setLineWidth(1);
1241 //label->setAlignment(AlignCenter); 1245 //label->setAlignment(AlignCenter);
1242 mWeekLabelsW.insert( i, label ); 1246 mWeekLabelsW.insert( i, label );
1243 } 1247 }
1244 mWeekLabelsW[1]->setText( i18n("W")); 1248 mWeekLabelsW[1]->setText( i18n("W"));
1245 mWeekLabelsW[1]->setFocusPolicy(WheelFocus); 1249 mWeekLabelsW[1]->setFocusPolicy(WheelFocus);
1246 1250
1247 1251
1248 int row, col; 1252 int row, col;
1249 mCells.resize( mNumCells ); 1253 mCells.resize( mNumCells );
1250 for( row = 0; row < mNumWeeks; ++row ) { 1254 for( row = 0; row < mNumWeeks; ++row ) {
1251 for( col = 0; col < mDaysPerWeek; ++col ) { 1255 for( col = 0; col < mDaysPerWeek; ++col ) {
1252 MonthViewCell *cell = new MonthViewCell( this, mMonthView ); 1256 MonthViewCell *cell = new MonthViewCell( this, mMonthView );
1253 mCells.insert( row * mDaysPerWeek + col, cell ); 1257 mCells.insert( row * mDaysPerWeek + col, cell );
1254 1258
1255 connect( cell, SIGNAL( defaultAction( Incidence * ) ), 1259 connect( cell, SIGNAL( defaultAction( Incidence * ) ),
1256 SLOT( defaultAction( Incidence * ) ) ); 1260 SLOT( defaultAction( Incidence * ) ) );
1257 connect( cell, SIGNAL( newEventSignal( QDateTime ) ), 1261 connect( cell, SIGNAL( newEventSignal( QDateTime ) ),
1258 SIGNAL( newEventSignal( QDateTime ) ) ); 1262 SIGNAL( newEventSignal( QDateTime ) ) );
1259 connect( cell, SIGNAL( showDaySignal( QDate ) ), 1263 connect( cell, SIGNAL( showDaySignal( QDate ) ),
1260 SIGNAL( showDaySignal( QDate ) ) ); 1264 SIGNAL( showDaySignal( QDate ) ) );
1261 connect( cell, SIGNAL( nextCell() ), 1265 connect( cell, SIGNAL( nextCell() ),
1262 SLOT( nextCell() ) ); 1266 SLOT( nextCell() ) );
1263 connect( cell, SIGNAL( prevCell() ), 1267 connect( cell, SIGNAL( prevCell() ),
1264 SLOT( prevCell() ) ); 1268 SLOT( prevCell() ) );
1265 connect( cell, SIGNAL( highlightIncidence( Incidence * , MonthViewCell *, int ) ), 1269 connect( cell, SIGNAL( highlightIncidence( Incidence * , MonthViewCell *, int ) ),
1266 SLOT( incidenceHighlighted( Incidence *, MonthViewCell *, int ) )); 1270 SLOT( incidenceHighlighted( Incidence *, MonthViewCell *, int ) ));
1267 } 1271 }
1268 } 1272 }
1269 mCellsW.resize( mDaysPerWeek ); 1273 mCellsW.resize( mDaysPerWeek );
1270 for( col = 0; col < mDaysPerWeek; ++col ) { 1274 for( col = 0; col < mDaysPerWeek; ++col ) {
1271 MonthViewCell *cell = new MonthViewCell( this, mWeekView ); 1275 MonthViewCell *cell = new MonthViewCell( this, mWeekView );
1272 mCellsW.insert( col, cell ); 1276 mCellsW.insert( col, cell );
1273 1277
1274 connect( cell, SIGNAL( defaultAction( Incidence * ) ), 1278 connect( cell, SIGNAL( defaultAction( Incidence * ) ),
1275 SLOT( defaultAction( Incidence * ) ) ); 1279 SLOT( defaultAction( Incidence * ) ) );
1276 connect( cell, SIGNAL( newEventSignal( QDateTime ) ), 1280 connect( cell, SIGNAL( newEventSignal( QDateTime ) ),
1277 SIGNAL( newEventSignal( QDateTime ) ) ); 1281 SIGNAL( newEventSignal( QDateTime ) ) );
1278 connect( cell, SIGNAL( showDaySignal( QDate ) ), 1282 connect( cell, SIGNAL( showDaySignal( QDate ) ),
1279 SIGNAL( showDaySignal( QDate ) ) ); 1283 SIGNAL( showDaySignal( QDate ) ) );
1280 connect( cell, SIGNAL( nextCell() ), 1284 connect( cell, SIGNAL( nextCell() ),
1281 SLOT( nextCell() ) ); 1285 SLOT( nextCell() ) );
1282 connect( cell, SIGNAL( prevCell() ), 1286 connect( cell, SIGNAL( prevCell() ),
1283 SLOT( prevCell() ) ); 1287 SLOT( prevCell() ) );
1284 connect( cell, SIGNAL( highlightIncidence( Incidence * , MonthViewCell *, int ) ), 1288 connect( cell, SIGNAL( highlightIncidence( Incidence * , MonthViewCell *, int ) ),
1285 SLOT( incidenceHighlighted( Incidence *, MonthViewCell *, int ) )); 1289 SLOT( incidenceHighlighted( Incidence *, MonthViewCell *, int ) ));
1286 cell->updateConfig(KOPrefs::instance()->mMonthViewUsesBigFont ); 1290 cell->updateConfig(KOPrefs::instance()->mMonthViewUsesBigFont );
1287 } 1291 }
1288 1292
1289 //connect( mWeekLabels[mNumWeeks], SIGNAL( clicked() ), SLOT( switchView() ) ); 1293 //connect( mWeekLabels[mNumWeeks], SIGNAL( clicked() ), SLOT( switchView() ) );
1290 mContextMenu = eventPopup(); 1294 mContextMenu = eventPopup();
1291 mContextMenu->addAdditionalItem(QIconSet(QPixmap()), 1295 mContextMenu->addAdditionalItem(QIconSet(QPixmap()),
1292 i18n("New Event..."),this, 1296 i18n("New Event..."),this,
1293 SLOT(slotNewEvent()),false); 1297 SLOT(slotNewEvent()),false);
1294 mContextMenu->addAdditionalItem(QIconSet(QPixmap()), 1298 mContextMenu->addAdditionalItem(QIconSet(QPixmap()),
1295 i18n("New Todo..."),this, 1299 i18n("New Todo..."),this,
1296 SLOT(slotNewTodo()),false); 1300 SLOT(slotNewTodo()),false);
1297 mContextMenu->addAdditionalItem(QIconSet(QPixmap()), 1301 mContextMenu->addAdditionalItem(QIconSet(QPixmap()),
1298 i18n("Journal"),this, 1302 i18n("Journal"),this,
1299 SLOT(slotEditJournal()),false); 1303 SLOT(slotEditJournal()),false);
1300 1304
1301 connect (mContextMenu ,SIGNAL(categoryChanged( Incidence * )),this, 1305 connect (mContextMenu ,SIGNAL(categoryChanged( Incidence * )),this,
1302 SLOT( catChanged( Incidence * ) )); 1306 SLOT( catChanged( Incidence * ) ));
1303 1307
1304 1308
1305 QString pathString = ""; 1309 QString pathString = "";
1306 if ( !KOPrefs::instance()->mToolBarMiniIcons ) { 1310 if ( !KOPrefs::instance()->mToolBarMiniIcons ) {
1307 if ( QApplication::desktop()->width() < 480 ) 1311 if ( QApplication::desktop()->width() < 480 )
1308 pathString += "icons16/"; 1312 pathString += "icons16/";
1309 } else 1313 } else
1310 pathString += "iconsmini/"; 1314 pathString += "iconsmini/";
1311 mNewItemMenu = new QPopupMenu( this ); 1315 mNewItemMenu = new QPopupMenu( this );
1312 mNewItemMenu->insertItem( SmallIcon( pathString +"newevent" ), i18n("New Event..."),this, SLOT(slotNewEvent())); 1316 mNewItemMenu->insertItem( SmallIcon( pathString +"newevent" ), i18n("New Event..."),this, SLOT(slotNewEvent()));
1313 mNewItemMenu->insertItem( SmallIcon( pathString +"newtodo" ),i18n("New Todo..."),this,SLOT(slotNewTodo()),false); 1317 mNewItemMenu->insertItem( SmallIcon( pathString +"newtodo" ),i18n("New Todo..."),this,SLOT(slotNewTodo()),false);
1314 mNewItemMenu->insertItem( SmallIcon( pathString +"journal" ),i18n("Journal"),this,SLOT(slotEditJournal()),false); 1318 mNewItemMenu->insertItem( SmallIcon( pathString +"journal" ),i18n("Journal"),this,SLOT(slotEditJournal()),false);
1315 1319
1316 // updateConfig(); //useless here... 1320 // updateConfig(); //useless here...
1317 // ... but we need mWidthLongDayLabel computed 1321 // ... but we need mWidthLongDayLabel computed
1318 QFontMetrics fontmetric(mDayLabels[0]->font()); 1322 QFontMetrics fontmetric(mDayLabels[0]->font());
1319 mWidthLongDayLabel = 0; 1323 mWidthLongDayLabel = 0;
1320 for (int i = 0; i < 7; i++) { 1324 for (int i = 0; i < 7; i++) {
1321 int width = fontmetric.width(KOGlobals::self()->calendarSystem()->weekDayName(i+1)); 1325 int width = fontmetric.width(KOGlobals::self()->calendarSystem()->weekDayName(i+1));
1322 if ( width > mWidthLongDayLabel ) mWidthLongDayLabel = width; 1326 if ( width > mWidthLongDayLabel ) mWidthLongDayLabel = width;
1323 } 1327 }
1324 1328
1325 //mWeekLabels[mNumWeeks]->setText( i18n("W")); 1329 //mWeekLabels[mNumWeeks]->setText( i18n("W"));
1326 1330
1327#if 0 1331#if 0
1328 if ( mShowWeekView ) 1332 if ( mShowWeekView )
1329 mWidStack->raiseWidget( mWeekView ); 1333 mWidStack->raiseWidget( mWeekView );
1330 else 1334 else
1331 mWidStack->raiseWidget( mMonthView ); 1335 mWidStack->raiseWidget( mMonthView );
1332#endif 1336#endif
1333 1337
1334 emit incidenceSelected( 0 ); 1338 emit incidenceSelected( 0 );
1335 1339
1336 mComputeLayoutTimer = new QTimer( this ); 1340 mComputeLayoutTimer = new QTimer( this );
1337 connect (mComputeLayoutTimer ,SIGNAL(timeout()), this, SLOT ( slotComputeLayout())); 1341 connect (mComputeLayoutTimer ,SIGNAL(timeout()), this, SLOT ( slotComputeLayout()));
1338 1342
1339 1343
1340#ifndef DESKTOP_VERSION 1344#ifndef DESKTOP_VERSION
1341 resize( QApplication::desktop()->size() ); 1345 resize( QApplication::desktop()->size() );
1342#else 1346#else
1343 resize(640, 480 ); 1347 resize(640, 480 );
1344 updatePossible = true; 1348 updatePossible = true;
1345#endif 1349#endif
1346 computeLayout(); 1350 computeLayout();
1347 1351
1348 if ( mShowWeekView ) 1352 if ( mShowWeekView )
1349 mWidStack->raiseWidget( mWeekView ); 1353 mWidStack->raiseWidget( mWeekView );
1350 else 1354 else
1351 mWidStack->raiseWidget( mMonthView ); 1355 mWidStack->raiseWidget( mMonthView );
1352} 1356}
1353 1357
1354KOMonthView::~KOMonthView() 1358KOMonthView::~KOMonthView()
1355{ 1359{
1356 delete mContextMenu; 1360 delete mContextMenu;
1357} 1361}
1358 1362
1359void KOMonthView::catChanged( Incidence * ) 1363void KOMonthView::catChanged( Incidence * )
1360{ 1364{
1361 updateView(); 1365 updateView();
1362} 1366}
1363void KOMonthView::incidenceHighlighted( Incidence * inc , MonthViewCell* mc, int mday ) 1367void KOMonthView::incidenceHighlighted( Incidence * inc , MonthViewCell* mc, int mday )
1364{ 1368{
1365 static Incidence * lastInc = 0; 1369 static Incidence * lastInc = 0;
1366 static MonthViewCell * lastCell = 0; 1370 static MonthViewCell * lastCell = 0;
1367 1371
1368 if ( lastInc == inc && lastCell == mc ) 1372 if ( lastInc == inc && lastCell == mc )
1369 return; 1373 return;
1370 lastInc = inc; 1374 lastInc = inc;
1371 lastCell = mc; 1375 lastCell = mc;
1372 //qDebug("KOMonthView::incidenceHighlighted %d %d %d", inc, mc, mday ); 1376 //qDebug("KOMonthView::incidenceHighlighted %d %d %d", inc, mc, mday );
1373 1377
1374 bool weekview = false; 1378 bool weekview = false;
1375 uint index = 0; 1379 uint index = 0;
1376 for (uint i = 0; i < mCellsW.count(); ++i) { 1380 for (uint i = 0; i < mCellsW.count(); ++i) {
1377 if ( mCellsW[i] == mc ) { 1381 if ( mCellsW[i] == mc ) {
1378 weekview = true; 1382 weekview = true;
1379 index = i; 1383 index = i;
1380 break; 1384 break;
1381 } 1385 }
1382 } 1386 }
1383 QPtrVector<MonthViewCell> *cells; 1387 QPtrVector<MonthViewCell> *cells;
1384 if ( weekview ) 1388 if ( weekview )
1385 cells = &mCellsW; 1389 cells = &mCellsW;
1386 else { 1390 else {
1387 for (uint i = 0; i < mCells.count(); ++i) { 1391 for (uint i = 0; i < mCells.count(); ++i) {
1388 if ( mCells[i] == mc ) { 1392 if ( mCells[i] == mc ) {
1389 index = i; 1393 index = i;
1390 break; 1394 break;
1391 } 1395 }
1392 } 1396 }
1393 cells = &mCells; 1397 cells = &mCells;
1394 } 1398 }
1395 for (uint i = 0; i < (*cells).count(); ++i) { 1399 for (uint i = 0; i < (*cells).count(); ++i) {
1396 (*cells)[i]->deHighLight(); 1400 (*cells)[i]->deHighLight();
1397 } 1401 }
1398 if ( ! inc ) 1402 if ( ! inc )
1399 return; 1403 return;
1400 1404
1401 uint count = (*cells).count(); 1405 uint count = (*cells).count();
1402 bool goLeft = (mday > 1 && index > 0); 1406 bool goLeft = (mday > 1 && index > 0);
1403 bool goRight = (mday < 3 && mday > 0 && index < count -1); 1407 bool goRight = (mday < 3 && mday > 0 && index < count -1);
1404 for (uint iii = 1; iii < count; ++iii) { 1408 for (uint iii = 1; iii < count; ++iii) {
1405 if ( goLeft ) { 1409 if ( goLeft ) {
1406 int left = index - iii; 1410 int left = index - iii;
1407 if ( left >= 0 ) { 1411 if ( left >= 0 ) {
1408 if ( (*cells)[(uint)left]->doHighLight(inc) ) 1412 if ( (*cells)[(uint)left]->doHighLight(inc) )
1409 goLeft = false; 1413 goLeft = false;
1410 } else 1414 } else
1411 goLeft = false; 1415 goLeft = false;
1412 } 1416 }
1413 if ( goRight ) { 1417 if ( goRight ) {
1414 uint right = index + iii; 1418 uint right = index + iii;
1415 if ( right < count ) { 1419 if ( right < count ) {
1416 if ( (*cells)[right]->doHighLight(inc) ) 1420 if ( (*cells)[right]->doHighLight(inc) )
1417 goRight = false; 1421 goRight = false;
1418 1422
1419 } else 1423 } else
1420 goRight = false; 1424 goRight = false;
1421 } 1425 }
1422 1426
1423 } 1427 }
1424#if 0 1428#if 0
1425 if ( mday > 1 && index > 0 ) 1429 if ( mday > 1 && index > 0 )
1426 for (int i = index-1; i >= 0; --i) { 1430 for (int i = index-1; i >= 0; --i) {
1427 //qDebug("index %d iii %d ", index, i); 1431 //qDebug("index %d iii %d ", index, i);
1428 if ( (*cells)[(uint)i]->doHighLight(inc) ) 1432 if ( (*cells)[(uint)i]->doHighLight(inc) )
1429 break; 1433 break;
1430 } 1434 }
1431 if ( mday < 3 && mday > 0 && index < (*cells).count()-1) 1435 if ( mday < 3 && mday > 0 && index < (*cells).count()-1)
1432 for (uint i = index+1; i < (*cells).count(); ++i) { 1436 for (uint i = index+1; i < (*cells).count(); ++i) {
1433 if ( (*cells)[i]->doHighLight(inc) ) 1437 if ( (*cells)[i]->doHighLight(inc) )
1434 break; 1438 break;
1435 } 1439 }
1436#endif 1440#endif
1437 1441
1438} 1442}
1439void KOMonthView::selectInternalWeekNum ( int n ) 1443void KOMonthView::selectInternalWeekNum ( int n )
1440{ 1444{
1441 switchView(); 1445 switchView();
1442 if ( !KOPrefs::instance()->mMonthViewWeek ) 1446 if ( !KOPrefs::instance()->mMonthViewWeek )
1443 emit selectMonth (); 1447 emit selectMonth ();
1444 else 1448 else
1445 emit selectWeekNum ( n ); 1449 emit selectWeekNum ( n );
1446} 1450}
1447 1451
1448int KOMonthView::currentWeek() 1452int KOMonthView::currentWeek()
1449{ 1453{
1450 if ( mShowWeekView ) 1454 if ( mShowWeekView )
1451 return mWeekLabelsW[0]->getWeekNum(); 1455 return mWeekLabelsW[0]->getWeekNum();
1452 return mWeekLabels[0]->getWeekNum(); 1456 return mWeekLabels[0]->getWeekNum();
1453} 1457}
1454void KOMonthView::switchView() 1458void KOMonthView::switchView()
1455{ 1459{
1456 if ( selectedCell( ) ) 1460 if ( selectedCell( ) )
1457 selectedCell()->deselect(); 1461 selectedCell()->deselect();
1458 mShowWeekView = !mShowWeekView; 1462 mShowWeekView = !mShowWeekView;
1459 KOPrefs::instance()->mMonthViewWeek = mShowWeekView; 1463 KOPrefs::instance()->mMonthViewWeek = mShowWeekView;
1460 if ( clPending ) { 1464 if ( clPending ) {
1461 computeLayout(); 1465 computeLayout();
1462 updateConfig(); 1466 updateConfig();
1463 } 1467 }
1464 if ( mShowWeekView ) 1468 if ( mShowWeekView )
1465 mWidStack->raiseWidget( mWeekView ); 1469 mWidStack->raiseWidget( mWeekView );
1466 else 1470 else
1467 mWidStack->raiseWidget( mMonthView ); 1471 mWidStack->raiseWidget( mMonthView );
1468 clPending = false; 1472 clPending = false;
1469} 1473}
1470 1474
1471int KOMonthView::maxDatesHint() 1475int KOMonthView::maxDatesHint()
1472{ 1476{
1473 return mNumCells; 1477 return mNumCells;
1474} 1478}
1475 1479
1476int KOMonthView::currentDateCount() 1480int KOMonthView::currentDateCount()
1477{ 1481{
1478 return mNumCells; 1482 return mNumCells;
1479} 1483}
1480 1484
1481QPtrList<Incidence> KOMonthView::selectedIncidences() 1485QPtrList<Incidence> KOMonthView::selectedIncidences()
1482{ 1486{
1483 QPtrList<Incidence> selected; 1487 QPtrList<Incidence> selected;
1484 1488
1485 if ( mSelectedCell ) { 1489 if ( mSelectedCell ) {
1486 Incidence *incidence = mSelectedCell->selectedIncidence(); 1490 Incidence *incidence = mSelectedCell->selectedIncidence();
1487 if ( incidence ) selected.append( incidence ); 1491 if ( incidence ) selected.append( incidence );
1488 } 1492 }
1489 1493
1490 return selected; 1494 return selected;
1491} 1495}
1492 1496
1493DateList KOMonthView::selectedDates() 1497DateList KOMonthView::selectedDates()
1494{ 1498{
1495 DateList selected; 1499 DateList selected;
1496 1500
1497 if ( mSelectedCell ) { 1501 if ( mSelectedCell ) {
1498 QDate qd = mSelectedCell->selectedIncidenceDate(); 1502 QDate qd = mSelectedCell->selectedIncidenceDate();
1499 if ( qd.isValid() ) selected.append( qd ); 1503 if ( qd.isValid() ) selected.append( qd );
1500 } 1504 }
1501 1505
1502 return selected; 1506 return selected;
1503} 1507}
1504#if 0 1508#if 0
1505void KOMonthView::printPreview(CalPrinter *calPrinter, const QDate &fd, 1509void KOMonthView::printPreview(CalPrinter *calPrinter, const QDate &fd,
1506 const QDate &td) 1510 const QDate &td)
1507{ 1511{
1508#ifndef KORG_NOPRINTER 1512#ifndef KORG_NOPRINTER
1509 calPrinter->preview(CalPrinter::Month, fd, td); 1513 calPrinter->preview(CalPrinter::Month, fd, td);
1510#endif 1514#endif
1511} 1515}
1512#endif 1516#endif
1513void KOMonthView::updateConfig() 1517void KOMonthView::updateConfig()
1514{ 1518{
1515 1519
1516 int mWeekStartsMonday = KGlobal::locale()->weekStartsMonday(); 1520 int mWeekStartsMonday = KGlobal::locale()->weekStartsMonday();
1517 1521
1518 if ( mShowWeekView || KOPrefs::instance()->mMonthViewSatSunTog ) { 1522 if ( mShowWeekView || KOPrefs::instance()->mMonthViewSatSunTog ) {
1519 mWeekStartsMonday = true; 1523 mWeekStartsMonday = true;
1520 } 1524 }
1521 QFontMetrics fontmetric(mDayLabels[0]->font()); 1525 QFontMetrics fontmetric(mDayLabels[0]->font());
1522 mWidthLongDayLabel = 0; 1526 mWidthLongDayLabel = 0;
1523 1527
1524 for (int i = 0; i < 7; i++) { 1528 for (int i = 0; i < 7; i++) {
1525 int width = fontmetric.width(KOGlobals::self()->calendarSystem()->weekDayName(i+1)); 1529 int width = fontmetric.width(KOGlobals::self()->calendarSystem()->weekDayName(i+1));
1526 if ( width > mWidthLongDayLabel ) mWidthLongDayLabel = width; 1530 if ( width > mWidthLongDayLabel ) mWidthLongDayLabel = width;
1527 } 1531 }
1528 bool temp = mShowSatSunComp ; 1532 bool temp = mShowSatSunComp ;
1529 mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ; 1533 mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ;
1530 if ( ! mShowWeekView ) { 1534 if ( ! mShowWeekView ) {
1531 if ( temp != KOPrefs::instance()->mMonthViewSatSunTog ) 1535 if ( temp != KOPrefs::instance()->mMonthViewSatSunTog )
1532 computeLayout(); 1536 computeLayout();
1533 } else 1537 } else
1534 doComputeLayoutWeek(); 1538 doComputeLayoutWeek();
1535 updateDayLabels(); 1539 updateDayLabels();
1536 //qDebug("KOMonthView::updateConfig() %d %d %d ",height(), mDayLabels[0]->sizeHint().height() ,mNumWeeks); 1540 //qDebug("KOMonthView::updateConfig() %d %d %d ",height(), mDayLabels[0]->sizeHint().height() ,mNumWeeks);
1537 //int cellHeight = (height() - mDayLabels[0]->sizeHint().height()) /mNumWeeks; 1541 //int cellHeight = (height() - mDayLabels[0]->sizeHint().height()) /mNumWeeks;
1538 //resizeEvent( 0 ); 1542 //resizeEvent( 0 );
1539 for (uint i = 0; i < mCells.count(); ++i) { 1543 for (uint i = 0; i < mCells.count(); ++i) {
1540 mCells[i]->updateConfig(); 1544 mCells[i]->updateConfig();
1541 } 1545 }
1542 1546
1543 for (uint i = 0; i < mCellsW.count(); ++i) { 1547 for (uint i = 0; i < mCellsW.count(); ++i) {
1544 mCellsW[i]->updateConfig(KOPrefs::instance()->mMonthViewUsesBigFont); 1548 mCellsW[i]->updateConfig(KOPrefs::instance()->mMonthViewUsesBigFont);
1545 } 1549 }
1546#ifdef DESKTOP_VERSION 1550#ifdef DESKTOP_VERSION
1547 MonthViewCell::toolTipGroup()->setEnabled(KOPrefs::instance()->mEnableToolTips); 1551 MonthViewCell::toolTipGroup()->setEnabled(KOPrefs::instance()->mEnableToolTips);
1548#endif 1552#endif
1549 updateView(); 1553 updateView();
1550} 1554}
1551 1555
1552void KOMonthView::updateDayLabels() 1556void KOMonthView::updateDayLabels()
1553{ 1557{
1554 1558
1555 QPtrVector<QLabel> *mDayLabelsT; 1559 QPtrVector<QLabel> *mDayLabelsT;
1556 1560
1557 mDayLabelsT = &mDayLabelsW; 1561 mDayLabelsT = &mDayLabelsW;
1558 for (int i = 0; i < 7; i++) { 1562 for (int i = 0; i < 7; i++) {
1559 { 1563 {
1560 bool show = mShortDayLabelsW; 1564 bool show = mShortDayLabelsW;
1561 if ( i > 4 && mShowSatSunComp && mWidthLongDayLabel > (*mDayLabelsT)[i]->width() ) 1565 if ( i > 4 && mShowSatSunComp && mWidthLongDayLabel > (*mDayLabelsT)[i]->width() )
1562 show = true; 1566 show = true;
1563 (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i+1,show)); 1567 (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i+1,show));
1564 } 1568 }
1565 } 1569 }
1566 mDayLabelsT = &mDayLabels; 1570 mDayLabelsT = &mDayLabels;
1567 for (int i = 0; i < 7; i++) { 1571 for (int i = 0; i < 7; i++) {
1568 if (KGlobal::locale()->weekStartsMonday() || KOPrefs::instance()->mMonthViewSatSunTog ) { 1572 if (KGlobal::locale()->weekStartsMonday() || KOPrefs::instance()->mMonthViewSatSunTog ) {
1569 bool show = mShortDayLabelsM; 1573 bool show = mShortDayLabelsM;
1570 if ( i > 4 && mShowSatSunComp && mWidthLongDayLabel > (*mDayLabelsT)[i]->width() ) 1574 if ( i > 4 && mShowSatSunComp && mWidthLongDayLabel > (*mDayLabelsT)[i]->width() )
1571 show = true; 1575 show = true;
1572 (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i+1,show)); 1576 (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i+1,show));
1573 } else { 1577 } else {
1574 if (i==0) (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(7,mShortDayLabelsM)); 1578 if (i==0) (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(7,mShortDayLabelsM));
1575 else (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i,mShortDayLabelsM)); 1579 else (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i,mShortDayLabelsM));
1576 1580
1577 } 1581 }
1578 } 1582 }
1579 1583
1580} 1584}
1581 1585
1582void KOMonthView::clearList() 1586void KOMonthView::clearList()
1583{ 1587{
1584 unsigned int i; 1588 unsigned int i;
1585 for( i = 0; i < mCells.size(); ++i ) { 1589 for( i = 0; i < mCells.size(); ++i ) {
1586 mCells[i]->clear(); 1590 mCells[i]->clear();
1587 } 1591 }
1588 for( i = 0; i < mCellsW.size(); ++i ) { 1592 for( i = 0; i < mCellsW.size(); ++i ) {
1589 mCellsW[i]->clear(); 1593 mCellsW[i]->clear();
1590 } 1594 }
1591} 1595}
1592void KOMonthView::showDates(const QDate &start, const QDate &) 1596void KOMonthView::showDates(const QDate &start, const QDate &)
1593{ 1597{
1594 // kdDebug() << "KOMonthView::showDates(): " << start.toString() << endl; 1598 // kdDebug() << "KOMonthView::showDates(): " << start.toString() << endl;
1595 1599
1596 QPtrVector<MonthViewCell> *cells; 1600 QPtrVector<MonthViewCell> *cells;
1597 QPtrVector<QLabel> *dayLabels; 1601 QPtrVector<QLabel> *dayLabels;
1598 QPtrVector<KOWeekButton> *weekLabels; 1602 QPtrVector<KOWeekButton> *weekLabels;
1599 uint weekNum = 6; 1603 uint weekNum = 6;
1600 mStartDate = start; 1604 mStartDate = start;
1601 if ( mShowWeekView ) { 1605 if ( mShowWeekView ) {
1602 weekNum = 1; 1606 weekNum = 1;
1603 cells = &mCellsW; 1607 cells = &mCellsW;
1604 dayLabels = &mDayLabelsW; 1608 dayLabels = &mDayLabelsW;
1605 weekLabels = &mWeekLabelsW; 1609 weekLabels = &mWeekLabelsW;
1606 if ( !KGlobal::locale()->weekStartsMonday() ) { 1610 if ( !KGlobal::locale()->weekStartsMonday() ) {
1607 mStartDate = mStartDate.addDays( 1 ); 1611 mStartDate = mStartDate.addDays( 1 );
1608 } 1612 }
1609 } else { 1613 } else {
1610 cells = &mCells; 1614 cells = &mCells;
1611 dayLabels = &mDayLabels; 1615 dayLabels = &mDayLabels;
1612 weekLabels = &mWeekLabels; 1616 weekLabels = &mWeekLabels;
1613 } 1617 }
1614 1618
1615 int mWeekStartsMonday = KGlobal::locale()->weekStartsMonday(); 1619 int mWeekStartsMonday = KGlobal::locale()->weekStartsMonday();
1616 1620
1617 if ( mShowWeekView || KOPrefs::instance()->mMonthViewSatSunTog ) { 1621 if ( mShowWeekView || KOPrefs::instance()->mMonthViewSatSunTog ) {
1618 mWeekStartsMonday = true; 1622 mWeekStartsMonday = true;
1619 } 1623 }
1620 int startWeekDay = mWeekStartsMonday ? 1 : 7; 1624 int startWeekDay = mWeekStartsMonday ? 1 : 7;
1621 1625
1622 while( KOGlobals::self()->calendarSystem()->dayOfWeek(mStartDate) != startWeekDay ) { 1626 while( KOGlobals::self()->calendarSystem()->dayOfWeek(mStartDate) != startWeekDay ) {
1623 mStartDate = mStartDate.addDays( -1 ); 1627 mStartDate = mStartDate.addDays( -1 );
1624 } 1628 }
1625 uint i; 1629 uint i;
1626 for( i = 0; i < (*cells).size(); ++i ) { 1630 for( i = 0; i < (*cells).size(); ++i ) {
1627 QDate date = mStartDate.addDays( i ); 1631 QDate date = mStartDate.addDays( i );
1628 (*cells)[i]->setDate( date ); 1632 (*cells)[i]->setDate( date );
1629 1633
1630#ifndef KORG_NOPLUGINS 1634#ifndef KORG_NOPLUGINS
1631 // add holiday, if present 1635 // add holiday, if present
1632 QString hstring(KOCore::self()->holiday(date)); 1636 QString hstring(KOCore::self()->holiday(date));
1633 (*cells)[i]->setHoliday( hstring ); 1637 (*cells)[i]->setHoliday( hstring );
1634#endif 1638#endif
1635 1639
1636 } 1640 }
1637 QDate date = mStartDate.addDays( mWeekStartsMonday ? 3 : 4 ); 1641 QDate date = mStartDate.addDays( mWeekStartsMonday ? 3 : 4 );
1638 for( i = 0; i < weekNum; ++i ) { 1642 for( i = 0; i < weekNum; ++i ) {
1639 int wno; 1643 int wno;
1640 // remember, according to ISO 8601, the first week of the year is the 1644 // remember, according to ISO 8601, the first week of the year is the
1641 // first week that contains a thursday. Thus we must subtract off 4, 1645 // first week that contains a thursday. Thus we must subtract off 4,
1642 // not just 1. 1646 // not just 1.
1643 int dayOfYear = date.dayOfYear(); 1647 int dayOfYear = date.dayOfYear();
1644 if (dayOfYear % 7 != 0) 1648 if (dayOfYear % 7 != 0)
1645 wno = dayOfYear / 7 + 1; 1649 wno = dayOfYear / 7 + 1;
1646 else 1650 else
1647 wno =dayOfYear / 7; 1651 wno =dayOfYear / 7;
1648 (*weekLabels)[i]->setWeekNum( wno ); 1652 (*weekLabels)[i]->setWeekNum( wno );
1649 date = date.addDays( 7 ); 1653 date = date.addDays( 7 );
1650 } 1654 }
1651 updateView(); 1655 updateView();
1652} 1656}
1653 1657
1654void KOMonthView::showEvents(QPtrList<Event>) 1658void KOMonthView::showEvents(QPtrList<Event>)
1655{ 1659{
1656 qDebug("KOMonthView::selectEvents is not implemented yet. "); 1660 qDebug("KOMonthView::selectEvents is not implemented yet. ");
1657} 1661}
1658 1662
1659void KOMonthView::changeEventDisplay(Event *, int) 1663void KOMonthView::changeEventDisplay(Event *, int)
1660{ 1664{
1661 // this should be re-written to be much more efficient, but this 1665 // this should be re-written to be much more efficient, but this
1662 // quick-and-dirty-hack gets the job done for right now. 1666 // quick-and-dirty-hack gets the job done for right now.
1663 //qDebug("KOMonthView::changeEventDisplay "); 1667 //qDebug("KOMonthView::changeEventDisplay ");
1664 updateView(); 1668 updateView();
1665} 1669}
1666 1670
1667void KOMonthView::updateView() 1671void KOMonthView::updateView()
1668{ 1672{
1669 1673
1670 if ( !updatePossible ) 1674 if ( !updatePossible )
1671 return; 1675 return;
1672 //qDebug("UUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU "); 1676 //qDebug("UUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU ");
1673 //QTime ti; 1677 //QTime ti;
1674 //ti.start(); 1678 //ti.start();
1675 clearSelection(); 1679 clearSelection();
1676 QPtrVector<MonthViewCell> *cells; 1680 QPtrVector<MonthViewCell> *cells;
1677 if ( mShowWeekView ) { 1681 if ( mShowWeekView ) {
1678 cells = &mCellsW; 1682 cells = &mCellsW;
1679 } else { 1683 } else {
1680 cells = &mCells; 1684 cells = &mCells;
1681 } 1685 }
1682#if 1 1686#if 1
1683 int i; 1687 int i;
1684 int timeSpan = (*cells).size()-1; 1688 int timeSpan = (*cells).size()-1;
1685 if ( KOPrefs::instance()->mMonthViewWeek ) 1689 if ( KOPrefs::instance()->mMonthViewWeek )
1686 timeSpan = 6; 1690 timeSpan = 6;
1687 for( i = 0; i < timeSpan + 1; ++i ) { 1691 for( i = 0; i < timeSpan + 1; ++i ) {
1688 (*cells)[i]->startUpdateCell(); 1692 (*cells)[i]->startUpdateCell();
1689 } 1693 }
1690 1694
1691 QPtrList<Event> events = calendar()->events(); 1695 QPtrList<Event> events = calendar()->events();
1692 Event *event; 1696 Event *event;
1693 QDateTime dt; 1697 QDateTime dt;
1694 QDate endDate = mStartDate.addDays( timeSpan ); 1698 QDate endDate = mStartDate.addDays( timeSpan );
1695 for( event = events.first(); event; event = events.next() ) { // for event 1699 for( event = events.first(); event; event = events.next() ) { // for event
1696 if ( event->doesRecur() ) { 1700 if ( event->doesRecur() ) {
1697 bool last; 1701 bool last;
1698 QDateTime incidenceStart = event->recurrence()->getPreviousDateTime( QDateTime( mStartDate ) , &last ); 1702 QDateTime incidenceStart = event->recurrence()->getPreviousDateTime( QDateTime( mStartDate ) , &last );
1699 QDateTime incidenceEnd; 1703 QDateTime incidenceEnd;
1700 int eventlen = event->dtStart().date().daysTo ( event->dtEnd().date() ); 1704 int eventlen = event->dtStart().date().daysTo ( event->dtEnd().date() );
1701 bool invalid = false; 1705 bool invalid = false;
1702 while( true ) { 1706 while( true ) {
1703 if ( incidenceStart.isValid() ) { 1707 if ( incidenceStart.isValid() ) {
1704 incidenceEnd = incidenceStart.addDays( eventlen ); 1708 incidenceEnd = incidenceStart.addDays( eventlen );
1705 int st = incidenceStart.date().daysTo( endDate ); 1709 int st = incidenceStart.date().daysTo( endDate );
1706 if ( st >= 0 ) { // start before timeend 1710 if ( st >= 0 ) { // start before timeend
1707 int end = mStartDate.daysTo( incidenceEnd.date() ); 1711 int end = mStartDate.daysTo( incidenceEnd.date() );
1708 if ( end >= 0 ) { // end after timestart --- got one! 1712 if ( end >= 0 ) { // end after timestart --- got one!
1709 //normalize 1713 //normalize
1710 st = timeSpan - st; 1714 st = timeSpan - st;
1711 if ( st < 0 ) st = 0; 1715 if ( st < 0 ) st = 0;
1712 if ( end > timeSpan ) end = timeSpan; 1716 if ( end > timeSpan ) end = timeSpan;
1713 int iii; 1717 int iii;
1714 //qDebug("found %s %d %d ",event->summary().latin1(), st, end ); 1718 //qDebug("found %s %d %d ",event->summary().latin1(), st, end );
1715 for ( iii = st;iii<= end;++iii) 1719 for ( iii = st;iii<= end;++iii)
1716 (*cells)[iii]->insertEvent( event ); 1720 (*cells)[iii]->insertEvent( event );
1717 } 1721 }
1718 } 1722 }
1719 } else { 1723 } else {
1720 if ( invalid ) 1724 if ( invalid )
1721 break; 1725 break;
1722 invalid = true; 1726 invalid = true;
1723 //qDebug("invalid %s", event->summary().latin1()); 1727 //qDebug("invalid %s", event->summary().latin1());
1724 incidenceStart = QDateTime( mStartDate ).addSecs( -2 );; 1728 incidenceStart = QDateTime( mStartDate ).addSecs( -2 );;
1725 } 1729 }
1726 if ( last ) 1730 if ( last )
1727 break; 1731 break;
1728 bool ok; 1732 bool ok;
1729 incidenceStart = event->getNextOccurence( incidenceStart.addSecs( 1 ) ,&ok ); 1733 incidenceStart = event->getNextOccurence( incidenceStart.addSecs( 1 ) ,&ok );
1730 if ( ! ok ) 1734 if ( ! ok )
1731 break; 1735 break;
1732 if ( incidenceStart.date() > endDate ) 1736 if ( incidenceStart.date() > endDate )
1733 break; 1737 break;
1734 } 1738 }
1735 } else { // no recur 1739 } else { // no recur
1736 if ( !KOPrefs::instance()->mShowSyncEvents && event->uid().left(2) == QString("la") ) 1740 if ( !KOPrefs::instance()->mShowSyncEvents && event->uid().left(2) == QString("la") )
1737 if ( event->uid().left(15) == QString("last-syncEvent-") ) 1741 if ( event->uid().left(15) == QString("last-syncEvent-") )
1738 continue; 1742 continue;
1739 int st = event->dtStart().date().daysTo( endDate ); 1743 int st = event->dtStart().date().daysTo( endDate );
1740 if ( st >= 0 ) { // start before timeend 1744 if ( st >= 0 ) { // start before timeend
1741 int end = mStartDate.daysTo( event->dtEnd().date() ); 1745 int end = mStartDate.daysTo( event->dtEnd().date() );
1742 if ( end >= 0 ) { // end after timestart --- got one! 1746 if ( end >= 0 ) { // end after timestart --- got one!
1743 //normalize 1747 //normalize
1744 st = timeSpan - st; 1748 st = timeSpan - st;
1745 if ( st < 0 ) st = 0; 1749 if ( st < 0 ) st = 0;
1746 if ( end > timeSpan ) end = timeSpan; 1750 if ( end > timeSpan ) end = timeSpan;
1747 int iii; 1751 int iii;
1748 for ( iii = st;iii<= end;++iii) 1752 for ( iii = st;iii<= end;++iii)
1749 (*cells)[iii]->insertEvent( event ); 1753 (*cells)[iii]->insertEvent( event );
1750 } 1754 }
1751 } 1755 }
1752 } 1756 }
1753 } 1757 }
1754 // insert due todos 1758 // insert due todos
1755 QPtrList<Todo> todos = calendar()->todos( ); 1759 QPtrList<Todo> todos = calendar()->todos( );
1756 Todo *todo; 1760 Todo *todo;
1757 for(todo = todos.first(); todo; todo = todos.next()) { 1761 for(todo = todos.first(); todo; todo = todos.next()) {
1758 //insertTodo( todo ); 1762 //insertTodo( todo );
1759 if ( todo->hasDueDate() ) { 1763 if ( todo->hasDueDate() ) {
1760 int day = mStartDate.daysTo( todo->dtDue().date() ); 1764 int day = mStartDate.daysTo( todo->dtDue().date() );
1761 if ( day >= 0 && day < timeSpan + 1) { 1765 if ( day >= 0 && day < timeSpan + 1) {
1762 (*cells)[day]->insertTodo( todo ); 1766 (*cells)[day]->insertTodo( todo );
1763 } 1767 }
1764 } 1768 }
1765 } 1769 }
1766 1770
1767 for( i = 0; i < timeSpan+1; ++i ) { 1771 for( i = 0; i < timeSpan+1; ++i ) {
1768 (*cells)[i]->finishUpdateCell(); 1772 (*cells)[i]->finishUpdateCell();
1769 } 1773 }
1770 processSelectionChange(); 1774 processSelectionChange();
1771 //qApp->processEvents(); 1775 //qApp->processEvents();
1772 for( i = 0; i < timeSpan+1; ++i ) { 1776 for( i = 0; i < timeSpan+1; ++i ) {
1773 //(*cells)[i]->repaintfinishUpdateCell(); 1777 //(*cells)[i]->repaintfinishUpdateCell();
1774 QTimer::singleShot( 0, (*cells)[i], SLOT ( repaintfinishUpdateCell() ) ); 1778 QTimer::singleShot( 0, (*cells)[i], SLOT ( repaintfinishUpdateCell() ) );
1775 } 1779 }
1776 setKeyBFocus(); 1780 setKeyBFocus();
1777#else 1781#else
1778 // old code 1782 // old code
1779 //qDebug("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ "); 1783 //qDebug("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ");
1780 int i; 1784 int i;
1781 for( i = 0; i < (*cells).count(); ++i ) { 1785 for( i = 0; i < (*cells).count(); ++i ) {
1782 (*cells)[i]->updateCell(); 1786 (*cells)[i]->updateCell();
1783 } 1787 }
1784 1788
1785 //qDebug("KOMonthView::updateView() "); 1789 //qDebug("KOMonthView::updateView() ");
1786 processSelectionChange(); 1790 processSelectionChange();
1787 // qDebug("---------------------------------------------------------------------+ "); 1791 // qDebug("---------------------------------------------------------------------+ ");
1788 (*cells)[0]->setFocus(); 1792 (*cells)[0]->setFocus();
1789#endif 1793#endif
1790 1794
1791 //qDebug("update time %d ", ti.elapsed()); 1795 //qDebug("update time %d ", ti.elapsed());
1792} 1796}
1793 1797
1794void KOMonthView::setKeyBoardFocus() 1798void KOMonthView::setKeyBoardFocus()
1795{ 1799{
1796 //qDebug("KOMonthView::setKeyBoardFocus() "); 1800 //qDebug("KOMonthView::setKeyBoardFocus() ");
1797 bool shootAgain = false; 1801 bool shootAgain = false;
1798 if ( mShowWeekView ) { 1802 if ( mShowWeekView ) {
1799 shootAgain = !mWeekLabelsW[1]->hasFocus(); 1803 shootAgain = !mWeekLabelsW[1]->hasFocus();
1800 mWeekLabelsW[1]->setFocus(); 1804 mWeekLabelsW[1]->setFocus();
1801 } 1805 }
1802 else { 1806 else {
1803 shootAgain = !mWeekLabels[mNumWeeks]->hasFocus(); 1807 shootAgain = !mWeekLabels[mNumWeeks]->hasFocus();
1804 mWeekLabels[mNumWeeks]->setFocus(); 1808 mWeekLabels[mNumWeeks]->setFocus();
1805 } 1809 }
1806 --mKBFcounter; 1810 --mKBFcounter;
1807 if ( shootAgain && mKBFcounter > 0 ) { 1811 if ( shootAgain && mKBFcounter > 0 ) {
1808 QTimer::singleShot( 50, this, SLOT ( setKeyBoardFocus() ) ); 1812 QTimer::singleShot( 50, this, SLOT ( setKeyBoardFocus() ) );
1809 } 1813 }
1810} 1814}
1811void KOMonthView::setKeyBFocus() 1815void KOMonthView::setKeyBFocus()
1812{ 1816{
1813 //qDebug("KOMonthView::setKeyBFocus() "); 1817 //qDebug("KOMonthView::setKeyBFocus() ");
1814 mKBFcounter = 10; 1818 mKBFcounter = 10;
1815 QTimer::singleShot( 0, this, SLOT ( setKeyBoardFocus() ) ); 1819 QTimer::singleShot( 0, this, SLOT ( setKeyBoardFocus() ) );
1816} 1820}
1817void KOMonthView::resizeEvent(QResizeEvent * e) 1821void KOMonthView::resizeEvent(QResizeEvent * e)
1818{ 1822{
1819 //qDebug("KOMonthView::resizeEvent %d %d -- %d %d ", e->size().width(), e->size().height(), e->oldSize().width(), e->oldSize().height()); 1823 //qDebug("KOMonthView::resizeEvent %d %d -- %d %d ", e->size().width(), e->size().height(), e->oldSize().width(), e->oldSize().height());
1820 if ( isVisible() ) { 1824 if ( isVisible() ) {
1821 //qDebug("KOMonthView::isVisible "); 1825 //qDebug("KOMonthView::isVisible ");
1822 slotComputeLayout(); 1826 slotComputeLayout();
1823 } else 1827 } else
1824 mComputeLayoutTimer->start( 100 ); 1828 mComputeLayoutTimer->start( 100 );
1825 if ( e ) 1829 if ( e )
1826 KOEventView::resizeEvent( e ); 1830 KOEventView::resizeEvent( e );
1827} 1831}
1828 1832
1829void KOMonthView::slotComputeLayout() 1833void KOMonthView::slotComputeLayout()
1830{ 1834{
1831 mComputeLayoutTimer->stop(); 1835 mComputeLayoutTimer->stop();
1832 //qDebug("KOMonthView::Post - resizeEvent %d %d ", width(), height() ); 1836 //qDebug("KOMonthView::Post - resizeEvent %d %d ", width(), height() );
1833 computeLayout(); 1837 computeLayout();
1834 clPending = true; 1838 clPending = true;
1835 setKeyBFocus(); 1839 setKeyBFocus();
1836} 1840}
1837 1841
1838void KOMonthView::doComputeLayoutWeek() 1842void KOMonthView::doComputeLayoutWeek()
1839{ 1843{
1840 1844
1841 int daysToShow; 1845 int daysToShow;
1842 bool combinedSatSun = false; 1846 bool combinedSatSun = false;
1843 if (mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ) { 1847 if (mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ) {
1844 daysToShow = 6; 1848 daysToShow = 6;
1845 combinedSatSun = true; 1849 combinedSatSun = true;
1846 } 1850 }
1847 int wid = width();//e 1851 int wid = width();//e
1848 int hei = height()-1-mNavigatorBar->height(); 1852 int hei = height()-1-mNavigatorBar->height();
1849#ifdef DESKTOP_VERSION 1853#ifdef DESKTOP_VERSION
1850 if ( !KOPrefs::instance()->mMonthViewWeekRowlayout ) { 1854 if ( !KOPrefs::instance()->mMonthViewWeekRowlayout ) {
1851 daysToShow = 2; 1855 daysToShow = 2;
1852 } else 1856 } else
1853#endif 1857#endif
1854 { 1858 {
1855 if ( wid < hei + 40 ) 1859 if ( wid < hei + 40 )
1856 daysToShow = 2; 1860 daysToShow = 2;
1857 else 1861 else
1858 daysToShow = 3; 1862 daysToShow = 3;
1859 } 1863 }
1860 bool landscape = (daysToShow == 3); 1864 bool landscape = (daysToShow == 3);
1861 mShowSatSunComp = true; 1865 mShowSatSunComp = true;
1862 combinedSatSun = true; 1866 combinedSatSun = true;
1863 1867
1864 //qDebug("KOMonthView::computeLayout() WWW ------------------------------------ "); 1868 //qDebug("KOMonthView::computeLayout() WWW ------------------------------------ ");
1865 QFontMetrics fm ( mWeekLabels[0]->font() ); 1869 QFontMetrics fm ( mWeekLabels[0]->font() );
1866 int weeklabelwid = fm.width( "888" ); 1870 int weeklabelwid = fm.width( "888" );
1867 wid -= weeklabelwid; 1871 wid -= weeklabelwid;
1868 1872
1869 int colWid = wid / daysToShow; 1873 int colWid = wid / daysToShow;
1870 int dayLabelHei = mDayLabelsW[0]->sizeHint().height(); 1874 int dayLabelHei = mDayLabelsW[0]->sizeHint().height();
1871 int cellHei = (hei - (5- daysToShow )*dayLabelHei) /(5- daysToShow ); 1875 int cellHei = (hei - (5- daysToShow )*dayLabelHei) /(5- daysToShow );
1872 int colModulo = wid % daysToShow; 1876 int colModulo = wid % daysToShow;
1873 int rowModulo = (hei- (5- daysToShow )*dayLabelHei) % daysToShow-1; 1877 int rowModulo = (hei- (5- daysToShow )*dayLabelHei) % daysToShow-1;
1874 //qDebug("rowmod %d ", rowModulo); 1878 //qDebug("rowmod %d ", rowModulo);
1875 int i; 1879 int i;
1876 int x,y,w,h; 1880 int x,y,w,h;
1877 x= 0; 1881 x= 0;
1878 y= 0; 1882 y= 0;
1879 w = colWid; 1883 w = colWid;
1880 h = dayLabelHei ; 1884 h = dayLabelHei ;
1881 for ( i = 0; i < 7; i++) { 1885 for ( i = 0; i < 7; i++) {
1882 if ( i && !( i % daysToShow) && i < 6) { 1886 if ( i && !( i % daysToShow) && i < 6) {
1883 y += hei/(5-daysToShow); 1887 y += hei/(5-daysToShow);
1884 x = 0; 1888 x = 0;
1885 w = colWid; 1889 w = colWid;
1886 } 1890 }
1887 if ( ((i) % daysToShow) >= daysToShow-colModulo ) { 1891 if ( ((i) % daysToShow) >= daysToShow-colModulo ) {
1888 ++w; 1892 ++w;
1889 } 1893 }
1890 int xC,yC,wC,hC; 1894 int xC,yC,wC,hC;
1891 if ( i >= 5 ) { 1895 if ( i >= 5 ) {
1892 int wi = width() - x - weeklabelwid; 1896 int wi = width() - x - weeklabelwid;
1893 if ( i == 5 ) { 1897 if ( i == 5 ) {
1894 xC = x+weeklabelwid; 1898 xC = x+weeklabelwid;
1895 yC = y; 1899 yC = y;
1896 wC = wi/2+wi%2; 1900 wC = wi/2+wi%2;
1897 hC = h; 1901 hC = h;
1898 } else { 1902 } else {
1899 xC = x+weeklabelwid; 1903 xC = x+weeklabelwid;
1900 yC = y; 1904 yC = y;
1901 wC = wi; 1905 wC = wi;
1902 hC = h; 1906 hC = h;
1903 } 1907 }
1904 x = x - w + wi - (wi/2 ); 1908 x = x - w + wi - (wi/2 );
1905 } 1909 }
1906 else { 1910 else {
1907 int wi = w; 1911 int wi = w;
1908 if ( !(( i+1) % daysToShow)) { 1912 if ( !(( i+1) % daysToShow)) {
1909 wi = width() - x - weeklabelwid; 1913 wi = width() - x - weeklabelwid;
1910 } 1914 }
1911 xC = x+weeklabelwid; 1915 xC = x+weeklabelwid;
1912 yC = y; 1916 yC = y;
1913 wC = wi; 1917 wC = wi;
1914 hC = h; 1918 hC = h;
1915 } 1919 }
1916 mDayLabelsW[mapWeekLayout(i,landscape)]->setGeometry( xC,yC,wC,hC); 1920 mDayLabelsW[mapWeekLayout(i,landscape)]->setGeometry( xC,yC,wC,hC);
1917 1921
1918 1922
1919 x += w; 1923 x += w;
1920 } 1924 }
1921 x= 0; 1925 x= 0;
1922 y= dayLabelHei; 1926 y= dayLabelHei;
1923 w = colWid; 1927 w = colWid;
1924 h = cellHei; 1928 h = cellHei;
1925 int max = 0; 1929 int max = 0;
1926 int w_count = mCellsW.count(); 1930 int w_count = mCellsW.count();
1927 for ( i = 0; i < w_count; ++i) { 1931 for ( i = 0; i < w_count; ++i) {
1928 if ( i > 6 ) { 1932 if ( i > 6 ) {
1929 mCellsW[i]->hide(); 1933 mCellsW[i]->hide();
1930 continue; 1934 continue;
1931 } 1935 }
1932 1936
1933 w = colWid; 1937 w = colWid;
1934 if ( ((i) % daysToShow) >= daysToShow-colModulo ) { 1938 if ( ((i) % daysToShow) >= daysToShow-colModulo ) {
1935 ++w; 1939 ++w;
1936 } 1940 }
1937 if ( i == (daysToShow-1-rowModulo)*7) 1941 if ( i == (daysToShow-1-rowModulo)*7)
1938 ++h; 1942 ++h;
1939 1943
1940 int xC,yC,wC,hC; 1944 int xC,yC,wC,hC;
1941 if ( i >= 5 ) { 1945 if ( i >= 5 ) {
1942 if ( i ==5 ) { 1946 if ( i ==5 ) {
1943 max = h/2; 1947 max = h/2;
1944 xC = x+weeklabelwid; 1948 xC = x+weeklabelwid;
1945 yC = y; 1949 yC = y;
1946 wC = w; 1950 wC = w;
1947 hC = max; 1951 hC = max;
1948 x -= w ;y += h/2; 1952 x -= w ;y += h/2;
1949 } else { 1953 } else {
1950 if ( ((i-1) % daysToShow) >= daysToShow-colModulo ) { 1954 if ( ((i-1) % daysToShow) >= daysToShow-colModulo ) {
1951 ++w; 1955 ++w;
1952 } 1956 }
1953 max = h-h/2; 1957 max = h-h/2;
1954 xC = x+weeklabelwid; 1958 xC = x+weeklabelwid;
1955 yC = y; 1959 yC = y;
1956 wC = w; 1960 wC = w;
1957 hC = max; 1961 hC = max;
1958 y -= h/2; 1962 y -= h/2;
1959 } 1963 }
1960 } else { 1964 } else {
1961 max = h; 1965 max = h;
1962 xC = x+weeklabelwid; 1966 xC = x+weeklabelwid;
1963 yC = y; 1967 yC = y;
1964 wC = w; 1968 wC = w;
1965 hC = h; 1969 hC = h;
1966 } 1970 }
1967 mCellsW[mapWeekLayout(i,landscape)]->setGeometry ( xC,yC,wC,hC ); 1971 mCellsW[mapWeekLayout(i,landscape)]->setGeometry ( xC,yC,wC,hC );
1968 1972
1969 1973
1970 x += w; 1974 x += w;
1971 if ( x + w/2 > wid ) { 1975 if ( x + w/2 > wid ) {
1972 x = 0; 1976 x = 0;
1973 y += h+dayLabelHei ; 1977 y += h+dayLabelHei ;
1974 } 1978 }
1975 //mCellsW[i]->dateLabel()->setMaximumHeight( max - mCellsW[i]->lineWidth()*2 ); 1979 //mCellsW[i]->dateLabel()->setMaximumHeight( max - mCellsW[i]->lineWidth()*2 );
1976 } 1980 }
1977 y= dayLabelHei; 1981 y= dayLabelHei;
1978 h = cellHei ; 1982 h = cellHei ;
1979 mWeekLabelsW[0]->setGeometry( 0,y,weeklabelwid,hei-dayLabelHei); 1983 mWeekLabelsW[0]->setGeometry( 0,y,weeklabelwid,hei-dayLabelHei);
1980 mWeekLabelsW[1]->setGeometry( 0,0,weeklabelwid,dayLabelHei); 1984 mWeekLabelsW[1]->setGeometry( 0,0,weeklabelwid,dayLabelHei);
1981 // qDebug("RRRRRRRRRRRRR %d %d old %d %d", e->size().width(),e->size().height() , e->oldSize().width(),e->oldSize().height()); 1985 // qDebug("RRRRRRRRRRRRR %d %d old %d %d", e->size().width(),e->size().height() , e->oldSize().width(),e->oldSize().height());
1982 //qDebug("parent %d %d ", topLevelWidget()->size().width(), topLevelWidget()->size().height()); 1986 //qDebug("parent %d %d ", topLevelWidget()->size().width(), topLevelWidget()->size().height());
1983 mShortDayLabelsW = mDayLabelsW[0]->width()-2 < mWidthLongDayLabel ; 1987 mShortDayLabelsW = mDayLabelsW[0]->width()-2 < mWidthLongDayLabel ;
1984 updateDayLabels(); 1988 updateDayLabels();
1985 //bool forceUpdate = !updatePossible; 1989 //bool forceUpdate = !updatePossible;
1986 updatePossible = true; 1990 updatePossible = true;
1987 //mWeekLabels[mNumWeeks]->setText( i18n("M")); 1991 //mWeekLabels[mNumWeeks]->setText( i18n("M"));
1988 //if ( forceUpdate ) 1992 //if ( forceUpdate )
1989 // updateView(); 1993 // updateView();
1990} 1994}
1991void KOMonthView::computeLayoutWeek() 1995void KOMonthView::computeLayoutWeek()
1992{ 1996{
1993 static int lastWid = 0; 1997 static int lastWid = 0;
1994 static int lastHei = 0; 1998 static int lastHei = 0;
1995 int tWid = topLevelWidget()->size().width(); 1999 int tWid = topLevelWidget()->size().width();
1996 int tHei = topLevelWidget()->size().height(); 2000 int tHei = topLevelWidget()->size().height();
1997 int wid = width();//e 2001 int wid = width();//e
1998 int hei = height()-1-mNavigatorBar->height(); 2002 int hei = height()-1-mNavigatorBar->height();
1999 if ( ((wid *3)/2) < tWid && (( hei *3) /2) < tHei ) 2003 if ( ((wid *3)/2) < tWid && (( hei *3) /2) < tHei )
2000 return; 2004 return;
2001 2005
2002 if ( lastWid == width() && lastHei == height() ) { 2006 if ( lastWid == width() && lastHei == height() ) {
2003 //qDebug("KOListWeekView::No compute layout needed "); 2007 //qDebug("KOListWeekView::No compute layout needed ");
2004 return; 2008 return;
2005 } 2009 }
2006 lastWid = width(); 2010 lastWid = width();
2007 lastHei = height(); 2011 lastHei = height();
2008 doComputeLayoutWeek(); 2012 doComputeLayoutWeek();
2009} 2013}
2010int KOMonthView::mapWeekLayout( int index, bool landscape ) 2014int KOMonthView::mapWeekLayout( int index, bool landscape )
2011{ 2015{
2012 if ( KOPrefs::instance()->mMonthViewWeekRowlayout ) 2016 if ( KOPrefs::instance()->mMonthViewWeekRowlayout )
2013 return index; 2017 return index;
2014 int diff = 0; 2018 int diff = 0;
2015 if ( !landscape ) diff = 1; 2019 if ( !landscape ) diff = 1;
2016 switch( index ) { 2020 switch( index ) {
2017 case 0: 2021 case 0:
2018 case 5: 2022 case 5:
2019 case 6: 2023 case 6:
2020 return index; 2024 return index;
2021 break; 2025 break;
2022 case 1: 2026 case 1:
2023 return 2+diff; 2027 return 2+diff;
2024 break; 2028 break;
2025 case 2: 2029 case 2:
2026 return 4-(3*diff); 2030 return 4-(3*diff);
2027 break; 2031 break;
2028 case 3: 2032 case 3:
2029 return 1+(3*diff); 2033 return 1+(3*diff);
2030 break; 2034 break;
2031 case 4: 2035 case 4:
2032 return 3-diff; 2036 return 3-diff;
2033 break; 2037 break;
2034 default: 2038 default:
2035 qDebug("KO: Error in mapping week layout "); 2039 qDebug("KO: Error in mapping week layout ");
2036 return index; 2040 return index;
2037 break; 2041 break;
2038 } 2042 }
2039 return index; 2043 return index;
2040} 2044}
2041void KOMonthView::computeLayout() 2045void KOMonthView::computeLayout()
2042{ 2046{
2043 2047
2044 2048
2045 static int lastWid = 0; 2049 static int lastWid = 0;
2046 static int lastHei = 0; 2050 static int lastHei = 0;
2047 2051
2048 if ( mShowWeekView ){ 2052 if ( mShowWeekView ){
2049 computeLayoutWeek(); 2053 computeLayoutWeek();
2050 return; 2054 return;
2051 } 2055 }
2052 int daysToShow = 7; 2056 int daysToShow = 7;
2053 bool combinedSatSun = false; 2057 bool combinedSatSun = false;
2054 if (mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ) { 2058 if (mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ) {
2055 daysToShow = 6; 2059 daysToShow = 6;
2056 combinedSatSun = true; 2060 combinedSatSun = true;
2057 } 2061 }
2058 int tWid = topLevelWidget()->size().width(); 2062 int tWid = topLevelWidget()->size().width();
2059 int tHei = topLevelWidget()->size().height(); 2063 int tHei = topLevelWidget()->size().height();
2060 2064
2061 int wid = width();//e 2065 int wid = width();//e
2062 int hei = height()-1-mNavigatorBar->height(); 2066 int hei = height()-1-mNavigatorBar->height();
2063 2067
2064 if ( ((wid *3)/2) < tWid && (( hei *3) /2) < tHei ) { 2068 if ( ((wid *3)/2) < tWid && (( hei *3) /2) < tHei ) {
2065 return; 2069 return;
2066 } 2070 }
2067 if ( lastWid == width() && lastHei == height() ){ 2071 if ( lastWid == width() && lastHei == height() ){
2068 //qDebug("KOMonthview::No compute layout needed "); 2072 //qDebug("KOMonthview::No compute layout needed ");
2069 return; 2073 return;
2070 } 2074 }
2071 2075
2072 lastWid = width(); 2076 lastWid = width();
2073 lastHei = height(); 2077 lastHei = height();
2074 //qDebug("KOMonthView::computeLayout() MMM ------------------- "); 2078 //qDebug("KOMonthView::computeLayout() MMM ------------------- ");
2075 QFontMetrics fm ( mWeekLabels[0]->font() ); 2079 QFontMetrics fm ( mWeekLabels[0]->font() );
2076 int weeklabelwid = fm.width( "888" ); 2080 int weeklabelwid = fm.width( "888" );
2077 wid -= weeklabelwid; 2081 wid -= weeklabelwid;
2078 2082
2079 int colWid = wid / daysToShow; 2083 int colWid = wid / daysToShow;
2080 int dayLabelHei = mDayLabels[0]->sizeHint().height(); 2084 int dayLabelHei = mDayLabels[0]->sizeHint().height();
2081 int cellHei = (hei - dayLabelHei) /6; 2085 int cellHei = (hei - dayLabelHei) /6;
2082 int colModulo = wid % daysToShow; 2086 int colModulo = wid % daysToShow;
2083 int rowModulo = (hei- dayLabelHei) % 6; 2087 int rowModulo = (hei- dayLabelHei) % 6;
2084 //qDebug("rowmod %d ", rowModulo); 2088 //qDebug("rowmod %d ", rowModulo);
2085 int i; 2089 int i;
2086 int x,y,w,h; 2090 int x,y,w,h;
2087 x= 0; 2091 x= 0;
2088 y= 0; 2092 y= 0;
2089 w = colWid; 2093 w = colWid;
2090 h = dayLabelHei ; 2094 h = dayLabelHei ;
2091 for ( i = 0; i < 7; i++) { 2095 for ( i = 0; i < 7; i++) {
2092 if ( i == daysToShow-colModulo ) 2096 if ( i == daysToShow-colModulo )
2093 ++w; 2097 ++w;
2094 if ( combinedSatSun ) { 2098 if ( combinedSatSun ) {
2095 if ( i >= daysToShow-1 ) { 2099 if ( i >= daysToShow-1 ) {
2096 2100
2097 if ( i == 6 ) 2101 if ( i == 6 )
2098 mDayLabels[i]->setGeometry( x+weeklabelwid,y,width()-x-weeklabelwid,h); 2102 mDayLabels[i]->setGeometry( x+weeklabelwid,y,width()-x-weeklabelwid,h);
2099 else 2103 else
2100 mDayLabels[i]->setGeometry( x+weeklabelwid,y,w/2,h); 2104 mDayLabels[i]->setGeometry( x+weeklabelwid,y,w/2,h);
2101 x -= w/2 ; 2105 x -= w/2 ;
2102 } 2106 }
2103 else 2107 else
2104 mDayLabels[i]->setGeometry( x+weeklabelwid,y,w,h); 2108 mDayLabels[i]->setGeometry( x+weeklabelwid,y,w,h);
2105 } else 2109 } else
2106 mDayLabels[i]->setGeometry( x+weeklabelwid,y,w,h); 2110 mDayLabels[i]->setGeometry( x+weeklabelwid,y,w,h);
2107 x += w; 2111 x += w;
2108 } 2112 }
2109 x= 0; 2113 x= 0;
2110 y= dayLabelHei; 2114 y= dayLabelHei;
2111 w = colWid; 2115 w = colWid;
2112 h = cellHei ; 2116 h = cellHei ;
2113 int max = 0; 2117 int max = 0;
2114 int mc_count = mCells.count(); 2118 int mc_count = mCells.count();
2115 for ( i = 0; i < mc_count; ++i) { 2119 for ( i = 0; i < mc_count; ++i) {
2116 //qDebug("iii %d ", i); 2120 //qDebug("iii %d ", i);
2117 w = colWid; 2121 w = colWid;
2118 if ( ((i) % 7) >= 7-colModulo ) { 2122 if ( ((i) % 7) >= 7-colModulo ) {
2119 ++w; 2123 ++w;
2120 } 2124 }
2121 if ( i == (6-rowModulo)*7) 2125 if ( i == (6-rowModulo)*7)
2122 ++h; 2126 ++h;
2123 if ( combinedSatSun ) { 2127 if ( combinedSatSun ) {
2124 if ( (i)%7 >= daysToShow-1 ) { 2128 if ( (i)%7 >= daysToShow-1 ) {
2125 if ( (i)%7 == daysToShow-1 ) { 2129 if ( (i)%7 == daysToShow-1 ) {
2126 w = width()-x-weeklabelwid; 2130 w = width()-x-weeklabelwid;
2127 max = h/2; 2131 max = h/2;
2128 mCells[i]->setGeometry ( x+weeklabelwid,y,w,max ); 2132 mCells[i]->setGeometry ( x+weeklabelwid,y,w,max );
2129 x -= w ;y += h/2; 2133 x -= w ;y += h/2;
2130 } else { 2134 } else {
2131 w = width()-x-weeklabelwid; 2135 w = width()-x-weeklabelwid;
2132 max = h-h/2; 2136 max = h-h/2;
2133 mCells[i]->setGeometry ( x+weeklabelwid,y,w,max ); 2137 mCells[i]->setGeometry ( x+weeklabelwid,y,w,max );
2134 y -= h/2; 2138 y -= h/2;
2135 } 2139 }
2136 } else { 2140 } else {
2137 max = h; 2141 max = h;
2138 mCells[i]->setGeometry ( x+weeklabelwid,y,w,h ); 2142 mCells[i]->setGeometry ( x+weeklabelwid,y,w,h );
2139 } 2143 }
2140 2144
2141 } 2145 }
2142 else { 2146 else {
2143 max = h; 2147 max = h;
2144 mCells[i]->setGeometry ( x+weeklabelwid,y,w,h ); 2148 mCells[i]->setGeometry ( x+weeklabelwid,y,w,h );
2145 } 2149 }
2146 x += w; 2150 x += w;
2147 if ( x + w/2 > wid ) { 2151 if ( x + w/2 > wid ) {
2148 x = 0; 2152 x = 0;
2149 y += h; 2153 y += h;
2150 } 2154 }
2151 //mCells[i]->dateLabel()->setMaximumHeight( max- mCells[i]->lineWidth()*2 ); 2155 //mCells[i]->dateLabel()->setMaximumHeight( max- mCells[i]->lineWidth()*2 );
2152 } 2156 }
2153 y= dayLabelHei; 2157 y= dayLabelHei;
2154 h = cellHei ; 2158 h = cellHei ;
2155 for ( i = 0; i < 6; i++) { 2159 for ( i = 0; i < 6; i++) {
2156 if ( i == (6-rowModulo)) 2160 if ( i == (6-rowModulo))
2157 ++h; 2161 ++h;
2158 mWeekLabels[i]->setGeometry( 0,y,weeklabelwid,h); 2162 mWeekLabels[i]->setGeometry( 0,y,weeklabelwid,h);
2159 y += h; 2163 y += h;
2160 } 2164 }
2161 mWeekLabels[6]->setGeometry( 0,0,weeklabelwid,dayLabelHei); 2165 mWeekLabels[6]->setGeometry( 0,0,weeklabelwid,dayLabelHei);
2162 // qDebug("RRRRRRRRRRRRR %d %d old %d %d", e->size().width(),e->size().height() , e->oldSize().width(),e->oldSize().height()); 2166 // qDebug("RRRRRRRRRRRRR %d %d old %d %d", e->size().width(),e->size().height() , e->oldSize().width(),e->oldSize().height());
2163 //qDebug("parent %d %d ", topLevelWidget()->size().width(), topLevelWidget()->size().height()); 2167 //qDebug("parent %d %d ", topLevelWidget()->size().width(), topLevelWidget()->size().height());
2164 mShortDayLabelsM = mDayLabels[0]->width()-2 < mWidthLongDayLabel ; 2168 mShortDayLabelsM = mDayLabels[0]->width()-2 < mWidthLongDayLabel ;
2165 updateDayLabels(); 2169 updateDayLabels();
2166 //bool forceUpdate = !updatePossible; 2170 //bool forceUpdate = !updatePossible;
2167 updatePossible = true; 2171 updatePossible = true;
2168 //mWeekLabels[mNumWeeks]->setText( i18n("W")); 2172 //mWeekLabels[mNumWeeks]->setText( i18n("W"));
2169} 2173}
2170 2174
2171void KOMonthView::showContextMenu( Incidence *incidence ) 2175void KOMonthView::showContextMenu( Incidence *incidence )
2172{ 2176{
2173 if( incidence ) 2177 if( incidence )
2174 mContextMenu->showIncidencePopup(incidence); 2178 mContextMenu->showIncidencePopup(incidence);
2175 else { 2179 else {
2176 //qDebug("KOMonthView::showContextMenu "); 2180 //qDebug("KOMonthView::showContextMenu ");
2177 mNewItemMenu->popup(QCursor::pos()); 2181 mNewItemMenu->popup(QCursor::pos());
2178 } 2182 }
2179 /* 2183 /*
2180 if( incidence && incidence->typeID() == eventID ) { 2184 if( incidence && incidence->typeID() == eventID ) {
2181 Event *event = static_cast<Event *>(incidence); 2185 Event *event = static_cast<Event *>(incidence);
2182 mContextMenu->showEventPopup(event); 2186 mContextMenu->showEventPopup(event);
2183 } else { 2187 } else {
2184 kdDebug() << "MonthView::showContextMenu(): cast failed." << endl; 2188 kdDebug() << "MonthView::showContextMenu(): cast failed." << endl;
2185 } 2189 }
2186 */ 2190 */
2187} 2191}
2188MonthViewCell * KOMonthView::selectedCell( ) 2192MonthViewCell * KOMonthView::selectedCell( )
2189{ 2193{
2190 return mSelectedCell; 2194 return mSelectedCell;
2191} 2195}
2192void KOMonthView::setSelectedCell( MonthViewCell *cell ) 2196void KOMonthView::setSelectedCell( MonthViewCell *cell )
2193{ 2197{
2194 //qDebug("KOMonthView::setSelectedCell %d", cell); 2198 //qDebug("KOMonthView::setSelectedCell %d", cell);
2195 if ( mSelectedCell && mSelectedCell != cell ) { 2199 if ( mSelectedCell && mSelectedCell != cell ) {
2196 MonthViewCell * mvc = mSelectedCell; 2200 MonthViewCell * mvc = mSelectedCell;
2197 mSelectedCell = cell; 2201 mSelectedCell = cell;
2198 mvc->deselect(); 2202 mvc->deselect();
2199 } else 2203 } else
2200 mSelectedCell = cell; 2204 mSelectedCell = cell;
2201 // if ( mSelectedCell ) 2205 // if ( mSelectedCell )
2202 // mSelectedCell->select(); 2206 // mSelectedCell->select();
2203 if ( !mSelectedCell ) 2207 if ( !mSelectedCell )
2204 emit incidenceSelected( 0 ); 2208 emit incidenceSelected( 0 );
2205 else 2209 else
2206 emit incidenceSelected( mSelectedCell->selectedIncidence() ); 2210 emit incidenceSelected( mSelectedCell->selectedIncidence() );
2207} 2211}
2208 2212
2209void KOMonthView::processSelectionChange() 2213void KOMonthView::processSelectionChange()
2210{ 2214{
2211 QPtrList<Incidence> incidences = selectedIncidences(); 2215 QPtrList<Incidence> incidences = selectedIncidences();
2212 if (incidences.count() > 0) { 2216 if (incidences.count() > 0) {
2213 emit incidenceSelected( incidences.first() ); 2217 emit incidenceSelected( incidences.first() );
2214 } else { 2218 } else {
2215 emit incidenceSelected( 0 ); 2219 emit incidenceSelected( 0 );
2216 clearSelection(); 2220 clearSelection();
2217 } 2221 }
2218} 2222}
2219 2223
2220void KOMonthView::clearSelection() 2224void KOMonthView::clearSelection()
2221{ 2225{
2222 if ( mSelectedCell ) { 2226 if ( mSelectedCell ) {
2223 mSelectedCell->deselect(); 2227 mSelectedCell->deselect();
2224 mSelectedCell = 0; 2228 mSelectedCell = 0;
2225 } 2229 }
2226} 2230}
2227 2231
2228void KOMonthView::keyReleaseEvent ( QKeyEvent * e) 2232void KOMonthView::keyReleaseEvent ( QKeyEvent * e)
2229{ 2233{
2230 if ( !e->isAutoRepeat() ) { 2234 if ( !e->isAutoRepeat() ) {
2231 mFlagKeyPressed = false; 2235 mFlagKeyPressed = false;
2232 } 2236 }
2233} 2237}
2234 2238
2235void KOMonthView::keyPressEvent ( QKeyEvent * e ) 2239void KOMonthView::keyPressEvent ( QKeyEvent * e )
2236{ 2240{
2237 2241
2238 qApp->processEvents(); 2242 qApp->processEvents();
2239 if ( e->isAutoRepeat() && !mFlagKeyPressed ) { 2243 if ( e->isAutoRepeat() && !mFlagKeyPressed ) {
2240 //e->ignore(); 2244 //e->ignore();
2241 e->accept(); 2245 e->accept();
2242 return; 2246 return;
2243 } 2247 }
2244 if (! e->isAutoRepeat() ) 2248 if (! e->isAutoRepeat() )
2245 mFlagKeyPressed = true; 2249 mFlagKeyPressed = true;
2246 switch(e->key()) { 2250 switch(e->key()) {
2247 case Key_Up: 2251 case Key_Up:
2248 { 2252 {
2249 if ( mShowWeekView ) { 2253 if ( mShowWeekView ) {
2250 emit selectWeekNum ( currentWeek() - 1 ); 2254 emit selectWeekNum ( currentWeek() - 1 );
2251 } 2255 }
2252 else { 2256 else {
2253 emit prevMonth(); 2257 emit prevMonth();
2254 } 2258 }
2255 } 2259 }
2256 e->accept(); 2260 e->accept();
2257 break; 2261 break;
2258 case Key_Down: 2262 case Key_Down:
2259 { 2263 {
2260 if ( mShowWeekView ) { 2264 if ( mShowWeekView ) {
2261 emit selectWeekNum ( currentWeek() +1); 2265 emit selectWeekNum ( currentWeek() +1);
2262 } 2266 }
2263 else { 2267 else {
2264 emit nextMonth(); 2268 emit nextMonth();
2265 } 2269 }
2266 2270
2267 } 2271 }
2268 e->accept(); 2272 e->accept();
2269 break; 2273 break;
2270 case Key_Return: 2274 case Key_Return:
2271 case Key_Enter: 2275 case Key_Enter:
2272 { 2276 {
2273 selectInternalWeekNum ( currentWeek() ); 2277 selectInternalWeekNum ( currentWeek() );
2274 } 2278 }
2275 e->accept(); 2279 e->accept();
2276 break; 2280 break;
2277 case Key_D: 2281 case Key_D:
2278 if ( mSelectedCell ) { 2282 if ( mSelectedCell ) {
2279 mSelectedCell->showDay(); 2283 mSelectedCell->showDay();
2280 e->accept(); 2284 e->accept();
2281 } else { 2285 } else {
2282 e->ignore(); 2286 e->ignore();
2283 } 2287 }
2284 break; 2288 break;
2285 default: 2289 default:
2286 e->ignore(); 2290 e->ignore();
2287 break; 2291 break;
2288 } 2292 }
2289} 2293}
2290 2294
2291void KOMonthView::nextCell() 2295void KOMonthView::nextCell()
2292{ 2296{
2293 focusNextPrevChild ( true ); 2297 focusNextPrevChild ( true );
2294} 2298}
2295void KOMonthView::prevCell() 2299void KOMonthView::prevCell()
2296{ 2300{
2297 focusNextPrevChild ( false ); 2301 focusNextPrevChild ( false );
2298} 2302}
2299 2303
2300void KOMonthView::slotNewTodo() 2304void KOMonthView::slotNewTodo()
2301{ 2305{
2302 //qDebug("KOMonthView::slotNewTodo() "); 2306 //qDebug("KOMonthView::slotNewTodo() ");
2303 if ( mPopupCell ){ 2307 if ( mPopupCell ){
2304 QDateTime dt( mPopupCell->date(), QTime( KOPrefs::instance()->mStartTime, 0 ) ); 2308 QDateTime dt( mPopupCell->date(), QTime( KOPrefs::instance()->mStartTime, 0 ) );
2305 emit newTodoSignal(dt,true); 2309 emit newTodoSignal(dt,true);
2306 } 2310 }
2307 mPopupCell = 0; 2311 mPopupCell = 0;
2308} 2312}
2309void KOMonthView::slotNewEvent() 2313void KOMonthView::slotNewEvent()
2310{ 2314{
2311 if ( mPopupCell ) { 2315 if ( mPopupCell ) {
2312 QDateTime dt( mPopupCell->date(), QTime( KOPrefs::instance()->mStartTime, 0 ) ); 2316 QDateTime dt( mPopupCell->date(), QTime( KOPrefs::instance()->mStartTime, 0 ) );
2313 emit newEventSignal( dt ); 2317 emit newEventSignal( dt );
2314 } 2318 }
2315 //qDebug("KOMonthView::slotNewEvent() "); 2319 //qDebug("KOMonthView::slotNewEvent() ");
2316 mPopupCell = 0; 2320 mPopupCell = 0;
2317} 2321}
2318 2322
2319void KOMonthView::slotEditJournal() 2323void KOMonthView::slotEditJournal()
2320{ 2324{
2321 if ( mPopupCell ) 2325 if ( mPopupCell )
2322 emit showJournalSignal( 7, mPopupCell->date() ); 2326 emit showJournalSignal( 7, mPopupCell->date() );
2323 //qDebug("KOMonthView::slotEditJournal() "); 2327 //qDebug("KOMonthView::slotEditJournal() ");
2324 mPopupCell = 0; 2328 mPopupCell = 0;
2325} 2329}
2326 2330
2327void KOMonthView::setPopupCell( MonthViewCell * c) 2331void KOMonthView::setPopupCell( MonthViewCell * c)
2328{ 2332{
2329 mPopupCell = c; 2333 mPopupCell = c;
2330} 2334}
diff --git a/korganizer/komonthview.h b/korganizer/komonthview.h
index 61a141a..1a9d16d 100644
--- a/korganizer/komonthview.h
+++ b/korganizer/komonthview.h
@@ -1,350 +1,351 @@
1/* 1/*
2 This file is part of KOrganizer. 2 This file is part of KOrganizer.
3 Copyright (c) 2000,2001 Cornelius Schumacher <schumacher@kde.org> 3 Copyright (c) 2000,2001 Cornelius Schumacher <schumacher@kde.org>
4 4
5 This program is free software; you can redistribute it and/or modify 5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by 6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or 7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version. 8 (at your option) any later version.
9 9
10 This program is distributed in the hope that it will be useful, 10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details. 13 GNU General Public License for more details.
14 14
15 You should have received a copy of the GNU General Public License 15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software 16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18*/ 18*/
19 19
20#ifndef _KOMONTHVIEW_H 20#ifndef _KOMONTHVIEW_H
21#define _KOMONTHVIEW_H 21#define _KOMONTHVIEW_H
22 22
23#include <qlabel.h> 23#include <qlabel.h>
24#include <qframe.h> 24#include <qframe.h>
25#include <qdatetime.h> 25#include <qdatetime.h>
26#include <qlistbox.h> 26#include <qlistbox.h>
27#include <qpoint.h> 27#include <qpoint.h>
28#include <qwidgetstack.h> 28#include <qwidgetstack.h>
29#include <qlayout.h> 29#include <qlayout.h>
30#include <qtimer.h> 30#include <qtimer.h>
31#include <qintdict.h> 31#include <qintdict.h>
32#include <qpushbutton.h> 32#include <qpushbutton.h>
33#include <qvaluelist.h> 33#include <qvaluelist.h>
34#include <qptrvector.h> 34#include <qptrvector.h>
35 35
36#include <libkcal/calendar.h> 36#include <libkcal/calendar.h>
37#include <libkcal/event.h> 37#include <libkcal/event.h>
38 38
39#include "koeventview.h" 39#include "koeventview.h"
40#include "navigatorbar.h" 40#include "navigatorbar.h"
41 41
42#ifdef DESKTOP_VERSION 42#ifdef DESKTOP_VERSION
43class QToolTipGroup; 43class QToolTipGroup;
44#endif 44#endif
45 45
46class KNOWhatsThis; 46class KNOWhatsThis;
47class MonthViewCell; 47class MonthViewCell;
48class KOWeekButton : public QPushButton 48class KOWeekButton : public QPushButton
49{ 49{
50 Q_OBJECT 50 Q_OBJECT
51 public: 51 public:
52 KOWeekButton( QWidget *parent=0, const char *name=0 ) : 52 KOWeekButton( QWidget *parent=0, const char *name=0 ) :
53 QPushButton( parent, name) 53 QPushButton( parent, name)
54 { 54 {
55 connect( this, SIGNAL( clicked() ), 55 connect( this, SIGNAL( clicked() ),
56 SLOT( bottonClicked() )); 56 SLOT( bottonClicked() ));
57 mNumber = -1; 57 mNumber = -1;
58 } 58 }
59 void setWeekNum ( int num ) {mNumber = num; setText( QString::number ( num ));} 59 void setWeekNum ( int num ) {mNumber = num; setText( QString::number ( num ));}
60 int getWeekNum() { return mNumber;} 60 int getWeekNum() { return mNumber;}
61 signals: 61 signals:
62 void selectWeekNum ( int ); 62 void selectWeekNum ( int );
63private: 63private:
64 void focusInEvent ( QFocusEvent * ){;} 64 void focusInEvent ( QFocusEvent * ){;}
65 int mNumber; 65 int mNumber;
66 void keyPressEvent ( QKeyEvent * e ) 66 void keyPressEvent ( QKeyEvent * e )
67 { 67 {
68 e->ignore(); 68 e->ignore();
69 } 69 }
70 70
71private slots : 71private slots :
72 void bottonClicked() { if ( mNumber > 0 ) emit selectWeekNum ( mNumber ); } 72 void bottonClicked() { if ( mNumber > 0 ) emit selectWeekNum ( mNumber ); }
73}; 73};
74 74
75class KNoScrollListBox: public QListBox 75class KNoScrollListBox: public QListBox
76{ 76{
77 Q_OBJECT 77 Q_OBJECT
78 public: 78 public:
79 KNoScrollListBox(QWidget *parent=0, const char *name=0); 79 KNoScrollListBox(QWidget *parent=0, const char *name=0);
80 ~KNoScrollListBox(); 80 ~KNoScrollListBox();
81 QString getWhatsThisText(QPoint p) ; 81 QString getWhatsThisText(QPoint p) ;
82 82
83 signals: 83 signals:
84 void shiftDown(); 84 void shiftDown();
85 void shiftUp(); 85 void shiftUp();
86 void rightClick(); 86 void rightClick();
87 void nextCell(); 87 void nextCell();
88 void prevCell(); 88 void prevCell();
89 void highlightIncidence( Incidence * , MonthViewCell*, int ); 89 void highlightIncidence( Incidence * , MonthViewCell*, int );
90 90 protected:
91 bool mBlockDeselect;
91 protected slots: 92 protected slots:
92 void oneDown(); 93 void oneDown();
93 void keyPressEvent(QKeyEvent *); 94 void keyPressEvent(QKeyEvent *);
94 void keyReleaseEvent(QKeyEvent *); 95 void keyReleaseEvent(QKeyEvent *);
95 void mousePressEvent(QMouseEvent *); 96 void mousePressEvent(QMouseEvent *);
96 void focusInEvent ( QFocusEvent * ); 97 void focusInEvent ( QFocusEvent * );
97 void focusOutEvent ( QFocusEvent * ); 98 void focusOutEvent ( QFocusEvent * );
98 99
99 private: 100 private:
100 bool resetOnFocusIn; 101 bool resetOnFocusIn;
101 KNOWhatsThis * mWT; 102 KNOWhatsThis * mWT;
102}; 103};
103 104
104 105
105class MonthViewItem: public QListBoxItem 106class MonthViewItem: public QListBoxItem
106{ 107{
107 public: 108 public:
108 MonthViewItem( Incidence *,const QString & title ); 109 MonthViewItem( Incidence *,const QString & title );
109 void recycle( Incidence *incidence, const QString & s); 110 void recycle( Incidence *incidence, const QString & s);
110 void setRecur(bool on) { mRecur = on; } 111 void setRecur(bool on) { mRecur = on; }
111 void setAlarm(bool on) { mAlarm = on; } 112 void setAlarm(bool on) { mAlarm = on; }
112 void setReply(bool on) { mReply = on; } 113 void setReply(bool on) { mReply = on; }
113 void setMoreInfo(bool on) { mInfo = on; } 114 void setMoreInfo(bool on) { mInfo = on; }
114 void setMultiDay(int type) { mMultiday = type; } 115 void setMultiDay(int type) { mMultiday = type; }
115 int multiDay() { return mMultiday; } 116 int multiDay() { return mMultiday; }
116 void setMultiDayPos(int type) { mdayPos = type; } 117 void setMultiDayPos(int type) { mdayPos = type; }
117 int gettMultiDayPos() { return mdayPos; } 118 int gettMultiDayPos() { return mdayPos; }
118 void setBlockRepaint(bool on) { mblockRepaint = on; } 119 void setBlockRepaint(bool on) { mblockRepaint = on; }
119 bool setHighlighted( Incidence * ); 120 bool setHighlighted( Incidence * );
120 121
121 void setPalette(const QPalette &p) { mPalette = p; } 122 void setPalette(const QPalette &p) { mPalette = p; }
122 QPalette palette() const { return mPalette; } 123 QPalette palette() const { return mPalette; }
123 bool setHighlightedFalse(); 124 bool setHighlightedFalse();
124 Incidence *incidence() const { return mIncidence; } 125 Incidence *incidence() const { return mIncidence; }
125 126
126 protected: 127 protected:
127 virtual void paint(QPainter *); 128 virtual void paint(QPainter *);
128 virtual int height(const QListBox *) const; 129 virtual int height(const QListBox *) const;
129 virtual int width(const QListBox *) const; 130 virtual int width(const QListBox *) const;
130 131
131 private: 132 private:
132 int mdayPos; 133 int mdayPos;
133 bool isWeekItem; 134 bool isWeekItem;
134 bool mblockRepaint; 135 bool mblockRepaint;
135 int mMultiday; 136 int mMultiday;
136 bool mRecur; 137 bool mRecur;
137 bool mAlarm; 138 bool mAlarm;
138 bool mReply; 139 bool mReply;
139 bool mInfo; 140 bool mInfo;
140 bool mDisplayHighlighted; 141 bool mDisplayHighlighted;
141 142
142 QPalette mPalette; 143 QPalette mPalette;
143 QDate mDate; 144 QDate mDate;
144 145
145 Incidence *mIncidence; 146 Incidence *mIncidence;
146}; 147};
147 148
148 149
149class KOMonthView; 150class KOMonthView;
150 151
151class MonthViewCell : public KNoScrollListBox 152class MonthViewCell : public KNoScrollListBox
152{ 153{
153 Q_OBJECT 154 Q_OBJECT
154 public: 155 public:
155 MonthViewCell(KOMonthView *,QWidget* ); 156 MonthViewCell(KOMonthView *,QWidget* );
156 ~MonthViewCell() {mAvailItemList.setAutoDelete( true );} 157 ~MonthViewCell() {mAvailItemList.setAutoDelete( true );}
157 158
158 void setDate( const QDate & ); 159 void setDate( const QDate & );
159 QDate date() const; 160 QDate date() const;
160 161
161 void setPrimary( bool ); 162 void setPrimary( bool );
162 bool isPrimary() const; 163 bool isPrimary() const;
163 164
164 void setHoliday( bool ); 165 void setHoliday( bool );
165 void setHoliday( const QString & ); 166 void setHoliday( const QString & );
166 167
167 void updateCell(); 168 void updateCell();
168 void startUpdateCell(); 169 void startUpdateCell();
169 void finishUpdateCell(); 170 void finishUpdateCell();
170 int insertEvent(Event *); 171 int insertEvent(Event *);
171 void insertTodo(Todo *); 172 void insertTodo(Todo *);
172 173
173 void updateConfig( bool bigFont = false ); 174 void updateConfig( bool bigFont = false );
174 175
175 void enableScrollBars( bool ); 176 void enableScrollBars( bool );
176 177
177 Incidence *selectedIncidence(); 178 Incidence *selectedIncidence();
178 QDate selectedIncidenceDate(); 179 QDate selectedIncidenceDate();
179 QPushButton * dateLabel() { return mLabel; } 180 QPushButton * dateLabel() { return mLabel; }
180 bool doHighLight( Incidence *); 181 bool doHighLight( Incidence *);
181 void deselect(); 182 void deselect();
182 void select(); 183 void select();
183#ifdef DESKTOP_VERSION 184#ifdef DESKTOP_VERSION
184 static QToolTipGroup *toolTipGroup(); 185 static QToolTipGroup *toolTipGroup();
185#endif 186#endif
186 signals: 187 signals:
187 void defaultAction( Incidence * ); 188 void defaultAction( Incidence * );
188 void newEventSignal( QDateTime ); 189 void newEventSignal( QDateTime );
189 void showDaySignal( QDate ); 190 void showDaySignal( QDate );
190 191
191 protected: 192 protected:
192 QStringList mToolTip; 193 QStringList mToolTip;
193 void resizeEvent( QResizeEvent * ); 194 void resizeEvent( QResizeEvent * );
194 195
195public slots: 196public slots:
196 void showDay(); 197 void showDay();
197 void deHighLight(); 198 void deHighLight();
198 void repaintfinishUpdateCell(); 199 void repaintfinishUpdateCell();
199 protected slots: 200 protected slots:
200 void defaultAction( QListBoxItem * ); 201 void defaultAction( QListBoxItem * );
201 void contextMenu( QListBoxItem * ); 202 void contextMenu( QListBoxItem * );
202 void selection( QListBoxItem * ); 203 void selection( QListBoxItem * );
203 void cellClicked( QListBoxItem * ); 204 void cellClicked( QListBoxItem * );
204 void newEvent(); 205 void newEvent();
205 206
206 private: 207 private:
207 int mdayCount; 208 int mdayCount;
208 QPtrList <MonthViewItem> mAvailItemList; 209 QPtrList <MonthViewItem> mAvailItemList;
209 KOMonthView *mMonthView; 210 KOMonthView *mMonthView;
210 int currentPalette; 211 int currentPalette;
211 212
212 QDate mDate; 213 QDate mDate;
213 bool mPrimary; 214 bool mPrimary;
214 bool mHoliday; 215 bool mHoliday;
215 QString mHolidayString; 216 QString mHolidayString;
216 217
217 //QLabel *mLabel; 218 //QLabel *mLabel;
218 QPushButton *mLabel; 219 QPushButton *mLabel;
219 //QListBox *mItemList; 220 //QListBox *mItemList;
220#ifdef DESKTOP_VERSION 221#ifdef DESKTOP_VERSION
221 static QToolTipGroup *mToolTipGroup; 222 static QToolTipGroup *mToolTipGroup;
222#endif 223#endif
223 QSize mLabelSize; 224 QSize mLabelSize;
224 QSize mLabelBigSize; 225 QSize mLabelBigSize;
225 QPalette mHolidayPalette; 226 QPalette mHolidayPalette;
226 QPalette mStandardPalette; 227 QPalette mStandardPalette;
227 QPalette mPrimaryPalette; 228 QPalette mPrimaryPalette;
228 QPalette mNonPrimaryPalette; 229 QPalette mNonPrimaryPalette;
229 void setMyPalette(); 230 void setMyPalette();
230 QPalette getPalette (); 231 QPalette getPalette ();
231 232
232}; 233};
233 234
234 235
235class KOMonthView: public KOEventView 236class KOMonthView: public KOEventView
236{ 237{
237 Q_OBJECT 238 Q_OBJECT
238 public: 239 public:
239 KOMonthView(Calendar *cal, QWidget *parent = 0, const char *name = 0 ); 240 KOMonthView(Calendar *cal, QWidget *parent = 0, const char *name = 0 );
240 ~KOMonthView(); 241 ~KOMonthView();
241 242
242 /** Returns maximum number of days supported by the komonthview */ 243 /** Returns maximum number of days supported by the komonthview */
243 virtual int maxDatesHint(); 244 virtual int maxDatesHint();
244 245
245 /** Returns number of currently shown dates. */ 246 /** Returns number of currently shown dates. */
246 virtual int currentDateCount(); 247 virtual int currentDateCount();
247 248
248 /** returns the currently selected events */ 249 /** returns the currently selected events */
249 virtual QPtrList<Incidence> selectedIncidences(); 250 virtual QPtrList<Incidence> selectedIncidences();
250 251
251 /** returns dates of the currently selected events */ 252 /** returns dates of the currently selected events */
252 virtual DateList selectedDates(); 253 virtual DateList selectedDates();
253#if 0 254#if 0
254 virtual void printPreview(CalPrinter *calPrinter, 255 virtual void printPreview(CalPrinter *calPrinter,
255 const QDate &, const QDate &); 256 const QDate &, const QDate &);
256#endif 257#endif
257 bool isMonthView() { return !mShowWeekView; } 258 bool isMonthView() { return !mShowWeekView; }
258 bool isUpdatePossible() { return updatePossible; } 259 bool isUpdatePossible() { return updatePossible; }
259 260
260 MonthViewCell * selectedCell(); 261 MonthViewCell * selectedCell();
261 bool skipResize; 262 bool skipResize;
262 NavigatorBar* navigatorBar() { return mNavigatorBar ;} 263 NavigatorBar* navigatorBar() { return mNavigatorBar ;}
263 void clearList(); 264 void clearList();
264 public slots: 265 public slots:
265 void incidenceHighlighted( Incidence *, MonthViewCell*, int ); 266 void incidenceHighlighted( Incidence *, MonthViewCell*, int );
266 void nextCell(); 267 void nextCell();
267 void prevCell(); 268 void prevCell();
268 virtual void updateView(); 269 virtual void updateView();
269 virtual void updateConfig(); 270 virtual void updateConfig();
270 virtual void showDates(const QDate &start, const QDate &end); 271 virtual void showDates(const QDate &start, const QDate &end);
271 virtual void showEvents(QPtrList<Event> eventList); 272 virtual void showEvents(QPtrList<Event> eventList);
272 273
273 void changeEventDisplay(Event *, int); 274 void changeEventDisplay(Event *, int);
274 275
275 void clearSelection(); 276 void clearSelection();
276 277
277 void showContextMenu( Incidence * ); 278 void showContextMenu( Incidence * );
278 279
279 void setSelectedCell( MonthViewCell * ); 280 void setSelectedCell( MonthViewCell * );
280 void setPopupCell( MonthViewCell * ); 281 void setPopupCell( MonthViewCell * );
281 void switchView(); 282 void switchView();
282 void setKeyBFocus(); 283 void setKeyBFocus();
283 284
284 protected slots: 285 protected slots:
285 void catChanged( Incidence * ); 286 void catChanged( Incidence * );
286 void setKeyBoardFocus(); 287 void setKeyBoardFocus();
287 void slotNewTodo(); 288 void slotNewTodo();
288 void slotNewEvent(); 289 void slotNewEvent();
289 void slotEditJournal(); 290 void slotEditJournal();
290 void slotComputeLayout(); 291 void slotComputeLayout();
291 void selectInternalWeekNum ( int ); 292 void selectInternalWeekNum ( int );
292 void processSelectionChange(); 293 void processSelectionChange();
293 signals: 294 signals:
294 void nextMonth(); 295 void nextMonth();
295 void prevMonth(); 296 void prevMonth();
296 void selectWeekNum ( int ); 297 void selectWeekNum ( int );
297 void selectMonth (); 298 void selectMonth ();
298 void showDaySignal( QDate ); 299 void showDaySignal( QDate );
299 void newTodoSignal( QDateTime, bool ); 300 void newTodoSignal( QDateTime, bool );
300 void showJournalSignal( int,QDate ); 301 void showJournalSignal( int,QDate );
301 protected: 302 protected:
302 void resizeEvent(QResizeEvent *); 303 void resizeEvent(QResizeEvent *);
303 void viewChanged(); 304 void viewChanged();
304 void updateDayLabels(); 305 void updateDayLabels();
305 int mapWeekLayout( int, bool ); 306 int mapWeekLayout( int, bool );
306 307
307 private: 308 private:
308 int mKBFcounter; 309 int mKBFcounter;
309 QTimer* mComputeLayoutTimer; 310 QTimer* mComputeLayoutTimer;
310 NavigatorBar* mNavigatorBar; 311 NavigatorBar* mNavigatorBar;
311 int currentWeek(); 312 int currentWeek();
312 bool clPending; 313 bool clPending;
313 QWidgetStack * mWidStack; 314 QWidgetStack * mWidStack;
314 QWidget* mMonthView; 315 QWidget* mMonthView;
315 QWidget* mWeekView; 316 QWidget* mWeekView;
316 bool mShowWeekView; 317 bool mShowWeekView;
317 bool updatePossible; 318 bool updatePossible;
318 int mDaysPerWeek; 319 int mDaysPerWeek;
319 int mNumWeeks; 320 int mNumWeeks;
320 int mNumCells; 321 int mNumCells;
321 //bool mWeekStartsMonday; 322 //bool mWeekStartsMonday;
322 bool mShowSatSunComp; 323 bool mShowSatSunComp;
323 void computeLayout(); 324 void computeLayout();
324 void computeLayoutWeek(); 325 void computeLayoutWeek();
325 void doComputeLayoutWeek(); 326 void doComputeLayoutWeek();
326 327
327 QPtrVector<MonthViewCell> mCells; 328 QPtrVector<MonthViewCell> mCells;
328 QPtrVector<QLabel> mDayLabels; 329 QPtrVector<QLabel> mDayLabels;
329 QPtrVector<KOWeekButton> mWeekLabels; 330 QPtrVector<KOWeekButton> mWeekLabels;
330 QPtrVector<MonthViewCell> mCellsW; 331 QPtrVector<MonthViewCell> mCellsW;
331 QPtrVector<QLabel> mDayLabelsW; 332 QPtrVector<QLabel> mDayLabelsW;
332 QPtrVector<KOWeekButton> mWeekLabelsW; 333 QPtrVector<KOWeekButton> mWeekLabelsW;
333 334
334 bool mShortDayLabelsM; 335 bool mShortDayLabelsM;
335 bool mShortDayLabelsW; 336 bool mShortDayLabelsW;
336 int mWidthLongDayLabel; 337 int mWidthLongDayLabel;
337 338
338 QDate mStartDate; 339 QDate mStartDate;
339 340
340 MonthViewCell *mSelectedCell; 341 MonthViewCell *mSelectedCell;
341 MonthViewCell *mPopupCell; 342 MonthViewCell *mPopupCell;
342 bool mFlagKeyPressed; 343 bool mFlagKeyPressed;
343 KOEventPopupMenu *mContextMenu; 344 KOEventPopupMenu *mContextMenu;
344 QPopupMenu *mNewItemMenu; 345 QPopupMenu *mNewItemMenu;
345 void keyPressEvent ( QKeyEvent * ) ; 346 void keyPressEvent ( QKeyEvent * ) ;
346 void keyReleaseEvent ( QKeyEvent * ) ; 347 void keyReleaseEvent ( QKeyEvent * ) ;
347 348
348}; 349};
349 350
350#endif 351#endif