-rw-r--r-- | libopie/pim/ocontact.cpp | 4 | ||||
-rw-r--r-- | libopie/pim/opimrecord.cpp | 4 | ||||
-rw-r--r-- | libopie/pim/opimrecord.h | 2 | ||||
-rw-r--r-- | libopie/pim/otodo.cpp | 2 | ||||
-rw-r--r-- | libopie2/opiepim/core/opimrecord.cpp | 4 | ||||
-rw-r--r-- | libopie2/opiepim/core/opimrecord.h | 2 | ||||
-rw-r--r-- | libopie2/opiepim/ocontact.cpp | 4 | ||||
-rw-r--r-- | libopie2/opiepim/otodo.cpp | 2 |
8 files changed, 12 insertions, 12 deletions
diff --git a/libopie/pim/ocontact.cpp b/libopie/pim/ocontact.cpp index 178559b..9cccfc8 100644 --- a/libopie/pim/ocontact.cpp +++ b/libopie/pim/ocontact.cpp | |||
@@ -438,387 +438,387 @@ QString OContact::toRichText() const | |||
438 | QString text; | 438 | QString text; |
439 | QString value, comp, state; | 439 | QString value, comp, state; |
440 | QString str; | 440 | QString str; |
441 | bool marker = false; | 441 | bool marker = false; |
442 | 442 | ||
443 | // name, jobtitle and company | 443 | // name, jobtitle and company |
444 | if ( !(value = fullName()).isEmpty() ) | 444 | if ( !(value = fullName()).isEmpty() ) |
445 | text += "<b><h3>" + Qtopia::escapeString(value) + "</h3></b><br>"; | 445 | text += "<b><h3>" + Qtopia::escapeString(value) + "</h3></b><br>"; |
446 | if ( !(value = jobTitle()).isEmpty() ) | 446 | if ( !(value = jobTitle()).isEmpty() ) |
447 | text += Qtopia::escapeString(value) + "<br>"; | 447 | text += Qtopia::escapeString(value) + "<br>"; |
448 | 448 | ||
449 | comp = company(); | 449 | comp = company(); |
450 | if ( !(value = department()).isEmpty() ) { | 450 | if ( !(value = department()).isEmpty() ) { |
451 | text += Qtopia::escapeString(value); | 451 | text += Qtopia::escapeString(value); |
452 | if ( comp ) | 452 | if ( comp ) |
453 | text += ", "; | 453 | text += ", "; |
454 | else | 454 | else |
455 | text += "<br>"; | 455 | text += "<br>"; |
456 | } | 456 | } |
457 | if ( !comp.isEmpty() ) | 457 | if ( !comp.isEmpty() ) |
458 | text += Qtopia::escapeString(comp) + "<br>"; | 458 | text += Qtopia::escapeString(comp) + "<br>"; |
459 | 459 | ||
460 | QString defEmail = defaultEmail(); | 460 | QString defEmail = defaultEmail(); |
461 | if ( !defEmail.isEmpty() ) | 461 | if ( !defEmail.isEmpty() ) |
462 | text += "<b>" + QObject::tr("Default Email: ") + "</b>" | 462 | text += "<b>" + QObject::tr("Default Email: ") + "</b>" |
463 | + Qtopia::escapeString(defEmail) + "<br>"; | 463 | + Qtopia::escapeString(defEmail) + "<br>"; |
464 | 464 | ||
465 | text += "<hr>"; | 465 | text += "<hr>"; |
466 | 466 | ||
467 | // business address | 467 | // business address |
468 | if ( !businessStreet().isEmpty() || !businessCity().isEmpty() || | 468 | if ( !businessStreet().isEmpty() || !businessCity().isEmpty() || |
469 | !businessZip().isEmpty() || !businessCountry().isEmpty() ) { | 469 | !businessZip().isEmpty() || !businessCountry().isEmpty() ) { |
470 | text += "<br>"; | 470 | text += "<br>"; |
471 | text += QObject::tr( "<b>Work Address:</b>" ); | 471 | text += QObject::tr( "<b>Work Address:</b>" ); |
472 | text += "<br>"; | 472 | text += "<br>"; |
473 | marker = true; | 473 | marker = true; |
474 | } | 474 | } |
475 | 475 | ||
476 | if ( !(value = businessStreet()).isEmpty() ) | 476 | if ( !(value = businessStreet()).isEmpty() ) |
477 | text += Qtopia::escapeString(value) + "<br>"; | 477 | text += Qtopia::escapeString(value) + "<br>"; |
478 | state = businessState(); | 478 | state = businessState(); |
479 | if ( !(value = businessZip()).isEmpty() ) | 479 | if ( !(value = businessZip()).isEmpty() ) |
480 | text += Qtopia::escapeString(value) + " "; | 480 | text += Qtopia::escapeString(value) + " "; |
481 | if ( !(value = businessCity()).isEmpty() ) { | 481 | if ( !(value = businessCity()).isEmpty() ) { |
482 | text += Qtopia::escapeString(value); | 482 | text += Qtopia::escapeString(value); |
483 | if ( state ) | 483 | if ( state ) |
484 | text += ", " + Qtopia::escapeString(state); | 484 | text += ", " + Qtopia::escapeString(state); |
485 | text += "<br>"; | 485 | text += "<br>"; |
486 | } else if ( !state.isEmpty() ) | 486 | } else if ( !state.isEmpty() ) |
487 | text += Qtopia::escapeString(state) + "<br>"; | 487 | text += Qtopia::escapeString(state) + "<br>"; |
488 | 488 | ||
489 | if ( !(value = businessCountry()).isEmpty() ) | 489 | if ( !(value = businessCountry()).isEmpty() ) |
490 | text += Qtopia::escapeString(value) + "<br>"; | 490 | text += Qtopia::escapeString(value) + "<br>"; |
491 | 491 | ||
492 | // rest of Business data | 492 | // rest of Business data |
493 | str = office(); | 493 | str = office(); |
494 | if ( !str.isEmpty() ){ | 494 | if ( !str.isEmpty() ){ |
495 | text += "<b>" + QObject::tr("Office: ") + "</b>" | 495 | text += "<b>" + QObject::tr("Office: ") + "</b>" |
496 | + Qtopia::escapeString(str) + "<br>"; | 496 | + Qtopia::escapeString(str) + "<br>"; |
497 | marker = true; | 497 | marker = true; |
498 | } | 498 | } |
499 | str = businessWebpage(); | 499 | str = businessWebpage(); |
500 | if ( !str.isEmpty() ){ | 500 | if ( !str.isEmpty() ){ |
501 | text += "<b>" + QObject::tr("Business Web Page: ") + "</b>" | 501 | text += "<b>" + QObject::tr("Business Web Page: ") + "</b>" |
502 | + Qtopia::escapeString(str) + "<br>"; | 502 | + Qtopia::escapeString(str) + "<br>"; |
503 | marker = true; | 503 | marker = true; |
504 | } | 504 | } |
505 | str = businessPhone(); | 505 | str = businessPhone(); |
506 | if ( !str.isEmpty() ){ | 506 | if ( !str.isEmpty() ){ |
507 | text += "<b>" + QObject::tr("Business Phone: ") + "</b>" | 507 | text += "<b>" + QObject::tr("Business Phone: ") + "</b>" |
508 | + Qtopia::escapeString(str) + "<br>"; | 508 | + Qtopia::escapeString(str) + "<br>"; |
509 | marker = true; | 509 | marker = true; |
510 | } | 510 | } |
511 | str = businessFax(); | 511 | str = businessFax(); |
512 | if ( !str.isEmpty() ){ | 512 | if ( !str.isEmpty() ){ |
513 | text += "<b>" + QObject::tr("Business Fax: ") + "</b>" | 513 | text += "<b>" + QObject::tr("Business Fax: ") + "</b>" |
514 | + Qtopia::escapeString(str) + "<br>"; | 514 | + Qtopia::escapeString(str) + "<br>"; |
515 | marker = true; | 515 | marker = true; |
516 | } | 516 | } |
517 | str = businessMobile(); | 517 | str = businessMobile(); |
518 | if ( !str.isEmpty() ){ | 518 | if ( !str.isEmpty() ){ |
519 | text += "<b>" + QObject::tr("Business Mobile: ") + "</b>" | 519 | text += "<b>" + QObject::tr("Business Mobile: ") + "</b>" |
520 | + Qtopia::escapeString(str) + "<br>"; | 520 | + Qtopia::escapeString(str) + "<br>"; |
521 | marker = true; | 521 | marker = true; |
522 | } | 522 | } |
523 | str = businessPager(); | 523 | str = businessPager(); |
524 | if ( !str.isEmpty() ){ | 524 | if ( !str.isEmpty() ){ |
525 | text += "<b>" + QObject::tr("Business Pager: ") + "</b>" | 525 | text += "<b>" + QObject::tr("Business Pager: ") + "</b>" |
526 | + Qtopia::escapeString(str) + "<br>"; | 526 | + Qtopia::escapeString(str) + "<br>"; |
527 | marker = true; | 527 | marker = true; |
528 | } | 528 | } |
529 | 529 | ||
530 | // home address | 530 | // home address |
531 | if ( !homeStreet().isEmpty() || !homeCity().isEmpty() || | 531 | if ( !homeStreet().isEmpty() || !homeCity().isEmpty() || |
532 | !homeZip().isEmpty() || !homeCountry().isEmpty() ) { | 532 | !homeZip().isEmpty() || !homeCountry().isEmpty() ) { |
533 | text += "<br>"; | 533 | text += "<br>"; |
534 | text += QObject::tr( "<b>Home Address:</b>" ); | 534 | text += QObject::tr( "<b>Home Address:</b>" ); |
535 | text += "<br>"; | 535 | text += "<br>"; |
536 | } | 536 | } |
537 | 537 | ||
538 | if ( !(value = homeStreet()).isEmpty() ) | 538 | if ( !(value = homeStreet()).isEmpty() ) |
539 | text += Qtopia::escapeString(value) + "<br>"; | 539 | text += Qtopia::escapeString(value) + "<br>"; |
540 | state = homeState(); | 540 | state = homeState(); |
541 | if ( !(value = homeZip()).isEmpty() ) | 541 | if ( !(value = homeZip()).isEmpty() ) |
542 | text += Qtopia::escapeString(value) + " "; | 542 | text += Qtopia::escapeString(value) + " "; |
543 | if ( !(value = homeCity()).isEmpty() ) { | 543 | if ( !(value = homeCity()).isEmpty() ) { |
544 | text += Qtopia::escapeString(value); | 544 | text += Qtopia::escapeString(value); |
545 | if ( !state.isEmpty() ) | 545 | if ( !state.isEmpty() ) |
546 | text += ", " + Qtopia::escapeString(state); | 546 | text += ", " + Qtopia::escapeString(state); |
547 | text += "<br>"; | 547 | text += "<br>"; |
548 | } else if (!state.isEmpty()) | 548 | } else if (!state.isEmpty()) |
549 | text += Qtopia::escapeString(state) + "<br>"; | 549 | text += Qtopia::escapeString(state) + "<br>"; |
550 | if ( !(value = homeCountry()).isEmpty() ) | 550 | if ( !(value = homeCountry()).isEmpty() ) |
551 | text += Qtopia::escapeString(value) + "<br>"; | 551 | text += Qtopia::escapeString(value) + "<br>"; |
552 | 552 | ||
553 | // rest of Home data | 553 | // rest of Home data |
554 | str = homeWebpage(); | 554 | str = homeWebpage(); |
555 | if ( !str.isEmpty() ){ | 555 | if ( !str.isEmpty() ){ |
556 | text += "<b>" + QObject::tr("Home Web Page: ") + "</b>" | 556 | text += "<b>" + QObject::tr("Home Web Page: ") + "</b>" |
557 | + Qtopia::escapeString(str) + "<br>"; | 557 | + Qtopia::escapeString(str) + "<br>"; |
558 | marker = true; | 558 | marker = true; |
559 | } | 559 | } |
560 | str = homePhone(); | 560 | str = homePhone(); |
561 | if ( !str.isEmpty() ){ | 561 | if ( !str.isEmpty() ){ |
562 | text += "<b>" + QObject::tr("Home Phone: ") + "</b>" | 562 | text += "<b>" + QObject::tr("Home Phone: ") + "</b>" |
563 | + Qtopia::escapeString(str) + "<br>"; | 563 | + Qtopia::escapeString(str) + "<br>"; |
564 | marker = true; | 564 | marker = true; |
565 | } | 565 | } |
566 | str = homeFax(); | 566 | str = homeFax(); |
567 | if ( !str.isEmpty() ){ | 567 | if ( !str.isEmpty() ){ |
568 | text += "<b>" + QObject::tr("Home Fax: ") + "</b>" | 568 | text += "<b>" + QObject::tr("Home Fax: ") + "</b>" |
569 | + Qtopia::escapeString(str) + "<br>"; | 569 | + Qtopia::escapeString(str) + "<br>"; |
570 | marker = true; | 570 | marker = true; |
571 | } | 571 | } |
572 | str = homeMobile(); | 572 | str = homeMobile(); |
573 | if ( !str.isEmpty() ){ | 573 | if ( !str.isEmpty() ){ |
574 | text += "<b>" + QObject::tr("Home Mobile: ") + "</b>" | 574 | text += "<b>" + QObject::tr("Home Mobile: ") + "</b>" |
575 | + Qtopia::escapeString(str) + "<br>"; | 575 | + Qtopia::escapeString(str) + "<br>"; |
576 | marker = true; | 576 | marker = true; |
577 | } | 577 | } |
578 | 578 | ||
579 | if ( marker ) | 579 | if ( marker ) |
580 | text += "<br><hr><br>"; | 580 | text += "<br><hr><br>"; |
581 | // the others... | 581 | // the others... |
582 | str = emails(); | 582 | str = emails(); |
583 | if ( !str.isEmpty() && ( str != defEmail ) ) | 583 | if ( !str.isEmpty() && ( str != defEmail ) ) |
584 | text += "<b>" + QObject::tr("All Emails: ") + "</b>" | 584 | text += "<b>" + QObject::tr("All Emails: ") + "</b>" |
585 | + Qtopia::escapeString(str) + "<br>"; | 585 | + Qtopia::escapeString(str) + "<br>"; |
586 | str = profession(); | 586 | str = profession(); |
587 | if ( !str.isEmpty() ) | 587 | if ( !str.isEmpty() ) |
588 | text += "<b>" + QObject::tr("Profession: ") + "</b>" | 588 | text += "<b>" + QObject::tr("Profession: ") + "</b>" |
589 | + Qtopia::escapeString(str) + "<br>"; | 589 | + Qtopia::escapeString(str) + "<br>"; |
590 | str = assistant(); | 590 | str = assistant(); |
591 | if ( !str.isEmpty() ) | 591 | if ( !str.isEmpty() ) |
592 | text += "<b>" + QObject::tr("Assistant: ") + "</b>" | 592 | text += "<b>" + QObject::tr("Assistant: ") + "</b>" |
593 | + Qtopia::escapeString(str) + "<br>"; | 593 | + Qtopia::escapeString(str) + "<br>"; |
594 | str = manager(); | 594 | str = manager(); |
595 | if ( !str.isEmpty() ) | 595 | if ( !str.isEmpty() ) |
596 | text += "<b>" + QObject::tr("Manager: ") + "</b>" | 596 | text += "<b>" + QObject::tr("Manager: ") + "</b>" |
597 | + Qtopia::escapeString(str) + "<br>"; | 597 | + Qtopia::escapeString(str) + "<br>"; |
598 | str = gender(); | 598 | str = gender(); |
599 | if ( !str.isEmpty() && str.toInt() != 0 ) { | 599 | if ( !str.isEmpty() && str.toInt() != 0 ) { |
600 | if ( str.toInt() == 1 ) | 600 | if ( str.toInt() == 1 ) |
601 | str = QObject::tr( "Male" ); | 601 | str = QObject::tr( "Male" ); |
602 | else if ( str.toInt() == 2 ) | 602 | else if ( str.toInt() == 2 ) |
603 | str = QObject::tr( "Female" ); | 603 | str = QObject::tr( "Female" ); |
604 | text += "<b>" + QObject::tr("Gender: ") + "</b>" + str + "<br>"; | 604 | text += "<b>" + QObject::tr("Gender: ") + "</b>" + str + "<br>"; |
605 | } | 605 | } |
606 | str = spouse(); | 606 | str = spouse(); |
607 | if ( !str.isEmpty() ) | 607 | if ( !str.isEmpty() ) |
608 | text += "<b>" + QObject::tr("Spouse: ") + "</b>" | 608 | text += "<b>" + QObject::tr("Spouse: ") + "</b>" |
609 | + Qtopia::escapeString(str) + "<br>"; | 609 | + Qtopia::escapeString(str) + "<br>"; |
610 | if ( birthday().isValid() ){ | 610 | if ( birthday().isValid() ){ |
611 | str = TimeString::numberDateString( birthday() ); | 611 | str = TimeString::numberDateString( birthday() ); |
612 | text += "<b>" + QObject::tr("Birthday: ") + "</b>" | 612 | text += "<b>" + QObject::tr("Birthday: ") + "</b>" |
613 | + Qtopia::escapeString(str) + "<br>"; | 613 | + Qtopia::escapeString(str) + "<br>"; |
614 | } | 614 | } |
615 | if ( anniversary().isValid() ){ | 615 | if ( anniversary().isValid() ){ |
616 | str = TimeString::numberDateString( anniversary() ); | 616 | str = TimeString::numberDateString( anniversary() ); |
617 | text += "<b>" + QObject::tr("Anniversary: ") + "</b>" | 617 | text += "<b>" + QObject::tr("Anniversary: ") + "</b>" |
618 | + Qtopia::escapeString(str) + "<br>"; | 618 | + Qtopia::escapeString(str) + "<br>"; |
619 | } | 619 | } |
620 | str = children(); | 620 | str = children(); |
621 | if ( !str.isEmpty() ) | 621 | if ( !str.isEmpty() ) |
622 | text += "<b>" + QObject::tr("Children: ") + "</b>" | 622 | text += "<b>" + QObject::tr("Children: ") + "</b>" |
623 | + Qtopia::escapeString(str) + "<br>"; | 623 | + Qtopia::escapeString(str) + "<br>"; |
624 | 624 | ||
625 | str = nickname(); | 625 | str = nickname(); |
626 | if ( !str.isEmpty() ) | 626 | if ( !str.isEmpty() ) |
627 | text += "<b>" + QObject::tr("Nickname: ") + "</b>" | 627 | text += "<b>" + QObject::tr("Nickname: ") + "</b>" |
628 | + Qtopia::escapeString(str) + "<br>"; | 628 | + Qtopia::escapeString(str) + "<br>"; |
629 | 629 | ||
630 | if ( categoryNames().count() ){ | 630 | if ( categoryNames("Contacts").count() ){ |
631 | text += "<b>" + QObject::tr( "Category:") + "</b> "; | 631 | text += "<b>" + QObject::tr( "Category:") + "</b> "; |
632 | text += categoryNames().join(", "); | 632 | text += categoryNames("Contacts").join(", "); |
633 | text += "<br>"; | 633 | text += "<br>"; |
634 | } | 634 | } |
635 | 635 | ||
636 | // notes last | 636 | // notes last |
637 | if ( !(value = notes()).isEmpty() ) { | 637 | if ( !(value = notes()).isEmpty() ) { |
638 | text += "<br><hr><b>" + QObject::tr( "Notes:") + "</b> "; | 638 | text += "<br><hr><b>" + QObject::tr( "Notes:") + "</b> "; |
639 | QRegExp reg("\n"); | 639 | QRegExp reg("\n"); |
640 | 640 | ||
641 | //QString tmp = Qtopia::escapeString(value); | 641 | //QString tmp = Qtopia::escapeString(value); |
642 | QString tmp = QStyleSheet::convertFromPlainText(value); | 642 | QString tmp = QStyleSheet::convertFromPlainText(value); |
643 | //tmp.replace( reg, "<br>" ); | 643 | //tmp.replace( reg, "<br>" ); |
644 | text += "<br>" + tmp + "<br>"; | 644 | text += "<br>" + tmp + "<br>"; |
645 | } | 645 | } |
646 | return text; | 646 | return text; |
647 | } | 647 | } |
648 | 648 | ||
649 | /*! | 649 | /*! |
650 | \internal | 650 | \internal |
651 | */ | 651 | */ |
652 | void OContact::insert( int key, const QString &v ) | 652 | void OContact::insert( int key, const QString &v ) |
653 | { | 653 | { |
654 | QString value = v.stripWhiteSpace(); | 654 | QString value = v.stripWhiteSpace(); |
655 | if ( value.isEmpty() ) | 655 | if ( value.isEmpty() ) |
656 | mMap.remove( key ); | 656 | mMap.remove( key ); |
657 | else | 657 | else |
658 | mMap.insert( key, value ); | 658 | mMap.insert( key, value ); |
659 | } | 659 | } |
660 | 660 | ||
661 | /*! | 661 | /*! |
662 | \internal | 662 | \internal |
663 | */ | 663 | */ |
664 | void OContact::replace( int key, const QString & v ) | 664 | void OContact::replace( int key, const QString & v ) |
665 | { | 665 | { |
666 | QString value = v.stripWhiteSpace(); | 666 | QString value = v.stripWhiteSpace(); |
667 | if ( value.isEmpty() ) | 667 | if ( value.isEmpty() ) |
668 | mMap.remove( key ); | 668 | mMap.remove( key ); |
669 | else | 669 | else |
670 | mMap.replace( key, value ); | 670 | mMap.replace( key, value ); |
671 | } | 671 | } |
672 | 672 | ||
673 | /*! | 673 | /*! |
674 | \internal | 674 | \internal |
675 | */ | 675 | */ |
676 | QString OContact::find( int key ) const | 676 | QString OContact::find( int key ) const |
677 | { | 677 | { |
678 | return mMap[key]; | 678 | return mMap[key]; |
679 | } | 679 | } |
680 | 680 | ||
681 | /*! | 681 | /*! |
682 | \internal | 682 | \internal |
683 | */ | 683 | */ |
684 | QString OContact::displayAddress( const QString &street, | 684 | QString OContact::displayAddress( const QString &street, |
685 | const QString &city, | 685 | const QString &city, |
686 | const QString &state, | 686 | const QString &state, |
687 | const QString &zip, | 687 | const QString &zip, |
688 | const QString &country ) const | 688 | const QString &country ) const |
689 | { | 689 | { |
690 | QString s = street; | 690 | QString s = street; |
691 | if ( !street.isEmpty() ) | 691 | if ( !street.isEmpty() ) |
692 | s+= "\n"; | 692 | s+= "\n"; |
693 | s += city; | 693 | s += city; |
694 | if ( !city.isEmpty() && !state.isEmpty() ) | 694 | if ( !city.isEmpty() && !state.isEmpty() ) |
695 | s += ", "; | 695 | s += ", "; |
696 | s += state; | 696 | s += state; |
697 | if ( !state.isEmpty() && !zip.isEmpty() ) | 697 | if ( !state.isEmpty() && !zip.isEmpty() ) |
698 | s += " "; | 698 | s += " "; |
699 | s += zip; | 699 | s += zip; |
700 | if ( !country.isEmpty() && !s.isEmpty() ) | 700 | if ( !country.isEmpty() && !s.isEmpty() ) |
701 | s += "\n"; | 701 | s += "\n"; |
702 | s += country; | 702 | s += country; |
703 | return s; | 703 | return s; |
704 | } | 704 | } |
705 | 705 | ||
706 | /*! | 706 | /*! |
707 | \internal | 707 | \internal |
708 | */ | 708 | */ |
709 | QString OContact::displayBusinessAddress() const | 709 | QString OContact::displayBusinessAddress() const |
710 | { | 710 | { |
711 | return displayAddress( businessStreet(), businessCity(), | 711 | return displayAddress( businessStreet(), businessCity(), |
712 | businessState(), businessZip(), | 712 | businessState(), businessZip(), |
713 | businessCountry() ); | 713 | businessCountry() ); |
714 | } | 714 | } |
715 | 715 | ||
716 | /*! | 716 | /*! |
717 | \internal | 717 | \internal |
718 | */ | 718 | */ |
719 | QString OContact::displayHomeAddress() const | 719 | QString OContact::displayHomeAddress() const |
720 | { | 720 | { |
721 | return displayAddress( homeStreet(), homeCity(), | 721 | return displayAddress( homeStreet(), homeCity(), |
722 | homeState(), homeZip(), | 722 | homeState(), homeZip(), |
723 | homeCountry() ); | 723 | homeCountry() ); |
724 | } | 724 | } |
725 | 725 | ||
726 | /*! | 726 | /*! |
727 | Returns the full name of the contact | 727 | Returns the full name of the contact |
728 | */ | 728 | */ |
729 | QString OContact::fullName() const | 729 | QString OContact::fullName() const |
730 | { | 730 | { |
731 | QString title = find( Qtopia::Title ); | 731 | QString title = find( Qtopia::Title ); |
732 | QString firstName = find( Qtopia::FirstName ); | 732 | QString firstName = find( Qtopia::FirstName ); |
733 | QString middleName = find( Qtopia::MiddleName ); | 733 | QString middleName = find( Qtopia::MiddleName ); |
734 | QString lastName = find( Qtopia::LastName ); | 734 | QString lastName = find( Qtopia::LastName ); |
735 | QString suffix = find( Qtopia::Suffix ); | 735 | QString suffix = find( Qtopia::Suffix ); |
736 | 736 | ||
737 | QString name = title; | 737 | QString name = title; |
738 | if ( !firstName.isEmpty() ) { | 738 | if ( !firstName.isEmpty() ) { |
739 | if ( !name.isEmpty() ) | 739 | if ( !name.isEmpty() ) |
740 | name += " "; | 740 | name += " "; |
741 | name += firstName; | 741 | name += firstName; |
742 | } | 742 | } |
743 | if ( !middleName.isEmpty() ) { | 743 | if ( !middleName.isEmpty() ) { |
744 | if ( !name.isEmpty() ) | 744 | if ( !name.isEmpty() ) |
745 | name += " "; | 745 | name += " "; |
746 | name += middleName; | 746 | name += middleName; |
747 | } | 747 | } |
748 | if ( !lastName.isEmpty() ) { | 748 | if ( !lastName.isEmpty() ) { |
749 | if ( !name.isEmpty() ) | 749 | if ( !name.isEmpty() ) |
750 | name += " "; | 750 | name += " "; |
751 | name += lastName; | 751 | name += lastName; |
752 | } | 752 | } |
753 | if ( !suffix.isEmpty() ) { | 753 | if ( !suffix.isEmpty() ) { |
754 | if ( !name.isEmpty() ) | 754 | if ( !name.isEmpty() ) |
755 | name += " "; | 755 | name += " "; |
756 | name += suffix; | 756 | name += suffix; |
757 | } | 757 | } |
758 | return name.simplifyWhiteSpace(); | 758 | return name.simplifyWhiteSpace(); |
759 | } | 759 | } |
760 | 760 | ||
761 | /*! | 761 | /*! |
762 | Returns a list of the names of the children of the contact. | 762 | Returns a list of the names of the children of the contact. |
763 | */ | 763 | */ |
764 | QStringList OContact::childrenList() const | 764 | QStringList OContact::childrenList() const |
765 | { | 765 | { |
766 | return QStringList::split( " ", find( Qtopia::Children ) ); | 766 | return QStringList::split( " ", find( Qtopia::Children ) ); |
767 | } | 767 | } |
768 | 768 | ||
769 | /*! \fn void OContact::insertEmail( const QString &email ) | 769 | /*! \fn void OContact::insertEmail( const QString &email ) |
770 | 770 | ||
771 | Insert \a email into the email list. Ensures \a email can only be added | 771 | Insert \a email into the email list. Ensures \a email can only be added |
772 | once. If there is no default email address set, it sets it to the \a email. | 772 | once. If there is no default email address set, it sets it to the \a email. |
773 | */ | 773 | */ |
774 | 774 | ||
775 | /*! \fn void OContact::removeEmail( const QString &email ) | 775 | /*! \fn void OContact::removeEmail( const QString &email ) |
776 | 776 | ||
777 | Removes the \a email from the email list. If the default email was \a email, | 777 | Removes the \a email from the email list. If the default email was \a email, |
778 | then the default email address is assigned to the first email in the | 778 | then the default email address is assigned to the first email in the |
779 | email list | 779 | email list |
780 | */ | 780 | */ |
781 | 781 | ||
782 | /*! \fn void OContact::clearEmails() | 782 | /*! \fn void OContact::clearEmails() |
783 | 783 | ||
784 | Clears the email list. | 784 | Clears the email list. |
785 | */ | 785 | */ |
786 | 786 | ||
787 | /*! \fn void OContact::insertEmails( const QStringList &emailList ) | 787 | /*! \fn void OContact::insertEmails( const QStringList &emailList ) |
788 | 788 | ||
789 | Appends the \a emailList to the exiting email list | 789 | Appends the \a emailList to the exiting email list |
790 | */ | 790 | */ |
791 | 791 | ||
792 | /*! | 792 | /*! |
793 | Returns a list of email addresses belonging to the contact, including | 793 | Returns a list of email addresses belonging to the contact, including |
794 | the default email address. | 794 | the default email address. |
795 | */ | 795 | */ |
796 | QStringList OContact::emailList() const | 796 | QStringList OContact::emailList() const |
797 | { | 797 | { |
798 | QString emailStr = emails(); | 798 | QString emailStr = emails(); |
799 | 799 | ||
800 | QStringList r; | 800 | QStringList r; |
801 | if ( !emailStr.isEmpty() ) { | 801 | if ( !emailStr.isEmpty() ) { |
802 | qDebug(" emailstr "); | 802 | qDebug(" emailstr "); |
803 | QStringList l = QStringList::split( emailSeparator(), emailStr ); | 803 | QStringList l = QStringList::split( emailSeparator(), emailStr ); |
804 | for ( QStringList::ConstIterator it = l.begin();it != l.end();++it ) | 804 | for ( QStringList::ConstIterator it = l.begin();it != l.end();++it ) |
805 | r += (*it).simplifyWhiteSpace(); | 805 | r += (*it).simplifyWhiteSpace(); |
806 | } | 806 | } |
807 | 807 | ||
808 | return r; | 808 | return r; |
809 | } | 809 | } |
810 | 810 | ||
811 | /*! | 811 | /*! |
812 | \overload | 812 | \overload |
813 | 813 | ||
814 | Generates the string for the contact to be filed as from the first, | 814 | Generates the string for the contact to be filed as from the first, |
815 | middle and last name of the contact. | 815 | middle and last name of the contact. |
816 | */ | 816 | */ |
817 | void OContact::setFileAs() | 817 | void OContact::setFileAs() |
818 | { | 818 | { |
819 | QString lastName, firstName, middleName, fileas; | 819 | QString lastName, firstName, middleName, fileas; |
820 | 820 | ||
821 | lastName = find( Qtopia::LastName ); | 821 | lastName = find( Qtopia::LastName ); |
822 | firstName = find( Qtopia::FirstName ); | 822 | firstName = find( Qtopia::FirstName ); |
823 | middleName = find( Qtopia::MiddleName ); | 823 | middleName = find( Qtopia::MiddleName ); |
824 | if ( !lastName.isEmpty() && !firstName.isEmpty() | 824 | if ( !lastName.isEmpty() && !firstName.isEmpty() |
diff --git a/libopie/pim/opimrecord.cpp b/libopie/pim/opimrecord.cpp index ac0f4a9..d45417a 100644 --- a/libopie/pim/opimrecord.cpp +++ b/libopie/pim/opimrecord.cpp | |||
@@ -1,166 +1,166 @@ | |||
1 | #include <qarray.h> | 1 | #include <qarray.h> |
2 | 2 | ||
3 | #include <qpe/categories.h> | 3 | #include <qpe/categories.h> |
4 | #include <qpe/categoryselect.h> | 4 | #include <qpe/categoryselect.h> |
5 | 5 | ||
6 | #include "opimrecord.h" | 6 | #include "opimrecord.h" |
7 | 7 | ||
8 | Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia ); | 8 | Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia ); |
9 | 9 | ||
10 | 10 | ||
11 | OPimRecord::OPimRecord( int uid ) | 11 | OPimRecord::OPimRecord( int uid ) |
12 | : Qtopia::Record() { | 12 | : Qtopia::Record() { |
13 | 13 | ||
14 | setUid( uid ); | 14 | setUid( uid ); |
15 | } | 15 | } |
16 | OPimRecord::~OPimRecord() { | 16 | OPimRecord::~OPimRecord() { |
17 | } | 17 | } |
18 | OPimRecord::OPimRecord( const OPimRecord& rec ) | 18 | OPimRecord::OPimRecord( const OPimRecord& rec ) |
19 | : Qtopia::Record( rec ) | 19 | : Qtopia::Record( rec ) |
20 | { | 20 | { |
21 | (*this) = rec; | 21 | (*this) = rec; |
22 | } | 22 | } |
23 | 23 | ||
24 | OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { | 24 | OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { |
25 | Qtopia::Record::operator=( rec ); | 25 | Qtopia::Record::operator=( rec ); |
26 | m_xrefman = rec.m_xrefman; | 26 | m_xrefman = rec.m_xrefman; |
27 | 27 | ||
28 | return *this; | 28 | return *this; |
29 | } | 29 | } |
30 | /* | 30 | /* |
31 | * category names | 31 | * category names |
32 | */ | 32 | */ |
33 | QStringList OPimRecord::categoryNames()const { | 33 | QStringList OPimRecord::categoryNames( const QString& appname ) const { |
34 | QStringList list; | 34 | QStringList list; |
35 | QArray<int> cats = categories(); | 35 | QArray<int> cats = categories(); |
36 | Categories catDB; | 36 | Categories catDB; |
37 | catDB.load( categoryFileName() ); | 37 | catDB.load( categoryFileName() ); |
38 | 38 | ||
39 | for (uint i = 0; i < cats.count(); i++ ) { | 39 | for (uint i = 0; i < cats.count(); i++ ) { |
40 | list << catDB.label("Todo List", cats[i] ); | 40 | list << catDB.label( appname, cats[i] ); |
41 | } | 41 | } |
42 | 42 | ||
43 | return list; | 43 | return list; |
44 | } | 44 | } |
45 | void OPimRecord::setCategoryNames( const QStringList& ) { | 45 | void OPimRecord::setCategoryNames( const QStringList& ) { |
46 | 46 | ||
47 | } | 47 | } |
48 | void OPimRecord::addCategoryName( const QString& ) { | 48 | void OPimRecord::addCategoryName( const QString& ) { |
49 | Categories catDB; | 49 | Categories catDB; |
50 | catDB.load( categoryFileName() ); | 50 | catDB.load( categoryFileName() ); |
51 | 51 | ||
52 | 52 | ||
53 | } | 53 | } |
54 | bool OPimRecord::isEmpty()const { | 54 | bool OPimRecord::isEmpty()const { |
55 | return ( uid() == 0 ); | 55 | return ( uid() == 0 ); |
56 | } | 56 | } |
57 | /*QString OPimRecord::crossToString()const { | 57 | /*QString OPimRecord::crossToString()const { |
58 | QString str; | 58 | QString str; |
59 | QMap<QString, QArray<int> >::ConstIterator it; | 59 | QMap<QString, QArray<int> >::ConstIterator it; |
60 | for (it = m_relations.begin(); it != m_relations.end(); ++it ) { | 60 | for (it = m_relations.begin(); it != m_relations.end(); ++it ) { |
61 | QArray<int> id = it.data(); | 61 | QArray<int> id = it.data(); |
62 | for ( uint i = 0; i < id.size(); ++i ) { | 62 | for ( uint i = 0; i < id.size(); ++i ) { |
63 | str += it.key() + "," + QString::number( i ) + ";"; | 63 | str += it.key() + "," + QString::number( i ) + ";"; |
64 | } | 64 | } |
65 | } | 65 | } |
66 | str = str.remove( str.length()-1, 1); // strip the ; | 66 | str = str.remove( str.length()-1, 1); // strip the ; |
67 | //qWarning("IDS " + str ); | 67 | //qWarning("IDS " + str ); |
68 | 68 | ||
69 | return str; | 69 | return str; |
70 | }*/ | 70 | }*/ |
71 | /* if uid = 1 assign a new one */ | 71 | /* if uid = 1 assign a new one */ |
72 | void OPimRecord::setUid( int uid ) { | 72 | void OPimRecord::setUid( int uid ) { |
73 | if ( uid == 1) | 73 | if ( uid == 1) |
74 | uid = uidGen().generate(); | 74 | uid = uidGen().generate(); |
75 | 75 | ||
76 | Qtopia::Record::setUid( uid ); | 76 | Qtopia::Record::setUid( uid ); |
77 | }; | 77 | }; |
78 | Qtopia::UidGen &OPimRecord::uidGen() { | 78 | Qtopia::UidGen &OPimRecord::uidGen() { |
79 | return m_uidGen; | 79 | return m_uidGen; |
80 | } | 80 | } |
81 | OPimXRefManager &OPimRecord::xrefmanager() { | 81 | OPimXRefManager &OPimRecord::xrefmanager() { |
82 | return m_xrefman; | 82 | return m_xrefman; |
83 | } | 83 | } |
84 | int OPimRecord::rtti(){ | 84 | int OPimRecord::rtti(){ |
85 | return 0; | 85 | return 0; |
86 | } | 86 | } |
87 | 87 | ||
88 | /** | 88 | /** |
89 | * now let's put our data into the stream | 89 | * now let's put our data into the stream |
90 | */ | 90 | */ |
91 | /* | 91 | /* |
92 | * First read UID | 92 | * First read UID |
93 | * Categories | 93 | * Categories |
94 | * XRef | 94 | * XRef |
95 | */ | 95 | */ |
96 | bool OPimRecord::loadFromStream( QDataStream& stream ) { | 96 | bool OPimRecord::loadFromStream( QDataStream& stream ) { |
97 | int Int; | 97 | int Int; |
98 | uint UInt; | 98 | uint UInt; |
99 | stream >> Int; | 99 | stream >> Int; |
100 | setUid(Int); | 100 | setUid(Int); |
101 | 101 | ||
102 | /** Categories */ | 102 | /** Categories */ |
103 | stream >> UInt; | 103 | stream >> UInt; |
104 | QArray<int> array(UInt); | 104 | QArray<int> array(UInt); |
105 | for (uint i = 0; i < UInt; i++ ) { | 105 | for (uint i = 0; i < UInt; i++ ) { |
106 | stream >> array[i]; | 106 | stream >> array[i]; |
107 | } | 107 | } |
108 | setCategories( array ); | 108 | setCategories( array ); |
109 | 109 | ||
110 | /* | 110 | /* |
111 | * now we do the X-Ref stuff | 111 | * now we do the X-Ref stuff |
112 | */ | 112 | */ |
113 | OPimXRef xref; | 113 | OPimXRef xref; |
114 | stream >> UInt; | 114 | stream >> UInt; |
115 | for ( uint i = 0; i < UInt; i++ ) { | 115 | for ( uint i = 0; i < UInt; i++ ) { |
116 | xref.setPartner( OPimXRef::One, partner( stream ) ); | 116 | xref.setPartner( OPimXRef::One, partner( stream ) ); |
117 | xref.setPartner( OPimXRef::Two, partner( stream ) ); | 117 | xref.setPartner( OPimXRef::Two, partner( stream ) ); |
118 | m_xrefman.add( xref ); | 118 | m_xrefman.add( xref ); |
119 | } | 119 | } |
120 | 120 | ||
121 | return true; | 121 | return true; |
122 | } | 122 | } |
123 | bool OPimRecord::saveToStream( QDataStream& stream )const { | 123 | bool OPimRecord::saveToStream( QDataStream& stream )const { |
124 | /** UIDs */ | 124 | /** UIDs */ |
125 | 125 | ||
126 | stream << uid(); | 126 | stream << uid(); |
127 | 127 | ||
128 | /** Categories */ | 128 | /** Categories */ |
129 | stream << categories().count(); | 129 | stream << categories().count(); |
130 | for ( uint i = 0; i < categories().count(); i++ ) { | 130 | for ( uint i = 0; i < categories().count(); i++ ) { |
131 | stream << categories()[i]; | 131 | stream << categories()[i]; |
132 | } | 132 | } |
133 | 133 | ||
134 | /* | 134 | /* |
135 | * first the XRef count | 135 | * first the XRef count |
136 | * then the xrefs | 136 | * then the xrefs |
137 | */ | 137 | */ |
138 | stream << m_xrefman.list().count(); | 138 | stream << m_xrefman.list().count(); |
139 | for ( OPimXRef::ValueList::ConstIterator it = m_xrefman.list().begin(); | 139 | for ( OPimXRef::ValueList::ConstIterator it = m_xrefman.list().begin(); |
140 | it != m_xrefman.list().end(); ++it ) { | 140 | it != m_xrefman.list().end(); ++it ) { |
141 | flush( (*it).partner( OPimXRef::One), stream ); | 141 | flush( (*it).partner( OPimXRef::One), stream ); |
142 | flush( (*it).partner( OPimXRef::Two), stream ); | 142 | flush( (*it).partner( OPimXRef::Two), stream ); |
143 | } | 143 | } |
144 | return true; | 144 | return true; |
145 | } | 145 | } |
146 | void OPimRecord::flush( const OPimXRefPartner& par, QDataStream& str ) const{ | 146 | void OPimRecord::flush( const OPimXRefPartner& par, QDataStream& str ) const{ |
147 | str << par.service(); | 147 | str << par.service(); |
148 | str << par.uid(); | 148 | str << par.uid(); |
149 | str << par.field(); | 149 | str << par.field(); |
150 | } | 150 | } |
151 | OPimXRefPartner OPimRecord::partner( QDataStream& stream ) { | 151 | OPimXRefPartner OPimRecord::partner( QDataStream& stream ) { |
152 | OPimXRefPartner par; | 152 | OPimXRefPartner par; |
153 | QString str; | 153 | QString str; |
154 | int i; | 154 | int i; |
155 | 155 | ||
156 | stream >> str; | 156 | stream >> str; |
157 | par.setService( str ); | 157 | par.setService( str ); |
158 | 158 | ||
159 | stream >> i; | 159 | stream >> i; |
160 | par.setUid( i ); | 160 | par.setUid( i ); |
161 | 161 | ||
162 | stream >> i ; | 162 | stream >> i ; |
163 | par.setField( i ); | 163 | par.setField( i ); |
164 | 164 | ||
165 | return par; | 165 | return par; |
166 | } | 166 | } |
diff --git a/libopie/pim/opimrecord.h b/libopie/pim/opimrecord.h index 665530f..c7f9460 100644 --- a/libopie/pim/opimrecord.h +++ b/libopie/pim/opimrecord.h | |||
@@ -1,134 +1,134 @@ | |||
1 | #ifndef OPIE_PIM_RECORD_H | 1 | #ifndef OPIE_PIM_RECORD_H |
2 | #define OPIE_PIM_RECORD_H | 2 | #define OPIE_PIM_RECORD_H |
3 | 3 | ||
4 | #include <qdatastream.h> | 4 | #include <qdatastream.h> |
5 | #include <qmap.h> | 5 | #include <qmap.h> |
6 | #include <qstring.h> | 6 | #include <qstring.h> |
7 | #include <qstringlist.h> | 7 | #include <qstringlist.h> |
8 | 8 | ||
9 | #include <qpe/palmtoprecord.h> | 9 | #include <qpe/palmtoprecord.h> |
10 | 10 | ||
11 | #include <opie/opimxrefmanager.h> | 11 | #include <opie/opimxrefmanager.h> |
12 | 12 | ||
13 | /** | 13 | /** |
14 | * This is the base class for | 14 | * This is the base class for |
15 | * all PIM Records | 15 | * all PIM Records |
16 | * | 16 | * |
17 | */ | 17 | */ |
18 | class OPimRecord : public Qtopia::Record { | 18 | class OPimRecord : public Qtopia::Record { |
19 | public: | 19 | public: |
20 | /** | 20 | /** |
21 | * c'tor | 21 | * c'tor |
22 | * uid of 0 isEmpty | 22 | * uid of 0 isEmpty |
23 | * uid of 1 will be assigned a new one | 23 | * uid of 1 will be assigned a new one |
24 | */ | 24 | */ |
25 | OPimRecord(int uid = 0); | 25 | OPimRecord(int uid = 0); |
26 | ~OPimRecord(); | 26 | ~OPimRecord(); |
27 | 27 | ||
28 | /** | 28 | /** |
29 | * copy c'tor | 29 | * copy c'tor |
30 | */ | 30 | */ |
31 | OPimRecord( const OPimRecord& rec ); | 31 | OPimRecord( const OPimRecord& rec ); |
32 | 32 | ||
33 | /** | 33 | /** |
34 | * copy operator | 34 | * copy operator |
35 | */ | 35 | */ |
36 | OPimRecord &operator=( const OPimRecord& ); | 36 | OPimRecord &operator=( const OPimRecord& ); |
37 | 37 | ||
38 | /** | 38 | /** |
39 | * category names resolved | 39 | * category names resolved |
40 | */ | 40 | */ |
41 | QStringList categoryNames()const; | 41 | QStringList categoryNames( const QString& appname )const; |
42 | 42 | ||
43 | /** | 43 | /** |
44 | * set category names they will be resolved | 44 | * set category names they will be resolved |
45 | */ | 45 | */ |
46 | void setCategoryNames( const QStringList& ); | 46 | void setCategoryNames( const QStringList& ); |
47 | 47 | ||
48 | /** | 48 | /** |
49 | * addCategoryName adds a name | 49 | * addCategoryName adds a name |
50 | * to the internal category list | 50 | * to the internal category list |
51 | */ | 51 | */ |
52 | void addCategoryName( const QString& ); | 52 | void addCategoryName( const QString& ); |
53 | 53 | ||
54 | /** | 54 | /** |
55 | * if a Record isEmpty | 55 | * if a Record isEmpty |
56 | * it's empty if it's 0 | 56 | * it's empty if it's 0 |
57 | */ | 57 | */ |
58 | virtual bool isEmpty()const; | 58 | virtual bool isEmpty()const; |
59 | 59 | ||
60 | /** | 60 | /** |
61 | * toRichText summary | 61 | * toRichText summary |
62 | */ | 62 | */ |
63 | virtual QString toRichText()const = 0; | 63 | virtual QString toRichText()const = 0; |
64 | 64 | ||
65 | /** | 65 | /** |
66 | * a small one line summary | 66 | * a small one line summary |
67 | */ | 67 | */ |
68 | virtual QString toShortText()const = 0; | 68 | virtual QString toShortText()const = 0; |
69 | 69 | ||
70 | /** | 70 | /** |
71 | * the name of the Record | 71 | * the name of the Record |
72 | */ | 72 | */ |
73 | virtual QString type()const = 0; | 73 | virtual QString type()const = 0; |
74 | 74 | ||
75 | /** | 75 | /** |
76 | * converts the internal structure to a map | 76 | * converts the internal structure to a map |
77 | */ | 77 | */ |
78 | virtual QMap<int, QString> toMap()const = 0; | 78 | virtual QMap<int, QString> toMap()const = 0; |
79 | 79 | ||
80 | /** | 80 | /** |
81 | * key value representation of extra items | 81 | * key value representation of extra items |
82 | */ | 82 | */ |
83 | virtual QMap<QString, QString> toExtraMap()const = 0; | 83 | virtual QMap<QString, QString> toExtraMap()const = 0; |
84 | 84 | ||
85 | /** | 85 | /** |
86 | * the name for a recordField | 86 | * the name for a recordField |
87 | */ | 87 | */ |
88 | virtual QString recordField(int)const = 0; | 88 | virtual QString recordField(int)const = 0; |
89 | 89 | ||
90 | /** | 90 | /** |
91 | * returns a reference of the | 91 | * returns a reference of the |
92 | * Cross Reference Manager | 92 | * Cross Reference Manager |
93 | * Partner 'One' is THIS PIM RECORD! | 93 | * Partner 'One' is THIS PIM RECORD! |
94 | * 'Two' is the Partner where we link to | 94 | * 'Two' is the Partner where we link to |
95 | */ | 95 | */ |
96 | OPimXRefManager& xrefmanager(); | 96 | OPimXRefManager& xrefmanager(); |
97 | 97 | ||
98 | /** | 98 | /** |
99 | * set the uid | 99 | * set the uid |
100 | */ | 100 | */ |
101 | virtual void setUid( int uid ); | 101 | virtual void setUid( int uid ); |
102 | 102 | ||
103 | /* | 103 | /* |
104 | * used inside the Templates for casting | 104 | * used inside the Templates for casting |
105 | * REIMPLEMENT in your .... | 105 | * REIMPLEMENT in your .... |
106 | */ | 106 | */ |
107 | static int rtti(); | 107 | static int rtti(); |
108 | 108 | ||
109 | /** | 109 | /** |
110 | * some marshalling and de marshalling code | 110 | * some marshalling and de marshalling code |
111 | * saves the OPimRecord | 111 | * saves the OPimRecord |
112 | * to and from a DataStream | 112 | * to and from a DataStream |
113 | */ | 113 | */ |
114 | virtual bool loadFromStream(QDataStream& ); | 114 | virtual bool loadFromStream(QDataStream& ); |
115 | virtual bool saveToStream( QDataStream& stream )const; | 115 | virtual bool saveToStream( QDataStream& stream )const; |
116 | 116 | ||
117 | protected: | 117 | protected: |
118 | Qtopia::UidGen &uidGen(); | 118 | Qtopia::UidGen &uidGen(); |
119 | // QString crossToString()const; | 119 | // QString crossToString()const; |
120 | 120 | ||
121 | private: | 121 | private: |
122 | class OPimRecordPrivate; | 122 | class OPimRecordPrivate; |
123 | OPimRecordPrivate *d; | 123 | OPimRecordPrivate *d; |
124 | OPimXRefManager m_xrefman; | 124 | OPimXRefManager m_xrefman; |
125 | static Qtopia::UidGen m_uidGen; | 125 | static Qtopia::UidGen m_uidGen; |
126 | 126 | ||
127 | private: | 127 | private: |
128 | void flush( const OPimXRefPartner&, QDataStream& stream )const; | 128 | void flush( const OPimXRefPartner&, QDataStream& stream )const; |
129 | OPimXRefPartner partner( QDataStream& ); | 129 | OPimXRefPartner partner( QDataStream& ); |
130 | }; | 130 | }; |
131 | 131 | ||
132 | 132 | ||
133 | 133 | ||
134 | #endif | 134 | #endif |
diff --git a/libopie/pim/otodo.cpp b/libopie/pim/otodo.cpp index cde2b3d..b4d4aa9 100644 --- a/libopie/pim/otodo.cpp +++ b/libopie/pim/otodo.cpp | |||
@@ -66,357 +66,357 @@ OTodo::OTodo(bool completed, int priority, | |||
66 | { | 66 | { |
67 | // qWarning("OTodoData " + summary); | 67 | // qWarning("OTodoData " + summary); |
68 | setCategories( category ); | 68 | setCategories( category ); |
69 | 69 | ||
70 | data = new OTodoData; | 70 | data = new OTodoData; |
71 | 71 | ||
72 | data->date = date; | 72 | data->date = date; |
73 | data->isCompleted = completed; | 73 | data->isCompleted = completed; |
74 | data->hasDate = hasDate; | 74 | data->hasDate = hasDate; |
75 | data->priority = priority; | 75 | data->priority = priority; |
76 | data->sum = summary; | 76 | data->sum = summary; |
77 | data->prog = progress; | 77 | data->prog = progress; |
78 | data->desc = Qtopia::simplifyMultiLineSpace(description ); | 78 | data->desc = Qtopia::simplifyMultiLineSpace(description ); |
79 | } | 79 | } |
80 | OTodo::OTodo(bool completed, int priority, | 80 | OTodo::OTodo(bool completed, int priority, |
81 | const QStringList &category, | 81 | const QStringList &category, |
82 | const QString& summary, | 82 | const QString& summary, |
83 | const QString &description, | 83 | const QString &description, |
84 | ushort progress, | 84 | ushort progress, |
85 | bool hasDate, QDate date, int uid ) | 85 | bool hasDate, QDate date, int uid ) |
86 | : OPimRecord( uid ) | 86 | : OPimRecord( uid ) |
87 | { | 87 | { |
88 | // qWarning("OTodoData" + summary); | 88 | // qWarning("OTodoData" + summary); |
89 | setCategories( idsFromString( category.join(";") ) ); | 89 | setCategories( idsFromString( category.join(";") ) ); |
90 | 90 | ||
91 | data = new OTodoData; | 91 | data = new OTodoData; |
92 | 92 | ||
93 | data->date = date; | 93 | data->date = date; |
94 | data->isCompleted = completed; | 94 | data->isCompleted = completed; |
95 | data->hasDate = hasDate; | 95 | data->hasDate = hasDate; |
96 | data->priority = priority; | 96 | data->priority = priority; |
97 | data->sum = summary; | 97 | data->sum = summary; |
98 | data->prog = progress; | 98 | data->prog = progress; |
99 | data->desc = Qtopia::simplifyMultiLineSpace(description ); | 99 | data->desc = Qtopia::simplifyMultiLineSpace(description ); |
100 | } | 100 | } |
101 | bool OTodo::match( const QRegExp ®Exp )const | 101 | bool OTodo::match( const QRegExp ®Exp )const |
102 | { | 102 | { |
103 | if( QString::number( data->priority ).find( regExp ) != -1 ){ | 103 | if( QString::number( data->priority ).find( regExp ) != -1 ){ |
104 | return true; | 104 | return true; |
105 | }else if( data->hasDate && data->date.toString().find( regExp) != -1 ){ | 105 | }else if( data->hasDate && data->date.toString().find( regExp) != -1 ){ |
106 | return true; | 106 | return true; |
107 | }else if(data->desc.find( regExp ) != -1 ){ | 107 | }else if(data->desc.find( regExp ) != -1 ){ |
108 | return true; | 108 | return true; |
109 | }else if(data->sum.find( regExp ) != -1 ) { | 109 | }else if(data->sum.find( regExp ) != -1 ) { |
110 | return true; | 110 | return true; |
111 | } | 111 | } |
112 | return false; | 112 | return false; |
113 | } | 113 | } |
114 | bool OTodo::isCompleted() const | 114 | bool OTodo::isCompleted() const |
115 | { | 115 | { |
116 | return data->isCompleted; | 116 | return data->isCompleted; |
117 | } | 117 | } |
118 | bool OTodo::hasDueDate() const | 118 | bool OTodo::hasDueDate() const |
119 | { | 119 | { |
120 | return data->hasDate; | 120 | return data->hasDate; |
121 | } | 121 | } |
122 | bool OTodo::hasStartDate()const { | 122 | bool OTodo::hasStartDate()const { |
123 | return data->start.isValid(); | 123 | return data->start.isValid(); |
124 | } | 124 | } |
125 | bool OTodo::hasCompletedDate()const { | 125 | bool OTodo::hasCompletedDate()const { |
126 | return data->completed.isValid(); | 126 | return data->completed.isValid(); |
127 | } | 127 | } |
128 | int OTodo::priority()const | 128 | int OTodo::priority()const |
129 | { | 129 | { |
130 | return data->priority; | 130 | return data->priority; |
131 | } | 131 | } |
132 | QString OTodo::summary() const | 132 | QString OTodo::summary() const |
133 | { | 133 | { |
134 | return data->sum; | 134 | return data->sum; |
135 | } | 135 | } |
136 | ushort OTodo::progress() const | 136 | ushort OTodo::progress() const |
137 | { | 137 | { |
138 | return data->prog; | 138 | return data->prog; |
139 | } | 139 | } |
140 | QDate OTodo::dueDate()const | 140 | QDate OTodo::dueDate()const |
141 | { | 141 | { |
142 | return data->date; | 142 | return data->date; |
143 | } | 143 | } |
144 | QDate OTodo::startDate()const { | 144 | QDate OTodo::startDate()const { |
145 | return data->start; | 145 | return data->start; |
146 | } | 146 | } |
147 | QDate OTodo::completedDate()const { | 147 | QDate OTodo::completedDate()const { |
148 | return data->completed; | 148 | return data->completed; |
149 | } | 149 | } |
150 | QString OTodo::description()const | 150 | QString OTodo::description()const |
151 | { | 151 | { |
152 | return data->desc; | 152 | return data->desc; |
153 | } | 153 | } |
154 | OPimState OTodo::state()const { | 154 | OPimState OTodo::state()const { |
155 | return data->state; | 155 | return data->state; |
156 | } | 156 | } |
157 | ORecur OTodo::recurrence()const { | 157 | ORecur OTodo::recurrence()const { |
158 | return data->recur; | 158 | return data->recur; |
159 | } | 159 | } |
160 | OPimMaintainer OTodo::maintainer()const { | 160 | OPimMaintainer OTodo::maintainer()const { |
161 | return data->maintainer; | 161 | return data->maintainer; |
162 | } | 162 | } |
163 | void OTodo::setCompleted( bool completed ) | 163 | void OTodo::setCompleted( bool completed ) |
164 | { | 164 | { |
165 | changeOrModify(); | 165 | changeOrModify(); |
166 | data->isCompleted = completed; | 166 | data->isCompleted = completed; |
167 | } | 167 | } |
168 | void OTodo::setHasDueDate( bool hasDate ) | 168 | void OTodo::setHasDueDate( bool hasDate ) |
169 | { | 169 | { |
170 | changeOrModify(); | 170 | changeOrModify(); |
171 | data->hasDate = hasDate; | 171 | data->hasDate = hasDate; |
172 | } | 172 | } |
173 | void OTodo::setDescription(const QString &desc ) | 173 | void OTodo::setDescription(const QString &desc ) |
174 | { | 174 | { |
175 | // qWarning( "desc " + desc ); | 175 | // qWarning( "desc " + desc ); |
176 | changeOrModify(); | 176 | changeOrModify(); |
177 | data->desc = Qtopia::simplifyMultiLineSpace(desc ); | 177 | data->desc = Qtopia::simplifyMultiLineSpace(desc ); |
178 | } | 178 | } |
179 | void OTodo::setSummary( const QString& sum ) | 179 | void OTodo::setSummary( const QString& sum ) |
180 | { | 180 | { |
181 | changeOrModify(); | 181 | changeOrModify(); |
182 | data->sum = sum; | 182 | data->sum = sum; |
183 | } | 183 | } |
184 | void OTodo::setPriority(int prio ) | 184 | void OTodo::setPriority(int prio ) |
185 | { | 185 | { |
186 | changeOrModify(); | 186 | changeOrModify(); |
187 | data->priority = prio; | 187 | data->priority = prio; |
188 | } | 188 | } |
189 | void OTodo::setDueDate( const QDate& date ) | 189 | void OTodo::setDueDate( const QDate& date ) |
190 | { | 190 | { |
191 | changeOrModify(); | 191 | changeOrModify(); |
192 | data->date = date; | 192 | data->date = date; |
193 | } | 193 | } |
194 | void OTodo::setStartDate( const QDate& date ) { | 194 | void OTodo::setStartDate( const QDate& date ) { |
195 | changeOrModify(); | 195 | changeOrModify(); |
196 | data->start = date; | 196 | data->start = date; |
197 | } | 197 | } |
198 | void OTodo::setCompletedDate( const QDate& date ) { | 198 | void OTodo::setCompletedDate( const QDate& date ) { |
199 | changeOrModify(); | 199 | changeOrModify(); |
200 | data->completed = date; | 200 | data->completed = date; |
201 | } | 201 | } |
202 | void OTodo::setState( const OPimState& state ) { | 202 | void OTodo::setState( const OPimState& state ) { |
203 | changeOrModify(); | 203 | changeOrModify(); |
204 | data->state = state; | 204 | data->state = state; |
205 | } | 205 | } |
206 | void OTodo::setRecurrence( const ORecur& rec) { | 206 | void OTodo::setRecurrence( const ORecur& rec) { |
207 | changeOrModify(); | 207 | changeOrModify(); |
208 | data->recur = rec; | 208 | data->recur = rec; |
209 | } | 209 | } |
210 | void OTodo::setMaintainer( const OPimMaintainer& pim ) { | 210 | void OTodo::setMaintainer( const OPimMaintainer& pim ) { |
211 | changeOrModify(); | 211 | changeOrModify(); |
212 | data->maintainer = pim; | 212 | data->maintainer = pim; |
213 | } | 213 | } |
214 | bool OTodo::isOverdue( ) | 214 | bool OTodo::isOverdue( ) |
215 | { | 215 | { |
216 | if( data->hasDate && !data->isCompleted) | 216 | if( data->hasDate && !data->isCompleted) |
217 | return QDate::currentDate() > data->date; | 217 | return QDate::currentDate() > data->date; |
218 | return false; | 218 | return false; |
219 | } | 219 | } |
220 | void OTodo::setProgress(ushort progress ) | 220 | void OTodo::setProgress(ushort progress ) |
221 | { | 221 | { |
222 | changeOrModify(); | 222 | changeOrModify(); |
223 | data->prog = progress; | 223 | data->prog = progress; |
224 | } | 224 | } |
225 | QString OTodo::toShortText() const { | 225 | QString OTodo::toShortText() const { |
226 | return summary(); | 226 | return summary(); |
227 | } | 227 | } |
228 | /*! | 228 | /*! |
229 | Returns a richt text string | 229 | Returns a richt text string |
230 | */ | 230 | */ |
231 | QString OTodo::toRichText() const | 231 | QString OTodo::toRichText() const |
232 | { | 232 | { |
233 | QString text; | 233 | QString text; |
234 | QStringList catlist; | 234 | QStringList catlist; |
235 | 235 | ||
236 | // Description of the todo | 236 | // Description of the todo |
237 | if ( !summary().isEmpty() ) { | 237 | if ( !summary().isEmpty() ) { |
238 | text += "<b>" + QObject::tr( "Summary:") + "</b><br>"; | 238 | text += "<b>" + QObject::tr( "Summary:") + "</b><br>"; |
239 | text += Qtopia::escapeString(summary() ).replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; | 239 | text += Qtopia::escapeString(summary() ).replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; |
240 | } | 240 | } |
241 | if( !description().isEmpty() ){ | 241 | if( !description().isEmpty() ){ |
242 | text += "<b>" + QObject::tr( "Description:" ) + "</b><br>"; | 242 | text += "<b>" + QObject::tr( "Description:" ) + "</b><br>"; |
243 | text += Qtopia::escapeString(description() ).replace(QRegExp( "[\n]"), "<br>" ) ; | 243 | text += Qtopia::escapeString(description() ).replace(QRegExp( "[\n]"), "<br>" ) ; |
244 | } | 244 | } |
245 | text += "<br><br><br>"; | 245 | text += "<br><br><br>"; |
246 | 246 | ||
247 | text += "<b>" + QObject::tr( "Priority:") +" </b>" | 247 | text += "<b>" + QObject::tr( "Priority:") +" </b>" |
248 | + QString::number( priority() ) + " <br>"; | 248 | + QString::number( priority() ) + " <br>"; |
249 | text += "<b>" + QObject::tr( "Progress:") + " </b>" | 249 | text += "<b>" + QObject::tr( "Progress:") + " </b>" |
250 | + QString::number( progress() ) + " %<br>"; | 250 | + QString::number( progress() ) + " %<br>"; |
251 | if (hasDueDate() ){ | 251 | if (hasDueDate() ){ |
252 | text += "<b>" + QObject::tr( "Deadline:") + " </b>"; | 252 | text += "<b>" + QObject::tr( "Deadline:") + " </b>"; |
253 | text += dueDate().toString(); | 253 | text += dueDate().toString(); |
254 | text += "<br>"; | 254 | text += "<br>"; |
255 | } | 255 | } |
256 | 256 | ||
257 | text += "<b>" + QObject::tr( "Category:") + "</b> "; | 257 | text += "<b>" + QObject::tr( "Category:") + "</b> "; |
258 | text += categoryNames().join(", "); | 258 | text += categoryNames( "Todo List" ).join(", "); |
259 | text += "<br>"; | 259 | text += "<br>"; |
260 | 260 | ||
261 | return text; | 261 | return text; |
262 | } | 262 | } |
263 | OPimNotifyManager& OTodo::notifiers() { | 263 | OPimNotifyManager& OTodo::notifiers() { |
264 | return data->notifiers; | 264 | return data->notifiers; |
265 | } | 265 | } |
266 | 266 | ||
267 | bool OTodo::operator<( const OTodo &toDoEvent )const{ | 267 | bool OTodo::operator<( const OTodo &toDoEvent )const{ |
268 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; | 268 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; |
269 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; | 269 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; |
270 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 270 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
271 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 271 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
272 | return priority() < toDoEvent.priority(); | 272 | return priority() < toDoEvent.priority(); |
273 | }else{ | 273 | }else{ |
274 | return dueDate() < toDoEvent.dueDate(); | 274 | return dueDate() < toDoEvent.dueDate(); |
275 | } | 275 | } |
276 | } | 276 | } |
277 | return false; | 277 | return false; |
278 | } | 278 | } |
279 | bool OTodo::operator<=(const OTodo &toDoEvent )const | 279 | bool OTodo::operator<=(const OTodo &toDoEvent )const |
280 | { | 280 | { |
281 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; | 281 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; |
282 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return true; | 282 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return true; |
283 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 283 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
284 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 284 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
285 | return priority() <= toDoEvent.priority(); | 285 | return priority() <= toDoEvent.priority(); |
286 | }else{ | 286 | }else{ |
287 | return dueDate() <= toDoEvent.dueDate(); | 287 | return dueDate() <= toDoEvent.dueDate(); |
288 | } | 288 | } |
289 | } | 289 | } |
290 | return true; | 290 | return true; |
291 | } | 291 | } |
292 | bool OTodo::operator>(const OTodo &toDoEvent )const | 292 | bool OTodo::operator>(const OTodo &toDoEvent )const |
293 | { | 293 | { |
294 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return false; | 294 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return false; |
295 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; | 295 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; |
296 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 296 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
297 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 297 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
298 | return priority() > toDoEvent.priority(); | 298 | return priority() > toDoEvent.priority(); |
299 | }else{ | 299 | }else{ |
300 | return dueDate() > toDoEvent.dueDate(); | 300 | return dueDate() > toDoEvent.dueDate(); |
301 | } | 301 | } |
302 | } | 302 | } |
303 | return false; | 303 | return false; |
304 | } | 304 | } |
305 | bool OTodo::operator>=(const OTodo &toDoEvent )const | 305 | bool OTodo::operator>=(const OTodo &toDoEvent )const |
306 | { | 306 | { |
307 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; | 307 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; |
308 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; | 308 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; |
309 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 309 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
310 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 310 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
311 | return priority() > toDoEvent.priority(); | 311 | return priority() > toDoEvent.priority(); |
312 | }else{ | 312 | }else{ |
313 | return dueDate() > toDoEvent.dueDate(); | 313 | return dueDate() > toDoEvent.dueDate(); |
314 | } | 314 | } |
315 | } | 315 | } |
316 | return true; | 316 | return true; |
317 | } | 317 | } |
318 | bool OTodo::operator==(const OTodo &toDoEvent )const | 318 | bool OTodo::operator==(const OTodo &toDoEvent )const |
319 | { | 319 | { |
320 | if ( data->priority != toDoEvent.data->priority ) return false; | 320 | if ( data->priority != toDoEvent.data->priority ) return false; |
321 | if ( data->priority != toDoEvent.data->prog ) return false; | 321 | if ( data->priority != toDoEvent.data->prog ) return false; |
322 | if ( data->isCompleted != toDoEvent.data->isCompleted ) return false; | 322 | if ( data->isCompleted != toDoEvent.data->isCompleted ) return false; |
323 | if ( data->hasDate != toDoEvent.data->hasDate ) return false; | 323 | if ( data->hasDate != toDoEvent.data->hasDate ) return false; |
324 | if ( data->date != toDoEvent.data->date ) return false; | 324 | if ( data->date != toDoEvent.data->date ) return false; |
325 | if ( data->sum != toDoEvent.data->sum ) return false; | 325 | if ( data->sum != toDoEvent.data->sum ) return false; |
326 | if ( data->desc != toDoEvent.data->desc ) return false; | 326 | if ( data->desc != toDoEvent.data->desc ) return false; |
327 | if ( data->maintainer != toDoEvent.data->maintainer ) | 327 | if ( data->maintainer != toDoEvent.data->maintainer ) |
328 | return false; | 328 | return false; |
329 | 329 | ||
330 | return OPimRecord::operator==( toDoEvent ); | 330 | return OPimRecord::operator==( toDoEvent ); |
331 | } | 331 | } |
332 | void OTodo::deref() { | 332 | void OTodo::deref() { |
333 | 333 | ||
334 | // qWarning("deref in ToDoEvent"); | 334 | // qWarning("deref in ToDoEvent"); |
335 | if ( data->deref() ) { | 335 | if ( data->deref() ) { |
336 | // qWarning("deleting"); | 336 | // qWarning("deleting"); |
337 | delete data; | 337 | delete data; |
338 | data= 0; | 338 | data= 0; |
339 | } | 339 | } |
340 | } | 340 | } |
341 | OTodo &OTodo::operator=(const OTodo &item ) | 341 | OTodo &OTodo::operator=(const OTodo &item ) |
342 | { | 342 | { |
343 | OPimRecord::operator=( item ); | 343 | OPimRecord::operator=( item ); |
344 | //qWarning("operator= ref "); | 344 | //qWarning("operator= ref "); |
345 | item.data->ref(); | 345 | item.data->ref(); |
346 | deref(); | 346 | deref(); |
347 | data = item.data; | 347 | data = item.data; |
348 | 348 | ||
349 | return *this; | 349 | return *this; |
350 | } | 350 | } |
351 | 351 | ||
352 | QMap<int, QString> OTodo::toMap() const { | 352 | QMap<int, QString> OTodo::toMap() const { |
353 | QMap<int, QString> map; | 353 | QMap<int, QString> map; |
354 | 354 | ||
355 | map.insert( Uid, QString::number( uid() ) ); | 355 | map.insert( Uid, QString::number( uid() ) ); |
356 | map.insert( Category, idsToString( categories() ) ); | 356 | map.insert( Category, idsToString( categories() ) ); |
357 | map.insert( HasDate, QString::number( data->hasDate ) ); | 357 | map.insert( HasDate, QString::number( data->hasDate ) ); |
358 | map.insert( Completed, QString::number( data->isCompleted ) ); | 358 | map.insert( Completed, QString::number( data->isCompleted ) ); |
359 | map.insert( Description, data->desc ); | 359 | map.insert( Description, data->desc ); |
360 | map.insert( Summary, data->sum ); | 360 | map.insert( Summary, data->sum ); |
361 | map.insert( Priority, QString::number( data->priority ) ); | 361 | map.insert( Priority, QString::number( data->priority ) ); |
362 | map.insert( DateDay, QString::number( data->date.day() ) ); | 362 | map.insert( DateDay, QString::number( data->date.day() ) ); |
363 | map.insert( DateMonth, QString::number( data->date.month() ) ); | 363 | map.insert( DateMonth, QString::number( data->date.month() ) ); |
364 | map.insert( DateYear, QString::number( data->date.year() ) ); | 364 | map.insert( DateYear, QString::number( data->date.year() ) ); |
365 | map.insert( Progress, QString::number( data->prog ) ); | 365 | map.insert( Progress, QString::number( data->prog ) ); |
366 | // map.insert( CrossReference, crossToString() ); | 366 | // map.insert( CrossReference, crossToString() ); |
367 | /* FIXME!!! map.insert( State, ); | 367 | /* FIXME!!! map.insert( State, ); |
368 | map.insert( Recurrence, ); | 368 | map.insert( Recurrence, ); |
369 | map.insert( Reminders, ); | 369 | map.insert( Reminders, ); |
370 | map. | 370 | map. |
371 | */ | 371 | */ |
372 | return map; | 372 | return map; |
373 | } | 373 | } |
374 | 374 | ||
375 | QMap<QString, QString> OTodo::toExtraMap()const { | 375 | QMap<QString, QString> OTodo::toExtraMap()const { |
376 | return data->extra; | 376 | return data->extra; |
377 | } | 377 | } |
378 | /** | 378 | /** |
379 | * change or modify looks at the ref count and either | 379 | * change or modify looks at the ref count and either |
380 | * creates a new QShared Object or it can modify it | 380 | * creates a new QShared Object or it can modify it |
381 | * right in place | 381 | * right in place |
382 | */ | 382 | */ |
383 | void OTodo::changeOrModify() { | 383 | void OTodo::changeOrModify() { |
384 | if ( data->count != 1 ) { | 384 | if ( data->count != 1 ) { |
385 | qWarning("changeOrModify"); | 385 | qWarning("changeOrModify"); |
386 | data->deref(); | 386 | data->deref(); |
387 | OTodoData* d2 = new OTodoData(); | 387 | OTodoData* d2 = new OTodoData(); |
388 | copy(data, d2 ); | 388 | copy(data, d2 ); |
389 | data = d2; | 389 | data = d2; |
390 | } | 390 | } |
391 | } | 391 | } |
392 | // WATCHOUT | 392 | // WATCHOUT |
393 | /* | 393 | /* |
394 | * if you add something to the Data struct | 394 | * if you add something to the Data struct |
395 | * be sure to copy it here | 395 | * be sure to copy it here |
396 | */ | 396 | */ |
397 | void OTodo::copy( OTodoData* src, OTodoData* dest ) { | 397 | void OTodo::copy( OTodoData* src, OTodoData* dest ) { |
398 | dest->date = src->date; | 398 | dest->date = src->date; |
399 | dest->isCompleted = src->isCompleted; | 399 | dest->isCompleted = src->isCompleted; |
400 | dest->hasDate = src->hasDate; | 400 | dest->hasDate = src->hasDate; |
401 | dest->priority = src->priority; | 401 | dest->priority = src->priority; |
402 | dest->desc = src->desc; | 402 | dest->desc = src->desc; |
403 | dest->sum = src->sum; | 403 | dest->sum = src->sum; |
404 | dest->extra = src->extra; | 404 | dest->extra = src->extra; |
405 | dest->prog = src->prog; | 405 | dest->prog = src->prog; |
406 | dest->state = src->state; | 406 | dest->state = src->state; |
407 | dest->recur = src->recur; | 407 | dest->recur = src->recur; |
408 | dest->maintainer = src->maintainer; | 408 | dest->maintainer = src->maintainer; |
409 | dest->start = src->start; | 409 | dest->start = src->start; |
410 | dest->completed = src->completed; | 410 | dest->completed = src->completed; |
411 | dest->notifiers = src->notifiers; | 411 | dest->notifiers = src->notifiers; |
412 | } | 412 | } |
413 | QString OTodo::type() const { | 413 | QString OTodo::type() const { |
414 | return QString::fromLatin1("OTodo"); | 414 | return QString::fromLatin1("OTodo"); |
415 | } | 415 | } |
416 | QString OTodo::recordField(int /*id*/ )const { | 416 | QString OTodo::recordField(int /*id*/ )const { |
417 | return QString::null; | 417 | return QString::null; |
418 | } | 418 | } |
419 | 419 | ||
420 | int OTodo::rtti(){ | 420 | int OTodo::rtti(){ |
421 | return OPimResolver::TodoList; | 421 | return OPimResolver::TodoList; |
422 | } | 422 | } |
diff --git a/libopie2/opiepim/core/opimrecord.cpp b/libopie2/opiepim/core/opimrecord.cpp index ac0f4a9..d45417a 100644 --- a/libopie2/opiepim/core/opimrecord.cpp +++ b/libopie2/opiepim/core/opimrecord.cpp | |||
@@ -1,166 +1,166 @@ | |||
1 | #include <qarray.h> | 1 | #include <qarray.h> |
2 | 2 | ||
3 | #include <qpe/categories.h> | 3 | #include <qpe/categories.h> |
4 | #include <qpe/categoryselect.h> | 4 | #include <qpe/categoryselect.h> |
5 | 5 | ||
6 | #include "opimrecord.h" | 6 | #include "opimrecord.h" |
7 | 7 | ||
8 | Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia ); | 8 | Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia ); |
9 | 9 | ||
10 | 10 | ||
11 | OPimRecord::OPimRecord( int uid ) | 11 | OPimRecord::OPimRecord( int uid ) |
12 | : Qtopia::Record() { | 12 | : Qtopia::Record() { |
13 | 13 | ||
14 | setUid( uid ); | 14 | setUid( uid ); |
15 | } | 15 | } |
16 | OPimRecord::~OPimRecord() { | 16 | OPimRecord::~OPimRecord() { |
17 | } | 17 | } |
18 | OPimRecord::OPimRecord( const OPimRecord& rec ) | 18 | OPimRecord::OPimRecord( const OPimRecord& rec ) |
19 | : Qtopia::Record( rec ) | 19 | : Qtopia::Record( rec ) |
20 | { | 20 | { |
21 | (*this) = rec; | 21 | (*this) = rec; |
22 | } | 22 | } |
23 | 23 | ||
24 | OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { | 24 | OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { |
25 | Qtopia::Record::operator=( rec ); | 25 | Qtopia::Record::operator=( rec ); |
26 | m_xrefman = rec.m_xrefman; | 26 | m_xrefman = rec.m_xrefman; |
27 | 27 | ||
28 | return *this; | 28 | return *this; |
29 | } | 29 | } |
30 | /* | 30 | /* |
31 | * category names | 31 | * category names |
32 | */ | 32 | */ |
33 | QStringList OPimRecord::categoryNames()const { | 33 | QStringList OPimRecord::categoryNames( const QString& appname ) const { |
34 | QStringList list; | 34 | QStringList list; |
35 | QArray<int> cats = categories(); | 35 | QArray<int> cats = categories(); |
36 | Categories catDB; | 36 | Categories catDB; |
37 | catDB.load( categoryFileName() ); | 37 | catDB.load( categoryFileName() ); |
38 | 38 | ||
39 | for (uint i = 0; i < cats.count(); i++ ) { | 39 | for (uint i = 0; i < cats.count(); i++ ) { |
40 | list << catDB.label("Todo List", cats[i] ); | 40 | list << catDB.label( appname, cats[i] ); |
41 | } | 41 | } |
42 | 42 | ||
43 | return list; | 43 | return list; |
44 | } | 44 | } |
45 | void OPimRecord::setCategoryNames( const QStringList& ) { | 45 | void OPimRecord::setCategoryNames( const QStringList& ) { |
46 | 46 | ||
47 | } | 47 | } |
48 | void OPimRecord::addCategoryName( const QString& ) { | 48 | void OPimRecord::addCategoryName( const QString& ) { |
49 | Categories catDB; | 49 | Categories catDB; |
50 | catDB.load( categoryFileName() ); | 50 | catDB.load( categoryFileName() ); |
51 | 51 | ||
52 | 52 | ||
53 | } | 53 | } |
54 | bool OPimRecord::isEmpty()const { | 54 | bool OPimRecord::isEmpty()const { |
55 | return ( uid() == 0 ); | 55 | return ( uid() == 0 ); |
56 | } | 56 | } |
57 | /*QString OPimRecord::crossToString()const { | 57 | /*QString OPimRecord::crossToString()const { |
58 | QString str; | 58 | QString str; |
59 | QMap<QString, QArray<int> >::ConstIterator it; | 59 | QMap<QString, QArray<int> >::ConstIterator it; |
60 | for (it = m_relations.begin(); it != m_relations.end(); ++it ) { | 60 | for (it = m_relations.begin(); it != m_relations.end(); ++it ) { |
61 | QArray<int> id = it.data(); | 61 | QArray<int> id = it.data(); |
62 | for ( uint i = 0; i < id.size(); ++i ) { | 62 | for ( uint i = 0; i < id.size(); ++i ) { |
63 | str += it.key() + "," + QString::number( i ) + ";"; | 63 | str += it.key() + "," + QString::number( i ) + ";"; |
64 | } | 64 | } |
65 | } | 65 | } |
66 | str = str.remove( str.length()-1, 1); // strip the ; | 66 | str = str.remove( str.length()-1, 1); // strip the ; |
67 | //qWarning("IDS " + str ); | 67 | //qWarning("IDS " + str ); |
68 | 68 | ||
69 | return str; | 69 | return str; |
70 | }*/ | 70 | }*/ |
71 | /* if uid = 1 assign a new one */ | 71 | /* if uid = 1 assign a new one */ |
72 | void OPimRecord::setUid( int uid ) { | 72 | void OPimRecord::setUid( int uid ) { |
73 | if ( uid == 1) | 73 | if ( uid == 1) |
74 | uid = uidGen().generate(); | 74 | uid = uidGen().generate(); |
75 | 75 | ||
76 | Qtopia::Record::setUid( uid ); | 76 | Qtopia::Record::setUid( uid ); |
77 | }; | 77 | }; |
78 | Qtopia::UidGen &OPimRecord::uidGen() { | 78 | Qtopia::UidGen &OPimRecord::uidGen() { |
79 | return m_uidGen; | 79 | return m_uidGen; |
80 | } | 80 | } |
81 | OPimXRefManager &OPimRecord::xrefmanager() { | 81 | OPimXRefManager &OPimRecord::xrefmanager() { |
82 | return m_xrefman; | 82 | return m_xrefman; |
83 | } | 83 | } |
84 | int OPimRecord::rtti(){ | 84 | int OPimRecord::rtti(){ |
85 | return 0; | 85 | return 0; |
86 | } | 86 | } |
87 | 87 | ||
88 | /** | 88 | /** |
89 | * now let's put our data into the stream | 89 | * now let's put our data into the stream |
90 | */ | 90 | */ |
91 | /* | 91 | /* |
92 | * First read UID | 92 | * First read UID |
93 | * Categories | 93 | * Categories |
94 | * XRef | 94 | * XRef |
95 | */ | 95 | */ |
96 | bool OPimRecord::loadFromStream( QDataStream& stream ) { | 96 | bool OPimRecord::loadFromStream( QDataStream& stream ) { |
97 | int Int; | 97 | int Int; |
98 | uint UInt; | 98 | uint UInt; |
99 | stream >> Int; | 99 | stream >> Int; |
100 | setUid(Int); | 100 | setUid(Int); |
101 | 101 | ||
102 | /** Categories */ | 102 | /** Categories */ |
103 | stream >> UInt; | 103 | stream >> UInt; |
104 | QArray<int> array(UInt); | 104 | QArray<int> array(UInt); |
105 | for (uint i = 0; i < UInt; i++ ) { | 105 | for (uint i = 0; i < UInt; i++ ) { |
106 | stream >> array[i]; | 106 | stream >> array[i]; |
107 | } | 107 | } |
108 | setCategories( array ); | 108 | setCategories( array ); |
109 | 109 | ||
110 | /* | 110 | /* |
111 | * now we do the X-Ref stuff | 111 | * now we do the X-Ref stuff |
112 | */ | 112 | */ |
113 | OPimXRef xref; | 113 | OPimXRef xref; |
114 | stream >> UInt; | 114 | stream >> UInt; |
115 | for ( uint i = 0; i < UInt; i++ ) { | 115 | for ( uint i = 0; i < UInt; i++ ) { |
116 | xref.setPartner( OPimXRef::One, partner( stream ) ); | 116 | xref.setPartner( OPimXRef::One, partner( stream ) ); |
117 | xref.setPartner( OPimXRef::Two, partner( stream ) ); | 117 | xref.setPartner( OPimXRef::Two, partner( stream ) ); |
118 | m_xrefman.add( xref ); | 118 | m_xrefman.add( xref ); |
119 | } | 119 | } |
120 | 120 | ||
121 | return true; | 121 | return true; |
122 | } | 122 | } |
123 | bool OPimRecord::saveToStream( QDataStream& stream )const { | 123 | bool OPimRecord::saveToStream( QDataStream& stream )const { |
124 | /** UIDs */ | 124 | /** UIDs */ |
125 | 125 | ||
126 | stream << uid(); | 126 | stream << uid(); |
127 | 127 | ||
128 | /** Categories */ | 128 | /** Categories */ |
129 | stream << categories().count(); | 129 | stream << categories().count(); |
130 | for ( uint i = 0; i < categories().count(); i++ ) { | 130 | for ( uint i = 0; i < categories().count(); i++ ) { |
131 | stream << categories()[i]; | 131 | stream << categories()[i]; |
132 | } | 132 | } |
133 | 133 | ||
134 | /* | 134 | /* |
135 | * first the XRef count | 135 | * first the XRef count |
136 | * then the xrefs | 136 | * then the xrefs |
137 | */ | 137 | */ |
138 | stream << m_xrefman.list().count(); | 138 | stream << m_xrefman.list().count(); |
139 | for ( OPimXRef::ValueList::ConstIterator it = m_xrefman.list().begin(); | 139 | for ( OPimXRef::ValueList::ConstIterator it = m_xrefman.list().begin(); |
140 | it != m_xrefman.list().end(); ++it ) { | 140 | it != m_xrefman.list().end(); ++it ) { |
141 | flush( (*it).partner( OPimXRef::One), stream ); | 141 | flush( (*it).partner( OPimXRef::One), stream ); |
142 | flush( (*it).partner( OPimXRef::Two), stream ); | 142 | flush( (*it).partner( OPimXRef::Two), stream ); |
143 | } | 143 | } |
144 | return true; | 144 | return true; |
145 | } | 145 | } |
146 | void OPimRecord::flush( const OPimXRefPartner& par, QDataStream& str ) const{ | 146 | void OPimRecord::flush( const OPimXRefPartner& par, QDataStream& str ) const{ |
147 | str << par.service(); | 147 | str << par.service(); |
148 | str << par.uid(); | 148 | str << par.uid(); |
149 | str << par.field(); | 149 | str << par.field(); |
150 | } | 150 | } |
151 | OPimXRefPartner OPimRecord::partner( QDataStream& stream ) { | 151 | OPimXRefPartner OPimRecord::partner( QDataStream& stream ) { |
152 | OPimXRefPartner par; | 152 | OPimXRefPartner par; |
153 | QString str; | 153 | QString str; |
154 | int i; | 154 | int i; |
155 | 155 | ||
156 | stream >> str; | 156 | stream >> str; |
157 | par.setService( str ); | 157 | par.setService( str ); |
158 | 158 | ||
159 | stream >> i; | 159 | stream >> i; |
160 | par.setUid( i ); | 160 | par.setUid( i ); |
161 | 161 | ||
162 | stream >> i ; | 162 | stream >> i ; |
163 | par.setField( i ); | 163 | par.setField( i ); |
164 | 164 | ||
165 | return par; | 165 | return par; |
166 | } | 166 | } |
diff --git a/libopie2/opiepim/core/opimrecord.h b/libopie2/opiepim/core/opimrecord.h index 665530f..c7f9460 100644 --- a/libopie2/opiepim/core/opimrecord.h +++ b/libopie2/opiepim/core/opimrecord.h | |||
@@ -1,134 +1,134 @@ | |||
1 | #ifndef OPIE_PIM_RECORD_H | 1 | #ifndef OPIE_PIM_RECORD_H |
2 | #define OPIE_PIM_RECORD_H | 2 | #define OPIE_PIM_RECORD_H |
3 | 3 | ||
4 | #include <qdatastream.h> | 4 | #include <qdatastream.h> |
5 | #include <qmap.h> | 5 | #include <qmap.h> |
6 | #include <qstring.h> | 6 | #include <qstring.h> |
7 | #include <qstringlist.h> | 7 | #include <qstringlist.h> |
8 | 8 | ||
9 | #include <qpe/palmtoprecord.h> | 9 | #include <qpe/palmtoprecord.h> |
10 | 10 | ||
11 | #include <opie/opimxrefmanager.h> | 11 | #include <opie/opimxrefmanager.h> |
12 | 12 | ||
13 | /** | 13 | /** |
14 | * This is the base class for | 14 | * This is the base class for |
15 | * all PIM Records | 15 | * all PIM Records |
16 | * | 16 | * |
17 | */ | 17 | */ |
18 | class OPimRecord : public Qtopia::Record { | 18 | class OPimRecord : public Qtopia::Record { |
19 | public: | 19 | public: |
20 | /** | 20 | /** |
21 | * c'tor | 21 | * c'tor |
22 | * uid of 0 isEmpty | 22 | * uid of 0 isEmpty |
23 | * uid of 1 will be assigned a new one | 23 | * uid of 1 will be assigned a new one |
24 | */ | 24 | */ |
25 | OPimRecord(int uid = 0); | 25 | OPimRecord(int uid = 0); |
26 | ~OPimRecord(); | 26 | ~OPimRecord(); |
27 | 27 | ||
28 | /** | 28 | /** |
29 | * copy c'tor | 29 | * copy c'tor |
30 | */ | 30 | */ |
31 | OPimRecord( const OPimRecord& rec ); | 31 | OPimRecord( const OPimRecord& rec ); |
32 | 32 | ||
33 | /** | 33 | /** |
34 | * copy operator | 34 | * copy operator |
35 | */ | 35 | */ |
36 | OPimRecord &operator=( const OPimRecord& ); | 36 | OPimRecord &operator=( const OPimRecord& ); |
37 | 37 | ||
38 | /** | 38 | /** |
39 | * category names resolved | 39 | * category names resolved |
40 | */ | 40 | */ |
41 | QStringList categoryNames()const; | 41 | QStringList categoryNames( const QString& appname )const; |
42 | 42 | ||
43 | /** | 43 | /** |
44 | * set category names they will be resolved | 44 | * set category names they will be resolved |
45 | */ | 45 | */ |
46 | void setCategoryNames( const QStringList& ); | 46 | void setCategoryNames( const QStringList& ); |
47 | 47 | ||
48 | /** | 48 | /** |
49 | * addCategoryName adds a name | 49 | * addCategoryName adds a name |
50 | * to the internal category list | 50 | * to the internal category list |
51 | */ | 51 | */ |
52 | void addCategoryName( const QString& ); | 52 | void addCategoryName( const QString& ); |
53 | 53 | ||
54 | /** | 54 | /** |
55 | * if a Record isEmpty | 55 | * if a Record isEmpty |
56 | * it's empty if it's 0 | 56 | * it's empty if it's 0 |
57 | */ | 57 | */ |
58 | virtual bool isEmpty()const; | 58 | virtual bool isEmpty()const; |
59 | 59 | ||
60 | /** | 60 | /** |
61 | * toRichText summary | 61 | * toRichText summary |
62 | */ | 62 | */ |
63 | virtual QString toRichText()const = 0; | 63 | virtual QString toRichText()const = 0; |
64 | 64 | ||
65 | /** | 65 | /** |
66 | * a small one line summary | 66 | * a small one line summary |
67 | */ | 67 | */ |
68 | virtual QString toShortText()const = 0; | 68 | virtual QString toShortText()const = 0; |
69 | 69 | ||
70 | /** | 70 | /** |
71 | * the name of the Record | 71 | * the name of the Record |
72 | */ | 72 | */ |
73 | virtual QString type()const = 0; | 73 | virtual QString type()const = 0; |
74 | 74 | ||
75 | /** | 75 | /** |
76 | * converts the internal structure to a map | 76 | * converts the internal structure to a map |
77 | */ | 77 | */ |
78 | virtual QMap<int, QString> toMap()const = 0; | 78 | virtual QMap<int, QString> toMap()const = 0; |
79 | 79 | ||
80 | /** | 80 | /** |
81 | * key value representation of extra items | 81 | * key value representation of extra items |
82 | */ | 82 | */ |
83 | virtual QMap<QString, QString> toExtraMap()const = 0; | 83 | virtual QMap<QString, QString> toExtraMap()const = 0; |
84 | 84 | ||
85 | /** | 85 | /** |
86 | * the name for a recordField | 86 | * the name for a recordField |
87 | */ | 87 | */ |
88 | virtual QString recordField(int)const = 0; | 88 | virtual QString recordField(int)const = 0; |
89 | 89 | ||
90 | /** | 90 | /** |
91 | * returns a reference of the | 91 | * returns a reference of the |
92 | * Cross Reference Manager | 92 | * Cross Reference Manager |
93 | * Partner 'One' is THIS PIM RECORD! | 93 | * Partner 'One' is THIS PIM RECORD! |
94 | * 'Two' is the Partner where we link to | 94 | * 'Two' is the Partner where we link to |
95 | */ | 95 | */ |
96 | OPimXRefManager& xrefmanager(); | 96 | OPimXRefManager& xrefmanager(); |
97 | 97 | ||
98 | /** | 98 | /** |
99 | * set the uid | 99 | * set the uid |
100 | */ | 100 | */ |
101 | virtual void setUid( int uid ); | 101 | virtual void setUid( int uid ); |
102 | 102 | ||
103 | /* | 103 | /* |
104 | * used inside the Templates for casting | 104 | * used inside the Templates for casting |
105 | * REIMPLEMENT in your .... | 105 | * REIMPLEMENT in your .... |
106 | */ | 106 | */ |
107 | static int rtti(); | 107 | static int rtti(); |
108 | 108 | ||
109 | /** | 109 | /** |
110 | * some marshalling and de marshalling code | 110 | * some marshalling and de marshalling code |
111 | * saves the OPimRecord | 111 | * saves the OPimRecord |
112 | * to and from a DataStream | 112 | * to and from a DataStream |
113 | */ | 113 | */ |
114 | virtual bool loadFromStream(QDataStream& ); | 114 | virtual bool loadFromStream(QDataStream& ); |
115 | virtual bool saveToStream( QDataStream& stream )const; | 115 | virtual bool saveToStream( QDataStream& stream )const; |
116 | 116 | ||
117 | protected: | 117 | protected: |
118 | Qtopia::UidGen &uidGen(); | 118 | Qtopia::UidGen &uidGen(); |
119 | // QString crossToString()const; | 119 | // QString crossToString()const; |
120 | 120 | ||
121 | private: | 121 | private: |
122 | class OPimRecordPrivate; | 122 | class OPimRecordPrivate; |
123 | OPimRecordPrivate *d; | 123 | OPimRecordPrivate *d; |
124 | OPimXRefManager m_xrefman; | 124 | OPimXRefManager m_xrefman; |
125 | static Qtopia::UidGen m_uidGen; | 125 | static Qtopia::UidGen m_uidGen; |
126 | 126 | ||
127 | private: | 127 | private: |
128 | void flush( const OPimXRefPartner&, QDataStream& stream )const; | 128 | void flush( const OPimXRefPartner&, QDataStream& stream )const; |
129 | OPimXRefPartner partner( QDataStream& ); | 129 | OPimXRefPartner partner( QDataStream& ); |
130 | }; | 130 | }; |
131 | 131 | ||
132 | 132 | ||
133 | 133 | ||
134 | #endif | 134 | #endif |
diff --git a/libopie2/opiepim/ocontact.cpp b/libopie2/opiepim/ocontact.cpp index 178559b..9cccfc8 100644 --- a/libopie2/opiepim/ocontact.cpp +++ b/libopie2/opiepim/ocontact.cpp | |||
@@ -438,387 +438,387 @@ QString OContact::toRichText() const | |||
438 | QString text; | 438 | QString text; |
439 | QString value, comp, state; | 439 | QString value, comp, state; |
440 | QString str; | 440 | QString str; |
441 | bool marker = false; | 441 | bool marker = false; |
442 | 442 | ||
443 | // name, jobtitle and company | 443 | // name, jobtitle and company |
444 | if ( !(value = fullName()).isEmpty() ) | 444 | if ( !(value = fullName()).isEmpty() ) |
445 | text += "<b><h3>" + Qtopia::escapeString(value) + "</h3></b><br>"; | 445 | text += "<b><h3>" + Qtopia::escapeString(value) + "</h3></b><br>"; |
446 | if ( !(value = jobTitle()).isEmpty() ) | 446 | if ( !(value = jobTitle()).isEmpty() ) |
447 | text += Qtopia::escapeString(value) + "<br>"; | 447 | text += Qtopia::escapeString(value) + "<br>"; |
448 | 448 | ||
449 | comp = company(); | 449 | comp = company(); |
450 | if ( !(value = department()).isEmpty() ) { | 450 | if ( !(value = department()).isEmpty() ) { |
451 | text += Qtopia::escapeString(value); | 451 | text += Qtopia::escapeString(value); |
452 | if ( comp ) | 452 | if ( comp ) |
453 | text += ", "; | 453 | text += ", "; |
454 | else | 454 | else |
455 | text += "<br>"; | 455 | text += "<br>"; |
456 | } | 456 | } |
457 | if ( !comp.isEmpty() ) | 457 | if ( !comp.isEmpty() ) |
458 | text += Qtopia::escapeString(comp) + "<br>"; | 458 | text += Qtopia::escapeString(comp) + "<br>"; |
459 | 459 | ||
460 | QString defEmail = defaultEmail(); | 460 | QString defEmail = defaultEmail(); |
461 | if ( !defEmail.isEmpty() ) | 461 | if ( !defEmail.isEmpty() ) |
462 | text += "<b>" + QObject::tr("Default Email: ") + "</b>" | 462 | text += "<b>" + QObject::tr("Default Email: ") + "</b>" |
463 | + Qtopia::escapeString(defEmail) + "<br>"; | 463 | + Qtopia::escapeString(defEmail) + "<br>"; |
464 | 464 | ||
465 | text += "<hr>"; | 465 | text += "<hr>"; |
466 | 466 | ||
467 | // business address | 467 | // business address |
468 | if ( !businessStreet().isEmpty() || !businessCity().isEmpty() || | 468 | if ( !businessStreet().isEmpty() || !businessCity().isEmpty() || |
469 | !businessZip().isEmpty() || !businessCountry().isEmpty() ) { | 469 | !businessZip().isEmpty() || !businessCountry().isEmpty() ) { |
470 | text += "<br>"; | 470 | text += "<br>"; |
471 | text += QObject::tr( "<b>Work Address:</b>" ); | 471 | text += QObject::tr( "<b>Work Address:</b>" ); |
472 | text += "<br>"; | 472 | text += "<br>"; |
473 | marker = true; | 473 | marker = true; |
474 | } | 474 | } |
475 | 475 | ||
476 | if ( !(value = businessStreet()).isEmpty() ) | 476 | if ( !(value = businessStreet()).isEmpty() ) |
477 | text += Qtopia::escapeString(value) + "<br>"; | 477 | text += Qtopia::escapeString(value) + "<br>"; |
478 | state = businessState(); | 478 | state = businessState(); |
479 | if ( !(value = businessZip()).isEmpty() ) | 479 | if ( !(value = businessZip()).isEmpty() ) |
480 | text += Qtopia::escapeString(value) + " "; | 480 | text += Qtopia::escapeString(value) + " "; |
481 | if ( !(value = businessCity()).isEmpty() ) { | 481 | if ( !(value = businessCity()).isEmpty() ) { |
482 | text += Qtopia::escapeString(value); | 482 | text += Qtopia::escapeString(value); |
483 | if ( state ) | 483 | if ( state ) |
484 | text += ", " + Qtopia::escapeString(state); | 484 | text += ", " + Qtopia::escapeString(state); |
485 | text += "<br>"; | 485 | text += "<br>"; |
486 | } else if ( !state.isEmpty() ) | 486 | } else if ( !state.isEmpty() ) |
487 | text += Qtopia::escapeString(state) + "<br>"; | 487 | text += Qtopia::escapeString(state) + "<br>"; |
488 | 488 | ||
489 | if ( !(value = businessCountry()).isEmpty() ) | 489 | if ( !(value = businessCountry()).isEmpty() ) |
490 | text += Qtopia::escapeString(value) + "<br>"; | 490 | text += Qtopia::escapeString(value) + "<br>"; |
491 | 491 | ||
492 | // rest of Business data | 492 | // rest of Business data |
493 | str = office(); | 493 | str = office(); |
494 | if ( !str.isEmpty() ){ | 494 | if ( !str.isEmpty() ){ |
495 | text += "<b>" + QObject::tr("Office: ") + "</b>" | 495 | text += "<b>" + QObject::tr("Office: ") + "</b>" |
496 | + Qtopia::escapeString(str) + "<br>"; | 496 | + Qtopia::escapeString(str) + "<br>"; |
497 | marker = true; | 497 | marker = true; |
498 | } | 498 | } |
499 | str = businessWebpage(); | 499 | str = businessWebpage(); |
500 | if ( !str.isEmpty() ){ | 500 | if ( !str.isEmpty() ){ |
501 | text += "<b>" + QObject::tr("Business Web Page: ") + "</b>" | 501 | text += "<b>" + QObject::tr("Business Web Page: ") + "</b>" |
502 | + Qtopia::escapeString(str) + "<br>"; | 502 | + Qtopia::escapeString(str) + "<br>"; |
503 | marker = true; | 503 | marker = true; |
504 | } | 504 | } |
505 | str = businessPhone(); | 505 | str = businessPhone(); |
506 | if ( !str.isEmpty() ){ | 506 | if ( !str.isEmpty() ){ |
507 | text += "<b>" + QObject::tr("Business Phone: ") + "</b>" | 507 | text += "<b>" + QObject::tr("Business Phone: ") + "</b>" |
508 | + Qtopia::escapeString(str) + "<br>"; | 508 | + Qtopia::escapeString(str) + "<br>"; |
509 | marker = true; | 509 | marker = true; |
510 | } | 510 | } |
511 | str = businessFax(); | 511 | str = businessFax(); |
512 | if ( !str.isEmpty() ){ | 512 | if ( !str.isEmpty() ){ |
513 | text += "<b>" + QObject::tr("Business Fax: ") + "</b>" | 513 | text += "<b>" + QObject::tr("Business Fax: ") + "</b>" |
514 | + Qtopia::escapeString(str) + "<br>"; | 514 | + Qtopia::escapeString(str) + "<br>"; |
515 | marker = true; | 515 | marker = true; |
516 | } | 516 | } |
517 | str = businessMobile(); | 517 | str = businessMobile(); |
518 | if ( !str.isEmpty() ){ | 518 | if ( !str.isEmpty() ){ |
519 | text += "<b>" + QObject::tr("Business Mobile: ") + "</b>" | 519 | text += "<b>" + QObject::tr("Business Mobile: ") + "</b>" |
520 | + Qtopia::escapeString(str) + "<br>"; | 520 | + Qtopia::escapeString(str) + "<br>"; |
521 | marker = true; | 521 | marker = true; |
522 | } | 522 | } |
523 | str = businessPager(); | 523 | str = businessPager(); |
524 | if ( !str.isEmpty() ){ | 524 | if ( !str.isEmpty() ){ |
525 | text += "<b>" + QObject::tr("Business Pager: ") + "</b>" | 525 | text += "<b>" + QObject::tr("Business Pager: ") + "</b>" |
526 | + Qtopia::escapeString(str) + "<br>"; | 526 | + Qtopia::escapeString(str) + "<br>"; |
527 | marker = true; | 527 | marker = true; |
528 | } | 528 | } |
529 | 529 | ||
530 | // home address | 530 | // home address |
531 | if ( !homeStreet().isEmpty() || !homeCity().isEmpty() || | 531 | if ( !homeStreet().isEmpty() || !homeCity().isEmpty() || |
532 | !homeZip().isEmpty() || !homeCountry().isEmpty() ) { | 532 | !homeZip().isEmpty() || !homeCountry().isEmpty() ) { |
533 | text += "<br>"; | 533 | text += "<br>"; |
534 | text += QObject::tr( "<b>Home Address:</b>" ); | 534 | text += QObject::tr( "<b>Home Address:</b>" ); |
535 | text += "<br>"; | 535 | text += "<br>"; |
536 | } | 536 | } |
537 | 537 | ||
538 | if ( !(value = homeStreet()).isEmpty() ) | 538 | if ( !(value = homeStreet()).isEmpty() ) |
539 | text += Qtopia::escapeString(value) + "<br>"; | 539 | text += Qtopia::escapeString(value) + "<br>"; |
540 | state = homeState(); | 540 | state = homeState(); |
541 | if ( !(value = homeZip()).isEmpty() ) | 541 | if ( !(value = homeZip()).isEmpty() ) |
542 | text += Qtopia::escapeString(value) + " "; | 542 | text += Qtopia::escapeString(value) + " "; |
543 | if ( !(value = homeCity()).isEmpty() ) { | 543 | if ( !(value = homeCity()).isEmpty() ) { |
544 | text += Qtopia::escapeString(value); | 544 | text += Qtopia::escapeString(value); |
545 | if ( !state.isEmpty() ) | 545 | if ( !state.isEmpty() ) |
546 | text += ", " + Qtopia::escapeString(state); | 546 | text += ", " + Qtopia::escapeString(state); |
547 | text += "<br>"; | 547 | text += "<br>"; |
548 | } else if (!state.isEmpty()) | 548 | } else if (!state.isEmpty()) |
549 | text += Qtopia::escapeString(state) + "<br>"; | 549 | text += Qtopia::escapeString(state) + "<br>"; |
550 | if ( !(value = homeCountry()).isEmpty() ) | 550 | if ( !(value = homeCountry()).isEmpty() ) |
551 | text += Qtopia::escapeString(value) + "<br>"; | 551 | text += Qtopia::escapeString(value) + "<br>"; |
552 | 552 | ||
553 | // rest of Home data | 553 | // rest of Home data |
554 | str = homeWebpage(); | 554 | str = homeWebpage(); |
555 | if ( !str.isEmpty() ){ | 555 | if ( !str.isEmpty() ){ |
556 | text += "<b>" + QObject::tr("Home Web Page: ") + "</b>" | 556 | text += "<b>" + QObject::tr("Home Web Page: ") + "</b>" |
557 | + Qtopia::escapeString(str) + "<br>"; | 557 | + Qtopia::escapeString(str) + "<br>"; |
558 | marker = true; | 558 | marker = true; |
559 | } | 559 | } |
560 | str = homePhone(); | 560 | str = homePhone(); |
561 | if ( !str.isEmpty() ){ | 561 | if ( !str.isEmpty() ){ |
562 | text += "<b>" + QObject::tr("Home Phone: ") + "</b>" | 562 | text += "<b>" + QObject::tr("Home Phone: ") + "</b>" |
563 | + Qtopia::escapeString(str) + "<br>"; | 563 | + Qtopia::escapeString(str) + "<br>"; |
564 | marker = true; | 564 | marker = true; |
565 | } | 565 | } |
566 | str = homeFax(); | 566 | str = homeFax(); |
567 | if ( !str.isEmpty() ){ | 567 | if ( !str.isEmpty() ){ |
568 | text += "<b>" + QObject::tr("Home Fax: ") + "</b>" | 568 | text += "<b>" + QObject::tr("Home Fax: ") + "</b>" |
569 | + Qtopia::escapeString(str) + "<br>"; | 569 | + Qtopia::escapeString(str) + "<br>"; |
570 | marker = true; | 570 | marker = true; |
571 | } | 571 | } |
572 | str = homeMobile(); | 572 | str = homeMobile(); |
573 | if ( !str.isEmpty() ){ | 573 | if ( !str.isEmpty() ){ |
574 | text += "<b>" + QObject::tr("Home Mobile: ") + "</b>" | 574 | text += "<b>" + QObject::tr("Home Mobile: ") + "</b>" |
575 | + Qtopia::escapeString(str) + "<br>"; | 575 | + Qtopia::escapeString(str) + "<br>"; |
576 | marker = true; | 576 | marker = true; |
577 | } | 577 | } |
578 | 578 | ||
579 | if ( marker ) | 579 | if ( marker ) |
580 | text += "<br><hr><br>"; | 580 | text += "<br><hr><br>"; |
581 | // the others... | 581 | // the others... |
582 | str = emails(); | 582 | str = emails(); |
583 | if ( !str.isEmpty() && ( str != defEmail ) ) | 583 | if ( !str.isEmpty() && ( str != defEmail ) ) |
584 | text += "<b>" + QObject::tr("All Emails: ") + "</b>" | 584 | text += "<b>" + QObject::tr("All Emails: ") + "</b>" |
585 | + Qtopia::escapeString(str) + "<br>"; | 585 | + Qtopia::escapeString(str) + "<br>"; |
586 | str = profession(); | 586 | str = profession(); |
587 | if ( !str.isEmpty() ) | 587 | if ( !str.isEmpty() ) |
588 | text += "<b>" + QObject::tr("Profession: ") + "</b>" | 588 | text += "<b>" + QObject::tr("Profession: ") + "</b>" |
589 | + Qtopia::escapeString(str) + "<br>"; | 589 | + Qtopia::escapeString(str) + "<br>"; |
590 | str = assistant(); | 590 | str = assistant(); |
591 | if ( !str.isEmpty() ) | 591 | if ( !str.isEmpty() ) |
592 | text += "<b>" + QObject::tr("Assistant: ") + "</b>" | 592 | text += "<b>" + QObject::tr("Assistant: ") + "</b>" |
593 | + Qtopia::escapeString(str) + "<br>"; | 593 | + Qtopia::escapeString(str) + "<br>"; |
594 | str = manager(); | 594 | str = manager(); |
595 | if ( !str.isEmpty() ) | 595 | if ( !str.isEmpty() ) |
596 | text += "<b>" + QObject::tr("Manager: ") + "</b>" | 596 | text += "<b>" + QObject::tr("Manager: ") + "</b>" |
597 | + Qtopia::escapeString(str) + "<br>"; | 597 | + Qtopia::escapeString(str) + "<br>"; |
598 | str = gender(); | 598 | str = gender(); |
599 | if ( !str.isEmpty() && str.toInt() != 0 ) { | 599 | if ( !str.isEmpty() && str.toInt() != 0 ) { |
600 | if ( str.toInt() == 1 ) | 600 | if ( str.toInt() == 1 ) |
601 | str = QObject::tr( "Male" ); | 601 | str = QObject::tr( "Male" ); |
602 | else if ( str.toInt() == 2 ) | 602 | else if ( str.toInt() == 2 ) |
603 | str = QObject::tr( "Female" ); | 603 | str = QObject::tr( "Female" ); |
604 | text += "<b>" + QObject::tr("Gender: ") + "</b>" + str + "<br>"; | 604 | text += "<b>" + QObject::tr("Gender: ") + "</b>" + str + "<br>"; |
605 | } | 605 | } |
606 | str = spouse(); | 606 | str = spouse(); |
607 | if ( !str.isEmpty() ) | 607 | if ( !str.isEmpty() ) |
608 | text += "<b>" + QObject::tr("Spouse: ") + "</b>" | 608 | text += "<b>" + QObject::tr("Spouse: ") + "</b>" |
609 | + Qtopia::escapeString(str) + "<br>"; | 609 | + Qtopia::escapeString(str) + "<br>"; |
610 | if ( birthday().isValid() ){ | 610 | if ( birthday().isValid() ){ |
611 | str = TimeString::numberDateString( birthday() ); | 611 | str = TimeString::numberDateString( birthday() ); |
612 | text += "<b>" + QObject::tr("Birthday: ") + "</b>" | 612 | text += "<b>" + QObject::tr("Birthday: ") + "</b>" |
613 | + Qtopia::escapeString(str) + "<br>"; | 613 | + Qtopia::escapeString(str) + "<br>"; |
614 | } | 614 | } |
615 | if ( anniversary().isValid() ){ | 615 | if ( anniversary().isValid() ){ |
616 | str = TimeString::numberDateString( anniversary() ); | 616 | str = TimeString::numberDateString( anniversary() ); |
617 | text += "<b>" + QObject::tr("Anniversary: ") + "</b>" | 617 | text += "<b>" + QObject::tr("Anniversary: ") + "</b>" |
618 | + Qtopia::escapeString(str) + "<br>"; | 618 | + Qtopia::escapeString(str) + "<br>"; |
619 | } | 619 | } |
620 | str = children(); | 620 | str = children(); |
621 | if ( !str.isEmpty() ) | 621 | if ( !str.isEmpty() ) |
622 | text += "<b>" + QObject::tr("Children: ") + "</b>" | 622 | text += "<b>" + QObject::tr("Children: ") + "</b>" |
623 | + Qtopia::escapeString(str) + "<br>"; | 623 | + Qtopia::escapeString(str) + "<br>"; |
624 | 624 | ||
625 | str = nickname(); | 625 | str = nickname(); |
626 | if ( !str.isEmpty() ) | 626 | if ( !str.isEmpty() ) |
627 | text += "<b>" + QObject::tr("Nickname: ") + "</b>" | 627 | text += "<b>" + QObject::tr("Nickname: ") + "</b>" |
628 | + Qtopia::escapeString(str) + "<br>"; | 628 | + Qtopia::escapeString(str) + "<br>"; |
629 | 629 | ||
630 | if ( categoryNames().count() ){ | 630 | if ( categoryNames("Contacts").count() ){ |
631 | text += "<b>" + QObject::tr( "Category:") + "</b> "; | 631 | text += "<b>" + QObject::tr( "Category:") + "</b> "; |
632 | text += categoryNames().join(", "); | 632 | text += categoryNames("Contacts").join(", "); |
633 | text += "<br>"; | 633 | text += "<br>"; |
634 | } | 634 | } |
635 | 635 | ||
636 | // notes last | 636 | // notes last |
637 | if ( !(value = notes()).isEmpty() ) { | 637 | if ( !(value = notes()).isEmpty() ) { |
638 | text += "<br><hr><b>" + QObject::tr( "Notes:") + "</b> "; | 638 | text += "<br><hr><b>" + QObject::tr( "Notes:") + "</b> "; |
639 | QRegExp reg("\n"); | 639 | QRegExp reg("\n"); |
640 | 640 | ||
641 | //QString tmp = Qtopia::escapeString(value); | 641 | //QString tmp = Qtopia::escapeString(value); |
642 | QString tmp = QStyleSheet::convertFromPlainText(value); | 642 | QString tmp = QStyleSheet::convertFromPlainText(value); |
643 | //tmp.replace( reg, "<br>" ); | 643 | //tmp.replace( reg, "<br>" ); |
644 | text += "<br>" + tmp + "<br>"; | 644 | text += "<br>" + tmp + "<br>"; |
645 | } | 645 | } |
646 | return text; | 646 | return text; |
647 | } | 647 | } |
648 | 648 | ||
649 | /*! | 649 | /*! |
650 | \internal | 650 | \internal |
651 | */ | 651 | */ |
652 | void OContact::insert( int key, const QString &v ) | 652 | void OContact::insert( int key, const QString &v ) |
653 | { | 653 | { |
654 | QString value = v.stripWhiteSpace(); | 654 | QString value = v.stripWhiteSpace(); |
655 | if ( value.isEmpty() ) | 655 | if ( value.isEmpty() ) |
656 | mMap.remove( key ); | 656 | mMap.remove( key ); |
657 | else | 657 | else |
658 | mMap.insert( key, value ); | 658 | mMap.insert( key, value ); |
659 | } | 659 | } |
660 | 660 | ||
661 | /*! | 661 | /*! |
662 | \internal | 662 | \internal |
663 | */ | 663 | */ |
664 | void OContact::replace( int key, const QString & v ) | 664 | void OContact::replace( int key, const QString & v ) |
665 | { | 665 | { |
666 | QString value = v.stripWhiteSpace(); | 666 | QString value = v.stripWhiteSpace(); |
667 | if ( value.isEmpty() ) | 667 | if ( value.isEmpty() ) |
668 | mMap.remove( key ); | 668 | mMap.remove( key ); |
669 | else | 669 | else |
670 | mMap.replace( key, value ); | 670 | mMap.replace( key, value ); |
671 | } | 671 | } |
672 | 672 | ||
673 | /*! | 673 | /*! |
674 | \internal | 674 | \internal |
675 | */ | 675 | */ |
676 | QString OContact::find( int key ) const | 676 | QString OContact::find( int key ) const |
677 | { | 677 | { |
678 | return mMap[key]; | 678 | return mMap[key]; |
679 | } | 679 | } |
680 | 680 | ||
681 | /*! | 681 | /*! |
682 | \internal | 682 | \internal |
683 | */ | 683 | */ |
684 | QString OContact::displayAddress( const QString &street, | 684 | QString OContact::displayAddress( const QString &street, |
685 | const QString &city, | 685 | const QString &city, |
686 | const QString &state, | 686 | const QString &state, |
687 | const QString &zip, | 687 | const QString &zip, |
688 | const QString &country ) const | 688 | const QString &country ) const |
689 | { | 689 | { |
690 | QString s = street; | 690 | QString s = street; |
691 | if ( !street.isEmpty() ) | 691 | if ( !street.isEmpty() ) |
692 | s+= "\n"; | 692 | s+= "\n"; |
693 | s += city; | 693 | s += city; |
694 | if ( !city.isEmpty() && !state.isEmpty() ) | 694 | if ( !city.isEmpty() && !state.isEmpty() ) |
695 | s += ", "; | 695 | s += ", "; |
696 | s += state; | 696 | s += state; |
697 | if ( !state.isEmpty() && !zip.isEmpty() ) | 697 | if ( !state.isEmpty() && !zip.isEmpty() ) |
698 | s += " "; | 698 | s += " "; |
699 | s += zip; | 699 | s += zip; |
700 | if ( !country.isEmpty() && !s.isEmpty() ) | 700 | if ( !country.isEmpty() && !s.isEmpty() ) |
701 | s += "\n"; | 701 | s += "\n"; |
702 | s += country; | 702 | s += country; |
703 | return s; | 703 | return s; |
704 | } | 704 | } |
705 | 705 | ||
706 | /*! | 706 | /*! |
707 | \internal | 707 | \internal |
708 | */ | 708 | */ |
709 | QString OContact::displayBusinessAddress() const | 709 | QString OContact::displayBusinessAddress() const |
710 | { | 710 | { |
711 | return displayAddress( businessStreet(), businessCity(), | 711 | return displayAddress( businessStreet(), businessCity(), |
712 | businessState(), businessZip(), | 712 | businessState(), businessZip(), |
713 | businessCountry() ); | 713 | businessCountry() ); |
714 | } | 714 | } |
715 | 715 | ||
716 | /*! | 716 | /*! |
717 | \internal | 717 | \internal |
718 | */ | 718 | */ |
719 | QString OContact::displayHomeAddress() const | 719 | QString OContact::displayHomeAddress() const |
720 | { | 720 | { |
721 | return displayAddress( homeStreet(), homeCity(), | 721 | return displayAddress( homeStreet(), homeCity(), |
722 | homeState(), homeZip(), | 722 | homeState(), homeZip(), |
723 | homeCountry() ); | 723 | homeCountry() ); |
724 | } | 724 | } |
725 | 725 | ||
726 | /*! | 726 | /*! |
727 | Returns the full name of the contact | 727 | Returns the full name of the contact |
728 | */ | 728 | */ |
729 | QString OContact::fullName() const | 729 | QString OContact::fullName() const |
730 | { | 730 | { |
731 | QString title = find( Qtopia::Title ); | 731 | QString title = find( Qtopia::Title ); |
732 | QString firstName = find( Qtopia::FirstName ); | 732 | QString firstName = find( Qtopia::FirstName ); |
733 | QString middleName = find( Qtopia::MiddleName ); | 733 | QString middleName = find( Qtopia::MiddleName ); |
734 | QString lastName = find( Qtopia::LastName ); | 734 | QString lastName = find( Qtopia::LastName ); |
735 | QString suffix = find( Qtopia::Suffix ); | 735 | QString suffix = find( Qtopia::Suffix ); |
736 | 736 | ||
737 | QString name = title; | 737 | QString name = title; |
738 | if ( !firstName.isEmpty() ) { | 738 | if ( !firstName.isEmpty() ) { |
739 | if ( !name.isEmpty() ) | 739 | if ( !name.isEmpty() ) |
740 | name += " "; | 740 | name += " "; |
741 | name += firstName; | 741 | name += firstName; |
742 | } | 742 | } |
743 | if ( !middleName.isEmpty() ) { | 743 | if ( !middleName.isEmpty() ) { |
744 | if ( !name.isEmpty() ) | 744 | if ( !name.isEmpty() ) |
745 | name += " "; | 745 | name += " "; |
746 | name += middleName; | 746 | name += middleName; |
747 | } | 747 | } |
748 | if ( !lastName.isEmpty() ) { | 748 | if ( !lastName.isEmpty() ) { |
749 | if ( !name.isEmpty() ) | 749 | if ( !name.isEmpty() ) |
750 | name += " "; | 750 | name += " "; |
751 | name += lastName; | 751 | name += lastName; |
752 | } | 752 | } |
753 | if ( !suffix.isEmpty() ) { | 753 | if ( !suffix.isEmpty() ) { |
754 | if ( !name.isEmpty() ) | 754 | if ( !name.isEmpty() ) |
755 | name += " "; | 755 | name += " "; |
756 | name += suffix; | 756 | name += suffix; |
757 | } | 757 | } |
758 | return name.simplifyWhiteSpace(); | 758 | return name.simplifyWhiteSpace(); |
759 | } | 759 | } |
760 | 760 | ||
761 | /*! | 761 | /*! |
762 | Returns a list of the names of the children of the contact. | 762 | Returns a list of the names of the children of the contact. |
763 | */ | 763 | */ |
764 | QStringList OContact::childrenList() const | 764 | QStringList OContact::childrenList() const |
765 | { | 765 | { |
766 | return QStringList::split( " ", find( Qtopia::Children ) ); | 766 | return QStringList::split( " ", find( Qtopia::Children ) ); |
767 | } | 767 | } |
768 | 768 | ||
769 | /*! \fn void OContact::insertEmail( const QString &email ) | 769 | /*! \fn void OContact::insertEmail( const QString &email ) |
770 | 770 | ||
771 | Insert \a email into the email list. Ensures \a email can only be added | 771 | Insert \a email into the email list. Ensures \a email can only be added |
772 | once. If there is no default email address set, it sets it to the \a email. | 772 | once. If there is no default email address set, it sets it to the \a email. |
773 | */ | 773 | */ |
774 | 774 | ||
775 | /*! \fn void OContact::removeEmail( const QString &email ) | 775 | /*! \fn void OContact::removeEmail( const QString &email ) |
776 | 776 | ||
777 | Removes the \a email from the email list. If the default email was \a email, | 777 | Removes the \a email from the email list. If the default email was \a email, |
778 | then the default email address is assigned to the first email in the | 778 | then the default email address is assigned to the first email in the |
779 | email list | 779 | email list |
780 | */ | 780 | */ |
781 | 781 | ||
782 | /*! \fn void OContact::clearEmails() | 782 | /*! \fn void OContact::clearEmails() |
783 | 783 | ||
784 | Clears the email list. | 784 | Clears the email list. |
785 | */ | 785 | */ |
786 | 786 | ||
787 | /*! \fn void OContact::insertEmails( const QStringList &emailList ) | 787 | /*! \fn void OContact::insertEmails( const QStringList &emailList ) |
788 | 788 | ||
789 | Appends the \a emailList to the exiting email list | 789 | Appends the \a emailList to the exiting email list |
790 | */ | 790 | */ |
791 | 791 | ||
792 | /*! | 792 | /*! |
793 | Returns a list of email addresses belonging to the contact, including | 793 | Returns a list of email addresses belonging to the contact, including |
794 | the default email address. | 794 | the default email address. |
795 | */ | 795 | */ |
796 | QStringList OContact::emailList() const | 796 | QStringList OContact::emailList() const |
797 | { | 797 | { |
798 | QString emailStr = emails(); | 798 | QString emailStr = emails(); |
799 | 799 | ||
800 | QStringList r; | 800 | QStringList r; |
801 | if ( !emailStr.isEmpty() ) { | 801 | if ( !emailStr.isEmpty() ) { |
802 | qDebug(" emailstr "); | 802 | qDebug(" emailstr "); |
803 | QStringList l = QStringList::split( emailSeparator(), emailStr ); | 803 | QStringList l = QStringList::split( emailSeparator(), emailStr ); |
804 | for ( QStringList::ConstIterator it = l.begin();it != l.end();++it ) | 804 | for ( QStringList::ConstIterator it = l.begin();it != l.end();++it ) |
805 | r += (*it).simplifyWhiteSpace(); | 805 | r += (*it).simplifyWhiteSpace(); |
806 | } | 806 | } |
807 | 807 | ||
808 | return r; | 808 | return r; |
809 | } | 809 | } |
810 | 810 | ||
811 | /*! | 811 | /*! |
812 | \overload | 812 | \overload |
813 | 813 | ||
814 | Generates the string for the contact to be filed as from the first, | 814 | Generates the string for the contact to be filed as from the first, |
815 | middle and last name of the contact. | 815 | middle and last name of the contact. |
816 | */ | 816 | */ |
817 | void OContact::setFileAs() | 817 | void OContact::setFileAs() |
818 | { | 818 | { |
819 | QString lastName, firstName, middleName, fileas; | 819 | QString lastName, firstName, middleName, fileas; |
820 | 820 | ||
821 | lastName = find( Qtopia::LastName ); | 821 | lastName = find( Qtopia::LastName ); |
822 | firstName = find( Qtopia::FirstName ); | 822 | firstName = find( Qtopia::FirstName ); |
823 | middleName = find( Qtopia::MiddleName ); | 823 | middleName = find( Qtopia::MiddleName ); |
824 | if ( !lastName.isEmpty() && !firstName.isEmpty() | 824 | if ( !lastName.isEmpty() && !firstName.isEmpty() |
diff --git a/libopie2/opiepim/otodo.cpp b/libopie2/opiepim/otodo.cpp index cde2b3d..b4d4aa9 100644 --- a/libopie2/opiepim/otodo.cpp +++ b/libopie2/opiepim/otodo.cpp | |||
@@ -66,357 +66,357 @@ OTodo::OTodo(bool completed, int priority, | |||
66 | { | 66 | { |
67 | // qWarning("OTodoData " + summary); | 67 | // qWarning("OTodoData " + summary); |
68 | setCategories( category ); | 68 | setCategories( category ); |
69 | 69 | ||
70 | data = new OTodoData; | 70 | data = new OTodoData; |
71 | 71 | ||
72 | data->date = date; | 72 | data->date = date; |
73 | data->isCompleted = completed; | 73 | data->isCompleted = completed; |
74 | data->hasDate = hasDate; | 74 | data->hasDate = hasDate; |
75 | data->priority = priority; | 75 | data->priority = priority; |
76 | data->sum = summary; | 76 | data->sum = summary; |
77 | data->prog = progress; | 77 | data->prog = progress; |
78 | data->desc = Qtopia::simplifyMultiLineSpace(description ); | 78 | data->desc = Qtopia::simplifyMultiLineSpace(description ); |
79 | } | 79 | } |
80 | OTodo::OTodo(bool completed, int priority, | 80 | OTodo::OTodo(bool completed, int priority, |
81 | const QStringList &category, | 81 | const QStringList &category, |
82 | const QString& summary, | 82 | const QString& summary, |
83 | const QString &description, | 83 | const QString &description, |
84 | ushort progress, | 84 | ushort progress, |
85 | bool hasDate, QDate date, int uid ) | 85 | bool hasDate, QDate date, int uid ) |
86 | : OPimRecord( uid ) | 86 | : OPimRecord( uid ) |
87 | { | 87 | { |
88 | // qWarning("OTodoData" + summary); | 88 | // qWarning("OTodoData" + summary); |
89 | setCategories( idsFromString( category.join(";") ) ); | 89 | setCategories( idsFromString( category.join(";") ) ); |
90 | 90 | ||
91 | data = new OTodoData; | 91 | data = new OTodoData; |
92 | 92 | ||
93 | data->date = date; | 93 | data->date = date; |
94 | data->isCompleted = completed; | 94 | data->isCompleted = completed; |
95 | data->hasDate = hasDate; | 95 | data->hasDate = hasDate; |
96 | data->priority = priority; | 96 | data->priority = priority; |
97 | data->sum = summary; | 97 | data->sum = summary; |
98 | data->prog = progress; | 98 | data->prog = progress; |
99 | data->desc = Qtopia::simplifyMultiLineSpace(description ); | 99 | data->desc = Qtopia::simplifyMultiLineSpace(description ); |
100 | } | 100 | } |
101 | bool OTodo::match( const QRegExp ®Exp )const | 101 | bool OTodo::match( const QRegExp ®Exp )const |
102 | { | 102 | { |
103 | if( QString::number( data->priority ).find( regExp ) != -1 ){ | 103 | if( QString::number( data->priority ).find( regExp ) != -1 ){ |
104 | return true; | 104 | return true; |
105 | }else if( data->hasDate && data->date.toString().find( regExp) != -1 ){ | 105 | }else if( data->hasDate && data->date.toString().find( regExp) != -1 ){ |
106 | return true; | 106 | return true; |
107 | }else if(data->desc.find( regExp ) != -1 ){ | 107 | }else if(data->desc.find( regExp ) != -1 ){ |
108 | return true; | 108 | return true; |
109 | }else if(data->sum.find( regExp ) != -1 ) { | 109 | }else if(data->sum.find( regExp ) != -1 ) { |
110 | return true; | 110 | return true; |
111 | } | 111 | } |
112 | return false; | 112 | return false; |
113 | } | 113 | } |
114 | bool OTodo::isCompleted() const | 114 | bool OTodo::isCompleted() const |
115 | { | 115 | { |
116 | return data->isCompleted; | 116 | return data->isCompleted; |
117 | } | 117 | } |
118 | bool OTodo::hasDueDate() const | 118 | bool OTodo::hasDueDate() const |
119 | { | 119 | { |
120 | return data->hasDate; | 120 | return data->hasDate; |
121 | } | 121 | } |
122 | bool OTodo::hasStartDate()const { | 122 | bool OTodo::hasStartDate()const { |
123 | return data->start.isValid(); | 123 | return data->start.isValid(); |
124 | } | 124 | } |
125 | bool OTodo::hasCompletedDate()const { | 125 | bool OTodo::hasCompletedDate()const { |
126 | return data->completed.isValid(); | 126 | return data->completed.isValid(); |
127 | } | 127 | } |
128 | int OTodo::priority()const | 128 | int OTodo::priority()const |
129 | { | 129 | { |
130 | return data->priority; | 130 | return data->priority; |
131 | } | 131 | } |
132 | QString OTodo::summary() const | 132 | QString OTodo::summary() const |
133 | { | 133 | { |
134 | return data->sum; | 134 | return data->sum; |
135 | } | 135 | } |
136 | ushort OTodo::progress() const | 136 | ushort OTodo::progress() const |
137 | { | 137 | { |
138 | return data->prog; | 138 | return data->prog; |
139 | } | 139 | } |
140 | QDate OTodo::dueDate()const | 140 | QDate OTodo::dueDate()const |
141 | { | 141 | { |
142 | return data->date; | 142 | return data->date; |
143 | } | 143 | } |
144 | QDate OTodo::startDate()const { | 144 | QDate OTodo::startDate()const { |
145 | return data->start; | 145 | return data->start; |
146 | } | 146 | } |
147 | QDate OTodo::completedDate()const { | 147 | QDate OTodo::completedDate()const { |
148 | return data->completed; | 148 | return data->completed; |
149 | } | 149 | } |
150 | QString OTodo::description()const | 150 | QString OTodo::description()const |
151 | { | 151 | { |
152 | return data->desc; | 152 | return data->desc; |
153 | } | 153 | } |
154 | OPimState OTodo::state()const { | 154 | OPimState OTodo::state()const { |
155 | return data->state; | 155 | return data->state; |
156 | } | 156 | } |
157 | ORecur OTodo::recurrence()const { | 157 | ORecur OTodo::recurrence()const { |
158 | return data->recur; | 158 | return data->recur; |
159 | } | 159 | } |
160 | OPimMaintainer OTodo::maintainer()const { | 160 | OPimMaintainer OTodo::maintainer()const { |
161 | return data->maintainer; | 161 | return data->maintainer; |
162 | } | 162 | } |
163 | void OTodo::setCompleted( bool completed ) | 163 | void OTodo::setCompleted( bool completed ) |
164 | { | 164 | { |
165 | changeOrModify(); | 165 | changeOrModify(); |
166 | data->isCompleted = completed; | 166 | data->isCompleted = completed; |
167 | } | 167 | } |
168 | void OTodo::setHasDueDate( bool hasDate ) | 168 | void OTodo::setHasDueDate( bool hasDate ) |
169 | { | 169 | { |
170 | changeOrModify(); | 170 | changeOrModify(); |
171 | data->hasDate = hasDate; | 171 | data->hasDate = hasDate; |
172 | } | 172 | } |
173 | void OTodo::setDescription(const QString &desc ) | 173 | void OTodo::setDescription(const QString &desc ) |
174 | { | 174 | { |
175 | // qWarning( "desc " + desc ); | 175 | // qWarning( "desc " + desc ); |
176 | changeOrModify(); | 176 | changeOrModify(); |
177 | data->desc = Qtopia::simplifyMultiLineSpace(desc ); | 177 | data->desc = Qtopia::simplifyMultiLineSpace(desc ); |
178 | } | 178 | } |
179 | void OTodo::setSummary( const QString& sum ) | 179 | void OTodo::setSummary( const QString& sum ) |
180 | { | 180 | { |
181 | changeOrModify(); | 181 | changeOrModify(); |
182 | data->sum = sum; | 182 | data->sum = sum; |
183 | } | 183 | } |
184 | void OTodo::setPriority(int prio ) | 184 | void OTodo::setPriority(int prio ) |
185 | { | 185 | { |
186 | changeOrModify(); | 186 | changeOrModify(); |
187 | data->priority = prio; | 187 | data->priority = prio; |
188 | } | 188 | } |
189 | void OTodo::setDueDate( const QDate& date ) | 189 | void OTodo::setDueDate( const QDate& date ) |
190 | { | 190 | { |
191 | changeOrModify(); | 191 | changeOrModify(); |
192 | data->date = date; | 192 | data->date = date; |
193 | } | 193 | } |
194 | void OTodo::setStartDate( const QDate& date ) { | 194 | void OTodo::setStartDate( const QDate& date ) { |
195 | changeOrModify(); | 195 | changeOrModify(); |
196 | data->start = date; | 196 | data->start = date; |
197 | } | 197 | } |
198 | void OTodo::setCompletedDate( const QDate& date ) { | 198 | void OTodo::setCompletedDate( const QDate& date ) { |
199 | changeOrModify(); | 199 | changeOrModify(); |
200 | data->completed = date; | 200 | data->completed = date; |
201 | } | 201 | } |
202 | void OTodo::setState( const OPimState& state ) { | 202 | void OTodo::setState( const OPimState& state ) { |
203 | changeOrModify(); | 203 | changeOrModify(); |
204 | data->state = state; | 204 | data->state = state; |
205 | } | 205 | } |
206 | void OTodo::setRecurrence( const ORecur& rec) { | 206 | void OTodo::setRecurrence( const ORecur& rec) { |
207 | changeOrModify(); | 207 | changeOrModify(); |
208 | data->recur = rec; | 208 | data->recur = rec; |
209 | } | 209 | } |
210 | void OTodo::setMaintainer( const OPimMaintainer& pim ) { | 210 | void OTodo::setMaintainer( const OPimMaintainer& pim ) { |
211 | changeOrModify(); | 211 | changeOrModify(); |
212 | data->maintainer = pim; | 212 | data->maintainer = pim; |
213 | } | 213 | } |
214 | bool OTodo::isOverdue( ) | 214 | bool OTodo::isOverdue( ) |
215 | { | 215 | { |
216 | if( data->hasDate && !data->isCompleted) | 216 | if( data->hasDate && !data->isCompleted) |
217 | return QDate::currentDate() > data->date; | 217 | return QDate::currentDate() > data->date; |
218 | return false; | 218 | return false; |
219 | } | 219 | } |
220 | void OTodo::setProgress(ushort progress ) | 220 | void OTodo::setProgress(ushort progress ) |
221 | { | 221 | { |
222 | changeOrModify(); | 222 | changeOrModify(); |
223 | data->prog = progress; | 223 | data->prog = progress; |
224 | } | 224 | } |
225 | QString OTodo::toShortText() const { | 225 | QString OTodo::toShortText() const { |
226 | return summary(); | 226 | return summary(); |
227 | } | 227 | } |
228 | /*! | 228 | /*! |
229 | Returns a richt text string | 229 | Returns a richt text string |
230 | */ | 230 | */ |
231 | QString OTodo::toRichText() const | 231 | QString OTodo::toRichText() const |
232 | { | 232 | { |
233 | QString text; | 233 | QString text; |
234 | QStringList catlist; | 234 | QStringList catlist; |
235 | 235 | ||
236 | // Description of the todo | 236 | // Description of the todo |
237 | if ( !summary().isEmpty() ) { | 237 | if ( !summary().isEmpty() ) { |
238 | text += "<b>" + QObject::tr( "Summary:") + "</b><br>"; | 238 | text += "<b>" + QObject::tr( "Summary:") + "</b><br>"; |
239 | text += Qtopia::escapeString(summary() ).replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; | 239 | text += Qtopia::escapeString(summary() ).replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; |
240 | } | 240 | } |
241 | if( !description().isEmpty() ){ | 241 | if( !description().isEmpty() ){ |
242 | text += "<b>" + QObject::tr( "Description:" ) + "</b><br>"; | 242 | text += "<b>" + QObject::tr( "Description:" ) + "</b><br>"; |
243 | text += Qtopia::escapeString(description() ).replace(QRegExp( "[\n]"), "<br>" ) ; | 243 | text += Qtopia::escapeString(description() ).replace(QRegExp( "[\n]"), "<br>" ) ; |
244 | } | 244 | } |
245 | text += "<br><br><br>"; | 245 | text += "<br><br><br>"; |
246 | 246 | ||
247 | text += "<b>" + QObject::tr( "Priority:") +" </b>" | 247 | text += "<b>" + QObject::tr( "Priority:") +" </b>" |
248 | + QString::number( priority() ) + " <br>"; | 248 | + QString::number( priority() ) + " <br>"; |
249 | text += "<b>" + QObject::tr( "Progress:") + " </b>" | 249 | text += "<b>" + QObject::tr( "Progress:") + " </b>" |
250 | + QString::number( progress() ) + " %<br>"; | 250 | + QString::number( progress() ) + " %<br>"; |
251 | if (hasDueDate() ){ | 251 | if (hasDueDate() ){ |
252 | text += "<b>" + QObject::tr( "Deadline:") + " </b>"; | 252 | text += "<b>" + QObject::tr( "Deadline:") + " </b>"; |
253 | text += dueDate().toString(); | 253 | text += dueDate().toString(); |
254 | text += "<br>"; | 254 | text += "<br>"; |
255 | } | 255 | } |
256 | 256 | ||
257 | text += "<b>" + QObject::tr( "Category:") + "</b> "; | 257 | text += "<b>" + QObject::tr( "Category:") + "</b> "; |
258 | text += categoryNames().join(", "); | 258 | text += categoryNames( "Todo List" ).join(", "); |
259 | text += "<br>"; | 259 | text += "<br>"; |
260 | 260 | ||
261 | return text; | 261 | return text; |
262 | } | 262 | } |
263 | OPimNotifyManager& OTodo::notifiers() { | 263 | OPimNotifyManager& OTodo::notifiers() { |
264 | return data->notifiers; | 264 | return data->notifiers; |
265 | } | 265 | } |
266 | 266 | ||
267 | bool OTodo::operator<( const OTodo &toDoEvent )const{ | 267 | bool OTodo::operator<( const OTodo &toDoEvent )const{ |
268 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; | 268 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; |
269 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; | 269 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; |
270 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 270 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
271 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 271 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
272 | return priority() < toDoEvent.priority(); | 272 | return priority() < toDoEvent.priority(); |
273 | }else{ | 273 | }else{ |
274 | return dueDate() < toDoEvent.dueDate(); | 274 | return dueDate() < toDoEvent.dueDate(); |
275 | } | 275 | } |
276 | } | 276 | } |
277 | return false; | 277 | return false; |
278 | } | 278 | } |
279 | bool OTodo::operator<=(const OTodo &toDoEvent )const | 279 | bool OTodo::operator<=(const OTodo &toDoEvent )const |
280 | { | 280 | { |
281 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; | 281 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; |
282 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return true; | 282 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return true; |
283 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 283 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
284 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 284 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
285 | return priority() <= toDoEvent.priority(); | 285 | return priority() <= toDoEvent.priority(); |
286 | }else{ | 286 | }else{ |
287 | return dueDate() <= toDoEvent.dueDate(); | 287 | return dueDate() <= toDoEvent.dueDate(); |
288 | } | 288 | } |
289 | } | 289 | } |
290 | return true; | 290 | return true; |
291 | } | 291 | } |
292 | bool OTodo::operator>(const OTodo &toDoEvent )const | 292 | bool OTodo::operator>(const OTodo &toDoEvent )const |
293 | { | 293 | { |
294 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return false; | 294 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return false; |
295 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; | 295 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; |
296 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 296 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
297 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 297 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
298 | return priority() > toDoEvent.priority(); | 298 | return priority() > toDoEvent.priority(); |
299 | }else{ | 299 | }else{ |
300 | return dueDate() > toDoEvent.dueDate(); | 300 | return dueDate() > toDoEvent.dueDate(); |
301 | } | 301 | } |
302 | } | 302 | } |
303 | return false; | 303 | return false; |
304 | } | 304 | } |
305 | bool OTodo::operator>=(const OTodo &toDoEvent )const | 305 | bool OTodo::operator>=(const OTodo &toDoEvent )const |
306 | { | 306 | { |
307 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; | 307 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; |
308 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; | 308 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; |
309 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 309 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
310 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 310 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
311 | return priority() > toDoEvent.priority(); | 311 | return priority() > toDoEvent.priority(); |
312 | }else{ | 312 | }else{ |
313 | return dueDate() > toDoEvent.dueDate(); | 313 | return dueDate() > toDoEvent.dueDate(); |
314 | } | 314 | } |
315 | } | 315 | } |
316 | return true; | 316 | return true; |
317 | } | 317 | } |
318 | bool OTodo::operator==(const OTodo &toDoEvent )const | 318 | bool OTodo::operator==(const OTodo &toDoEvent )const |
319 | { | 319 | { |
320 | if ( data->priority != toDoEvent.data->priority ) return false; | 320 | if ( data->priority != toDoEvent.data->priority ) return false; |
321 | if ( data->priority != toDoEvent.data->prog ) return false; | 321 | if ( data->priority != toDoEvent.data->prog ) return false; |
322 | if ( data->isCompleted != toDoEvent.data->isCompleted ) return false; | 322 | if ( data->isCompleted != toDoEvent.data->isCompleted ) return false; |
323 | if ( data->hasDate != toDoEvent.data->hasDate ) return false; | 323 | if ( data->hasDate != toDoEvent.data->hasDate ) return false; |
324 | if ( data->date != toDoEvent.data->date ) return false; | 324 | if ( data->date != toDoEvent.data->date ) return false; |
325 | if ( data->sum != toDoEvent.data->sum ) return false; | 325 | if ( data->sum != toDoEvent.data->sum ) return false; |
326 | if ( data->desc != toDoEvent.data->desc ) return false; | 326 | if ( data->desc != toDoEvent.data->desc ) return false; |
327 | if ( data->maintainer != toDoEvent.data->maintainer ) | 327 | if ( data->maintainer != toDoEvent.data->maintainer ) |
328 | return false; | 328 | return false; |
329 | 329 | ||
330 | return OPimRecord::operator==( toDoEvent ); | 330 | return OPimRecord::operator==( toDoEvent ); |
331 | } | 331 | } |
332 | void OTodo::deref() { | 332 | void OTodo::deref() { |
333 | 333 | ||
334 | // qWarning("deref in ToDoEvent"); | 334 | // qWarning("deref in ToDoEvent"); |
335 | if ( data->deref() ) { | 335 | if ( data->deref() ) { |
336 | // qWarning("deleting"); | 336 | // qWarning("deleting"); |
337 | delete data; | 337 | delete data; |
338 | data= 0; | 338 | data= 0; |
339 | } | 339 | } |
340 | } | 340 | } |
341 | OTodo &OTodo::operator=(const OTodo &item ) | 341 | OTodo &OTodo::operator=(const OTodo &item ) |
342 | { | 342 | { |
343 | OPimRecord::operator=( item ); | 343 | OPimRecord::operator=( item ); |
344 | //qWarning("operator= ref "); | 344 | //qWarning("operator= ref "); |
345 | item.data->ref(); | 345 | item.data->ref(); |
346 | deref(); | 346 | deref(); |
347 | data = item.data; | 347 | data = item.data; |
348 | 348 | ||
349 | return *this; | 349 | return *this; |
350 | } | 350 | } |
351 | 351 | ||
352 | QMap<int, QString> OTodo::toMap() const { | 352 | QMap<int, QString> OTodo::toMap() const { |
353 | QMap<int, QString> map; | 353 | QMap<int, QString> map; |
354 | 354 | ||
355 | map.insert( Uid, QString::number( uid() ) ); | 355 | map.insert( Uid, QString::number( uid() ) ); |
356 | map.insert( Category, idsToString( categories() ) ); | 356 | map.insert( Category, idsToString( categories() ) ); |
357 | map.insert( HasDate, QString::number( data->hasDate ) ); | 357 | map.insert( HasDate, QString::number( data->hasDate ) ); |
358 | map.insert( Completed, QString::number( data->isCompleted ) ); | 358 | map.insert( Completed, QString::number( data->isCompleted ) ); |
359 | map.insert( Description, data->desc ); | 359 | map.insert( Description, data->desc ); |
360 | map.insert( Summary, data->sum ); | 360 | map.insert( Summary, data->sum ); |
361 | map.insert( Priority, QString::number( data->priority ) ); | 361 | map.insert( Priority, QString::number( data->priority ) ); |
362 | map.insert( DateDay, QString::number( data->date.day() ) ); | 362 | map.insert( DateDay, QString::number( data->date.day() ) ); |
363 | map.insert( DateMonth, QString::number( data->date.month() ) ); | 363 | map.insert( DateMonth, QString::number( data->date.month() ) ); |
364 | map.insert( DateYear, QString::number( data->date.year() ) ); | 364 | map.insert( DateYear, QString::number( data->date.year() ) ); |
365 | map.insert( Progress, QString::number( data->prog ) ); | 365 | map.insert( Progress, QString::number( data->prog ) ); |
366 | // map.insert( CrossReference, crossToString() ); | 366 | // map.insert( CrossReference, crossToString() ); |
367 | /* FIXME!!! map.insert( State, ); | 367 | /* FIXME!!! map.insert( State, ); |
368 | map.insert( Recurrence, ); | 368 | map.insert( Recurrence, ); |
369 | map.insert( Reminders, ); | 369 | map.insert( Reminders, ); |
370 | map. | 370 | map. |
371 | */ | 371 | */ |
372 | return map; | 372 | return map; |
373 | } | 373 | } |
374 | 374 | ||
375 | QMap<QString, QString> OTodo::toExtraMap()const { | 375 | QMap<QString, QString> OTodo::toExtraMap()const { |
376 | return data->extra; | 376 | return data->extra; |
377 | } | 377 | } |
378 | /** | 378 | /** |
379 | * change or modify looks at the ref count and either | 379 | * change or modify looks at the ref count and either |
380 | * creates a new QShared Object or it can modify it | 380 | * creates a new QShared Object or it can modify it |
381 | * right in place | 381 | * right in place |
382 | */ | 382 | */ |
383 | void OTodo::changeOrModify() { | 383 | void OTodo::changeOrModify() { |
384 | if ( data->count != 1 ) { | 384 | if ( data->count != 1 ) { |
385 | qWarning("changeOrModify"); | 385 | qWarning("changeOrModify"); |
386 | data->deref(); | 386 | data->deref(); |
387 | OTodoData* d2 = new OTodoData(); | 387 | OTodoData* d2 = new OTodoData(); |
388 | copy(data, d2 ); | 388 | copy(data, d2 ); |
389 | data = d2; | 389 | data = d2; |
390 | } | 390 | } |
391 | } | 391 | } |
392 | // WATCHOUT | 392 | // WATCHOUT |
393 | /* | 393 | /* |
394 | * if you add something to the Data struct | 394 | * if you add something to the Data struct |
395 | * be sure to copy it here | 395 | * be sure to copy it here |
396 | */ | 396 | */ |
397 | void OTodo::copy( OTodoData* src, OTodoData* dest ) { | 397 | void OTodo::copy( OTodoData* src, OTodoData* dest ) { |
398 | dest->date = src->date; | 398 | dest->date = src->date; |
399 | dest->isCompleted = src->isCompleted; | 399 | dest->isCompleted = src->isCompleted; |
400 | dest->hasDate = src->hasDate; | 400 | dest->hasDate = src->hasDate; |
401 | dest->priority = src->priority; | 401 | dest->priority = src->priority; |
402 | dest->desc = src->desc; | 402 | dest->desc = src->desc; |
403 | dest->sum = src->sum; | 403 | dest->sum = src->sum; |
404 | dest->extra = src->extra; | 404 | dest->extra = src->extra; |
405 | dest->prog = src->prog; | 405 | dest->prog = src->prog; |
406 | dest->state = src->state; | 406 | dest->state = src->state; |
407 | dest->recur = src->recur; | 407 | dest->recur = src->recur; |
408 | dest->maintainer = src->maintainer; | 408 | dest->maintainer = src->maintainer; |
409 | dest->start = src->start; | 409 | dest->start = src->start; |
410 | dest->completed = src->completed; | 410 | dest->completed = src->completed; |
411 | dest->notifiers = src->notifiers; | 411 | dest->notifiers = src->notifiers; |
412 | } | 412 | } |
413 | QString OTodo::type() const { | 413 | QString OTodo::type() const { |
414 | return QString::fromLatin1("OTodo"); | 414 | return QString::fromLatin1("OTodo"); |
415 | } | 415 | } |
416 | QString OTodo::recordField(int /*id*/ )const { | 416 | QString OTodo::recordField(int /*id*/ )const { |
417 | return QString::null; | 417 | return QString::null; |
418 | } | 418 | } |
419 | 419 | ||
420 | int OTodo::rtti(){ | 420 | int OTodo::rtti(){ |
421 | return OPimResolver::TodoList; | 421 | return OPimResolver::TodoList; |
422 | } | 422 | } |