summaryrefslogtreecommitdiffabout
path: root/korganizer
authorzautrix <zautrix>2005-04-04 20:24:30 (UTC)
committer zautrix <zautrix>2005-04-04 20:24:30 (UTC)
commitc408fcb55de18d1e3e1d20803c3885e3074cfaa4 (patch) (unidiff)
tree092f6e385210a9fa7bd625c2e0cae3ceba68f513 /korganizer
parent8e7f4812c4ad239b6a17cce8aa84c00274ced4df (diff)
downloadkdepimpi-c408fcb55de18d1e3e1d20803c3885e3074cfaa4.zip
kdepimpi-c408fcb55de18d1e3e1d20803c3885e3074cfaa4.tar.gz
kdepimpi-c408fcb55de18d1e3e1d20803c3885e3074cfaa4.tar.bz2
month view fixes
Diffstat (limited to 'korganizer') (more/less context) (ignore whitespace changes)
-rw-r--r--korganizer/komonthview.cpp116
-rw-r--r--korganizer/komonthview.h5
2 files changed, 67 insertions, 54 deletions
diff --git a/korganizer/komonthview.cpp b/korganizer/komonthview.cpp
index 9f7db69..1ed288b 100644
--- a/korganizer/komonthview.cpp
+++ b/korganizer/komonthview.cpp
@@ -39,120 +39,146 @@
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 mWT = new KNOWhatsThis(this); 85 mWT = new KNOWhatsThis(this);
86 resetOnFocusIn = true; 86 resetOnFocusIn = true;
87 setVScrollBarMode(QScrollView::AlwaysOff);
88 setHScrollBarMode(QScrollView::AlwaysOff);
87} 89}
88KNoScrollListBox::~KNoScrollListBox() 90KNoScrollListBox::~KNoScrollListBox()
89{ 91{
90 92
91} 93}
92 94
93 95
94void KNoScrollListBox::focusInEvent ( QFocusEvent * e ) 96void KNoScrollListBox::focusInEvent ( QFocusEvent * e )
95{ 97{
96 QListBox::focusInEvent ( e ); 98 QListBox::focusInEvent ( e );
97 QListBoxItem * i = item ( 0 ); 99 QListBoxItem * i = item ( 0 );
98 if ( i && resetOnFocusIn ) { 100 if ( i && resetOnFocusIn ) {
99 setCurrentItem( i ); 101 setCurrentItem( i );
100 setSelected ( 0, true ); 102 setSelected ( 0, true );
101 } 103 }
102 resetOnFocusIn = true; 104 resetOnFocusIn = true;
105
106 if ( KOPrefs::instance()->mEnableMonthScroll || KOPrefs::instance()->mMonthViewWeek ) {
107 QListBoxItem *fi = firstItem ();
108 if (fi ) {
109 int ihei = fi->height( this );
110 int hei = numRows () * ihei;
111 if ( hei < height() - horizontalScrollBar()->height () ) {
112 setVScrollBarMode(QScrollView::AlwaysOff);
113 }
114 else
115 setVScrollBarMode(QScrollView::Auto);
116 if ( ihei *3 > height() ) {
117 setHScrollBarMode(QScrollView::AlwaysOff);
118 }
119 else {
120 setHScrollBarMode(QScrollView::Auto);
121 }
122 } else {
123 setVScrollBarMode(QScrollView::Auto);
124 setHScrollBarMode(QScrollView::Auto);
125 }
126 }
103} 127}
104void KNoScrollListBox::focusOutEvent ( QFocusEvent * e ) 128void KNoScrollListBox::focusOutEvent ( QFocusEvent * e )
105{ 129{
106 int i = currentItem (); 130 int i = currentItem ();
107 if ( i >= 0 ) { 131 if ( i >= 0 ) {
108 setSelected ( i, false ); 132 setSelected ( i, false );
109 } 133 }
110 QListBox::focusOutEvent ( e ); 134 QListBox::focusOutEvent ( e );
135 setVScrollBarMode(QScrollView::AlwaysOff);
136 setHScrollBarMode(QScrollView::AlwaysOff);
111} 137}
112 138
113QString KNoScrollListBox::getWhatsThisText(QPoint p) 139QString KNoScrollListBox::getWhatsThisText(QPoint p)
114{ 140{
115 QListBoxItem* item = itemAt ( p ); 141 QListBoxItem* item = itemAt ( p );
116 if ( ! item ) { 142 if ( ! item ) {
117 return i18n("Click in the cell\nto add an event!"); 143 return i18n("Click in the cell\nto add an event!");
118 } 144 }
119 return KIncidenceFormatter::instance()->getFormattedText(((MonthViewItem*) item)->incidence(), 145 return KIncidenceFormatter::instance()->getFormattedText(((MonthViewItem*) item)->incidence(),
120 KOPrefs::instance()->mWTshowDetails, 146 KOPrefs::instance()->mWTshowDetails,
121 KOPrefs::instance()->mWTshowCreated, 147 KOPrefs::instance()->mWTshowCreated,
122 KOPrefs::instance()->mWTshowChanged); 148 KOPrefs::instance()->mWTshowChanged);
123} 149}
124void KNoScrollListBox::keyPressEvent(QKeyEvent *e) 150void KNoScrollListBox::keyPressEvent(QKeyEvent *e)
125{ 151{
126 //qDebug("KNoScrollListBox::keyPressEvent "); 152 //qDebug("KNoScrollListBox::keyPressEvent ");
127 switch(e->key()) { 153 switch(e->key()) {
128 case Key_Right: 154 case Key_Right:
129 if ( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton ) 155 if ( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton )
130 { 156 {
131 e->ignore(); 157 e->ignore();
132 return; 158 return;
133 } 159 }
134 scrollBy(10,0); 160 scrollBy(10,0);
135 break; 161 break;
136 case Key_Left: 162 case Key_Left:
137 if (e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton ) 163 if (e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton )
138 { 164 {
139 e->ignore(); 165 e->ignore();
140 return; 166 return;
141 } 167 }
142 scrollBy(-10,0); 168 scrollBy(-10,0);
143 break; 169 break;
144 case Key_Up: 170 case Key_Up:
145 if( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton) { 171 if( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton) {
146 e->ignore(); 172 e->ignore();
147 break; 173 break;
148 } 174 }
149 if ( count() ) { 175 if ( count() ) {
150 setCurrentItem((currentItem()+count()-1)%count()); 176 setCurrentItem((currentItem()+count()-1)%count());
151 if(!itemVisible(currentItem())) { 177 if(!itemVisible(currentItem())) {
152 if((unsigned int) currentItem() == (count()-1)) { 178 if((unsigned int) currentItem() == (count()-1)) {
153 setTopItem(currentItem()-numItemsVisible()+1); 179 setTopItem(currentItem()-numItemsVisible()+1);
154 } else { 180 } else {
155 setTopItem(topItem()-1); 181 setTopItem(topItem()-1);
156 } 182 }
157 } 183 }
158 } 184 }
@@ -198,96 +224,97 @@ void KNoScrollListBox::keyPressEvent(QKeyEvent *e)
198} 224}
199 225
200void KNoScrollListBox::oneDown() 226void KNoScrollListBox::oneDown()
201{ 227{
202 if ( count () ) { 228 if ( count () ) {
203 resetOnFocusIn = false; 229 resetOnFocusIn = false;
204 setCurrentItem((currentItem()+1)%count()); 230 setCurrentItem((currentItem()+1)%count());
205 if(!itemVisible(currentItem())) { 231 if(!itemVisible(currentItem())) {
206 if(currentItem() == 0) { 232 if(currentItem() == 0) {
207 setTopItem(0); 233 setTopItem(0);
208 } else { 234 } else {
209 setTopItem(topItem()+1); 235 setTopItem(topItem()+1);
210 } 236 }
211 } 237 }
212 } 238 }
213} 239}
214void KNoScrollListBox::keyReleaseEvent(QKeyEvent *e) 240void KNoScrollListBox::keyReleaseEvent(QKeyEvent *e)
215{ 241{
216 switch(e->key()) { 242 switch(e->key()) {
217 case Key_Shift: 243 case Key_Shift:
218 emit shiftUp(); 244 emit shiftUp();
219 break; 245 break;
220 default: 246 default:
221 break; 247 break;
222 } 248 }
223} 249}
224 250
225void KNoScrollListBox::mousePressEvent(QMouseEvent *e) 251void KNoScrollListBox::mousePressEvent(QMouseEvent *e)
226{ 252{
227 QListBox::mousePressEvent(e); 253 QListBox::mousePressEvent(e);
228 254
229 if(e->button() == RightButton) { 255 if(e->button() == RightButton) {
230 emit rightClick(); 256 emit rightClick();
231 } 257 }
232} 258}
233 259
234MonthViewItem::MonthViewItem( Incidence *incidence, QDate qd, const QString & s) 260MonthViewItem::MonthViewItem( Incidence *incidence, QDate qd, const QString & s)
235 : QListBoxItem() 261 : QListBoxItem()
236{ 262{
237 mblockRepaint = true; 263 mblockRepaint = true;
238 setText( s ); 264 setText( s );
239 mMultiday = 0; 265 mMultiday = 0;
240 mIncidence = incidence; 266 mIncidence = incidence;
241 mDate = qd; 267 mDate = qd;
242 mRecur = false; 268 mRecur = false;
243 mAlarm = false; 269 mAlarm = false;
244 mReply = false; 270 mReply = false;
245 mInfo = false; 271 mInfo = false;
272 isWeekItem = KOPrefs::instance()->mMonthViewWeek;
246 //qDebug("NEWWWWWWWWWWWWW "); 273 //qDebug("NEWWWWWWWWWWWWW ");
247} 274}
248void MonthViewItem::recycle( Incidence *incidence, QDate qd, const QString & s) 275void MonthViewItem::recycle( Incidence *incidence, QDate qd, const QString & s)
249{ 276{
250 setText( s ); 277 setText( s );
251 mMultiday = 0; 278 mMultiday = 0;
252 mIncidence = incidence; 279 mIncidence = incidence;
253 mDate = qd; 280 mDate = qd;
254 mRecur = false; 281 mRecur = false;
255 mAlarm = false; 282 mAlarm = false;
256 mReply = false; 283 mReply = false;
257 mInfo = false; 284 mInfo = false;
258 //qDebug("recucleeeeeeeeeeeeeeeee "); 285 //qDebug("recucleeeeeeeeeeeeeeeee ");
259} 286}
260 287
261void MonthViewItem::paint(QPainter *p) 288void MonthViewItem::paint(QPainter *p)
262{ 289{
263 if ( mblockRepaint ) { 290 if ( mblockRepaint ) {
264 //qDebug("block "); 291 //qDebug("block ");
265 return; 292 return;
266 } 293 }
267 //qDebug("NON block "); 294 //qDebug("NON block ");
268#if QT_VERSION >= 0x030000 295#if QT_VERSION >= 0x030000
269 bool sel = isSelected(); 296 bool sel = isSelected();
270#else 297#else
271 bool sel = selected(); 298 bool sel = selected();
272#endif 299#endif
273 300
274 301
275 if (KOPrefs::instance()->mMonthViewUsesCategoryColor) 302 if (KOPrefs::instance()->mMonthViewUsesCategoryColor)
276 { 303 {
277 p->setBackgroundColor( palette().color( QPalette::Normal, \ 304 p->setBackgroundColor( palette().color( QPalette::Normal, \
278 sel ? QColorGroup::Highlight : QColorGroup::Background ) ); 305 sel ? QColorGroup::Highlight : QColorGroup::Background ) );
279 p->eraseRect( 0, 0, listBox()->maxItemWidth(), height( listBox() ) ); 306 p->eraseRect( 0, 0, listBox()->maxItemWidth(), height( listBox() ) );
280 } 307 }
281 int x = 1; 308 int x = 1;
282 //int y = 3;//(height() - mRecurPixmap.height()) /2; 309 //int y = 3;//(height() - mRecurPixmap.height()) /2;
283 int size = PIXMAP_SIZE; 310 int size = PIXMAP_SIZE;
284 if ( QApplication::desktop()->width() < 300 ) 311 if ( QApplication::desktop()->width() < 300 )
285 size = 3; 312 size = 3;
286 int heihei = height( listBox () ); 313 int heihei = height( listBox () );
287 int y = (heihei - size -1 ) /2; 314 int y = (heihei - size -1 ) /2;
288 315
289 if ( KOPrefs::instance()->mMonthShowIcons ) { 316 if ( KOPrefs::instance()->mMonthShowIcons ) {
290 if ( mInfo ) { 317 if ( mInfo ) {
291 p->fillRect ( x, y,size,size, Qt::darkGreen ); 318 p->fillRect ( x, y,size,size, Qt::darkGreen );
292 x += size + 1; 319 x += size + 1;
293 } 320 }
@@ -335,133 +362,131 @@ void MonthViewItem::paint(QPainter *p)
335 } 362 }
336 x += sizeM/2 + 1; 363 x += sizeM/2 + 1;
337 x += sizeM + 1; 364 x += sizeM + 1;
338 } 365 }
339 366
340 if ( mIncidence->type() == "Todo" ){ 367 if ( mIncidence->type() == "Todo" ){
341 Todo* td = ( Todo* ) mIncidence; 368 Todo* td = ( Todo* ) mIncidence;
342 if ( td->isCompleted() ) { 369 if ( td->isCompleted() ) {
343 int half = size/2; 370 int half = size/2;
344 p->drawLine ( x, heihei/2, x +half , heihei/2 +half ) ; 371 p->drawLine ( x, heihei/2, x +half , heihei/2 +half ) ;
345 p->drawLine ( x +half , heihei/2 +half , x +half+half +2 , heihei/2 -2 ) ; 372 p->drawLine ( x +half , heihei/2 +half , x +half+half +2 , heihei/2 -2 ) ;
346 x += half+half + 4; 373 x += half+half + 4;
347 374
348 } else { 375 } else {
349 int val = td->percentComplete()/20; 376 int val = td->percentComplete()/20;
350 p->fillRect ( x+1, y-2, val ,size+4,Qt::black ); 377 p->fillRect ( x+1, y-2, val ,size+4,Qt::black );
351 p->drawRect ( x, y-2,7,size+4); 378 p->drawRect ( x, y-2,7,size+4);
352 x += size + 3; 379 x += size + 3;
353 } 380 }
354 } 381 }
355 QFontMetrics fm = p->fontMetrics(); 382 QFontMetrics fm = p->fontMetrics();
356 int yPos; 383 int yPos;
357 int pmheight = size; 384 int pmheight = size;
358 if( pmheight < fm.height() ) 385 if( pmheight < fm.height() )
359 yPos = fm.ascent() + fm.leading()/2; 386 yPos = fm.ascent() + fm.leading()/2;
360 else 387 else
361 yPos = pmheight/2 - fm.height()/2 + fm.ascent(); 388 yPos = pmheight/2 - fm.height()/2 + fm.ascent();
362 p->setPen( palette().color( QPalette::Normal, sel ? \ 389 p->setPen( palette().color( QPalette::Normal, sel ? \
363 QColorGroup::HighlightedText : QColorGroup::Foreground ) ); 390 QColorGroup::HighlightedText : QColorGroup::Foreground ) );
364 p->drawText( x, yPos, text() ); 391 p->drawText( x, yPos, text() );
365 if ( mIncidence->cancelled() ) { 392 if ( mIncidence->cancelled() ) {
366 int wid = fm.width( text() ); 393 int wid = fm.width( text() );
367 p->drawLine( x, heihei/2-1 ,x+wid, heihei/2-1 ); 394 p->drawLine( x, heihei/2-1 ,x+wid, heihei/2-1 );
368 } 395 }
369 396
370} 397}
371 398
372int MonthViewItem::height(const QListBox *lb) const 399int MonthViewItem::height(const QListBox *lb) const
373{ 400{
374 int ret = 10; 401 int ret = 10;
375 if ( lb ) 402 if ( lb )
376 ret = lb->fontMetrics().lineSpacing()+1; 403 ret = lb->fontMetrics().lineSpacing()+1;
377 return ret; 404 return ret;
378} 405}
379 406
380int MonthViewItem::width(const QListBox *lb) const 407int MonthViewItem::width(const QListBox *lb) const
381{ 408{
382 409
383 if( KOPrefs::instance()->mEnableMonthScroll || KOPrefs::instance()->mMonthViewWeek ) { 410 if( KOPrefs::instance()->mEnableMonthScroll || isWeekItem ) {
384 int size = PIXMAP_SIZE; 411 int size = PIXMAP_SIZE;
385 if ( QApplication::desktop()->width() < 300 ) 412 if ( QApplication::desktop()->width() < 300 )
386 size = 3; 413 size = 3;
387 int x = 1; 414 int x = 1;
388 if ( KOPrefs::instance()->mMonthShowIcons ) { 415 if ( KOPrefs::instance()->mMonthShowIcons ) {
389 if ( mInfo ) { 416 if ( mInfo ) {
390 x += size + 1; 417 x += size + 1;
391 } 418 }
392 if( mRecur ) { 419 if( mRecur ) {
393 x += size+1; 420 x += size+1;
394 } 421 }
395 if( mAlarm ) { 422 if( mAlarm ) {
396 x += size+1; 423 x += size+1;
397 } 424 }
398 if( mReply ) { 425 if( mReply ) {
399 x += size+1; 426 x += size+1;
400 } 427 }
401 } 428 }
402 if( mMultiday ) { 429 if( mMultiday ) {
403 x += size+1+2+size/2; 430 x += size+1+2+size/2;
404 } 431 }
405 return( x + lb->fontMetrics().width( text() ) + 1 ); 432 return( x + lb->fontMetrics().width( text() ) + 1 );
406 } 433 }
407 if ( ! lb ) 434 if ( ! lb )
408 return 10; 435 return 10;
409 //qDebug("ret wid %d ", lb->width()); 436 //qDebug("ret wid %d ", lb->width());
410 return lb->width(); 437 return lb->width();
411} 438}
412 439
413 440
414MonthViewCell::MonthViewCell( KOMonthView *parent,QWidget* par ) 441MonthViewCell::MonthViewCell( KOMonthView *parent,QWidget* par )
415 : KNoScrollListBox( par ), 442 : KNoScrollListBox( par ),
416 mMonthView( parent ) 443 mMonthView( parent )
417{ 444{
418
419 mCurrentAvailItem = 0;
420 //QVBoxLayout *topLayout = new QVBoxLayout( this ); 445 //QVBoxLayout *topLayout = new QVBoxLayout( this );
421 currentPalette = 0; 446 currentPalette = 0;
422 // mLabel = new QLabel( this );QPushButton 447 // mLabel = new QLabel( this );QPushButton
423 mLabel = new QPushButton( this ); 448 mLabel = new QPushButton( this );
424 //mLabel->setFrameStyle( QFrame::Panel | QFrame::Plain ); 449 //mLabel->setFrameStyle( QFrame::Panel | QFrame::Plain );
425 //mLabel->setLineWidth( 1 ); 450 //mLabel->setLineWidth( 1 );
426 //mLabel->setAlignment( AlignCenter ); 451 //mLabel->setAlignment( AlignCenter );
427 mLabel->setFlat( true ); 452 mLabel->setFlat( true );
428 mLabel->setFocusPolicy(NoFocus); 453 mLabel->setFocusPolicy(NoFocus);
429 //mItemList = new KNoScrollListBox( this ); 454 //mItemList = new KNoScrollListBox( this );
430 setMinimumSize( 10, 10 ); 455 setMinimumSize( 10, 10 );
431 setFrameStyle( QFrame::Panel | QFrame::Plain ); 456 setFrameStyle( QFrame::Panel | QFrame::Plain );
432 setLineWidth( 1 ); 457 setLineWidth( 1 );
433 //topLayout->addWidget( mItemList ); 458 //topLayout->addWidget( mItemList );
434 mLabel->raise(); 459 mLabel->raise();
435 // QColor( 0,0,255 ) QColor( 160,1600,255 ) 460 // QColor( 0,0,255 ) QColor( 160,1600,255 )
436 mStandardPalette = palette(); 461 mStandardPalette = palette();
437 mStandardPalette.setColor(QColorGroup::Base, mStandardPalette.color( QPalette::Normal, QColorGroup::Background ) ); 462 mStandardPalette.setColor(QColorGroup::Base, mStandardPalette.color( QPalette::Normal, QColorGroup::Background ) );
438 463
439 enableScrollBars( false ); 464 enableScrollBars( false );
440 updateConfig(); 465 updateConfig();
441 //connect( mLabel, SIGNAL( clicked( )), SLOT( newEvent() )); 466 //connect( mLabel, SIGNAL( clicked( )), SLOT( newEvent() ));
442 connect( mLabel, SIGNAL( clicked( )), SLOT( showDay() )); 467 connect( mLabel, SIGNAL( clicked( )), SLOT( showDay() ));
443 connect( this , SIGNAL( doubleClicked( QListBoxItem *) ), 468 connect( this , SIGNAL( doubleClicked( QListBoxItem *) ),
444 SLOT( defaultAction( QListBoxItem * ) ) ); 469 SLOT( defaultAction( QListBoxItem * ) ) );
445 connect( this, SIGNAL( rightButtonPressed( QListBoxItem *, 470 connect( this, SIGNAL( rightButtonPressed( QListBoxItem *,
446 const QPoint &) ), 471 const QPoint &) ),
447 SLOT( contextMenu( QListBoxItem * ) ) ); 472 SLOT( contextMenu( QListBoxItem * ) ) );
448 connect( this, SIGNAL( highlighted( QListBoxItem *) ), 473 connect( this, SIGNAL( highlighted( QListBoxItem *) ),
449 SLOT( selection( QListBoxItem * ) ) ); 474 SLOT( selection( QListBoxItem * ) ) );
450 connect( this, SIGNAL( clicked( QListBoxItem * ) ), 475 connect( this, SIGNAL( clicked( QListBoxItem * ) ),
451 SLOT( cellClicked( QListBoxItem * ) ) ); 476 SLOT( cellClicked( QListBoxItem * ) ) );
452 connect( this, SIGNAL( clicked( QListBoxItem * ) ), 477 connect( this, SIGNAL( clicked( QListBoxItem * ) ),
453 SLOT( selection( QListBoxItem * ) ) ); 478 SLOT( selection( QListBoxItem * ) ) );
454} 479}
455#ifdef DESKTOP_VERSION 480#ifdef DESKTOP_VERSION
456QToolTipGroup *MonthViewCell::toolTipGroup() 481QToolTipGroup *MonthViewCell::toolTipGroup()
457{ 482{
458 if (!mToolTipGroup) mToolTipGroup = new QToolTipGroup(0); 483 if (!mToolTipGroup) mToolTipGroup = new QToolTipGroup(0);
459 return mToolTipGroup; 484 return mToolTipGroup;
460} 485}
461#endif 486#endif
462 487
463void MonthViewCell::setDate( const QDate &date ) 488void MonthViewCell::setDate( const QDate &date )
464{ 489{
465 // kdDebug() << "MonthViewCell::setDate(): " << date.toString() << endl; 490 // kdDebug() << "MonthViewCell::setDate(): " << date.toString() << endl;
466 mDate = date; 491 mDate = date;
467 492
@@ -527,399 +552,386 @@ bool MonthViewCell::isPrimary() const
527{ 552{
528 return mPrimary; 553 return mPrimary;
529} 554}
530 555
531void MonthViewCell::setHoliday( bool holiday ) 556void MonthViewCell::setHoliday( bool holiday )
532{ 557{
533 mHoliday = holiday; 558 mHoliday = holiday;
534 //setMyPalette(); 559 //setMyPalette();
535} 560}
536 561
537void MonthViewCell::setHoliday( const QString &holiday ) 562void MonthViewCell::setHoliday( const QString &holiday )
538{ 563{
539 mHolidayString = holiday; 564 mHolidayString = holiday;
540 565
541 if ( !holiday.isEmpty() ) { 566 if ( !holiday.isEmpty() ) {
542 setHoliday( true ); 567 setHoliday( true );
543 } 568 }
544} 569}
545 570
546void MonthViewCell::startUpdateCell() 571void MonthViewCell::startUpdateCell()
547{ 572{
548 573
549 setFocusPolicy(NoFocus); 574 setFocusPolicy(NoFocus);
550 if ( !mMonthView->isUpdatePossible() ) 575 if ( !mMonthView->isUpdatePossible() )
551 return; 576 return;
552 MonthViewItem *mitem = (MonthViewItem*) firstItem (); 577 MonthViewItem *mitem = (MonthViewItem*) firstItem ();
553 while ( mitem ) { 578 while ( mitem ) {
554 mitem->setBlockRepaint( true ); 579 mitem->setBlockRepaint( true );
555 mitem = (MonthViewItem *)mitem->next(); 580 mitem = (MonthViewItem *)mitem->next();
556 } 581 }
557 if ( mAvailItemList.count() > 20 ) { 582 if ( mAvailItemList.count() > 20 ) {
558 mAvailItemList.setAutoDelete( true ); 583 mAvailItemList.setAutoDelete( true );
559 mAvailItemList.clear(); 584 mAvailItemList.clear();
560 mAvailItemList.setAutoDelete( false ); 585 mAvailItemList.setAutoDelete( false );
561 } 586 }
562 /* 587 /*
563 if ( !isVisible() ){ 588 if ( !isVisible() ){
564 return; 589 return;
565 } 590 }
566 */ 591 */
567 // qDebug("MonthViewCell::updateCell() "); 592 // qDebug("MonthViewCell::updateCell() ");
568 setPrimary( mDate.month()%2 ); 593 setPrimary( mDate.month()%2 );
569 setHoliday( KOGlobals::self()->calendarSystem()->dayOfWeek(mDate) == KOGlobals::self()->calendarSystem()->weekDayOfPray() || ( mDate.dayOfWeek() == 6 ) && KOPrefs::instance()-> mExcludeSaturdays); 594 setHoliday( KOGlobals::self()->calendarSystem()->dayOfWeek(mDate) == KOGlobals::self()->calendarSystem()->weekDayOfPray() || ( mDate.dayOfWeek() == 6 ) && KOPrefs::instance()-> mExcludeSaturdays);
570 if ( mDate == QDate::currentDate() ) { 595 if ( mDate == QDate::currentDate() ) {
571 setLineWidth( 3 ); 596 setLineWidth( 3 );
572 } else { 597 } else {
573 setLineWidth( 1 ); 598 setLineWidth( 1 );
574 } 599 }
575 mCurrentAvailItem = (MonthViewItem*) firstItem (); 600 MonthViewItem* CurrentAvailItem = (MonthViewItem*) firstItem ();
576 //clear(); 601 //clear();
602 while ( CurrentAvailItem ) {
603 MonthViewItem *item = CurrentAvailItem;
604 CurrentAvailItem = (MonthViewItem *)item->next();
605 mAvailItemList.append( item );
606 takeItem ( item );
607 }
577 608
578#ifdef DESKTOP_VERSION 609#ifdef DESKTOP_VERSION
579 QToolTip::remove(this); 610 QToolTip::remove(this);
580#endif 611#endif
581 mToolTip.clear(); 612 mToolTip.clear();
582 //qApp->processEvents(); 613 //qApp->processEvents();
583#if 0 614#if 0
584 if ( !mHolidayString.isEmpty() ) { 615 if ( !mHolidayString.isEmpty() ) {
585 MonthViewItem *item = new MonthViewItem( 0, mDate, mHolidayString ); 616 MonthViewItem *item = new MonthViewItem( 0, mDate, mHolidayString );
586 item->setPalette( mHolidayPalette ); 617 item->setPalette( mHolidayPalette );
587 insertItem( item ); 618 insertItem( item );
588 mToolTip.append ( mHolidayString ); 619 mToolTip.append ( mHolidayString );
589 } 620 }
590#endif 621#endif
591} 622}
592 623
593void MonthViewCell::insertEvent(Event *event) 624void MonthViewCell::insertEvent(Event *event)
594{ 625{
595 QString mToolTipText; 626 QString mToolTipText;
596 bool insertNewItem = false;
597 setFocusPolicy(WheelFocus); 627 setFocusPolicy(WheelFocus);
598 if ( !(event->doesRecur() == Recurrence::rNone) ) { 628 if ( !(event->doesRecur() == Recurrence::rNone) ) {
599 if ( !KOPrefs::instance()->mMonthDailyRecur && event->doesRecur() == Recurrence::rDaily ) 629 if ( !KOPrefs::instance()->mMonthDailyRecur && event->doesRecur() == Recurrence::rDaily )
600 return; 630 return;
601 else 631 else
602 if ( !KOPrefs::instance()->mMonthWeeklyRecur && event->doesRecur() == Recurrence::rWeekly ) 632 if ( !KOPrefs::instance()->mMonthWeeklyRecur && event->doesRecur() == Recurrence::rWeekly )
603 return; 633 return;
604 } 634 }
605 635
606 if ( event->isHoliday()) { 636 if ( event->isHoliday()) {
607 setHoliday( true ); 637 setHoliday( true );
608 if ( mDate.dayOfWeek() == 7 ) 638 if ( mDate.dayOfWeek() == 7 )
609 setLineWidth( 3 ); 639 setLineWidth( 3 );
610 } 640 }
611 QString text; 641 QString text;
612 int multiday = 0;// 1 = start, 2 = midddle, 3 = end day 642 int multiday = 0;// 1 = start, 2 = midddle, 3 = end day
613 if (event->isMultiDay()) { 643 if (event->isMultiDay()) {
614 QString prefix = "<->";multiday = 2; 644 QString prefix = "<->";multiday = 2;
615 QString time; 645 QString time;
616 if ( event->doesRecur() ) { 646 if ( event->doesRecur() ) {
617 if ( event->recursOn( mDate) ) { 647 if ( event->recursOn( mDate) ) {
618 prefix ="->" ;multiday = 1; 648 prefix ="->" ;multiday = 1;
619 } 649 }
620 else { 650 else {
621 int days = event->dtStart().date().daysTo ( event->dtEnd().date() ); 651 int days = event->dtStart().date().daysTo ( event->dtEnd().date() );
622 if ( event->recursOn( mDate.addDays( -days)) ) { 652 if ( event->recursOn( mDate.addDays( -days)) ) {
623 prefix ="<-" ;multiday = 3; 653 prefix ="<-" ;multiday = 3;
624 } 654 }
625 } 655 }
626 656
627 } else { 657 } else {
628 if (mDate == event->dtStart().date()) { 658 if (mDate == event->dtStart().date()) {
629 prefix ="->" ;multiday = 1; 659 prefix ="->" ;multiday = 1;
630 } else if (mDate == event->dtEnd().date()) { 660 } else if (mDate == event->dtEnd().date()) {
631 prefix ="<-" ;multiday = 3; 661 prefix ="<-" ;multiday = 3;
632 } 662 }
633 } 663 }
634 if ( !event->doesFloat() ) { 664 if ( !event->doesFloat() ) {
635 if ( mDate == event->dtStart().date () ) 665 if ( mDate == event->dtStart().date () )
636 time = KGlobal::locale()->formatTime(event->dtStart().time())+" "; 666 time = KGlobal::locale()->formatTime(event->dtStart().time())+" ";
637 else if ( mDate == event->dtEnd().date () ) 667 else if ( mDate == event->dtEnd().date () )
638 time = KGlobal::locale()->formatTime(event->dtEnd().time())+" "; 668 time = KGlobal::locale()->formatTime(event->dtEnd().time())+" ";
639 669
640 } 670 }
641 text = time + event->summary(); 671 text = time + event->summary();
642 mToolTipText += prefix + text; 672 mToolTipText += prefix + text;
643 } else { 673 } else {
644 if (event->doesFloat()) { 674 if (event->doesFloat()) {
645 text = event->summary(); 675 text = event->summary();
646 mToolTipText += text; 676 mToolTipText += text;
647 } 677 }
648 else { 678 else {
649 text = KGlobal::locale()->formatTime(event->dtStart().time()); 679 text = KGlobal::locale()->formatTime(event->dtStart().time());
650 text += " " + event->summary(); 680 text += " " + event->summary();
651 mToolTipText += KGlobal::locale()->formatTime(event->dtStart().time()) +"-"+KGlobal::locale()->formatTime(event->dtEnd().time())+" " + event->summary(); 681 mToolTipText += KGlobal::locale()->formatTime(event->dtStart().time()) +"-"+KGlobal::locale()->formatTime(event->dtEnd().time())+" " + event->summary();
652 } 682 }
653 } 683 }
654 MonthViewItem *item ; 684 MonthViewItem *item ;
655 if ( mCurrentAvailItem ) { 685
656 item = mCurrentAvailItem; 686 if ( mAvailItemList.count() ) {
657 mCurrentAvailItem = (MonthViewItem*) item->next(); 687 item = mAvailItemList.first();
688 mAvailItemList.remove( item );
658 item->recycle( event, mDate, text ); 689 item->recycle( event, mDate, text );
659 } else { 690 } else {
660 if ( mAvailItemList.count() ) { 691 item = new MonthViewItem( event, mDate, text );
661 item = mAvailItemList.first();
662 mAvailItemList.remove( item );
663 item->recycle( event, mDate, text );
664 insertNewItem = true;
665 } else {
666 insertNewItem = true;
667 item = new MonthViewItem( event, mDate, text );
668 }
669 } 692 }
693
670 QPalette pal; 694 QPalette pal;
671 if (KOPrefs::instance()->mMonthViewUsesCategoryColor) { 695 if (KOPrefs::instance()->mMonthViewUsesCategoryColor) {
672 QStringList categories = event->categories(); 696 QStringList categories = event->categories();
673 QString cat = categories.first(); 697 QString cat = categories.first();
674 if ( KOPrefs::instance()->mMonthViewUsesForegroundColor ) { 698 if ( KOPrefs::instance()->mMonthViewUsesForegroundColor ) {
675 pal = getPalette(); 699 pal = getPalette();
676 if (cat.isEmpty()) { 700 if (cat.isEmpty()) {
677 pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->mEventColor); 701 pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->mEventColor);
678 } else { 702 } else {
679 pal.setColor(QColorGroup::Foreground, *(KOPrefs::instance()->categoryColor(cat))); 703 pal.setColor(QColorGroup::Foreground, *(KOPrefs::instance()->categoryColor(cat)));
680 } 704 }
681 705
682 } else { 706 } else {
683 if (cat.isEmpty()) { 707 if (cat.isEmpty()) {
684 pal = QPalette(KOPrefs::instance()->mEventColor, KOPrefs::instance()->mEventColor); 708 pal = QPalette(KOPrefs::instance()->mEventColor, KOPrefs::instance()->mEventColor);
685 } else { 709 } else {
686 pal = QPalette(*(KOPrefs::instance()->categoryColor(cat)), *(KOPrefs::instance()->categoryColor(cat))); 710 pal = QPalette(*(KOPrefs::instance()->categoryColor(cat)), *(KOPrefs::instance()->categoryColor(cat)));
687 } 711 }
688 } 712 }
689 713
690 } else { 714 } else {
691 pal = mStandardPalette ; 715 pal = mStandardPalette ;
692 } 716 }
693 item->setPalette( pal ); 717 item->setPalette( pal );
694 item->setRecur( event->recurrence()->doesRecur() ); 718 item->setRecur( event->recurrence()->doesRecur() );
695 item->setAlarm( event->isAlarmEnabled() && multiday < 2 ); 719 item->setAlarm( event->isAlarmEnabled() && multiday < 2 );
696 item->setMoreInfo( event->description().length() > 0 ); 720 item->setMoreInfo( event->description().length() > 0 );
697#ifdef DESKTOP_VERSION 721#ifdef DESKTOP_VERSION
698 Attendee *me = event->attendeeByMails(KOPrefs::instance()->mAdditionalMails, 722 Attendee *me = event->attendeeByMails(KOPrefs::instance()->mAdditionalMails,
699 KOPrefs::instance()->email()); 723 KOPrefs::instance()->email());
700 if ( me != 0 ) { 724 if ( me != 0 ) {
701 if ( me->status() == Attendee::NeedsAction && me->RSVP()) 725 if ( me->status() == Attendee::NeedsAction && me->RSVP())
702 item->setReply(true && multiday < 2); 726 item->setReply(true && multiday < 2);
703 else 727 else
704 item->setReply(false); 728 item->setReply(false);
705 } else 729 } else
706 item->setReply(false); 730 item->setReply(false);
707#endif 731#endif
708 item->setMultiDay( multiday ); 732 item->setMultiDay( multiday );
709 if ( insertNewItem) 733 insertItem( item );
710 insertItem( item );
711 mToolTip.append( mToolTipText ); 734 mToolTip.append( mToolTipText );
712} 735}
713void MonthViewCell::insertTodo(Todo *todo) 736void MonthViewCell::insertTodo(Todo *todo)
714{ 737{
715 bool insertNewItem = false;
716 setFocusPolicy(WheelFocus); 738 setFocusPolicy(WheelFocus);
717 QString text; 739 QString text;
718 if (todo->hasDueDate()) { 740 if (todo->hasDueDate()) {
719 if (!todo->doesFloat()) { 741 if (!todo->doesFloat()) {
720 text += KGlobal::locale()->formatTime(todo->dtDue().time()); 742 text += KGlobal::locale()->formatTime(todo->dtDue().time());
721 text += " "; 743 text += " ";
722 } 744 }
723 } 745 }
724 text += todo->summary(); 746 text += todo->summary();
725 MonthViewItem *item ; 747 MonthViewItem *item ;
726 if ( mCurrentAvailItem ) { 748 if ( mAvailItemList.count() ) {
727 item = mCurrentAvailItem; 749 item = mAvailItemList.first();
728 mCurrentAvailItem = (MonthViewItem*) item->next(); 750 mAvailItemList.remove( item );
729 item->recycle( todo, mDate, text ); 751 item->recycle( todo, mDate, text );
730 } else { 752 } else {
731 if ( mAvailItemList.count() ) { 753 item = new MonthViewItem( todo, mDate, text );
732 item = mAvailItemList.first();
733 mAvailItemList.remove( item );
734 item->recycle( todo, mDate, text );
735 insertNewItem = true;
736 } else {
737 insertNewItem = true;
738 item = new MonthViewItem( todo, mDate, text );
739 }
740 } 754 }
741 //MonthViewItem *item = new MonthViewItem( todo, mDate, text ); 755 //MonthViewItem *item = new MonthViewItem( todo, mDate, text );
742 //item->setPalette( mStandardPalette ); 756 //item->setPalette( mStandardPalette );
743 QPalette pal; 757 QPalette pal;
744 if (KOPrefs::instance()->mMonthViewUsesCategoryColor) { 758 if (KOPrefs::instance()->mMonthViewUsesCategoryColor) {
745 QStringList categories = todo->categories(); 759 QStringList categories = todo->categories();
746 QString cat = categories.first(); 760 QString cat = categories.first();
747 if ( KOPrefs::instance()->mMonthViewUsesForegroundColor ) { 761 if ( KOPrefs::instance()->mMonthViewUsesForegroundColor ) {
748 pal = getPalette(); 762 pal = getPalette();
749 if (cat.isEmpty()) { 763 if (cat.isEmpty()) {
750 pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->mEventColor); 764 pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->mEventColor);
751 } else { 765 } else {
752 pal.setColor(QColorGroup::Foreground, *(KOPrefs::instance()->categoryColor(cat))); 766 pal.setColor(QColorGroup::Foreground, *(KOPrefs::instance()->categoryColor(cat)));
753 } 767 }
754 768
755 } else { 769 } else {
756 if (cat.isEmpty()) { 770 if (cat.isEmpty()) {
757 pal = QPalette(KOPrefs::instance()->mEventColor, KOPrefs::instance()->mEventColor); 771 pal = QPalette(KOPrefs::instance()->mEventColor, KOPrefs::instance()->mEventColor);
758 } else { 772 } else {
759 pal = QPalette(*(KOPrefs::instance()->categoryColor(cat)), *(KOPrefs::instance()->categoryColor(cat))); 773 pal = QPalette(*(KOPrefs::instance()->categoryColor(cat)), *(KOPrefs::instance()->categoryColor(cat)));
760 } 774 }
761 } 775 }
762 776
763 } else { 777 } else {
764 pal = mStandardPalette ; 778 pal = mStandardPalette ;
765 } 779 }
766 item->setPalette( pal ); 780 item->setPalette( pal );
767 item->setRecur( todo->recurrence()->doesRecur() ); 781 item->setRecur( todo->recurrence()->doesRecur() );
768 item->setAlarm( todo->isAlarmEnabled() ); 782 item->setAlarm( todo->isAlarmEnabled() );
769 item->setMoreInfo( todo->description().length() > 0 ); 783 item->setMoreInfo( todo->description().length() > 0 );
770 if ( insertNewItem) 784 insertItem( item );
771 insertItem( item );
772 mToolTip.append( text ); 785 mToolTip.append( text );
773} 786}
774void MonthViewCell::repaintfinishUpdateCell() 787void MonthViewCell::repaintfinishUpdateCell()
775{ 788{
776 MonthViewItem *mitem = (MonthViewItem*) firstItem (); 789 MonthViewItem *mitem = (MonthViewItem*) firstItem ();
777 while ( mitem ) { 790 while ( mitem ) {
778 mitem->setBlockRepaint( false ); 791 mitem->setBlockRepaint( false );
779 updateItem ( mitem ); 792 updateItem ( mitem );
780 mitem = (MonthViewItem *)mitem->next(); 793 mitem = (MonthViewItem *)mitem->next();
781 } 794 }
782} 795}
783void MonthViewCell::finishUpdateCell() 796void MonthViewCell::finishUpdateCell()
784{ 797{
785 while ( mCurrentAvailItem ) { 798
786 MonthViewItem *item = mCurrentAvailItem;
787 mCurrentAvailItem = (MonthViewItem *)item->next();
788 mAvailItemList.append( item );
789 takeItem ( item );
790 }
791 799
792 800
793#ifdef DESKTOP_VERSION 801#ifdef DESKTOP_VERSION
794 if (mToolTip.count() > 0 ) { 802 if (mToolTip.count() > 0 ) {
795 mToolTip.sort(); 803 mToolTip.sort();
796 QToolTip::add(this,mToolTip.join("\n"),toolTipGroup(),""); 804 QToolTip::add(this,mToolTip.join("\n"),toolTipGroup(),"");
797 } 805 }
798#endif 806#endif
799 sort(); 807 sort();
800 //setMyPalette(); 808 //setMyPalette();
801 setMyPalette(); 809 setMyPalette();
802 810
803 resizeEvent( 0 ); 811 resizeEvent( 0 );
804 812
805} 813}
806void MonthViewCell::updateCell() 814void MonthViewCell::updateCell()
807{ 815{
808 //qDebug("MonthViewCell::updateCell() "); 816 //qDebug("MonthViewCell::updateCell() ");
809 if ( !mMonthView->isUpdatePossible() ) 817 if ( !mMonthView->isUpdatePossible() )
810 return; 818 return;
811 startUpdateCell(); 819 startUpdateCell();
812 //mLabel->setMaximumWidth( width() - mItemList->lineWidth()*2); 820 //mLabel->setMaximumWidth( width() - mItemList->lineWidth()*2);
813 QPtrList<Event> events = mMonthView->calendar()->events( mDate, true ); 821 QPtrList<Event> events = mMonthView->calendar()->events( mDate, true );
814 Event *event; 822 Event *event;
815 for( event = events.first(); event; event = events.next() ) { // for event 823 for( event = events.first(); event; event = events.next() ) { // for event
816 insertEvent(event); 824 insertEvent(event);
817 } 825 }
818 // insert due todos 826 // insert due todos
819 QPtrList<Todo> todos = mMonthView->calendar()->todos( mDate ); 827 QPtrList<Todo> todos = mMonthView->calendar()->todos( mDate );
820 Todo *todo; 828 Todo *todo;
821 for(todo = todos.first(); todo; todo = todos.next()) { 829 for(todo = todos.first(); todo; todo = todos.next()) {
822 insertTodo( todo ); 830 insertTodo( todo );
823 } 831 }
824 finishUpdateCell(); 832 finishUpdateCell();
825 // if ( isVisible()) 833 // if ( isVisible())
826 //qApp->processEvents(); 834 //qApp->processEvents();
827} 835}
828 836
829void MonthViewCell::updateConfig( bool bigFont ) // = false 837void MonthViewCell::updateConfig( bool bigFont ) // = false
830{ 838{
831 839
832 if ( bigFont ) { 840 if ( bigFont ) {
833 QFont fo = KOPrefs::instance()->mMonthViewFont; 841 QFont fo = KOPrefs::instance()->mMonthViewFont;
834 int ps = fo.pointSize() + 2; 842 int ps = fo.pointSize() + 2;
835 if ( ps < 18 ) 843 if ( ps < 18 )
836 ps += 2; 844 ps += 2;
837 fo.setPointSize( ps ); 845 fo.setPointSize( ps );
838 setFont( fo ); 846 setFont( fo );
839 } else 847 } else
840 setFont( KOPrefs::instance()->mMonthViewFont ); 848 setFont( KOPrefs::instance()->mMonthViewFont );
841 849
842 QFontMetrics fm( font() ); 850 QFontMetrics fm( font() );
843 mLabelSize = fm.size( 0, "30" ) + QSize( 4, 2 ); 851 mLabelSize = fm.size( 0, "30" ) + QSize( 4, 2 );
844 mLabelBigSize = fm.size( 0, "Mag 30" ) + QSize( 2, 2 ); 852 mLabelBigSize = fm.size( 0, "Mag 30" ) + QSize( 2, 2 );
845 mHolidayPalette = mStandardPalette; 853 mHolidayPalette = mStandardPalette;
846 mPrimaryPalette = mStandardPalette; 854 mPrimaryPalette = mStandardPalette;
847 mNonPrimaryPalette = mStandardPalette; 855 mNonPrimaryPalette = mStandardPalette;
848 if ( KOPrefs::instance()->mMonthViewUsesDayColors ) { 856 if ( KOPrefs::instance()->mMonthViewUsesDayColors ) {
849 mHolidayPalette.setColor(QColorGroup::Base, KOPrefs::instance()->mMonthViewHolidayColor ); 857 mHolidayPalette.setColor(QColorGroup::Base, KOPrefs::instance()->mMonthViewHolidayColor );
850 mHolidayPalette.setColor(QColorGroup::Background, KOPrefs::instance()->mMonthViewHolidayColor ); 858 mHolidayPalette.setColor(QColorGroup::Background, KOPrefs::instance()->mMonthViewHolidayColor );
851 mHolidayPalette.setColor(QColorGroup::Foreground, KOPrefs::instance()->mMonthViewHolidayColor.dark()); 859 mHolidayPalette.setColor(QColorGroup::Foreground, KOPrefs::instance()->mMonthViewHolidayColor.dark());
852 mPrimaryPalette.setColor(QColorGroup::Foreground,KOPrefs::instance()->mMonthViewOddColor.dark()); 860 mPrimaryPalette.setColor(QColorGroup::Foreground,KOPrefs::instance()->mMonthViewOddColor.dark());
853 mPrimaryPalette.setColor(QColorGroup::Base,KOPrefs::instance()->mMonthViewOddColor); 861 mPrimaryPalette.setColor(QColorGroup::Base,KOPrefs::instance()->mMonthViewOddColor);
854 mPrimaryPalette.setColor(QColorGroup::Background,KOPrefs::instance()->mMonthViewOddColor); 862 mPrimaryPalette.setColor(QColorGroup::Background,KOPrefs::instance()->mMonthViewOddColor);
855 mNonPrimaryPalette.setColor(QColorGroup::Foreground,KOPrefs::instance()->mMonthViewEvenColor.dark()); 863 mNonPrimaryPalette.setColor(QColorGroup::Foreground,KOPrefs::instance()->mMonthViewEvenColor.dark());
856 mNonPrimaryPalette.setColor(QColorGroup::Base,KOPrefs::instance()->mMonthViewEvenColor); 864 mNonPrimaryPalette.setColor(QColorGroup::Base,KOPrefs::instance()->mMonthViewEvenColor);
857 mNonPrimaryPalette.setColor(QColorGroup::Background,KOPrefs::instance()->mMonthViewEvenColor); 865 mNonPrimaryPalette.setColor(QColorGroup::Background,KOPrefs::instance()->mMonthViewEvenColor);
858 } 866 }
859 //updateCell(); 867 //updateCell();
860} 868}
861 869
862void MonthViewCell::enableScrollBars( bool enabled ) 870void MonthViewCell::enableScrollBars( bool enabled )
863{ 871{
872
873 return;
864 if ( enabled ) { 874 if ( enabled ) {
865 QListBoxItem *fi = firstItem (); 875 QListBoxItem *fi = firstItem ();
866 if (fi ) { 876 if (fi ) {
867 int ihei = fi->height( this ); 877 int ihei = fi->height( this );
868 int hei = numRows () * ihei; 878 int hei = numRows () * ihei;
869 if ( hei < height() - horizontalScrollBar()->height () ) { 879 if ( hei < height() - horizontalScrollBar()->height () ) {
870 setVScrollBarMode(QScrollView::AlwaysOff); 880 setVScrollBarMode(QScrollView::AlwaysOff);
871 } 881 }
872 else 882 else
873 setVScrollBarMode(QScrollView::Auto); 883 setVScrollBarMode(QScrollView::Auto);
874 if ( ihei *3 > height() ) 884 if ( ihei *3 > height() ) {
875 setHScrollBarMode(QScrollView::AlwaysOff); 885 setHScrollBarMode(QScrollView::AlwaysOff);
876 else 886 }
887 else {
877 setHScrollBarMode(QScrollView::Auto); 888 setHScrollBarMode(QScrollView::Auto);
889 }
878 } else { 890 } else {
879 setVScrollBarMode(QScrollView::Auto); 891 setVScrollBarMode(QScrollView::Auto);
880 setHScrollBarMode(QScrollView::Auto); 892 setHScrollBarMode(QScrollView::Auto);
881 } 893 }
882 } else { 894 } else {
883 setVScrollBarMode(QScrollView::AlwaysOff); 895 setVScrollBarMode(QScrollView::AlwaysOff);
884 setHScrollBarMode(QScrollView::AlwaysOff); 896 setHScrollBarMode(QScrollView::AlwaysOff);
885 } 897 }
886} 898}
887 899
888Incidence *MonthViewCell::selectedIncidence() 900Incidence *MonthViewCell::selectedIncidence()
889{ 901{
890 int index = currentItem(); 902 int index = currentItem();
891 if ( index < 0 ) return 0; 903 if ( index < 0 ) return 0;
892 904
893 MonthViewItem *mitem = 905 MonthViewItem *mitem =
894 static_cast<MonthViewItem *>( item( index ) ); 906 static_cast<MonthViewItem *>( item( index ) );
895 907
896 if ( !mitem ) return 0; 908 if ( !mitem ) return 0;
897 909
898 return mitem->incidence(); 910 return mitem->incidence();
899} 911}
900 912
901QDate MonthViewCell::selectedIncidenceDate() 913QDate MonthViewCell::selectedIncidenceDate()
902{ 914{
903 QDate qd; 915 QDate qd;
904 int index = currentItem(); 916 int index = currentItem();
905 if ( index < 0 ) return qd; 917 if ( index < 0 ) return qd;
906 918
907 MonthViewItem *mitem = 919 MonthViewItem *mitem =
908 static_cast<MonthViewItem *>( item( index ) ); 920 static_cast<MonthViewItem *>( item( index ) );
909 921
910 if ( !mitem ) return qd; 922 if ( !mitem ) return qd;
911 923
912 return mitem->incidenceDate(); 924 return mitem->incidenceDate();
913} 925}
914 926
915void MonthViewCell::deselect() 927void MonthViewCell::deselect()
916{ 928{
917 clearSelection(); 929 clearSelection();
918 enableScrollBars( false ); 930 enableScrollBars( false );
919 // updateCell(); 931 // updateCell();
920} 932}
921void MonthViewCell::select() 933void MonthViewCell::select()
922{ 934{
923 ;// updateCell(); 935 ;// updateCell();
924} 936}
925 937
@@ -936,97 +948,96 @@ void MonthViewCell::resizeEvent ( QResizeEvent * e )
936 bool smallDisplay = QApplication::desktop()->width() < 320 && KOPrefs::instance()->mMonthViewSatSunTog; 948 bool smallDisplay = QApplication::desktop()->width() < 320 && KOPrefs::instance()->mMonthViewSatSunTog;
937 if ( KOPrefs::instance()->mMonthViewWeek || KOGlobals::self()->calendarSystem()->day( mDate ) == 1 || (mDate.dayOfWeek() == 7 && !smallDisplay ) || KOPrefs::instance()->mMonthShowShort) { 949 if ( KOPrefs::instance()->mMonthViewWeek || KOGlobals::self()->calendarSystem()->day( mDate ) == 1 || (mDate.dayOfWeek() == 7 && !smallDisplay ) || KOPrefs::instance()->mMonthShowShort) {
938 text = KOGlobals::self()->calendarSystem()->monthName( mDate, true ) + " "; 950 text = KOGlobals::self()->calendarSystem()->monthName( mDate, true ) + " ";
939 mLabel->resize( mLabelBigSize ); 951 mLabel->resize( mLabelBigSize );
940 text += QString::number( KOGlobals::self()->calendarSystem()->day(mDate) ); 952 text += QString::number( KOGlobals::self()->calendarSystem()->day(mDate) );
941 } else { 953 } else {
942 mLabel->resize( mLabelSize ); 954 mLabel->resize( mLabelSize );
943 text += QString::number( KOGlobals::self()->calendarSystem()->day(mDate) ); 955 text += QString::number( KOGlobals::self()->calendarSystem()->day(mDate) );
944 } 956 }
945 mLabel->setText( text ); 957 mLabel->setText( text );
946 958
947 int size = height() - mLabel->height() - lineWidth()-1; 959 int size = height() - mLabel->height() - lineWidth()-1;
948 //qDebug("LW %d ", lineWidth()); 960 //qDebug("LW %d ", lineWidth());
949 if ( size > 0 ) 961 if ( size > 0 )
950 verticalScrollBar()->setMaximumHeight( size ); 962 verticalScrollBar()->setMaximumHeight( size );
951 size = width() - mLabel->width() -lineWidth()-1; 963 size = width() - mLabel->width() -lineWidth()-1;
952 if ( size > 0 ) 964 if ( size > 0 )
953 horizontalScrollBar()->setMaximumWidth( size ); 965 horizontalScrollBar()->setMaximumWidth( size );
954 mLabel->move( width()-lineWidth() - mLabel->width(), height()-lineWidth() - mLabel->height() ); 966 mLabel->move( width()-lineWidth() - mLabel->width(), height()-lineWidth() - mLabel->height() );
955 //mLabel->setMaximumWidth( width() - mItemList->lineWidth()*2); 967 //mLabel->setMaximumWidth( width() - mItemList->lineWidth()*2);
956 // mItemList->resize ( width(), height () ); 968 // mItemList->resize ( width(), height () );
957 if ( e ) 969 if ( e )
958 KNoScrollListBox::resizeEvent ( e ); 970 KNoScrollListBox::resizeEvent ( e );
959} 971}
960 972
961void MonthViewCell::defaultAction( QListBoxItem *item ) 973void MonthViewCell::defaultAction( QListBoxItem *item )
962{ 974{
963 if ( !item ) { 975 if ( !item ) {
964 QDateTime dt( date(), QTime( KOPrefs::instance()->mStartTime, 0 ) ); 976 QDateTime dt( date(), QTime( KOPrefs::instance()->mStartTime, 0 ) );
965 emit newEventSignal( dt ); 977 emit newEventSignal( dt );
966 return; 978 return;
967 } 979 }
968 980
969 MonthViewItem *eventItem = static_cast<MonthViewItem *>( item ); 981 MonthViewItem *eventItem = static_cast<MonthViewItem *>( item );
970 Incidence *incidence = eventItem->incidence(); 982 Incidence *incidence = eventItem->incidence();
971 if ( incidence ) mMonthView->defaultAction( incidence ); 983 if ( incidence ) mMonthView->defaultAction( incidence );
972} 984}
973void MonthViewCell::showDay() 985void MonthViewCell::showDay()
974{ 986{
975 emit showDaySignal( date() ); 987 emit showDaySignal( date() );
976} 988}
977void MonthViewCell::newEvent() 989void MonthViewCell::newEvent()
978{ 990{
979 QDateTime dt( date(), QTime( KOPrefs::instance()->mStartTime, 0 ) ); 991 QDateTime dt( date(), QTime( KOPrefs::instance()->mStartTime, 0 ) );
980 emit newEventSignal( dt ); 992 emit newEventSignal( dt );
981} 993}
982void MonthViewCell::cellClicked( QListBoxItem *item ) 994void MonthViewCell::cellClicked( QListBoxItem *item )
983{ 995{
984 static QListBoxItem * lastClicked = 0;
985 if ( item == 0 ) { 996 if ( item == 0 ) {
986 QDateTime dt( date(), QTime( KOPrefs::instance()->mStartTime, 0 ) ); 997 QDateTime dt( date(), QTime( KOPrefs::instance()->mStartTime, 0 ) );
987 emit newEventSignal( dt ); 998 emit newEventSignal( dt );
988 return; 999 return;
989 } 1000 }
990 /* 1001 /*
991 if ( lastClicked ) 1002 if ( lastClicked )
992 if ( ! item ) { 1003 if ( ! item ) {
993 if ( lastClicked->listBox() != item->listBox() ) 1004 if ( lastClicked->listBox() != item->listBox() )
994 lastClicked->listBox()->clearSelection(); 1005 lastClicked->listBox()->clearSelection();
995 } 1006 }
996 */ 1007 */
997 1008
998 mMonthView->setSelectedCell( this ); 1009 mMonthView->setSelectedCell( this );
999 if( KOPrefs::instance()->mEnableMonthScroll || KOPrefs::instance()->mMonthViewWeek ) enableScrollBars( true ); 1010 if( KOPrefs::instance()->mEnableMonthScroll || KOPrefs::instance()->mMonthViewWeek ) enableScrollBars( true );
1000 select(); 1011 select();
1001} 1012}
1002 1013
1003void MonthViewCell::contextMenu( QListBoxItem *item ) 1014void MonthViewCell::contextMenu( QListBoxItem *item )
1004{ 1015{
1005 if ( !item ) return; 1016 if ( !item ) return;
1006 1017
1007 MonthViewItem *eventItem = static_cast<MonthViewItem *>( item ); 1018 MonthViewItem *eventItem = static_cast<MonthViewItem *>( item );
1008 Incidence *incidence = eventItem->incidence(); 1019 Incidence *incidence = eventItem->incidence();
1009 if ( incidence ) mMonthView->showContextMenu( incidence ); 1020 if ( incidence ) mMonthView->showContextMenu( incidence );
1010} 1021}
1011 1022
1012void MonthViewCell::selection( QListBoxItem *item ) 1023void MonthViewCell::selection( QListBoxItem *item )
1013{ 1024{
1014 if ( !item ) return; 1025 if ( !item ) return;
1015 1026
1016 mMonthView->setSelectedCell( this ); 1027 mMonthView->setSelectedCell( this );
1017} 1028}
1018 1029
1019 1030
1020// ******************************************************************************* 1031// *******************************************************************************
1021// ******************************************************************************* 1032// *******************************************************************************
1022// ******************************************************************************* 1033// *******************************************************************************
1023 1034
1024 1035
1025KOMonthView::KOMonthView(Calendar *calendar, QWidget *parent, const char *name) 1036KOMonthView::KOMonthView(Calendar *calendar, QWidget *parent, const char *name)
1026 : KOEventView( calendar, parent, name ), 1037 : KOEventView( calendar, parent, name ),
1027 mDaysPerWeek( 7 ), mNumWeeks( 6 ), mNumCells( mDaysPerWeek * mNumWeeks ), 1038 mDaysPerWeek( 7 ), mNumWeeks( 6 ), mNumCells( mDaysPerWeek * mNumWeeks ),
1028 mWidthLongDayLabel( 0 ), mSelectedCell( 0 ) 1039 mWidthLongDayLabel( 0 ), mSelectedCell( 0 )
1029{ 1040{
1030 mFlagKeyPressed = false; 1041 mFlagKeyPressed = false;
1031 mShortDayLabelsM = false; 1042 mShortDayLabelsM = false;
1032 mShortDayLabelsW = false; 1043 mShortDayLabelsW = false;
@@ -1046,113 +1057,113 @@ KOMonthView::KOMonthView(Calendar *calendar, QWidget *parent, const char *name)
1046#endif 1057#endif
1047 hb->addWidget( mNavigatorBar ); 1058 hb->addWidget( mNavigatorBar );
1048 hb->addWidget( mWidStack ); 1059 hb->addWidget( mWidStack );
1049 mShowWeekView = KOPrefs::instance()->mMonthViewWeek; 1060 mShowWeekView = KOPrefs::instance()->mMonthViewWeek;
1050 updatePossible = false; 1061 updatePossible = false;
1051 //updatePossible = true; 1062 //updatePossible = true;
1052 mCells.setAutoDelete( true ); 1063 mCells.setAutoDelete( true );
1053 mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ; 1064 mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ;
1054 mDayLabels.resize( mDaysPerWeek ); 1065 mDayLabels.resize( mDaysPerWeek );
1055 mDayLabelsW.resize( mDaysPerWeek ); 1066 mDayLabelsW.resize( mDaysPerWeek );
1056 QFont bfont = font(); 1067 QFont bfont = font();
1057 if ( QApplication::desktop()->width() < 650 ) { 1068 if ( QApplication::desktop()->width() < 650 ) {
1058 bfont.setPointSize( bfont.pointSize() - 2 ); 1069 bfont.setPointSize( bfont.pointSize() - 2 );
1059 } 1070 }
1060 bfont.setBold( true ); 1071 bfont.setBold( true );
1061 int i; 1072 int i;
1062 1073
1063 for( i = 0; i < mDaysPerWeek; i++ ) { 1074 for( i = 0; i < mDaysPerWeek; i++ ) {
1064 QLabel *label = new QLabel( mMonthView ); 1075 QLabel *label = new QLabel( mMonthView );
1065 label->setFont(bfont); 1076 label->setFont(bfont);
1066 label->setFrameStyle(QFrame::Panel|QFrame::Raised); 1077 label->setFrameStyle(QFrame::Panel|QFrame::Raised);
1067 label->setLineWidth(1); 1078 label->setLineWidth(1);
1068 label->setAlignment(AlignCenter); 1079 label->setAlignment(AlignCenter);
1069 mDayLabels.insert( i, label ); 1080 mDayLabels.insert( i, label );
1070 label = new QLabel( mWeekView ); 1081 label = new QLabel( mWeekView );
1071 label->setFont(bfont); 1082 label->setFont(bfont);
1072 label->setFrameStyle(QFrame::Panel|QFrame::Raised); 1083 label->setFrameStyle(QFrame::Panel|QFrame::Raised);
1073 label->setLineWidth(1); 1084 label->setLineWidth(1);
1074 label->setAlignment(AlignCenter); 1085 label->setAlignment(AlignCenter);
1075 mDayLabelsW.insert( i, label ); 1086 mDayLabelsW.insert( i, label );
1076 } 1087 }
1077 1088
1078 bfont.setBold( false ); 1089 bfont.setBold( false );
1079 mWeekLabels.resize( mNumWeeks+1 ); 1090 mWeekLabels.resize( mNumWeeks+1 );
1080 mWeekLabelsW.resize( 2 ); 1091 mWeekLabelsW.resize( 2 );
1081 for( i = 0; i < mNumWeeks+1; i++ ) { 1092 for( i = 0; i < mNumWeeks+1; i++ ) {
1082 KOWeekButton *label = new KOWeekButton( mMonthView ); 1093 KOWeekButton *label = new KOWeekButton( mMonthView );
1083 label->setFocusPolicy(NoFocus); 1094 label->setFocusPolicy(NoFocus);
1084 label->setFont(bfont); 1095 label->setFont(bfont);
1085 connect( label, SIGNAL( selectWeekNum ( int )),this, SLOT( selectInternalWeekNum ( int )) ); 1096 connect( label, SIGNAL( selectWeekNum ( int )),this, SLOT( selectInternalWeekNum ( int )) );
1086 label->setFlat(true); 1097 label->setFlat(true);
1087 QWhatsThis::add(label,i18n("Click on the week number to\nshow week zoomed")); 1098 QWhatsThis::add(label,i18n("Click on the week number to\nshow week zoomed"));
1088 //label->setFrameStyle(QFrame::Panel|QFrame::Raised); 1099 //label->setFrameStyle(QFrame::Panel|QFrame::Raised);
1089 //label->setLineWidth(1); 1100 //label->setLineWidth(1);
1090 //label->setAlignment(AlignCenter); 1101 //label->setAlignment(AlignCenter);
1091 mWeekLabels.insert( i, label ); 1102 mWeekLabels.insert( i, label );
1092 } 1103 }
1093 mWeekLabels[mNumWeeks]->setText( i18n("W")); 1104 mWeekLabels[mNumWeeks]->setText( i18n("W"));
1094 mWeekLabels[0]->setFocusPolicy(WheelFocus); 1105 mWeekLabels[mNumWeeks]->setFocusPolicy(WheelFocus);
1095 QWhatsThis::add(mWeekLabels[mNumWeeks],i18n("Click on this to\nselect week number")); 1106 QWhatsThis::add(mWeekLabels[mNumWeeks],i18n("Click on this to\nselect week number"));
1096 1107
1097 for( i = 0; i < 1+1; i++ ) { 1108 for( i = 0; i < 1+1; i++ ) {
1098 KOWeekButton *label = new KOWeekButton( mWeekView ); 1109 KOWeekButton *label = new KOWeekButton( mWeekView );
1099 label->setFocusPolicy(NoFocus); 1110 label->setFocusPolicy(NoFocus);
1100 label->setFont(bfont); 1111 label->setFont(bfont);
1101 connect( label, SIGNAL( selectWeekNum ( int )),this, SLOT( selectInternalWeekNum ( int )) ); 1112 connect( label, SIGNAL( selectWeekNum ( int )),this, SLOT( selectInternalWeekNum ( int )) );
1102 label->setFlat(true); 1113 label->setFlat(true);
1103 QWhatsThis::add(label,i18n("Click on the week number to\nshow week zoomed")); 1114 QWhatsThis::add(label,i18n("Click on the week number to\nshow week zoomed"));
1104 //label->setFrameStyle(QFrame::Panel|QFrame::Raised); 1115 //label->setFrameStyle(QFrame::Panel|QFrame::Raised);
1105 //label->setLineWidth(1); 1116 //label->setLineWidth(1);
1106 //label->setAlignment(AlignCenter); 1117 //label->setAlignment(AlignCenter);
1107 mWeekLabelsW.insert( i, label ); 1118 mWeekLabelsW.insert( i, label );
1108 } 1119 }
1109 mWeekLabelsW[1]->setText( i18n("W")); 1120 mWeekLabelsW[1]->setText( i18n("W"));
1110 mWeekLabelsW[0]->setFocusPolicy(WheelFocus); 1121 mWeekLabelsW[1]->setFocusPolicy(WheelFocus);
1111 1122
1112 1123
1113 int row, col; 1124 int row, col;
1114 mCells.resize( mNumCells ); 1125 mCells.resize( mNumCells );
1115 for( row = 0; row < mNumWeeks; ++row ) { 1126 for( row = 0; row < mNumWeeks; ++row ) {
1116 for( col = 0; col < mDaysPerWeek; ++col ) { 1127 for( col = 0; col < mDaysPerWeek; ++col ) {
1117 MonthViewCell *cell = new MonthViewCell( this, mMonthView ); 1128 MonthViewCell *cell = new MonthViewCell( this, mMonthView );
1118 mCells.insert( row * mDaysPerWeek + col, cell ); 1129 mCells.insert( row * mDaysPerWeek + col, cell );
1119 1130
1120 connect( cell, SIGNAL( defaultAction( Incidence * ) ), 1131 connect( cell, SIGNAL( defaultAction( Incidence * ) ),
1121 SLOT( defaultAction( Incidence * ) ) ); 1132 SLOT( defaultAction( Incidence * ) ) );
1122 connect( cell, SIGNAL( newEventSignal( QDateTime ) ), 1133 connect( cell, SIGNAL( newEventSignal( QDateTime ) ),
1123 SIGNAL( newEventSignal( QDateTime ) ) ); 1134 SIGNAL( newEventSignal( QDateTime ) ) );
1124 connect( cell, SIGNAL( showDaySignal( QDate ) ), 1135 connect( cell, SIGNAL( showDaySignal( QDate ) ),
1125 SIGNAL( showDaySignal( QDate ) ) ); 1136 SIGNAL( showDaySignal( QDate ) ) );
1126 } 1137 }
1127 } 1138 }
1128 mCellsW.resize( mDaysPerWeek ); 1139 mCellsW.resize( mDaysPerWeek );
1129 for( col = 0; col < mDaysPerWeek; ++col ) { 1140 for( col = 0; col < mDaysPerWeek; ++col ) {
1130 MonthViewCell *cell = new MonthViewCell( this, mWeekView ); 1141 MonthViewCell *cell = new MonthViewCell( this, mWeekView );
1131 mCellsW.insert( col, cell ); 1142 mCellsW.insert( col, cell );
1132 1143
1133 connect( cell, SIGNAL( defaultAction( Incidence * ) ), 1144 connect( cell, SIGNAL( defaultAction( Incidence * ) ),
1134 SLOT( defaultAction( Incidence * ) ) ); 1145 SLOT( defaultAction( Incidence * ) ) );
1135 connect( cell, SIGNAL( newEventSignal( QDateTime ) ), 1146 connect( cell, SIGNAL( newEventSignal( QDateTime ) ),
1136 SIGNAL( newEventSignal( QDateTime ) ) ); 1147 SIGNAL( newEventSignal( QDateTime ) ) );
1137 connect( cell, SIGNAL( showDaySignal( QDate ) ), 1148 connect( cell, SIGNAL( showDaySignal( QDate ) ),
1138 SIGNAL( showDaySignal( QDate ) ) ); 1149 SIGNAL( showDaySignal( QDate ) ) );
1139 cell->updateConfig(KOPrefs::instance()->mMonthViewUsesBigFont ); 1150 cell->updateConfig(KOPrefs::instance()->mMonthViewUsesBigFont );
1140 } 1151 }
1141 1152
1142 //connect( mWeekLabels[mNumWeeks], SIGNAL( clicked() ), SLOT( switchView() ) ); 1153 //connect( mWeekLabels[mNumWeeks], SIGNAL( clicked() ), SLOT( switchView() ) );
1143 mContextMenu = eventPopup(); 1154 mContextMenu = eventPopup();
1144 // updateConfig(); //useless here... 1155 // updateConfig(); //useless here...
1145 // ... but we need mWidthLongDayLabel computed 1156 // ... but we need mWidthLongDayLabel computed
1146 QFontMetrics fontmetric(mDayLabels[0]->font()); 1157 QFontMetrics fontmetric(mDayLabels[0]->font());
1147 mWidthLongDayLabel = 0; 1158 mWidthLongDayLabel = 0;
1148 for (int i = 0; i < 7; i++) { 1159 for (int i = 0; i < 7; i++) {
1149 int width = fontmetric.width(KOGlobals::self()->calendarSystem()->weekDayName(i+1)); 1160 int width = fontmetric.width(KOGlobals::self()->calendarSystem()->weekDayName(i+1));
1150 if ( width > mWidthLongDayLabel ) mWidthLongDayLabel = width; 1161 if ( width > mWidthLongDayLabel ) mWidthLongDayLabel = width;
1151 } 1162 }
1152 1163
1153 //mWeekLabels[mNumWeeks]->setText( i18n("W")); 1164 //mWeekLabels[mNumWeeks]->setText( i18n("W"));
1154 1165
1155#if 0 1166#if 0
1156 if ( mShowWeekView ) 1167 if ( mShowWeekView )
1157 mWidStack->raiseWidget( mWeekView ); 1168 mWidStack->raiseWidget( mWeekView );
1158 else 1169 else
@@ -1353,97 +1364,97 @@ void KOMonthView::showDates(const QDate &start, const QDate &)
1353 1364
1354 if ( mShowWeekView || KOPrefs::instance()->mMonthViewSatSunTog ) { 1365 if ( mShowWeekView || KOPrefs::instance()->mMonthViewSatSunTog ) {
1355 mWeekStartsMonday = true; 1366 mWeekStartsMonday = true;
1356 } 1367 }
1357 int startWeekDay = mWeekStartsMonday ? 1 : 7; 1368 int startWeekDay = mWeekStartsMonday ? 1 : 7;
1358 1369
1359 while( KOGlobals::self()->calendarSystem()->dayOfWeek(mStartDate) != startWeekDay ) { 1370 while( KOGlobals::self()->calendarSystem()->dayOfWeek(mStartDate) != startWeekDay ) {
1360 mStartDate = mStartDate.addDays( -1 ); 1371 mStartDate = mStartDate.addDays( -1 );
1361 } 1372 }
1362 bool primary = false; 1373 bool primary = false;
1363 uint i; 1374 uint i;
1364 for( i = 0; i < (*cells).size(); ++i ) { 1375 for( i = 0; i < (*cells).size(); ++i ) {
1365 QDate date = mStartDate.addDays( i ); 1376 QDate date = mStartDate.addDays( i );
1366 (*cells)[i]->setDate( date ); 1377 (*cells)[i]->setDate( date );
1367 1378
1368#ifndef KORG_NOPLUGINS 1379#ifndef KORG_NOPLUGINS
1369 // add holiday, if present 1380 // add holiday, if present
1370 QString hstring(KOCore::self()->holiday(date)); 1381 QString hstring(KOCore::self()->holiday(date));
1371 (*cells)[i]->setHoliday( hstring ); 1382 (*cells)[i]->setHoliday( hstring );
1372#endif 1383#endif
1373 1384
1374 } 1385 }
1375 QDate date = mStartDate.addDays( mWeekStartsMonday ? 3 : 4 ); 1386 QDate date = mStartDate.addDays( mWeekStartsMonday ? 3 : 4 );
1376 for( i = 0; i < weekNum; ++i ) { 1387 for( i = 0; i < weekNum; ++i ) {
1377 int wno; 1388 int wno;
1378 // remember, according to ISO 8601, the first week of the year is the 1389 // remember, according to ISO 8601, the first week of the year is the
1379 // first week that contains a thursday. Thus we must subtract off 4, 1390 // first week that contains a thursday. Thus we must subtract off 4,
1380 // not just 1. 1391 // not just 1.
1381 int dayOfYear = date.dayOfYear(); 1392 int dayOfYear = date.dayOfYear();
1382 if (dayOfYear % 7 != 0) 1393 if (dayOfYear % 7 != 0)
1383 wno = dayOfYear / 7 + 1; 1394 wno = dayOfYear / 7 + 1;
1384 else 1395 else
1385 wno =dayOfYear / 7; 1396 wno =dayOfYear / 7;
1386 (*weekLabels)[i]->setWeekNum( wno ); 1397 (*weekLabels)[i]->setWeekNum( wno );
1387 date = date.addDays( 7 ); 1398 date = date.addDays( 7 );
1388 } 1399 }
1389 updateView(); 1400 updateView();
1390} 1401}
1391 1402
1392void KOMonthView::showEvents(QPtrList<Event>) 1403void KOMonthView::showEvents(QPtrList<Event>)
1393{ 1404{
1394 qDebug("KOMonthView::selectEvents is not implemented yet. "); 1405 qDebug("KOMonthView::selectEvents is not implemented yet. ");
1395} 1406}
1396 1407
1397void KOMonthView::changeEventDisplay(Event *, int) 1408void KOMonthView::changeEventDisplay(Event *, int)
1398{ 1409{
1399 // this should be re-written to be much more efficient, but this 1410 // this should be re-written to be much more efficient, but this
1400 // quick-and-dirty-hack gets the job done for right now. 1411 // quick-and-dirty-hack gets the job done for right now.
1401 qDebug("KOMonthView::changeEventDisplay "); 1412 //qDebug("KOMonthView::changeEventDisplay ");
1402 updateView(); 1413 updateView();
1403} 1414}
1404 1415
1405void KOMonthView::updateView() 1416void KOMonthView::updateView()
1406{ 1417{
1407 1418
1408 if ( !updatePossible ) 1419 if ( !updatePossible )
1409 return; 1420 return;
1410 //qDebug("UUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU "); 1421 //qDebug("UUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU ");
1411 //QTime ti; 1422 //QTime ti;
1412 //ti.start(); 1423 //ti.start();
1413 clearSelection(); 1424 clearSelection();
1414 QPtrVector<MonthViewCell> *cells; 1425 QPtrVector<MonthViewCell> *cells;
1415 if ( mShowWeekView ) { 1426 if ( mShowWeekView ) {
1416 cells = &mCellsW; 1427 cells = &mCellsW;
1417 } else { 1428 } else {
1418 cells = &mCells; 1429 cells = &mCells;
1419 } 1430 }
1420#if 1 1431#if 1
1421 int i; 1432 int i;
1422 int timeSpan = (*cells).size()-1; 1433 int timeSpan = (*cells).size()-1;
1423 if ( KOPrefs::instance()->mMonthViewWeek ) 1434 if ( KOPrefs::instance()->mMonthViewWeek )
1424 timeSpan = 6; 1435 timeSpan = 6;
1425 for( i = 0; i < timeSpan + 1; ++i ) { 1436 for( i = 0; i < timeSpan + 1; ++i ) {
1426 (*cells)[i]->startUpdateCell(); 1437 (*cells)[i]->startUpdateCell();
1427 } 1438 }
1428 1439
1429 QPtrList<Event> events = calendar()->events(); 1440 QPtrList<Event> events = calendar()->events();
1430 Event *event; 1441 Event *event;
1431 QDateTime dt; 1442 QDateTime dt;
1432 bool ok; 1443 bool ok;
1433 QDate endDate = mStartDate.addDays( timeSpan ); 1444 QDate endDate = mStartDate.addDays( timeSpan );
1434 for( event = events.first(); event; event = events.next() ) { // for event 1445 for( event = events.first(); event; event = events.next() ) { // for event
1435 if ( event->doesRecur() ) { 1446 if ( event->doesRecur() ) {
1436 bool last; 1447 bool last;
1437 QDateTime incidenceStart = event->recurrence()->getPreviousDateTime( QDateTime( mStartDate ) , &last ); 1448 QDateTime incidenceStart = event->recurrence()->getPreviousDateTime( QDateTime( mStartDate ) , &last );
1438 QDateTime incidenceEnd; 1449 QDateTime incidenceEnd;
1439 int eventlen = event->dtStart().date().daysTo ( event->dtEnd().date() ); 1450 int eventlen = event->dtStart().date().daysTo ( event->dtEnd().date() );
1440 bool invalid = false; 1451 bool invalid = false;
1441 while( true ) { 1452 while( true ) {
1442 if ( incidenceStart.isValid() ) { 1453 if ( incidenceStart.isValid() ) {
1443 incidenceEnd = incidenceStart.addDays( eventlen ); 1454 incidenceEnd = incidenceStart.addDays( eventlen );
1444 int st = incidenceStart.date().daysTo( endDate ); 1455 int st = incidenceStart.date().daysTo( endDate );
1445 if ( st >= 0 ) { // start before timeend 1456 if ( st >= 0 ) { // start before timeend
1446 int end = mStartDate.daysTo( incidenceEnd.date() ); 1457 int end = mStartDate.daysTo( incidenceEnd.date() );
1447 if ( end >= 0 ) { // end after timestart --- got one! 1458 if ( end >= 0 ) { // end after timestart --- got one!
1448 //normalize 1459 //normalize
1449 st = timeSpan - st; 1460 st = timeSpan - st;
@@ -1483,104 +1494,105 @@ void KOMonthView::updateView()
1483 int iii; 1494 int iii;
1484 for ( iii = st;iii<= end;++iii) 1495 for ( iii = st;iii<= end;++iii)
1485 (*cells)[iii]->insertEvent( event ); 1496 (*cells)[iii]->insertEvent( event );
1486 } 1497 }
1487 } 1498 }
1488 } 1499 }
1489 } 1500 }
1490 // insert due todos 1501 // insert due todos
1491 QPtrList<Todo> todos = calendar()->todos( ); 1502 QPtrList<Todo> todos = calendar()->todos( );
1492 Todo *todo; 1503 Todo *todo;
1493 for(todo = todos.first(); todo; todo = todos.next()) { 1504 for(todo = todos.first(); todo; todo = todos.next()) {
1494 //insertTodo( todo ); 1505 //insertTodo( todo );
1495 if ( todo->hasDueDate() ) { 1506 if ( todo->hasDueDate() ) {
1496 int day = mStartDate.daysTo( todo->dtDue().date() ); 1507 int day = mStartDate.daysTo( todo->dtDue().date() );
1497 if ( day >= 0 && day < timeSpan + 1) { 1508 if ( day >= 0 && day < timeSpan + 1) {
1498 (*cells)[day]->insertTodo( todo ); 1509 (*cells)[day]->insertTodo( todo );
1499 } 1510 }
1500 } 1511 }
1501 } 1512 }
1502 1513
1503 for( i = 0; i < timeSpan+1; ++i ) { 1514 for( i = 0; i < timeSpan+1; ++i ) {
1504 (*cells)[i]->finishUpdateCell(); 1515 (*cells)[i]->finishUpdateCell();
1505 } 1516 }
1506 processSelectionChange(); 1517 processSelectionChange();
1507 //qApp->processEvents(); 1518 //qApp->processEvents();
1508 for( i = 0; i < timeSpan+1; ++i ) { 1519 for( i = 0; i < timeSpan+1; ++i ) {
1509 (*cells)[i]->repaintfinishUpdateCell(); 1520 (*cells)[i]->repaintfinishUpdateCell();
1510 } 1521 }
1511 setKeyBFocus(); 1522 setKeyBFocus();
1512#else 1523#else
1513 // old code 1524 // old code
1514 //qDebug("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ "); 1525 //qDebug("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ");
1515 int i; 1526 int i;
1516 for( i = 0; i < (*cells).count(); ++i ) { 1527 for( i = 0; i < (*cells).count(); ++i ) {
1517 (*cells)[i]->updateCell(); 1528 (*cells)[i]->updateCell();
1518 } 1529 }
1519 1530
1520 //qDebug("KOMonthView::updateView() "); 1531 //qDebug("KOMonthView::updateView() ");
1521 processSelectionChange(); 1532 processSelectionChange();
1522 // qDebug("---------------------------------------------------------------------+ "); 1533 // qDebug("---------------------------------------------------------------------+ ");
1523 (*cells)[0]->setFocus(); 1534 (*cells)[0]->setFocus();
1524#endif 1535#endif
1525 1536
1526 //qDebug("update time %d ", ti.elapsed()); 1537 //qDebug("update time %d ", ti.elapsed());
1527} 1538}
1528 1539
1529void KOMonthView::setKeyBoardFocus() 1540void KOMonthView::setKeyBoardFocus()
1530{ 1541{
1542 //qDebug("KOMonthView::setKeyBoardFocus() ");
1531 bool shootAgain = false; 1543 bool shootAgain = false;
1532 if ( mShowWeekView ) { 1544 if ( mShowWeekView ) {
1533 shootAgain = !mWeekLabelsW[0]->hasFocus(); 1545 shootAgain = !mWeekLabelsW[1]->hasFocus();
1534 mWeekLabelsW[0]->setFocus(); 1546 mWeekLabelsW[1]->setFocus();
1535 } 1547 }
1536 else { 1548 else {
1537 shootAgain = !mWeekLabels[0]->hasFocus(); 1549 shootAgain = !mWeekLabels[mNumWeeks]->hasFocus();
1538 mWeekLabels[0]->setFocus(); 1550 mWeekLabels[mNumWeeks]->setFocus();
1539 } 1551 }
1540 if ( shootAgain ) { 1552 if ( shootAgain ) {
1541 QTimer::singleShot( 0, this, SLOT ( setKeyBFocus() ) ); 1553 QTimer::singleShot( 0, this, SLOT ( setKeyBFocus() ) );
1542 } 1554 }
1543} 1555}
1544void KOMonthView::setKeyBFocus() 1556void KOMonthView::setKeyBFocus()
1545{ 1557{
1546 //qDebug("KOMonthView::setKeyBFocus() "); 1558 //qDebug("KOMonthView::setKeyBFocus() ");
1547 QTimer::singleShot( 0, this, SLOT ( setKeyBoardFocus() ) ); 1559 QTimer::singleShot( 0, this, SLOT ( setKeyBoardFocus() ) );
1548} 1560}
1549void KOMonthView::resizeEvent(QResizeEvent * e) 1561void KOMonthView::resizeEvent(QResizeEvent * e)
1550{ 1562{
1551 //qDebug("KOMonthView::resizeEvent %d %d -- %d %d ", e->size().width(), e->size().height(), e->oldSize().width(), e->oldSize().height()); 1563 //qDebug("KOMonthView::resizeEvent %d %d -- %d %d ", e->size().width(), e->size().height(), e->oldSize().width(), e->oldSize().height());
1552 if ( isVisible() ) { 1564 if ( isVisible() ) {
1553 //qDebug("KOMonthView::isVisible "); 1565 //qDebug("KOMonthView::isVisible ");
1554 slotComputeLayout(); 1566 slotComputeLayout();
1555 } else 1567 } else
1556 mComputeLayoutTimer->start( 100 ); 1568 mComputeLayoutTimer->start( 100 );
1557} 1569}
1558 1570
1559void KOMonthView::slotComputeLayout() 1571void KOMonthView::slotComputeLayout()
1560{ 1572{
1561 mComputeLayoutTimer->stop(); 1573 mComputeLayoutTimer->stop();
1562 //qDebug("KOMonthView::Post - resizeEvent %d %d ", width(), height() ); 1574 //qDebug("KOMonthView::Post - resizeEvent %d %d ", width(), height() );
1563 computeLayout(); 1575 computeLayout();
1564 clPending = true; 1576 clPending = true;
1565 setKeyBFocus(); 1577 setKeyBFocus();
1566} 1578}
1567void KOMonthView::computeLayoutWeek() 1579void KOMonthView::computeLayoutWeek()
1568{ 1580{
1569 static int lastWid = 0; 1581 static int lastWid = 0;
1570 static int lastHei = 0; 1582 static int lastHei = 0;
1571 int daysToShow; 1583 int daysToShow;
1572 bool combinedSatSun = false; 1584 bool combinedSatSun = false;
1573 if (mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ) { 1585 if (mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ) {
1574 daysToShow = 6; 1586 daysToShow = 6;
1575 combinedSatSun = true; 1587 combinedSatSun = true;
1576 } 1588 }
1577 int tWid = topLevelWidget()->size().width(); 1589 int tWid = topLevelWidget()->size().width();
1578 int tHei = topLevelWidget()->size().height(); 1590 int tHei = topLevelWidget()->size().height();
1579 1591
1580 int wid = width();//e 1592 int wid = width();//e
1581 int hei = height()-1-mNavigatorBar->height(); 1593 int hei = height()-1-mNavigatorBar->height();
1582 1594
1583 if ( ((wid *3)/2) < tWid && (( hei *3) /2) < tHei ) 1595 if ( ((wid *3)/2) < tWid && (( hei *3) /2) < tHei )
1584 return; 1596 return;
1585 1597
1586 if ( lastWid == width() && lastHei == height() ) { 1598 if ( lastWid == width() && lastHei == height() ) {
diff --git a/korganizer/komonthview.h b/korganizer/komonthview.h
index e04cdf5..e962756 100644
--- a/korganizer/komonthview.h
+++ b/korganizer/komonthview.h
@@ -14,233 +14,234 @@
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 KOWeekButton : public QPushButton 47class KOWeekButton : public QPushButton
48{ 48{
49 Q_OBJECT 49 Q_OBJECT
50 public: 50 public:
51 KOWeekButton( QWidget *parent=0, const char *name=0 ) : 51 KOWeekButton( QWidget *parent=0, const char *name=0 ) :
52 QPushButton( parent, name) 52 QPushButton( parent, name)
53 { 53 {
54 connect( this, SIGNAL( clicked() ), 54 connect( this, SIGNAL( clicked() ),
55 SLOT( bottonClicked() )); 55 SLOT( bottonClicked() ));
56 mNumber = -1; 56 mNumber = -1;
57 } 57 }
58 void setWeekNum ( int num ) {mNumber = num; setText( QString::number ( num ));} 58 void setWeekNum ( int num ) {mNumber = num; setText( QString::number ( num ));}
59 int getWeekNum() { return mNumber;} 59 int getWeekNum() { return mNumber;}
60 signals: 60 signals:
61 void selectWeekNum ( int ); 61 void selectWeekNum ( int );
62private: 62private:
63 void focusInEvent ( QFocusEvent * ){;}
63 int mNumber; 64 int mNumber;
64 void keyPressEvent ( QKeyEvent * e ) 65 void keyPressEvent ( QKeyEvent * e )
65 { 66 {
66 e->ignore(); 67 e->ignore();
67 } 68 }
68 69
69private slots : 70private slots :
70 void bottonClicked() { if ( mNumber > 0 ) emit selectWeekNum ( mNumber ); } 71 void bottonClicked() { if ( mNumber > 0 ) emit selectWeekNum ( mNumber ); }
71}; 72};
72 73
73class KNoScrollListBox: public QListBox 74class KNoScrollListBox: public QListBox
74{ 75{
75 Q_OBJECT 76 Q_OBJECT
76 public: 77 public:
77 KNoScrollListBox(QWidget *parent=0, const char *name=0); 78 KNoScrollListBox(QWidget *parent=0, const char *name=0);
78 ~KNoScrollListBox(); 79 ~KNoScrollListBox();
79 QString getWhatsThisText(QPoint p) ; 80 QString getWhatsThisText(QPoint p) ;
80 81
81 signals: 82 signals:
82 void shiftDown(); 83 void shiftDown();
83 void shiftUp(); 84 void shiftUp();
84 void rightClick(); 85 void rightClick();
85 86
86 protected slots: 87 protected slots:
87 void oneDown(); 88 void oneDown();
88 void keyPressEvent(QKeyEvent *); 89 void keyPressEvent(QKeyEvent *);
89 void keyReleaseEvent(QKeyEvent *); 90 void keyReleaseEvent(QKeyEvent *);
90 void mousePressEvent(QMouseEvent *); 91 void mousePressEvent(QMouseEvent *);
91 void focusInEvent ( QFocusEvent * ); 92 void focusInEvent ( QFocusEvent * );
92 void focusOutEvent ( QFocusEvent * ); 93 void focusOutEvent ( QFocusEvent * );
93 94
94 private: 95 private:
95 bool resetOnFocusIn; 96 bool resetOnFocusIn;
96 KNOWhatsThis * mWT; 97 KNOWhatsThis * mWT;
97}; 98};
98 99
99 100
100class MonthViewItem: public QListBoxItem 101class MonthViewItem: public QListBoxItem
101{ 102{
102 public: 103 public:
103 MonthViewItem( Incidence *, QDate qd, const QString & title ); 104 MonthViewItem( Incidence *, QDate qd, const QString & title );
104 void recycle( Incidence *incidence, QDate qd, const QString & s); 105 void recycle( Incidence *incidence, QDate qd, const QString & s);
105 void setRecur(bool on) { mRecur = on; } 106 void setRecur(bool on) { mRecur = on; }
106 void setAlarm(bool on) { mAlarm = on; } 107 void setAlarm(bool on) { mAlarm = on; }
107 void setReply(bool on) { mReply = on; } 108 void setReply(bool on) { mReply = on; }
108 void setMoreInfo(bool on) { mInfo = on; } 109 void setMoreInfo(bool on) { mInfo = on; }
109 void setMultiDay(int type) { mMultiday = type; } 110 void setMultiDay(int type) { mMultiday = type; }
110 void setBlockRepaint(bool on) { mblockRepaint = on; } 111 void setBlockRepaint(bool on) { mblockRepaint = on; }
111 112
112 113
113 void setPalette(const QPalette &p) { mPalette = p; } 114 void setPalette(const QPalette &p) { mPalette = p; }
114 QPalette palette() const { return mPalette; } 115 QPalette palette() const { return mPalette; }
115 116
116 Incidence *incidence() const { return mIncidence; } 117 Incidence *incidence() const { return mIncidence; }
117 QDate incidenceDate() { return mDate; } 118 QDate incidenceDate() { return mDate; }
118 119
119 protected: 120 protected:
120 virtual void paint(QPainter *); 121 virtual void paint(QPainter *);
121 virtual int height(const QListBox *) const; 122 virtual int height(const QListBox *) const;
122 virtual int width(const QListBox *) const; 123 virtual int width(const QListBox *) const;
123 124
124 private: 125 private:
126 bool isWeekItem;
125 bool mblockRepaint; 127 bool mblockRepaint;
126 int mMultiday; 128 int mMultiday;
127 bool mRecur; 129 bool mRecur;
128 bool mAlarm; 130 bool mAlarm;
129 bool mReply; 131 bool mReply;
130 bool mInfo; 132 bool mInfo;
131 133
132 QPalette mPalette; 134 QPalette mPalette;
133 QDate mDate; 135 QDate mDate;
134 136
135 Incidence *mIncidence; 137 Incidence *mIncidence;
136}; 138};
137 139
138 140
139class KOMonthView; 141class KOMonthView;
140 142
141class MonthViewCell : public KNoScrollListBox 143class MonthViewCell : public KNoScrollListBox
142{ 144{
143 Q_OBJECT 145 Q_OBJECT
144 public: 146 public:
145 MonthViewCell(KOMonthView *,QWidget* ); 147 MonthViewCell(KOMonthView *,QWidget* );
146 ~MonthViewCell() {mAvailItemList.setAutoDelete( true );} 148 ~MonthViewCell() {mAvailItemList.setAutoDelete( true );}
147 149
148 void setDate( const QDate & ); 150 void setDate( const QDate & );
149 QDate date() const; 151 QDate date() const;
150 152
151 void setPrimary( bool ); 153 void setPrimary( bool );
152 bool isPrimary() const; 154 bool isPrimary() const;
153 155
154 void setHoliday( bool ); 156 void setHoliday( bool );
155 void setHoliday( const QString & ); 157 void setHoliday( const QString & );
156 158
157 void updateCell(); 159 void updateCell();
158 void startUpdateCell(); 160 void startUpdateCell();
159 void finishUpdateCell(); 161 void finishUpdateCell();
160 void repaintfinishUpdateCell(); 162 void repaintfinishUpdateCell();
161 void insertEvent(Event *); 163 void insertEvent(Event *);
162 void insertTodo(Todo *); 164 void insertTodo(Todo *);
163 165
164 void updateConfig( bool bigFont = false ); 166 void updateConfig( bool bigFont = false );
165 167
166 void enableScrollBars( bool ); 168 void enableScrollBars( bool );
167 169
168 Incidence *selectedIncidence(); 170 Incidence *selectedIncidence();
169 QDate selectedIncidenceDate(); 171 QDate selectedIncidenceDate();
170 QPushButton * dateLabel() { return mLabel; } 172 QPushButton * dateLabel() { return mLabel; }
171 173
172 void deselect(); 174 void deselect();
173 void select(); 175 void select();
174#ifdef DESKTOP_VERSION 176#ifdef DESKTOP_VERSION
175 static QToolTipGroup *toolTipGroup(); 177 static QToolTipGroup *toolTipGroup();
176#endif 178#endif
177 signals: 179 signals:
178 void defaultAction( Incidence * ); 180 void defaultAction( Incidence * );
179 void newEventSignal( QDateTime ); 181 void newEventSignal( QDateTime );
180 void showDaySignal( QDate ); 182 void showDaySignal( QDate );
181 183
182 protected: 184 protected:
183 QStringList mToolTip; 185 QStringList mToolTip;
184 void resizeEvent( QResizeEvent * ); 186 void resizeEvent( QResizeEvent * );
185 187
186 188
187public slots: 189public slots:
188 void showDay(); 190 void showDay();
189 191
190 protected slots: 192 protected slots:
191 void defaultAction( QListBoxItem * ); 193 void defaultAction( QListBoxItem * );
192 void contextMenu( QListBoxItem * ); 194 void contextMenu( QListBoxItem * );
193 void selection( QListBoxItem * ); 195 void selection( QListBoxItem * );
194 void cellClicked( QListBoxItem * ); 196 void cellClicked( QListBoxItem * );
195 void newEvent(); 197 void newEvent();
196 198
197 private: 199 private:
198 MonthViewItem* mCurrentAvailItem;
199 QPtrList <MonthViewItem> mAvailItemList; 200 QPtrList <MonthViewItem> mAvailItemList;
200 KOMonthView *mMonthView; 201 KOMonthView *mMonthView;
201 int currentPalette; 202 int currentPalette;
202 203
203 QDate mDate; 204 QDate mDate;
204 bool mPrimary; 205 bool mPrimary;
205 bool mHoliday; 206 bool mHoliday;
206 QString mHolidayString; 207 QString mHolidayString;
207 208
208 //QLabel *mLabel; 209 //QLabel *mLabel;
209 QPushButton *mLabel; 210 QPushButton *mLabel;
210 //QListBox *mItemList; 211 //QListBox *mItemList;
211#ifdef DESKTOP_VERSION 212#ifdef DESKTOP_VERSION
212 static QToolTipGroup *mToolTipGroup; 213 static QToolTipGroup *mToolTipGroup;
213#endif 214#endif
214 QSize mLabelSize; 215 QSize mLabelSize;
215 QSize mLabelBigSize; 216 QSize mLabelBigSize;
216 QPalette mHolidayPalette; 217 QPalette mHolidayPalette;
217 QPalette mStandardPalette; 218 QPalette mStandardPalette;
218 QPalette mPrimaryPalette; 219 QPalette mPrimaryPalette;
219 QPalette mNonPrimaryPalette; 220 QPalette mNonPrimaryPalette;
220 void setMyPalette(); 221 void setMyPalette();
221 QPalette getPalette (); 222 QPalette getPalette ();
222 223
223}; 224};
224 225
225 226
226class KOMonthView: public KOEventView 227class KOMonthView: public KOEventView
227{ 228{
228 Q_OBJECT 229 Q_OBJECT
229 public: 230 public:
230 KOMonthView(Calendar *cal, QWidget *parent = 0, const char *name = 0 ); 231 KOMonthView(Calendar *cal, QWidget *parent = 0, const char *name = 0 );
231 ~KOMonthView(); 232 ~KOMonthView();
232 233
233 /** Returns maximum number of days supported by the komonthview */ 234 /** Returns maximum number of days supported by the komonthview */
234 virtual int maxDatesHint(); 235 virtual int maxDatesHint();
235 236
236 /** Returns number of currently shown dates. */ 237 /** Returns number of currently shown dates. */
237 virtual int currentDateCount(); 238 virtual int currentDateCount();
238 239
239 /** returns the currently selected events */ 240 /** returns the currently selected events */
240 virtual QPtrList<Incidence> selectedIncidences(); 241 virtual QPtrList<Incidence> selectedIncidences();
241 242
242 /** returns dates of the currently selected events */ 243 /** returns dates of the currently selected events */
243 virtual DateList selectedDates(); 244 virtual DateList selectedDates();
244 245
245 virtual void printPreview(CalPrinter *calPrinter, 246 virtual void printPreview(CalPrinter *calPrinter,
246 const QDate &, const QDate &); 247 const QDate &, const QDate &);