summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/pim/datebook/datebookday.cpp13
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
538void DateBookDay::slotWeekChanged( bool bStartOnMonday ) 538void DateBookDay::slotWeekChanged( bool bStartOnMonday )
539{ 539{
540 header->setStartOfWeek( bStartOnMonday ); 540 header->setStartOfWeek( bStartOnMonday );
541 // redraw(); 541 // redraw();
542} 542}
543 543
544void DateBookDay::keyPressEvent(QKeyEvent *e) 544void 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
566DateBookDayWidget::DateBookDayWidget( const EffectiveEvent &e, 566DateBookDayWidget::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, "&#60;" ); 578 strDesc.insert( where, "&#60;" );
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, "&#60;" ); 588 // strCat.insert( where, "&#60;" );
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, "&#60;" ); 596 strNote.insert( where, "&#60;" );
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}
626void DateBookDayWidget::setAllDayText( QString &text ) { 629void 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}
629void DateBookDayWidget::setEventText( QString& text ) { 632void 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
651DateBookDayWidget::~DateBookDayWidget() 654DateBookDayWidget::~DateBookDayWidget()
652{ 655{
653} 656}
654 657
655void DateBookDayWidget::paintEvent( QPaintEvent *e ) 658void 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;