-rw-r--r-- | libkcal/todo.cpp | 18 |
1 files changed, 16 insertions, 2 deletions
diff --git a/libkcal/todo.cpp b/libkcal/todo.cpp index 5260051..4ada2d8 100644 --- a/libkcal/todo.cpp +++ b/libkcal/todo.cpp | |||
@@ -524,36 +524,50 @@ bool Todo::setRecurDates() | |||
524 | } | 524 | } |
525 | return true; | 525 | return true; |
526 | } | 526 | } |
527 | void Todo::setPercentComplete(int v) | 527 | void Todo::setPercentComplete(int v) |
528 | { | 528 | { |
529 | if ( mHasRecurrenceID && v == 100 && mPercentComplete != 100 ) { | 529 | if ( mHasRecurrenceID && v == 100 && mPercentComplete != 100 ) { |
530 | if ( !setRecurDates() ) | 530 | if ( !setRecurDates() ) |
531 | v = 0; | 531 | v = 0; |
532 | } | 532 | } |
533 | mPercentComplete = v; | 533 | mPercentComplete = v; |
534 | if ( v != 100 ) | 534 | if ( v != 100 ) |
535 | mHasCompletedDate = false; | 535 | mHasCompletedDate = false; |
536 | updated(); | 536 | updated(); |
537 | } | 537 | } |
538 | QDateTime Todo::getNextAlarmDateTime( bool * ok, int * offset, QDateTime start_dt ) const | 538 | QDateTime Todo::getNextAlarmDateTime( bool * ok, int * offset, QDateTime start_dt ) const |
539 | { | 539 | { |
540 | if ( isCompleted() || ! hasDueDate() || cancelled() || !alarmEnabled() ) { | 540 | *ok = false; |
541 | *ok = false; | 541 | if ( ! hasDueDate() || cancelled() || !alarmEnabled() ) { |
542 | return QDateTime (); | 542 | return QDateTime (); |
543 | } | 543 | } |
544 | // if the recurring todo is set to complete and requested time < start time of todo | ||
545 | // we want to get the alarm. | ||
546 | bool iscompleted = isCompleted(); | ||
547 | if ( iscompleted && doesRecur() ) { | ||
548 | Todo * to = (Todo*) this; | ||
549 | to->checkSetCompletedFalse(); | ||
550 | iscompleted = isCompleted(); | ||
551 | if ( hasStartDate() && start_dt < dtStart() ){ | ||
552 | iscompleted = false; | ||
553 | } | ||
554 | } | ||
555 | if ( iscompleted ) { | ||
556 | return QDateTime (); | ||
557 | } | ||
544 | QDateTime incidenceStart; | 558 | QDateTime incidenceStart; |
545 | incidenceStart = dtDue(); | 559 | incidenceStart = dtDue(); |
546 | bool enabled = false; | 560 | bool enabled = false; |
547 | Alarm* alarm; | 561 | Alarm* alarm; |
548 | int off = 0; | 562 | int off = 0; |
549 | QDateTime alarmStart = QDateTime::currentDateTime().addDays( 3650 );; | 563 | QDateTime alarmStart = QDateTime::currentDateTime().addDays( 3650 );; |
550 | // if ( QDateTime::currentDateTime() > incidenceStart ){ | 564 | // if ( QDateTime::currentDateTime() > incidenceStart ){ |
551 | // *ok = false; | 565 | // *ok = false; |
552 | // return incidenceStart; | 566 | // return incidenceStart; |
553 | // } | 567 | // } |
554 | for (QPtrListIterator<Alarm> it(mAlarms); (alarm = it.current()) != 0; ++it) { | 568 | for (QPtrListIterator<Alarm> it(mAlarms); (alarm = it.current()) != 0; ++it) { |
555 | if (alarm->enabled()) { | 569 | if (alarm->enabled()) { |
556 | if ( alarm->hasTime () ) { | 570 | if ( alarm->hasTime () ) { |
557 | if ( alarm->time() < alarmStart ) { | 571 | if ( alarm->time() < alarmStart ) { |
558 | alarmStart = alarm->time(); | 572 | alarmStart = alarm->time(); |
559 | enabled = true; | 573 | enabled = true; |