-rw-r--r-- | korganizer/komonthview.cpp | 57 | ||||
-rw-r--r-- | korganizer/komonthview.h | 6 |
2 files changed, 18 insertions, 45 deletions
diff --git a/korganizer/komonthview.cpp b/korganizer/komonthview.cpp index 00e5a6f..aeb3974 100644 --- a/korganizer/komonthview.cpp +++ b/korganizer/komonthview.cpp | |||
@@ -257,205 +257,184 @@ void KNoScrollListBox::oneDown() | |||
257 | } | 257 | } |
258 | } | 258 | } |
259 | } | 259 | } |
260 | } | 260 | } |
261 | void KNoScrollListBox::keyReleaseEvent(QKeyEvent *e) | 261 | void KNoScrollListBox::keyReleaseEvent(QKeyEvent *e) |
262 | { | 262 | { |
263 | switch(e->key()) { | 263 | switch(e->key()) { |
264 | case Key_Shift: | 264 | case Key_Shift: |
265 | emit shiftUp(); | 265 | emit shiftUp(); |
266 | break; | 266 | break; |
267 | default: | 267 | default: |
268 | break; | 268 | break; |
269 | } | 269 | } |
270 | } | 270 | } |
271 | 271 | ||
272 | void KNoScrollListBox::mousePressEvent(QMouseEvent *e) | 272 | void KNoScrollListBox::mousePressEvent(QMouseEvent *e) |
273 | { | 273 | { |
274 | QListBox::mousePressEvent(e); | 274 | QListBox::mousePressEvent(e); |
275 | 275 | ||
276 | if(e->button() == RightButton) { | 276 | if(e->button() == RightButton) { |
277 | emit rightClick(); | 277 | emit rightClick(); |
278 | } | 278 | } |
279 | } | 279 | } |
280 | 280 | ||
281 | MonthViewItem::MonthViewItem( Incidence *incidence, QDate qd, const QString & s) | 281 | MonthViewItem::MonthViewItem( Incidence *incidence, const QString & s) |
282 | : QListBoxItem() | 282 | : QListBoxItem() |
283 | { | 283 | { |
284 | mDisplayHightlighted = false; | ||
285 | mblockRepaint = true; | 284 | mblockRepaint = true; |
286 | setText( s ); | ||
287 | mMultiday = 0; | ||
288 | mIncidence = incidence; | ||
289 | mDate = qd; | ||
290 | mRecur = false; | ||
291 | mAlarm = false; | ||
292 | mReply = false; | ||
293 | mInfo = false; | ||
294 | mdayPos = 0; | ||
295 | isWeekItem = KOPrefs::instance()->mMonthViewWeek; | 285 | isWeekItem = KOPrefs::instance()->mMonthViewWeek; |
286 | recycle( incidence, s ); | ||
296 | } | 287 | } |
297 | void MonthViewItem::recycle( Incidence *incidence, QDate qd, const QString & s) | 288 | void MonthViewItem::recycle( Incidence *incidence, const QString & s) |
298 | { | 289 | { |
299 | mDisplayHightlighted = false; | 290 | mDisplayHightlighted = false; |
300 | setText( s ); | 291 | setText( s ); |
301 | mMultiday = 0; | 292 | mMultiday = 0; |
302 | mIncidence = incidence; | 293 | mIncidence = incidence; |
303 | mDate = qd; | ||
304 | mRecur = false; | ||
305 | mAlarm = false; | ||
306 | mReply = false; | ||
307 | mInfo = false; | ||
308 | mdayPos = 0; | ||
309 | } | ||
310 | void MonthViewItem::clearData() | ||
311 | { | ||
312 | mDisplayHightlighted = false; | ||
313 | setText( "" ); | ||
314 | mMultiday = 0; | ||
315 | mIncidence = 0; | ||
316 | mRecur = false; | 294 | mRecur = false; |
317 | mAlarm = false; | 295 | mAlarm = false; |
318 | mReply = false; | 296 | mReply = false; |
319 | mInfo = false; | 297 | mInfo = false; |
320 | mdayPos = 0; | 298 | mdayPos = 0; |
321 | } | 299 | } |
300 | |||
322 | bool MonthViewItem::setHighlightedFalse() | 301 | bool MonthViewItem::setHighlightedFalse() |
323 | { | 302 | { |
324 | if ( !mDisplayHightlighted ) | 303 | if ( !mDisplayHightlighted ) |
325 | return false; | 304 | return false; |
326 | mDisplayHightlighted = false; | 305 | mDisplayHightlighted = false; |
327 | return true; | 306 | return true; |
328 | } | 307 | } |
329 | 308 | ||
330 | bool MonthViewItem::setHighlighted( Incidence * inc ) | 309 | bool MonthViewItem::setHighlighted( Incidence * inc ) |
331 | { | 310 | { |
332 | if ( inc == mIncidence ) { | 311 | if ( inc == mIncidence ) { |
333 | if ( mDisplayHightlighted ) | 312 | if ( mDisplayHightlighted ) |
334 | return false; | 313 | return false; |
335 | mDisplayHightlighted = true; | 314 | mDisplayHightlighted = true; |
336 | return true; | 315 | return true; |
337 | } else { | 316 | } else { |
338 | if ( !mDisplayHightlighted ) | 317 | if ( !mDisplayHightlighted ) |
339 | return false; | 318 | return false; |
340 | mDisplayHightlighted = false; | 319 | mDisplayHightlighted = false; |
341 | return true; | 320 | return true; |
342 | } | 321 | } |
343 | return false; | 322 | return false; |
344 | } | 323 | } |
345 | void MonthViewItem::paint(QPainter *p) | 324 | void MonthViewItem::paint(QPainter *p) |
346 | { | 325 | { |
347 | if ( mblockRepaint ) { | 326 | if ( mblockRepaint || !mIncidence ) { |
348 | return; | 327 | return; |
349 | } | 328 | } |
350 | #if QT_VERSION >= 0x030000 | 329 | #if QT_VERSION >= 0x030000 |
351 | bool sel = isSelected(); | 330 | bool sel = isSelected(); |
352 | #else | 331 | #else |
353 | bool sel = selected(); | 332 | bool sel = selected(); |
354 | #endif | 333 | #endif |
355 | int heihei = height( listBox () ); | 334 | int heihei = height( listBox () ); |
356 | int x = 1; | 335 | int x = 1; |
357 | if (KOPrefs::instance()->mMonthViewUsesCategoryColor || mDisplayHightlighted ) | 336 | if (KOPrefs::instance()->mMonthViewUsesCategoryColor || mDisplayHightlighted || sel ) |
358 | { | 337 | { |
359 | if ( mDisplayHightlighted ) | 338 | if ( mDisplayHightlighted ) |
360 | sel = true; | 339 | sel = true; |
361 | p->setBackgroundColor( palette().color( QPalette::Normal, \ | 340 | p->setBackgroundColor( palette().color( QPalette::Normal, \ |
362 | sel ? QColorGroup::Highlight : QColorGroup::Background ) ); | 341 | sel ? QColorGroup::Highlight : QColorGroup::Background ) ); |
363 | p->eraseRect( 0, 0, listBox()->maxItemWidth(), heihei ); | 342 | p->eraseRect( 0, 0, listBox()->maxItemWidth(), heihei ); |
364 | } | 343 | } |
365 | 344 | ||
366 | //int y = 3;//(height() - mRecurPixmap.height()) /2; | 345 | //int y = 3;//(height() - mRecurPixmap.height()) /2; |
367 | int size = PIXMAP_SIZE; | 346 | int size = PIXMAP_SIZE; |
368 | if ( QApplication::desktop()->width() < 300 ) | 347 | if ( QApplication::desktop()->width() < 300 ) |
369 | size = 3; | 348 | size = 3; |
370 | int y = (heihei - size -1 ) /2; | 349 | int y = (heihei - size -1 ) /2; |
371 | 350 | ||
372 | if ( mIncidence->calID() > 1 ) { | 351 | if ( mIncidence->calID() > 1 ) { |
373 | p->fillRect ( x, y-2,size,size+4, KOPrefs::instance()->defaultColor( mIncidence->calID() ) ); | 352 | p->fillRect ( x, y-2,size,size+4, KOPrefs::instance()->defaultColor( mIncidence->calID() ) ); |
374 | p->drawRect ( x, y-2,size,size+4); | 353 | p->drawRect ( x, y-2,size,size+4); |
375 | x += size + 1; | 354 | x += size + 1; |
376 | } | 355 | } |
377 | if ( KOPrefs::instance()->mMonthShowIcons ) { | 356 | if ( KOPrefs::instance()->mMonthShowIcons ) { |
378 | if ( mInfo ) { | 357 | if ( mInfo ) { |
379 | p->fillRect ( x, y,size,size, Qt::darkGreen ); | 358 | p->fillRect ( x, y,size,size, Qt::darkGreen ); |
380 | x += size + 1; | 359 | x += size + 1; |
381 | } | 360 | } |
382 | if ( mRecur ) { | 361 | if ( mRecur ) { |
383 | p->fillRect ( x, y,size,size, Qt::blue ); | 362 | p->fillRect ( x, y,size,size, Qt::blue ); |
384 | x += size + 1; | 363 | x += size + 1; |
385 | } | 364 | } |
386 | if ( mAlarm ) { | 365 | if ( mAlarm ) { |
387 | p->fillRect ( x, y,size,size, Qt::red ); | 366 | p->fillRect ( x, y,size,size, Qt::red ); |
388 | x += size + 1; | 367 | x += size + 1; |
389 | } | 368 | } |
390 | if ( mReply ) { | 369 | if ( mReply ) { |
391 | p->fillRect ( x, y,size,size, Qt::yellow ); | 370 | p->fillRect ( x, y,size,size, Qt::yellow ); |
392 | x += size + 1; | 371 | x += size + 1; |
393 | } | 372 | } |
394 | } | 373 | } |
395 | if ( mMultiday ) { | 374 | if ( mMultiday ) { |
396 | int yyy = y+(size/2); | 375 | int yyy = y+(size/2); |
397 | int sizeM = size+2; | 376 | int sizeM = size+2; |
398 | p->setBrush( QBrush::SolidPattern ); | 377 | p->setBrush( QBrush( p->pen().color() ) ); |
399 | p->drawLine ( x+1, yyy, x +sizeM +sizeM/2-1, yyy ) ; | 378 | p->drawLine ( x+1, yyy, x +sizeM +sizeM/2-1, yyy ) ; |
400 | if ( mMultiday == 2 || mMultiday == 3 ) { | 379 | if ( mMultiday == 2 || mMultiday == 3 ) { |
401 | QPointArray pa ( 3 ); | 380 | QPointArray pa ( 3 ); |
402 | pa.setPoint (0, x, yyy ); | 381 | pa.setPoint (0, x, yyy ); |
403 | pa.setPoint (1, x+sizeM/2, yyy+sizeM/2 ); | 382 | pa.setPoint (1, x+sizeM/2, yyy+sizeM/2 ); |
404 | pa.setPoint (2, x+sizeM/2, yyy-sizeM/2 ); | 383 | pa.setPoint (2, x+sizeM/2, yyy-sizeM/2 ); |
405 | p->drawPolygon( pa ); | 384 | p->drawPolygon( pa ); |
406 | } | 385 | } |
407 | if ( mMultiday == 2 || mMultiday == 1 ) { | 386 | if ( mMultiday == 2 || mMultiday == 1 ) { |
408 | QPointArray pa ( 3 ); | 387 | QPointArray pa ( 3 ); |
409 | pa.setPoint (0, x+sizeM +sizeM/2, yyy ); | 388 | pa.setPoint (0, x+sizeM +sizeM/2, yyy ); |
410 | pa.setPoint (1, x+sizeM, yyy+sizeM/2 ); | 389 | pa.setPoint (1, x+sizeM, yyy+sizeM/2 ); |
411 | pa.setPoint (2, x+sizeM, yyy-sizeM/2 ); | 390 | pa.setPoint (2, x+sizeM, yyy-sizeM/2 ); |
412 | p->drawPolygon( pa ); | 391 | p->drawPolygon( pa ); |
413 | } | 392 | } |
414 | if ( mMultiday == 1 ) { | 393 | if ( mMultiday == 1 ) { |
415 | // p->fillRect ( x, yyy-sizeM/2+1, sizeM/2, size, QBrush ( QBrush::SolidPattern ) ); | 394 | // p->fillRect ( x, yyy-sizeM/2+1, sizeM/2, size, QBrush ( QBrush::SolidPattern ) ); |
416 | p->drawLine ( x+1, yyy-sizeM/2, x+1, yyy+sizeM/2 ); | 395 | p->drawLine ( x+1, yyy-sizeM/2, x+1, yyy+sizeM/2 ); |
417 | } | 396 | } |
418 | if ( mMultiday == 3 ) { | 397 | if ( mMultiday == 3 ) { |
419 | // p->fillRect ( x+sizeM, yyy-sizeM/2+1, sizeM/2, size, QBrush ( QBrush::SolidPattern ) ); | 398 | // p->fillRect ( x+sizeM, yyy-sizeM/2+1, sizeM/2, size, QBrush ( QBrush::SolidPattern ) ); |
420 | p->drawLine ( x+sizeM +sizeM/2-1, yyy-sizeM/2, x+sizeM +sizeM/2-1, yyy+sizeM/2 ); | 399 | p->drawLine ( x+sizeM +sizeM/2-1, yyy-sizeM/2, x+sizeM +sizeM/2-1, yyy+sizeM/2 ); |
421 | 400 | ||
422 | } | 401 | } |
423 | x += sizeM/2 + 1; | 402 | x += sizeM/2 + 1; |
424 | x += sizeM + 1; | 403 | x += sizeM + 1; |
425 | } | 404 | } |
426 | 405 | ||
427 | if ( mIncidence->typeID() == todoID ){ | 406 | if ( mIncidence->typeID() == todoID ){ |
428 | Todo* td = ( Todo* ) mIncidence; | 407 | Todo* td = ( Todo* ) mIncidence; |
429 | if ( td->isCompleted() ) { | 408 | if ( td->isCompleted() ) { |
430 | int half = size/2; | 409 | int half = size/2; |
431 | p->drawLine ( x, heihei/2, x +half , heihei/2 +half ) ; | 410 | p->drawLine ( x, heihei/2, x +half , heihei/2 +half ) ; |
432 | p->drawLine ( x +half , heihei/2 +half , x +half+half +2 , heihei/2 -2 ) ; | 411 | p->drawLine ( x +half , heihei/2 +half , x +half+half +2 , heihei/2 -2 ) ; |
433 | x += half+half + 4; | 412 | x += half+half + 4; |
434 | 413 | ||
435 | } else { | 414 | } else { |
436 | int val = td->percentComplete()/20; | 415 | int val = td->percentComplete()/20; |
437 | p->fillRect ( x+1, y-2, val ,size+4,Qt::black ); | 416 | p->fillRect ( x+1, y-2, val ,size+4,p->pen().color() ); |
438 | p->drawRect ( x, y-2,7,size+4); | 417 | p->drawRect ( x, y-2,7,size+4); |
439 | x += size + 3; | 418 | x += size + 3; |
440 | } | 419 | } |
441 | } | 420 | } |
442 | QFontMetrics fm = p->fontMetrics(); | 421 | QFontMetrics fm = p->fontMetrics(); |
443 | int yPos; | 422 | int yPos; |
444 | int pmheight = size; | 423 | int pmheight = size; |
445 | if( pmheight < fm.height() ) | 424 | if( pmheight < fm.height() ) |
446 | yPos = fm.ascent() + fm.leading()/2; | 425 | yPos = fm.ascent() + fm.leading()/2; |
447 | else | 426 | else |
448 | yPos = pmheight/2 - fm.height()/2 + fm.ascent(); | 427 | yPos = pmheight/2 - fm.height()/2 + fm.ascent(); |
449 | p->setPen( palette().color( QPalette::Normal, sel ? \ | 428 | p->setPen( palette().color( QPalette::Normal, sel ? \ |
450 | QColorGroup::HighlightedText : QColorGroup::Foreground ) ); | 429 | QColorGroup::HighlightedText : QColorGroup::Foreground ) ); |
451 | if ( KOPrefs::instance()->mMonthShowTimes || isWeekItem) { | 430 | if ( KOPrefs::instance()->mMonthShowTimes || isWeekItem) { |
452 | p->drawText( x, yPos, text() ); | 431 | p->drawText( x, yPos, text() ); |
453 | if ( mIncidence->cancelled() ) { | 432 | if ( mIncidence->cancelled() ) { |
454 | int wid = fm.width( text() ); | 433 | int wid = fm.width( text() ); |
455 | p->drawLine( x, heihei/2 ,x+wid, heihei/2 ); | 434 | p->drawLine( x, heihei/2 ,x+wid, heihei/2 ); |
456 | } | 435 | } |
457 | } else { | 436 | } else { |
458 | QString pText = text(); | 437 | QString pText = text(); |
459 | if( pText.mid(2,1) == ":" ) | 438 | if( pText.mid(2,1) == ":" ) |
460 | pText = pText.mid( 6 ); | 439 | pText = pText.mid( 6 ); |
461 | p->drawText( x, yPos, pText ); | 440 | p->drawText( x, yPos, pText ); |
@@ -647,49 +626,49 @@ void MonthViewCell::startUpdateCell() | |||
647 | MonthViewItem *mitem = (MonthViewItem*) firstItem (); | 626 | MonthViewItem *mitem = (MonthViewItem*) firstItem (); |
648 | while ( mitem ) { | 627 | while ( mitem ) { |
649 | mitem->setBlockRepaint( true ); | 628 | mitem->setBlockRepaint( true ); |
650 | mitem = (MonthViewItem *)mitem->next(); | 629 | mitem = (MonthViewItem *)mitem->next(); |
651 | } | 630 | } |
652 | if ( mAvailItemList.count() > 20 ) { | 631 | if ( mAvailItemList.count() > 20 ) { |
653 | mAvailItemList.setAutoDelete( true ); | 632 | mAvailItemList.setAutoDelete( true ); |
654 | mAvailItemList.clear(); | 633 | mAvailItemList.clear(); |
655 | mAvailItemList.setAutoDelete( false ); | 634 | mAvailItemList.setAutoDelete( false ); |
656 | clear(); | 635 | clear(); |
657 | } | 636 | } |
658 | 637 | ||
659 | setPrimary( mDate.month()%2 ); | 638 | setPrimary( mDate.month()%2 ); |
660 | setHoliday( KOGlobals::self()->calendarSystem()->dayOfWeek(mDate) == KOGlobals::self()->calendarSystem()->weekDayOfPray() || ( mDate.dayOfWeek() == 6 ) && KOPrefs::instance()-> mExcludeSaturdays); | 639 | setHoliday( KOGlobals::self()->calendarSystem()->dayOfWeek(mDate) == KOGlobals::self()->calendarSystem()->weekDayOfPray() || ( mDate.dayOfWeek() == 6 ) && KOPrefs::instance()-> mExcludeSaturdays); |
661 | if ( mDate == QDate::currentDate() ) { | 640 | if ( mDate == QDate::currentDate() ) { |
662 | setLineWidth( 3 ); | 641 | setLineWidth( 3 ); |
663 | } else { | 642 | } else { |
664 | setLineWidth( 1 ); | 643 | setLineWidth( 1 ); |
665 | } | 644 | } |
666 | MonthViewItem* CurrentAvailItem = (MonthViewItem*) firstItem (); | 645 | MonthViewItem* CurrentAvailItem = (MonthViewItem*) firstItem (); |
667 | //clear(); | 646 | //clear(); |
668 | while ( CurrentAvailItem ) { | 647 | while ( CurrentAvailItem ) { |
669 | MonthViewItem *item = CurrentAvailItem; | 648 | MonthViewItem *item = CurrentAvailItem; |
670 | //item->setHighlightedFalse(); | 649 | //item->setHighlightedFalse(); |
671 | item->clearData(); | 650 | item->recycle( 0, ""); |
672 | CurrentAvailItem = (MonthViewItem *)item->next(); | 651 | CurrentAvailItem = (MonthViewItem *)item->next(); |
673 | mAvailItemList.append( item ); | 652 | mAvailItemList.append( item ); |
674 | takeItem ( item ); | 653 | takeItem ( item ); |
675 | } | 654 | } |
676 | 655 | ||
677 | #ifdef DESKTOP_VERSION | 656 | #ifdef DESKTOP_VERSION |
678 | QToolTip::remove(this); | 657 | QToolTip::remove(this); |
679 | #endif | 658 | #endif |
680 | mToolTip.clear(); | 659 | mToolTip.clear(); |
681 | //qApp->processEvents(); | 660 | //qApp->processEvents(); |
682 | #if 0 | 661 | #if 0 |
683 | if ( !mHolidayString.isEmpty() ) { | 662 | if ( !mHolidayString.isEmpty() ) { |
684 | MonthViewItem *item = new MonthViewItem( 0, mDate, mHolidayString ); | 663 | MonthViewItem *item = new MonthViewItem( 0, mDate, mHolidayString ); |
685 | item->setPalette( mHolidayPalette ); | 664 | item->setPalette( mHolidayPalette ); |
686 | insertItem( item ); | 665 | insertItem( item ); |
687 | mToolTip.append ( mHolidayString ); | 666 | mToolTip.append ( mHolidayString ); |
688 | } | 667 | } |
689 | #endif | 668 | #endif |
690 | } | 669 | } |
691 | 670 | ||
692 | int MonthViewCell::insertEvent(Event *event) | 671 | int MonthViewCell::insertEvent(Event *event) |
693 | { | 672 | { |
694 | bool useToolTips = true; | 673 | bool useToolTips = true; |
695 | #ifndef DESKTOP_VERSION | 674 | #ifndef DESKTOP_VERSION |
@@ -743,78 +722,79 @@ int MonthViewCell::insertEvent(Event *event) | |||
743 | text = time + event->summary(); | 722 | text = time + event->summary(); |
744 | if ( useToolTips ) | 723 | if ( useToolTips ) |
745 | mToolTipText += prefix + text; | 724 | mToolTipText += prefix + text; |
746 | } else { | 725 | } else { |
747 | if (event->doesFloat()) { | 726 | if (event->doesFloat()) { |
748 | text = event->summary(); | 727 | text = event->summary(); |
749 | if ( useToolTips ) | 728 | if ( useToolTips ) |
750 | mToolTipText += text; | 729 | mToolTipText += text; |
751 | } | 730 | } |
752 | else { | 731 | else { |
753 | text = KGlobal::locale()->formatTime(event->dtStart().time()); | 732 | text = KGlobal::locale()->formatTime(event->dtStart().time()); |
754 | text += " " + event->summary(); | 733 | text += " " + event->summary(); |
755 | if ( useToolTips ) | 734 | if ( useToolTips ) |
756 | mToolTipText += KGlobal::locale()->formatTime(event->dtStart().time()) +"-"+KGlobal::locale()->formatTime(event->dtEnd().time())+" " + event->summary(); | 735 | mToolTipText += KGlobal::locale()->formatTime(event->dtStart().time()) +"-"+KGlobal::locale()->formatTime(event->dtEnd().time())+" " + event->summary(); |
757 | } | 736 | } |
758 | } | 737 | } |
759 | if ( useToolTips && ! event->location().isEmpty() ) { | 738 | if ( useToolTips && ! event->location().isEmpty() ) { |
760 | mToolTipText += " (" + event->location() +")"; | 739 | mToolTipText += " (" + event->location() +")"; |
761 | } | 740 | } |
762 | MonthViewItem *item ; | 741 | MonthViewItem *item ; |
763 | 742 | ||
764 | if ( mAvailItemList.count() ) { | 743 | if ( mAvailItemList.count() ) { |
765 | item = mAvailItemList.first(); | 744 | item = mAvailItemList.first(); |
766 | mAvailItemList.remove( item ); | 745 | mAvailItemList.remove( item ); |
767 | item->recycle( event, mDate, text ); | 746 | item->recycle( event, text ); |
768 | } else { | 747 | } else { |
769 | item = new MonthViewItem( event, mDate, text ); | 748 | item = new MonthViewItem( event, text ); |
770 | } | 749 | } |
771 | 750 | ||
772 | QPalette pal; | 751 | QPalette pal; |
773 | if (KOPrefs::instance()->mMonthViewUsesCategoryColor) { | 752 | if (KOPrefs::instance()->mMonthViewUsesCategoryColor) { |
774 | QStringList categories = event->categories(); | 753 | QStringList categories = event->categories(); |
775 | QString cat = categories.first(); | 754 | QString cat = categories.first(); |
776 | if ( KOPrefs::instance()->mMonthViewUsesForegroundColor ) { | 755 | if ( KOPrefs::instance()->mMonthViewUsesForegroundColor ) { |
777 | pal = getPalette(); | 756 | pal = getPalette(); |
778 | if (cat.isEmpty()) { | 757 | if (cat.isEmpty()) { |
779 | //pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->mEventColor); | 758 | //pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->mEventColor); |
780 | pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->defaultColor( event->calID() )); | 759 | pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->defaultColor( event->calID() )); |
781 | } else { | 760 | } else { |
782 | pal.setColor(QColorGroup::Foreground, *(KOPrefs::instance()->categoryColor(cat))); | 761 | pal.setColor(QColorGroup::Foreground, *(KOPrefs::instance()->categoryColor(cat))); |
783 | } | 762 | } |
784 | 763 | ||
785 | } else { | 764 | } else { |
786 | if (cat.isEmpty()) { | 765 | if (cat.isEmpty()) { |
787 | //pal = QPalette(KOPrefs::instance()->mEventColor, KOPrefs::instance()->mEventColor); | 766 | //pal = QPalette(KOPrefs::instance()->mEventColor, KOPrefs::instance()->mEventColor); |
788 | pal = QPalette( KOPrefs::instance()->defaultColor( event->calID() ), KOPrefs::instance()->defaultColor( event->calID() )); | 767 | pal = QPalette( KOPrefs::instance()->defaultColor( event->calID() ), KOPrefs::instance()->defaultColor( event->calID() )); |
789 | } else { | 768 | } else { |
790 | pal = QPalette(*(KOPrefs::instance()->categoryColor(cat)), *(KOPrefs::instance()->categoryColor(cat))); | 769 | pal = QPalette(*(KOPrefs::instance()->categoryColor(cat)), *(KOPrefs::instance()->categoryColor(cat))); |
791 | } | 770 | } |
792 | } | 771 | } |
793 | 772 | ||
794 | } else { | 773 | } else { |
795 | pal = mStandardPalette ; | 774 | pal = mStandardPalette ; |
796 | } | 775 | } |
776 | pal.setColor(QColorGroup::Highlight, KOPrefs::instance()->mHighlightColor); | ||
797 | item->setPalette( pal ); | 777 | item->setPalette( pal ); |
798 | item->setRecur( event->recurrence()->doesRecur() ); | 778 | item->setRecur( event->recurrence()->doesRecur() ); |
799 | item->setAlarm( event->isAlarmEnabled() && multiday < 2 && event->alarmEnabled() ); | 779 | item->setAlarm( event->isAlarmEnabled() && multiday < 2 && event->alarmEnabled() ); |
800 | item->setMoreInfo( event->description().length() > 0 ); | 780 | item->setMoreInfo( event->description().length() > 0 ); |
801 | #ifdef DESKTOP_VERSION | 781 | #ifdef DESKTOP_VERSION |
802 | Attendee *me = event->attendeeByMails(KOPrefs::instance()->mAdditionalMails, | 782 | Attendee *me = event->attendeeByMails(KOPrefs::instance()->mAdditionalMails, |
803 | KOPrefs::instance()->email()); | 783 | KOPrefs::instance()->email()); |
804 | if ( me != 0 ) { | 784 | if ( me != 0 ) { |
805 | if ( me->status() == Attendee::NeedsAction && me->RSVP()) | 785 | if ( me->status() == Attendee::NeedsAction && me->RSVP()) |
806 | item->setReply(true && multiday < 2); | 786 | item->setReply(true && multiday < 2); |
807 | else | 787 | else |
808 | item->setReply(false); | 788 | item->setReply(false); |
809 | } else | 789 | } else |
810 | item->setReply(false); | 790 | item->setReply(false); |
811 | #endif | 791 | #endif |
812 | 792 | ||
813 | item->setMultiDay( multiday ); | 793 | item->setMultiDay( multiday ); |
814 | if ( multiday ) { | 794 | if ( multiday ) { |
815 | insertItem( item ,mdayCount); | 795 | insertItem( item ,mdayCount); |
816 | ++mdayCount; | 796 | ++mdayCount; |
817 | } else { | 797 | } else { |
818 | uint i = mdayCount; | 798 | uint i = mdayCount; |
819 | uint pos = mdayCount; | 799 | uint pos = mdayCount; |
820 | uint itcount = count(); | 800 | uint itcount = count(); |
@@ -832,79 +812,80 @@ int MonthViewCell::insertEvent(Event *event) | |||
832 | ++pos; | 812 | ++pos; |
833 | } | 813 | } |
834 | insertItem( item ,pos); | 814 | insertItem( item ,pos); |
835 | } | 815 | } |
836 | if ( useToolTips ) { | 816 | if ( useToolTips ) { |
837 | mToolTip.append( mToolTipText ); | 817 | mToolTip.append( mToolTipText ); |
838 | } | 818 | } |
839 | return mdayCount; | 819 | return mdayCount; |
840 | } | 820 | } |
841 | void MonthViewCell::insertTodo(Todo *todo) | 821 | void MonthViewCell::insertTodo(Todo *todo) |
842 | { | 822 | { |
843 | setFocusPolicy(WheelFocus); | 823 | setFocusPolicy(WheelFocus); |
844 | QString text; | 824 | QString text; |
845 | if (todo->hasDueDate()) { | 825 | if (todo->hasDueDate()) { |
846 | if (!todo->doesFloat()) { | 826 | if (!todo->doesFloat()) { |
847 | text += KGlobal::locale()->formatTime(todo->dtDue().time()); | 827 | text += KGlobal::locale()->formatTime(todo->dtDue().time()); |
848 | text += " "; | 828 | text += " "; |
849 | } | 829 | } |
850 | } | 830 | } |
851 | text += todo->summary(); | 831 | text += todo->summary(); |
852 | MonthViewItem *item ; | 832 | MonthViewItem *item ; |
853 | if ( mAvailItemList.count() ) { | 833 | if ( mAvailItemList.count() ) { |
854 | item = mAvailItemList.first(); | 834 | item = mAvailItemList.first(); |
855 | mAvailItemList.remove( item ); | 835 | mAvailItemList.remove( item ); |
856 | item->recycle( todo, mDate, text ); | 836 | item->recycle( todo, text ); |
857 | } else { | 837 | } else { |
858 | item = new MonthViewItem( todo, mDate, text ); | 838 | item = new MonthViewItem( todo, text ); |
859 | } | 839 | } |
860 | //MonthViewItem *item = new MonthViewItem( todo, mDate, text ); | 840 | //MonthViewItem *item = new MonthViewItem( todo, mDate, text ); |
861 | //item->setPalette( mStandardPalette ); | 841 | //item->setPalette( mStandardPalette ); |
862 | QPalette pal; | 842 | QPalette pal; |
863 | if (KOPrefs::instance()->mMonthViewUsesCategoryColor) { | 843 | if (KOPrefs::instance()->mMonthViewUsesCategoryColor) { |
864 | QStringList categories = todo->categories(); | 844 | QStringList categories = todo->categories(); |
865 | QString cat = categories.first(); | 845 | QString cat = categories.first(); |
866 | if ( KOPrefs::instance()->mMonthViewUsesForegroundColor ) { | 846 | if ( KOPrefs::instance()->mMonthViewUsesForegroundColor ) { |
867 | pal = getPalette(); | 847 | pal = getPalette(); |
868 | if (cat.isEmpty()) { | 848 | if (cat.isEmpty()) { |
869 | //pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->mEventColor); | 849 | //pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->mEventColor); |
870 | pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->defaultColor( todo->calID() )); | 850 | pal.setColor(QColorGroup::Foreground,KOPrefs::instance()->defaultColor( todo->calID() )); |
871 | } else { | 851 | } else { |
872 | pal.setColor(QColorGroup::Foreground, *(KOPrefs::instance()->categoryColor(cat))); | 852 | pal.setColor(QColorGroup::Foreground, *(KOPrefs::instance()->categoryColor(cat))); |
873 | } | 853 | } |
874 | 854 | ||
875 | } else { | 855 | } else { |
876 | if (cat.isEmpty()) { | 856 | if (cat.isEmpty()) { |
877 | //pal = QPalette(KOPrefs::instance()->mEventColor, KOPrefs::instance()->mEventColor); | 857 | //pal = QPalette(KOPrefs::instance()->mEventColor, KOPrefs::instance()->mEventColor); |
878 | pal = QPalette(KOPrefs::instance()->defaultColor( todo->calID() ), KOPrefs::instance()->defaultColor( todo->calID() )); | 858 | pal = QPalette(KOPrefs::instance()->defaultColor( todo->calID() ), KOPrefs::instance()->defaultColor( todo->calID() )); |
879 | } else { | 859 | } else { |
880 | pal = QPalette(*(KOPrefs::instance()->categoryColor(cat)), *(KOPrefs::instance()->categoryColor(cat))); | 860 | pal = QPalette(*(KOPrefs::instance()->categoryColor(cat)), *(KOPrefs::instance()->categoryColor(cat))); |
881 | } | 861 | } |
882 | } | 862 | } |
883 | 863 | ||
884 | } else { | 864 | } else { |
885 | pal = mStandardPalette ; | 865 | pal = mStandardPalette ; |
886 | } | 866 | } |
867 | pal.setColor(QColorGroup::Highlight, KOPrefs::instance()->mHighlightColor); | ||
887 | item->setPalette( pal ); | 868 | item->setPalette( pal ); |
888 | item->setRecur( todo->recurrence()->doesRecur() ); | 869 | item->setRecur( todo->recurrence()->doesRecur() ); |
889 | item->setAlarm( todo->isAlarmEnabled() && todo->alarmEnabled() ); | 870 | item->setAlarm( todo->isAlarmEnabled() && todo->alarmEnabled() ); |
890 | item->setMoreInfo( todo->description().length() > 0 ); | 871 | item->setMoreInfo( todo->description().length() > 0 ); |
891 | insertItem( item , count()); | 872 | insertItem( item , count()); |
892 | #ifdef DESKTOP_VERSION | 873 | #ifdef DESKTOP_VERSION |
893 | mToolTip.append( text ); | 874 | mToolTip.append( text ); |
894 | #endif | 875 | #endif |
895 | } | 876 | } |
896 | void MonthViewCell::repaintfinishUpdateCell() | 877 | void MonthViewCell::repaintfinishUpdateCell() |
897 | { | 878 | { |
898 | MonthViewItem *mitem = (MonthViewItem*) firstItem (); | 879 | MonthViewItem *mitem = (MonthViewItem*) firstItem (); |
899 | while ( mitem ) { | 880 | while ( mitem ) { |
900 | mitem->setBlockRepaint( false ); | 881 | mitem->setBlockRepaint( false ); |
901 | updateItem ( mitem ); | 882 | updateItem ( mitem ); |
902 | mitem = (MonthViewItem *)mitem->next(); | 883 | mitem = (MonthViewItem *)mitem->next(); |
903 | } | 884 | } |
904 | } | 885 | } |
905 | void MonthViewCell::finishUpdateCell() | 886 | void MonthViewCell::finishUpdateCell() |
906 | { | 887 | { |
907 | 888 | ||
908 | 889 | ||
909 | 890 | ||
910 | #ifdef DESKTOP_VERSION | 891 | #ifdef DESKTOP_VERSION |
@@ -1002,55 +983,49 @@ void MonthViewCell::enableScrollBars( bool enabled ) | |||
1002 | } else { | 983 | } else { |
1003 | setVScrollBarMode(QScrollView::AlwaysOff); | 984 | setVScrollBarMode(QScrollView::AlwaysOff); |
1004 | setHScrollBarMode(QScrollView::AlwaysOff); | 985 | setHScrollBarMode(QScrollView::AlwaysOff); |
1005 | } | 986 | } |
1006 | } | 987 | } |
1007 | 988 | ||
1008 | Incidence *MonthViewCell::selectedIncidence() | 989 | Incidence *MonthViewCell::selectedIncidence() |
1009 | { | 990 | { |
1010 | int index = currentItem(); | 991 | int index = currentItem(); |
1011 | if ( index < 0 ) return 0; | 992 | if ( index < 0 ) return 0; |
1012 | 993 | ||
1013 | MonthViewItem *mitem = | 994 | MonthViewItem *mitem = |
1014 | static_cast<MonthViewItem *>( item( index ) ); | 995 | static_cast<MonthViewItem *>( item( index ) ); |
1015 | 996 | ||
1016 | if ( !mitem ) return 0; | 997 | if ( !mitem ) return 0; |
1017 | 998 | ||
1018 | return mitem->incidence(); | 999 | return mitem->incidence(); |
1019 | } | 1000 | } |
1020 | 1001 | ||
1021 | QDate MonthViewCell::selectedIncidenceDate() | 1002 | QDate MonthViewCell::selectedIncidenceDate() |
1022 | { | 1003 | { |
1023 | QDate qd; | 1004 | QDate qd; |
1024 | int index = currentItem(); | 1005 | int index = currentItem(); |
1025 | if ( index < 0 ) return qd; | 1006 | if ( index < 0 ) return qd; |
1026 | 1007 | return mDate; | |
1027 | MonthViewItem *mitem = | ||
1028 | static_cast<MonthViewItem *>( item( index ) ); | ||
1029 | |||
1030 | if ( !mitem ) return qd; | ||
1031 | |||
1032 | return mitem->incidenceDate(); | ||
1033 | } | 1008 | } |
1034 | 1009 | ||
1035 | void MonthViewCell::deselect() | 1010 | void MonthViewCell::deselect() |
1036 | { | 1011 | { |
1037 | clearSelection(); | 1012 | clearSelection(); |
1038 | enableScrollBars( false ); | 1013 | enableScrollBars( false ); |
1039 | // updateCell(); | 1014 | // updateCell(); |
1040 | } | 1015 | } |
1041 | void MonthViewCell::select() | 1016 | void MonthViewCell::select() |
1042 | { | 1017 | { |
1043 | ;// updateCell(); | 1018 | ;// updateCell(); |
1044 | } | 1019 | } |
1045 | 1020 | ||
1046 | void MonthViewCell::resizeEvent ( QResizeEvent * e ) | 1021 | void MonthViewCell::resizeEvent ( QResizeEvent * e ) |
1047 | { | 1022 | { |
1048 | if ( !mMonthView->isUpdatePossible() ) | 1023 | if ( !mMonthView->isUpdatePossible() ) |
1049 | return; | 1024 | return; |
1050 | //qDebug("++++++++++++++MonthViewCell::resizeEvent %d %d ", width(), height()); | 1025 | //qDebug("++++++++++++++MonthViewCell::resizeEvent %d %d ", width(), height()); |
1051 | deselect(); | 1026 | deselect(); |
1052 | mLabel->setMaximumHeight( height() - lineWidth()*2 ); | 1027 | mLabel->setMaximumHeight( height() - lineWidth()*2 ); |
1053 | 1028 | ||
1054 | QString text; | 1029 | QString text; |
1055 | mLabel->setText( text ); | 1030 | mLabel->setText( text ); |
1056 | bool smallDisplay = QApplication::desktop()->width() < 320 && KOPrefs::instance()->mMonthViewSatSunTog; | 1031 | bool smallDisplay = QApplication::desktop()->width() < 320 && KOPrefs::instance()->mMonthViewSatSunTog; |
diff --git a/korganizer/komonthview.h b/korganizer/komonthview.h index ac97860..2622d10 100644 --- a/korganizer/komonthview.h +++ b/korganizer/komonthview.h | |||
@@ -84,67 +84,65 @@ class KNoScrollListBox: public QListBox | |||
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 highligtIncidence( Incidence * , MonthViewCell*, int ); | 89 | void highligtIncidence( Incidence * , MonthViewCell*, int ); |
90 | 90 | ||
91 | protected slots: | 91 | protected slots: |
92 | void oneDown(); | 92 | void oneDown(); |
93 | void keyPressEvent(QKeyEvent *); | 93 | void keyPressEvent(QKeyEvent *); |
94 | void keyReleaseEvent(QKeyEvent *); | 94 | void keyReleaseEvent(QKeyEvent *); |
95 | void mousePressEvent(QMouseEvent *); | 95 | void mousePressEvent(QMouseEvent *); |
96 | void focusInEvent ( QFocusEvent * ); | 96 | void focusInEvent ( QFocusEvent * ); |
97 | void focusOutEvent ( QFocusEvent * ); | 97 | void focusOutEvent ( QFocusEvent * ); |
98 | 98 | ||
99 | private: | 99 | private: |
100 | bool resetOnFocusIn; | 100 | bool resetOnFocusIn; |
101 | KNOWhatsThis * mWT; | 101 | KNOWhatsThis * mWT; |
102 | }; | 102 | }; |
103 | 103 | ||
104 | 104 | ||
105 | class MonthViewItem: public QListBoxItem | 105 | class MonthViewItem: public QListBoxItem |
106 | { | 106 | { |
107 | public: | 107 | public: |
108 | MonthViewItem( Incidence *, QDate qd, const QString & title ); | 108 | MonthViewItem( Incidence *,const QString & title ); |
109 | void recycle( Incidence *incidence, QDate qd, const QString & s); | 109 | void recycle( Incidence *incidence, const QString & s); |
110 | void clearData(); | ||
111 | void setRecur(bool on) { mRecur = on; } | 110 | void setRecur(bool on) { mRecur = on; } |
112 | void setAlarm(bool on) { mAlarm = on; } | 111 | void setAlarm(bool on) { mAlarm = on; } |
113 | void setReply(bool on) { mReply = on; } | 112 | void setReply(bool on) { mReply = on; } |
114 | void setMoreInfo(bool on) { mInfo = on; } | 113 | void setMoreInfo(bool on) { mInfo = on; } |
115 | void setMultiDay(int type) { mMultiday = type; } | 114 | void setMultiDay(int type) { mMultiday = type; } |
116 | int multiDay() { return mMultiday; } | 115 | int multiDay() { return mMultiday; } |
117 | void setMultiDayPos(int type) { mdayPos = type; } | 116 | void setMultiDayPos(int type) { mdayPos = type; } |
118 | int gettMultiDayPos() { return mdayPos; } | 117 | int gettMultiDayPos() { return mdayPos; } |
119 | void setBlockRepaint(bool on) { mblockRepaint = on; } | 118 | void setBlockRepaint(bool on) { mblockRepaint = on; } |
120 | bool setHighlighted( Incidence * ); | 119 | bool setHighlighted( Incidence * ); |
121 | 120 | ||
122 | void setPalette(const QPalette &p) { mPalette = p; } | 121 | void setPalette(const QPalette &p) { mPalette = p; } |
123 | QPalette palette() const { return mPalette; } | 122 | QPalette palette() const { return mPalette; } |
124 | bool setHighlightedFalse(); | 123 | bool setHighlightedFalse(); |
125 | Incidence *incidence() const { return mIncidence; } | 124 | Incidence *incidence() const { return mIncidence; } |
126 | QDate incidenceDate() { return mDate; } | ||
127 | 125 | ||
128 | protected: | 126 | protected: |
129 | virtual void paint(QPainter *); | 127 | virtual void paint(QPainter *); |
130 | virtual int height(const QListBox *) const; | 128 | virtual int height(const QListBox *) const; |
131 | virtual int width(const QListBox *) const; | 129 | virtual int width(const QListBox *) const; |
132 | 130 | ||
133 | private: | 131 | private: |
134 | int mdayPos; | 132 | int mdayPos; |
135 | bool isWeekItem; | 133 | bool isWeekItem; |
136 | bool mblockRepaint; | 134 | bool mblockRepaint; |
137 | int mMultiday; | 135 | int mMultiday; |
138 | bool mRecur; | 136 | bool mRecur; |
139 | bool mAlarm; | 137 | bool mAlarm; |
140 | bool mReply; | 138 | bool mReply; |
141 | bool mInfo; | 139 | bool mInfo; |
142 | bool mDisplayHightlighted; | 140 | bool mDisplayHightlighted; |
143 | 141 | ||
144 | QPalette mPalette; | 142 | QPalette mPalette; |
145 | QDate mDate; | 143 | QDate mDate; |
146 | 144 | ||
147 | Incidence *mIncidence; | 145 | Incidence *mIncidence; |
148 | }; | 146 | }; |
149 | 147 | ||
150 | 148 | ||