-rw-r--r-- | core/pim/todo/mainwindow.cpp | 2 | ||||
-rw-r--r-- | core/pim/todo/todotable.cpp | 7 |
2 files changed, 6 insertions, 3 deletions
diff --git a/core/pim/todo/mainwindow.cpp b/core/pim/todo/mainwindow.cpp index d3f4cb4..a28fc3e 100644 --- a/core/pim/todo/mainwindow.cpp +++ b/core/pim/todo/mainwindow.cpp | |||
@@ -395,64 +395,65 @@ void TodoWindow::slotDuplicate() | |||
395 | if(syncing) { | 395 | if(syncing) { |
396 | QMessageBox::warning(this, tr("Todo"), | 396 | QMessageBox::warning(this, tr("Todo"), |
397 | tr("Can not edit data, currently syncing")); | 397 | tr("Can not edit data, currently syncing")); |
398 | return; | 398 | return; |
399 | } | 399 | } |
400 | ToDoEvent ev = table->currentEntry(); | 400 | ToDoEvent ev = table->currentEntry(); |
401 | ToDoEvent ev2 = ToDoEvent( ev ); // what about the uid | 401 | ToDoEvent ev2 = ToDoEvent( ev ); // what about the uid |
402 | int uid; | 402 | int uid; |
403 | { // uid | 403 | { // uid |
404 | Qtopia::UidGen *uidgen = new Qtopia::UidGen(); | 404 | Qtopia::UidGen *uidgen = new Qtopia::UidGen(); |
405 | uid = uidgen->generate(); | 405 | uid = uidgen->generate(); |
406 | delete uidgen; | 406 | delete uidgen; |
407 | } | 407 | } |
408 | ev2.setUid( uid ); | 408 | ev2.setUid( uid ); |
409 | table->setPaintingEnabled( false ); | 409 | table->setPaintingEnabled( false ); |
410 | table->addEntry( ev2 ); | 410 | table->addEntry( ev2 ); |
411 | table->setPaintingEnabled( true ); | 411 | table->setPaintingEnabled( true ); |
412 | 412 | ||
413 | mStack->raiseWidget( 1 ); | 413 | mStack->raiseWidget( 1 ); |
414 | } | 414 | } |
415 | void TodoWindow::slotShowPopup( const QPoint &p ) | 415 | void TodoWindow::slotShowPopup( const QPoint &p ) |
416 | { | 416 | { |
417 | contextMenu->popup( p ); | 417 | contextMenu->popup( p ); |
418 | } | 418 | } |
419 | 419 | ||
420 | void TodoWindow::showCompleted( bool s ) | 420 | void TodoWindow::showCompleted( bool s ) |
421 | { | 421 | { |
422 | if ( !table->isUpdatesEnabled() ) | 422 | if ( !table->isUpdatesEnabled() ) |
423 | return; | 423 | return; |
424 | table->setPaintingEnabled( false ); | 424 | table->setPaintingEnabled( false ); |
425 | table->setShowCompleted( s ); | 425 | table->setShowCompleted( s ); |
426 | table->setPaintingEnabled( true ); | 426 | table->setPaintingEnabled( true ); |
427 | mStack->raiseWidget( 1 ); | ||
427 | } | 428 | } |
428 | 429 | ||
429 | void TodoWindow::currentEntryChanged( int r, int ) | 430 | void TodoWindow::currentEntryChanged( int r, int ) |
430 | { | 431 | { |
431 | if ( r != -1 && table->rowHeight( r ) > 0 ) { | 432 | if ( r != -1 && table->rowHeight( r ) > 0 ) { |
432 | editAction->setEnabled( TRUE ); | 433 | editAction->setEnabled( TRUE ); |
433 | deleteAction->setEnabled( TRUE ); | 434 | deleteAction->setEnabled( TRUE ); |
434 | duplicateAction->setEnabled( TRUE ); | 435 | duplicateAction->setEnabled( TRUE ); |
435 | deleteAllAction->setEnabled( TRUE ); | 436 | deleteAllAction->setEnabled( TRUE ); |
436 | } else { | 437 | } else { |
437 | editAction->setEnabled( FALSE ); | 438 | editAction->setEnabled( FALSE ); |
438 | deleteAction->setEnabled( FALSE ); | 439 | deleteAction->setEnabled( FALSE ); |
439 | duplicateAction->setEnabled( FALSE ); | 440 | duplicateAction->setEnabled( FALSE ); |
440 | deleteAllAction->setEnabled( FALSE ); | 441 | deleteAllAction->setEnabled( FALSE ); |
441 | } | 442 | } |
442 | } | 443 | } |
443 | 444 | ||
444 | void TodoWindow::setCategory( int c ) | 445 | void TodoWindow::setCategory( int c ) |
445 | { | 446 | { |
446 | if ( c <= 0 ) return; | 447 | if ( c <= 0 ) return; |
447 | if ( !table->isUpdatesEnabled() ) | 448 | if ( !table->isUpdatesEnabled() ) |
448 | return; | 449 | return; |
449 | table->setPaintingEnabled( false ); | 450 | table->setPaintingEnabled( false ); |
450 | for ( unsigned int i = 1; i < catMenu->count(); i++ ) | 451 | for ( unsigned int i = 1; i < catMenu->count(); i++ ) |
451 | catMenu->setItemChecked( i, c == (int)i ); | 452 | catMenu->setItemChecked( i, c == (int)i ); |
452 | if ( c == 1 ) { | 453 | if ( c == 1 ) { |
453 | table->setShowCategory( QString::null ); | 454 | table->setShowCategory( QString::null ); |
454 | setCaption( tr("Todo") + " - " + tr( "All Categories" ) ); | 455 | setCaption( tr("Todo") + " - " + tr( "All Categories" ) ); |
455 | } else if ( c == (int)catMenu->count() - 1 ) { | 456 | } else if ( c == (int)catMenu->count() - 1 ) { |
456 | table->setShowCategory( tr( "Unfiled" ) ); | 457 | table->setShowCategory( tr( "Unfiled" ) ); |
457 | setCaption( tr("Todo") + " - " + tr( "Unfiled" ) ); | 458 | setCaption( tr("Todo") + " - " + tr( "Unfiled" ) ); |
458 | } else { | 459 | } else { |
@@ -516,64 +517,65 @@ void TodoWindow::closeEvent( QCloseEvent *e ) | |||
516 | 517 | ||
517 | if ( table->save( todolistXMLFilename() ) ) { | 518 | if ( table->save( todolistXMLFilename() ) ) { |
518 | e->accept(); | 519 | e->accept(); |
519 | // repeat for categories... | 520 | // repeat for categories... |
520 | // if writing configs fail, it will emit an | 521 | // if writing configs fail, it will emit an |
521 | // error, but I feel that it is "ok" for us to exit | 522 | // error, but I feel that it is "ok" for us to exit |
522 | // espically since we aren't told if the write succeeded... | 523 | // espically since we aren't told if the write succeeded... |
523 | Config config( "todo" ); | 524 | Config config( "todo" ); |
524 | config.setGroup( "View" ); | 525 | config.setGroup( "View" ); |
525 | config.writeEntry( "ShowComplete", table->showCompleted() ); | 526 | config.writeEntry( "ShowComplete", table->showCompleted() ); |
526 | config.writeEntry( "Category", table->showCategory() ); | 527 | config.writeEntry( "Category", table->showCategory() ); |
527 | /* added 20.01.2k2 by se */ | 528 | /* added 20.01.2k2 by se */ |
528 | config.writeEntry( "ShowDeadLine", table->showDeadline()); | 529 | config.writeEntry( "ShowDeadLine", table->showDeadline()); |
529 | } else { | 530 | } else { |
530 | if ( QMessageBox::critical( this, tr("Out of space"), | 531 | if ( QMessageBox::critical( this, tr("Out of space"), |
531 | tr("Todo was unable\n" | 532 | tr("Todo was unable\n" |
532 | "to save your changes.\n" | 533 | "to save your changes.\n" |
533 | "Free up some space\n" | 534 | "Free up some space\n" |
534 | "and try again.\n" | 535 | "and try again.\n" |
535 | "\nQuit Anyway?"), | 536 | "\nQuit Anyway?"), |
536 | QMessageBox::Yes|QMessageBox::Escape, | 537 | QMessageBox::Yes|QMessageBox::Escape, |
537 | QMessageBox::No|QMessageBox::Default) | 538 | QMessageBox::No|QMessageBox::Default) |
538 | != QMessageBox::No ) | 539 | != QMessageBox::No ) |
539 | e->accept(); | 540 | e->accept(); |
540 | else | 541 | else |
541 | e->ignore(); | 542 | e->ignore(); |
542 | } | 543 | } |
543 | } | 544 | } |
544 | 545 | ||
545 | void TodoWindow::slotFind() | 546 | void TodoWindow::slotFind() |
546 | { | 547 | { |
547 | // put everything back to view all for searching... | 548 | // put everything back to view all for searching... |
549 | mStack->raiseWidget( 1 ); | ||
548 | if ( !catMenu->isItemChecked( 0 ) ) | 550 | if ( !catMenu->isItemChecked( 0 ) ) |
549 | setCategory( 0 ); | 551 | setCategory( 0 ); |
550 | 552 | ||
551 | FindDialog dlg( "Todo List", this ); | 553 | FindDialog dlg( "Todo List", this ); |
552 | QObject::connect( &dlg, | 554 | QObject::connect( &dlg, |
553 | SIGNAL(signalFindClicked(const QString &, | 555 | SIGNAL(signalFindClicked(const QString &, |
554 | bool, bool, int)), | 556 | bool, bool, int)), |
555 | table, | 557 | table, |
556 | SLOT(slotDoFind(const QString&, bool, bool, int)) ); | 558 | SLOT(slotDoFind(const QString&, bool, bool, int)) ); |
557 | QObject::connect( table, SIGNAL(signalNotFound()), &dlg, | 559 | QObject::connect( table, SIGNAL(signalNotFound()), &dlg, |
558 | SLOT(slotNotFound()) ); | 560 | SLOT(slotNotFound()) ); |
559 | QObject::connect( table, SIGNAL(signalWrapAround()), &dlg, | 561 | QObject::connect( table, SIGNAL(signalWrapAround()), &dlg, |
560 | SLOT(slotWrapAround()) ); | 562 | SLOT(slotWrapAround()) ); |
561 | dlg.exec(); | 563 | dlg.exec(); |
562 | if ( table->numSelections() ) | 564 | if ( table->numSelections() ) |
563 | table->clearSelection(); | 565 | table->clearSelection(); |
564 | table->clearFindRow(); | 566 | table->clearFindRow(); |
565 | } | 567 | } |
566 | 568 | ||
567 | 569 | ||
568 | void TodoWindow::setDocument( const QString &filename ) | 570 | void TodoWindow::setDocument( const QString &filename ) |
569 | { | 571 | { |
570 | if ( filename.find(".vcs") != int(filename.length()) - 4 ) return; | 572 | if ( filename.find(".vcs") != int(filename.length()) - 4 ) return; |
571 | 573 | ||
572 | ToDoDB todoDB(filename, new ToDoVCalResource() ); | 574 | ToDoDB todoDB(filename, new ToDoVCalResource() ); |
573 | QValueList<ToDoEvent> tl = todoDB.rawToDos(); | 575 | QValueList<ToDoEvent> tl = todoDB.rawToDos(); |
574 | for( QValueList<ToDoEvent>::Iterator it = tl.begin(); it != tl.end(); ++it ) { | 576 | for( QValueList<ToDoEvent>::Iterator it = tl.begin(); it != tl.end(); ++it ) { |
575 | table->addEntry( *it ); | 577 | table->addEntry( *it ); |
576 | } | 578 | } |
577 | } | 579 | } |
578 | 580 | ||
579 | static const char * beamfile = "/tmp/obex/todo.vcs"; | 581 | static const char * beamfile = "/tmp/obex/todo.vcs"; |
diff --git a/core/pim/todo/todotable.cpp b/core/pim/todo/todotable.cpp index 753c036..dc60cc4 100644 --- a/core/pim/todo/todotable.cpp +++ b/core/pim/todo/todotable.cpp | |||
@@ -569,108 +569,109 @@ void TodoTable::updateJournal( const ToDoEvent &todo, journal_action action ) | |||
569 | QString attr; | 569 | QString attr; |
570 | for(uint i=0; i < arrat.count(); i++ ){ | 570 | for(uint i=0; i < arrat.count(); i++ ){ |
571 | attr.append(QString::number(arrat[i])+";" ); | 571 | attr.append(QString::number(arrat[i])+";" ); |
572 | } | 572 | } |
573 | if(!attr.isEmpty() ) // remove the last ; | 573 | if(!attr.isEmpty() ) // remove the last ; |
574 | attr.remove(attr.length()-1, 1 ); | 574 | attr.remove(attr.length()-1, 1 ); |
575 | buf += " Categories=\"" + attr + "\""; | 575 | buf += " Categories=\"" + attr + "\""; |
576 | buf += " Description=\"" + todo.description() + "\""; | 576 | buf += " Description=\"" + todo.description() + "\""; |
577 | if(todo.hasDate() ) { | 577 | if(todo.hasDate() ) { |
578 | buf += " DateYear=\""+QString::number( todo.date().year() ) + "\""; | 578 | buf += " DateYear=\""+QString::number( todo.date().year() ) + "\""; |
579 | buf += " DateMonth=\"" + QString::number( todo.date().month() ) + "\""; | 579 | buf += " DateMonth=\"" + QString::number( todo.date().month() ) + "\""; |
580 | buf += " DateDay=\"" + QString::number( todo.date().day() ) + "\""; | 580 | buf += " DateDay=\"" + QString::number( todo.date().day() ) + "\""; |
581 | } | 581 | } |
582 | buf += "/>\n"; | 582 | buf += "/>\n"; |
583 | str = buf.utf8(); | 583 | str = buf.utf8(); |
584 | f.writeBlock( str.data(), str.length() ); | 584 | f.writeBlock( str.data(), str.length() ); |
585 | f.close(); | 585 | f.close(); |
586 | } | 586 | } |
587 | 587 | ||
588 | void TodoTable::rowHeightChanged( int row ) | 588 | void TodoTable::rowHeightChanged( int row ) |
589 | { | 589 | { |
590 | if ( enablePainting ) | 590 | if ( enablePainting ) |
591 | QTable::rowHeightChanged( row ); | 591 | QTable::rowHeightChanged( row ); |
592 | } | 592 | } |
593 | 593 | ||
594 | void TodoTable::loadFile( const QString &/*we use the standard*/ ) | 594 | void TodoTable::loadFile( const QString &/*we use the standard*/ ) |
595 | { | 595 | { |
596 | 596 | ||
597 | QList<ToDoEvent> list; | 597 | QList<ToDoEvent> list; |
598 | ToDoDB todoDB; | 598 | ToDoDB todoDB; |
599 | QValueList<ToDoEvent> vaList = todoDB.rawToDos(); | 599 | QValueList<ToDoEvent> vaList = todoDB.rawToDos(); |
600 | for(QValueList<ToDoEvent>::ConstIterator it = vaList.begin(); it != vaList.end(); ++it ){ | 600 | for(QValueList<ToDoEvent>::ConstIterator it = vaList.begin(); it != vaList.end(); ++it ){ |
601 | list.append( new ToDoEvent( (*it) ) ); | 601 | ToDoEvent *event = new ToDoEvent( (*it) ); |
602 | list.append( event ); | ||
602 | } | 603 | } |
603 | vaList.clear(); | 604 | vaList.clear(); |
604 | // qDebug("parsing done=%d", t.elapsed() ); | 605 | // qDebug("parsing done=%d", t.elapsed() ); |
605 | if ( list.count() > 0 ) { | 606 | if ( list.count() > 0 ) { |
606 | internalAddEntries( list ); | 607 | internalAddEntries( list ); |
607 | list.clear(); | 608 | list.clear(); |
608 | } | 609 | } |
609 | // qDebug("loading done: t=%d", t.elapsed() ); | 610 | // qDebug("loading done: t=%d", t.elapsed() ); |
610 | } | 611 | } |
611 | 612 | ||
612 | void TodoTable::journalFreeReplaceEntry( const ToDoEvent &todo, int row ) | 613 | void TodoTable::journalFreeReplaceEntry( const ToDoEvent &todo, int row ) |
613 | { | 614 | { |
614 | QString strTodo; | 615 | QString strTodo; |
615 | strTodo = todo.description().left(40).simplifyWhiteSpace(); | 616 | strTodo = todo.description().left(40).simplifyWhiteSpace(); |
616 | if ( row == -1 ) { | 617 | if ( row == -1 ) { |
617 | QMapIterator<CheckItem*, ToDoEvent *> it; | 618 | QMapIterator<CheckItem*, ToDoEvent *> it; |
618 | for ( it = todoList.begin(); it != todoList.end(); ++it ) { | 619 | for ( it = todoList.begin(); it != todoList.end(); ++it ) { |
619 | if ( *(*it) == todo ) { | 620 | if ( *(*it) == todo ) { |
620 | row = it.key()->row(); | 621 | row = it.key()->row(); |
621 | it.key()->setChecked( todo.isCompleted() ); | 622 | it.key()->setChecked( todo.isCompleted() ); |
622 | static_cast<ComboItem*>(item(row, 1))->setText( QString::number(todo.priority()) ); | 623 | static_cast<ComboItem*>(item(row, 1))->setText( QString::number(todo.priority()) ); |
623 | item( row, 2 )->setText( strTodo ); | 624 | item( row, 2 )->setText( strTodo ); |
624 | 625 | ||
625 | if (showDeadl){ | 626 | if (showDeadl){ |
626 | static_cast<DueTextItem*>(item(row,3))->setToDoEvent(&todo ); | 627 | static_cast<DueTextItem*>(item(row,3))->setToDoEvent(&todo ); |
627 | } | 628 | } |
628 | 629 | ||
629 | *(*it) = todo; | 630 | *(*it) = todo; |
630 | } | 631 | } |
631 | } | 632 | } |
632 | } else { | 633 | } else { |
633 | ToDoEvent *t = todoList[static_cast<CheckItem*>(item(row, 0))]; | 634 | ToDoEvent *t = todoList[static_cast<CheckItem*>(item(row, 0))]; |
634 | todoList.remove( static_cast<CheckItem*>(item(row, 0)) ); | 635 | todoList.remove( static_cast<CheckItem*>(item(row, 0)) ); |
635 | delete t; | 636 | delete t; |
636 | static_cast<CheckItem*>(item(row, 0))->setChecked( todo.isCompleted() ); | 637 | static_cast<CheckItem*>(item(row, 0))->setChecked( todo.isCompleted() ); |
637 | static_cast<ComboItem*>(item(row, 1))->setText( QString::number(todo.priority()) ); | 638 | static_cast<ComboItem*>(item(row, 1))->setText( QString::number(todo.priority()) ); |
638 | item( row, 2 )->setText( strTodo ); | 639 | item( row, 2 )->setText( strTodo ); |
639 | 640 | ||
640 | if (showDeadl){ | 641 | if (showDeadl){ |
641 | static_cast<DueTextItem*>(item(row,3))->setToDoEvent(&todo ); | 642 | static_cast<DueTextItem*>(item(row,3))->setToDoEvent(&todo ); |
642 | } | 643 | } |
643 | 644 | ToDoEvent *ev = new ToDoEvent( todo ); | |
644 | todoList.insert( static_cast<CheckItem*>(item(row,0)), new ToDoEvent(todo) ); | 645 | todoList.insert( static_cast<CheckItem*>(item(row,0)), new ToDoEvent(ev) ); |
645 | } | 646 | } |
646 | } | 647 | } |
647 | 648 | ||
648 | void TodoTable::journalFreeRemoveEntry( int row ) | 649 | void TodoTable::journalFreeRemoveEntry( int row ) |
649 | { | 650 | { |
650 | CheckItem *chk; | 651 | CheckItem *chk; |
651 | chk = static_cast<CheckItem*>(item(row, 0 )); | 652 | chk = static_cast<CheckItem*>(item(row, 0 )); |
652 | if ( !chk ) | 653 | if ( !chk ) |
653 | return; | 654 | return; |
654 | todoList.remove( chk ); | 655 | todoList.remove( chk ); |
655 | 656 | ||
656 | realignTable( row ); | 657 | realignTable( row ); |
657 | } | 658 | } |
658 | 659 | ||
659 | void TodoTable::keyPressEvent( QKeyEvent *e ) | 660 | void TodoTable::keyPressEvent( QKeyEvent *e ) |
660 | { | 661 | { |
661 | if ( e->key() == Key_Space || e->key() == Key_Return ) { | 662 | if ( e->key() == Key_Space || e->key() == Key_Return ) { |
662 | switch ( currentColumn() ) { | 663 | switch ( currentColumn() ) { |
663 | case 0: { | 664 | case 0: { |
664 | CheckItem *i = static_cast<CheckItem*>(item(currentRow(), | 665 | CheckItem *i = static_cast<CheckItem*>(item(currentRow(), |
665 | currentColumn())); | 666 | currentColumn())); |
666 | if ( i ) | 667 | if ( i ) |
667 | i->toggle(); | 668 | i->toggle(); |
668 | break; | 669 | break; |
669 | } | 670 | } |
670 | case 1: | 671 | case 1: |
671 | break; | 672 | break; |
672 | case 2: | 673 | case 2: |
673 | emit signalEdit(); | 674 | emit signalEdit(); |
674 | default: | 675 | default: |
675 | break; | 676 | break; |
676 | } | 677 | } |