-rw-r--r-- | core/pim/datebook/datebookday.cpp | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/core/pim/datebook/datebookday.cpp b/core/pim/datebook/datebookday.cpp index 325b902..aaf3e16 100644 --- a/core/pim/datebook/datebookday.cpp +++ b/core/pim/datebook/datebookday.cpp | |||
@@ -536,169 +536,172 @@ int DateBookDay::startViewTime() const | |||
536 | } | 536 | } |
537 | 537 | ||
538 | void DateBookDay::slotWeekChanged( bool bStartOnMonday ) | 538 | void DateBookDay::slotWeekChanged( bool bStartOnMonday ) |
539 | { | 539 | { |
540 | header->setStartOfWeek( bStartOnMonday ); | 540 | header->setStartOfWeek( bStartOnMonday ); |
541 | // redraw(); | 541 | // redraw(); |
542 | } | 542 | } |
543 | 543 | ||
544 | void DateBookDay::keyPressEvent(QKeyEvent *e) | 544 | void DateBookDay::keyPressEvent(QKeyEvent *e) |
545 | { | 545 | { |
546 | switch(e->key()) { | 546 | switch(e->key()) { |
547 | case Key_Up: | 547 | case Key_Up: |
548 | view->moveUp(); | 548 | view->moveUp(); |
549 | break; | 549 | break; |
550 | case Key_Down: | 550 | case Key_Down: |
551 | view->moveDown(); | 551 | view->moveDown(); |
552 | break; | 552 | break; |
553 | case Key_Left: | 553 | case Key_Left: |
554 | setDate(QDate(currDate).addDays(-1)); | 554 | setDate(QDate(currDate).addDays(-1)); |
555 | break; | 555 | break; |
556 | case Key_Right: | 556 | case Key_Right: |
557 | setDate(QDate(currDate).addDays(1)); | 557 | setDate(QDate(currDate).addDays(1)); |
558 | break; | 558 | break; |
559 | default: | 559 | default: |
560 | e->ignore(); | 560 | e->ignore(); |
561 | } | 561 | } |
562 | } | 562 | } |
563 | 563 | ||
564 | //=========================================================================== | 564 | //=========================================================================== |
565 | 565 | ||
566 | DateBookDayWidget::DateBookDayWidget( const EffectiveEvent &e, | 566 | DateBookDayWidget::DateBookDayWidget( const EffectiveEvent &e, |
567 | DateBookDay *db ) | 567 | DateBookDay *db ) |
568 | : QWidget( db->dayView()->viewport() ), ev( e ), dateBook( db ) | 568 | : QWidget( db->dayView()->viewport() ), ev( e ), dateBook( db ) |
569 | { | 569 | { |
570 | 570 | ||
571 | 571 | ||
572 | // why would someone use "<"? Oh well, fix it up... | 572 | // why would someone use "<"? Oh well, fix it up... |
573 | // I wonder what other things may be messed up... | 573 | // I wonder what other things may be messed up... |
574 | QString strDesc = ev.description(); | 574 | QString strDesc = ev.description(); |
575 | int where = strDesc.find( "<" ); | 575 | int where = strDesc.find( "<" ); |
576 | while ( where != -1 ) { | 576 | while ( where != -1 ) { |
577 | strDesc.remove( where, 1 ); | 577 | strDesc.remove( where, 1 ); |
578 | strDesc.insert( where, "<" ); | 578 | strDesc.insert( where, "<" ); |
579 | where = strDesc.find( "<", where ); | 579 | where = strDesc.find( "<", where ); |
580 | } | 580 | } |
581 | 581 | ||
582 | QString strCat; | 582 | QString strCat; |
583 | // ### Fix later... | 583 | // ### Fix later... |
584 | // QString strCat = ev.category(); | 584 | // QString strCat = ev.category(); |
585 | // where = strCat.find( "<" ); | 585 | // where = strCat.find( "<" ); |
586 | // while ( where != -1 ) { | 586 | // while ( where != -1 ) { |
587 | // strCat.remove( where, 1 ); | 587 | // strCat.remove( where, 1 ); |
588 | // strCat.insert( where, "<" ); | 588 | // strCat.insert( where, "<" ); |
589 | // where = strCat.find( "<", where ); | 589 | // where = strCat.find( "<", where ); |
590 | // } | 590 | // } |
591 | 591 | ||
592 | QString strNote = ev.notes(); | 592 | QString strNote = ev.notes(); |
593 | where = strNote.find( "<" ); | 593 | where = strNote.find( "<" ); |
594 | while ( where != -1 ) { | 594 | while ( where != -1 ) { |
595 | strNote.remove( where, 1 ); | 595 | strNote.remove( where, 1 ); |
596 | strNote.insert( where, "<" ); | 596 | strNote.insert( where, "<" ); |
597 | where = strNote.find( "<", where ); | 597 | where = strNote.find( "<", where ); |
598 | } | 598 | } |
599 | 599 | ||
600 | text = "<b>" + strDesc + "</b><br>" + "<i>" | 600 | text = "<b>" + strDesc + "</b><br>" + "<i>"; |
601 | + strCat + "</i><br>"; | 601 | if ( !strCat.isEmpty() ) { |
602 | text += strCat + "</i><br>"; | ||
603 | } | ||
602 | if (ev.event().type() == Event::Normal ) | 604 | if (ev.event().type() == Event::Normal ) |
603 | setEventText( text ); | 605 | setEventText( text ); |
604 | else | 606 | else |
605 | setAllDayText( text ); | 607 | setAllDayText( text ); |
606 | 608 | ||
607 | text += "<br><br>" + strNote; | 609 | text += "<br><br>" + strNote; |
608 | 610 | ||
609 | setBackgroundMode( PaletteBase ); | 611 | setBackgroundMode( PaletteBase ); |
610 | 612 | ||
611 | QTime start = ev.start(); | 613 | QTime start = ev.start(); |
612 | QTime end = ev.end(); | 614 | QTime end = ev.end(); |
613 | int y = start.hour()*60+start.minute(); | 615 | int y = start.hour()*60+start.minute(); |
614 | int h = end.hour()*60+end.minute()-y; | 616 | int h = end.hour()*60+end.minute()-y; |
615 | int rh = dateBook->dayView()->rowHeight(0); | 617 | int rh = dateBook->dayView()->rowHeight(0); |
616 | y = y*rh/60; | 618 | y = y*rh/60; |
617 | h = h*rh/60; | 619 | h = h*rh/60; |
618 | if ( h < 3 ) | 620 | if ( h < 3 ) { |
619 | h = 3; | 621 | h = 3; |
622 | } | ||
620 | geom.setY( y ); | 623 | geom.setY( y ); |
621 | geom.setHeight( h ); | 624 | geom.setHeight( h ); |
622 | geom.setX( 0 ); | 625 | geom.setX( 0 ); |
623 | geom.setWidth(dateBook->dayView()->columnWidth(0)-1); | 626 | geom.setWidth(dateBook->dayView()->columnWidth(0)-1); |
624 | 627 | ||
625 | } | 628 | } |
626 | void DateBookDayWidget::setAllDayText( QString &text ) { | 629 | void DateBookDayWidget::setAllDayText( QString &text ) { |
627 | text += "<b>" + tr("This is an all day event.") + "</b><br>"; | 630 | text += "<b>" + tr("This is an all day event.") + "</b><br>"; |
628 | } | 631 | } |
629 | void DateBookDayWidget::setEventText( QString& text ) { | 632 | void DateBookDayWidget::setEventText( QString& text ) { |
630 | bool whichClock = dateBook->dayView()->whichClock(); | 633 | bool whichClock = dateBook->dayView()->whichClock(); |
631 | text += "<b>" + tr("Start") + "</b>: "; | 634 | text += "<b>" + tr("Time") + "</b>: "; |
632 | if ( ev.startDate() != ev.date() ) { | 635 | if ( ev.startDate() != ev.date() ) { |
633 | // multi-day event. Show start date | 636 | // multi-day event. Show start date |
634 | text += TimeString::longDateString( ev.startDate() ); | 637 | text += TimeString::longDateString( ev.startDate() ); |
635 | } else { | 638 | } else { |
636 | // Show start time. | 639 | // Show start time. |
637 | text += TimeString::timeString( ev.start(), whichClock, FALSE ); | 640 | text += TimeString::timeString( ev.start(), whichClock, FALSE ); |
638 | } | 641 | } |
639 | 642 | ||
640 | text += "<br><b>" + tr("End") + "</b>: "; | 643 | text += "<b>" + tr(" - ") + "</b>"; |
641 | if ( ev.endDate() != ev.date() ) { | 644 | if ( ev.endDate() != ev.date() ) { |
642 | // multi-day event. Show end date | 645 | // multi-day event. Show end date |
643 | text += TimeString::longDateString( ev.endDate() ); | 646 | text += TimeString::longDateString( ev.endDate() ); |
644 | } else { | 647 | } else { |
645 | // Show end time. | 648 | // Show end time. |
646 | text += TimeString::timeString( ev.end(), whichClock, FALSE ); | 649 | text += TimeString::timeString( ev.end(), whichClock, FALSE ); |
647 | } | 650 | } |
648 | 651 | ||
649 | } | 652 | } |
650 | 653 | ||
651 | DateBookDayWidget::~DateBookDayWidget() | 654 | DateBookDayWidget::~DateBookDayWidget() |
652 | { | 655 | { |
653 | } | 656 | } |
654 | 657 | ||
655 | void DateBookDayWidget::paintEvent( QPaintEvent *e ) | 658 | void DateBookDayWidget::paintEvent( QPaintEvent *e ) |
656 | { | 659 | { |
657 | QPainter p( this ); | 660 | QPainter p( this ); |
658 | 661 | ||
659 | if (dateBook->getSelectedWidget() == this) | 662 | if (dateBook->getSelectedWidget() == this) |
660 | { | 663 | { |
661 | p.setBrush( QColor( 155, 240, 230 ) ); // selected item | 664 | p.setBrush( QColor( 155, 240, 230 ) ); // selected item |
662 | } else | 665 | } else |
663 | { | 666 | { |
664 | if (dateBook->date() == QDate::currentDate()) | 667 | if (dateBook->date() == QDate::currentDate()) |
665 | { | 668 | { |
666 | QTime curTime = QTime::currentTime(); | 669 | QTime curTime = QTime::currentTime(); |
667 | 670 | ||
668 | if (ev.end() < curTime) | 671 | if (ev.end() < curTime) |
669 | { | 672 | { |
670 | p.setBrush( QColor( 180, 180, 180 ) ); // grey, inactive | 673 | p.setBrush( QColor( 180, 180, 180 ) ); // grey, inactive |
671 | } else | 674 | } else |
672 | { | 675 | { |
673 | //change color in dependence of the time till the event starts | 676 | //change color in dependence of the time till the event starts |
674 | int duration = curTime.secsTo(ev.start()); | 677 | int duration = curTime.secsTo(ev.start()); |
675 | if (duration < 0) duration = 0; | 678 | if (duration < 0) duration = 0; |
676 | int colChange = duration*160/86400; //86400: secs per day, 160: max color shift | 679 | int colChange = duration*160/86400; //86400: secs per day, 160: max color shift |
677 | 680 | ||
678 | p.setBrush( QColor( 200-colChange, 200-colChange, 255 ) ); //blue | 681 | p.setBrush( QColor( 200-colChange, 200-colChange, 255 ) ); //blue |
679 | } | 682 | } |
680 | } else | 683 | } else |
681 | { | 684 | { |
682 | p.setBrush( QColor( 220, 220, 220 ) ); //light grey, inactive (not current date) | 685 | p.setBrush( QColor( 220, 220, 220 ) ); //light grey, inactive (not current date) |
683 | //perhaps make a distinction between future/past dates | 686 | //perhaps make a distinction between future/past dates |
684 | } | 687 | } |
685 | } | 688 | } |
686 | 689 | ||
687 | p.setPen( QColor(100, 100, 100) ); | 690 | p.setPen( QColor(100, 100, 100) ); |
688 | p.drawRect(rect()); | 691 | p.drawRect(rect()); |
689 | 692 | ||
690 | // p.drawRect(0,0, 5, height()); | 693 | // p.drawRect(0,0, 5, height()); |
691 | 694 | ||
692 | int y = 0; | 695 | int y = 0; |
693 | int d = 0; | 696 | int d = 0; |
694 | 697 | ||
695 | if ( ev.event().hasAlarm() ) { | 698 | if ( ev.event().hasAlarm() ) { |
696 | p.drawPixmap( width() - 16, 0, Resource::loadPixmap( "bell" ) ); | 699 | p.drawPixmap( width() - 16, 0, Resource::loadPixmap( "bell" ) ); |
697 | y = 20; | 700 | y = 20; |
698 | d = 20; | 701 | d = 20; |
699 | } | 702 | } |
700 | 703 | ||
701 | if ( ev.event().hasRepeat() ) { | 704 | if ( ev.event().hasRepeat() ) { |
702 | p.drawPixmap( width() - 16, y, Resource::loadPixmap( "repeat" ) ); | 705 | p.drawPixmap( width() - 16, y, Resource::loadPixmap( "repeat" ) ); |
703 | d = 20; | 706 | d = 20; |
704 | y += 20; | 707 | y += 20; |