-rw-r--r-- | libopie/pim/ocontact.cpp | 1 | ||||
-rw-r--r-- | libopie/pim/ocontact.h | 4 | ||||
-rw-r--r-- | libopie/pim/opimrecord.cpp | 8 | ||||
-rw-r--r-- | libopie/pim/opimrecord.h | 15 | ||||
-rw-r--r-- | libopie2/opiepim/core/opimrecord.cpp | 8 | ||||
-rw-r--r-- | libopie2/opiepim/core/opimrecord.h | 15 | ||||
-rw-r--r-- | libopie2/opiepim/ocontact.cpp | 1 | ||||
-rw-r--r-- | libopie2/opiepim/ocontact.h | 4 |
8 files changed, 44 insertions, 12 deletions
diff --git a/libopie/pim/ocontact.cpp b/libopie/pim/ocontact.cpp index aeb69ee..a7ca975 100644 --- a/libopie/pim/ocontact.cpp +++ b/libopie/pim/ocontact.cpp | |||
@@ -572,567 +572,568 @@ QString OContact::toRichText() const | |||
572 | text += "<b>" + QObject::tr("Home Mobile: ") + "</b>" | 572 | text += "<b>" + QObject::tr("Home Mobile: ") + "</b>" |
573 | + Qtopia::escapeString(str) + "<br>"; | 573 | + Qtopia::escapeString(str) + "<br>"; |
574 | marker = true; | 574 | marker = true; |
575 | } | 575 | } |
576 | 576 | ||
577 | if ( marker ) | 577 | if ( marker ) |
578 | text += "<br><hr><br>"; | 578 | text += "<br><hr><br>"; |
579 | // the others... | 579 | // the others... |
580 | str = emails(); | 580 | str = emails(); |
581 | if ( !str.isEmpty() && ( str != defEmail ) ) | 581 | if ( !str.isEmpty() && ( str != defEmail ) ) |
582 | text += "<b>" + QObject::tr("All Emails: ") + "</b>" | 582 | text += "<b>" + QObject::tr("All Emails: ") + "</b>" |
583 | + Qtopia::escapeString(str) + "<br>"; | 583 | + Qtopia::escapeString(str) + "<br>"; |
584 | str = profession(); | 584 | str = profession(); |
585 | if ( !str.isEmpty() ) | 585 | if ( !str.isEmpty() ) |
586 | text += "<b>" + QObject::tr("Profession: ") + "</b>" | 586 | text += "<b>" + QObject::tr("Profession: ") + "</b>" |
587 | + Qtopia::escapeString(str) + "<br>"; | 587 | + Qtopia::escapeString(str) + "<br>"; |
588 | str = assistant(); | 588 | str = assistant(); |
589 | if ( !str.isEmpty() ) | 589 | if ( !str.isEmpty() ) |
590 | text += "<b>" + QObject::tr("Assistant: ") + "</b>" | 590 | text += "<b>" + QObject::tr("Assistant: ") + "</b>" |
591 | + Qtopia::escapeString(str) + "<br>"; | 591 | + Qtopia::escapeString(str) + "<br>"; |
592 | str = manager(); | 592 | str = manager(); |
593 | if ( !str.isEmpty() ) | 593 | if ( !str.isEmpty() ) |
594 | text += "<b>" + QObject::tr("Manager: ") + "</b>" | 594 | text += "<b>" + QObject::tr("Manager: ") + "</b>" |
595 | + Qtopia::escapeString(str) + "<br>"; | 595 | + Qtopia::escapeString(str) + "<br>"; |
596 | str = gender(); | 596 | str = gender(); |
597 | if ( !str.isEmpty() && str.toInt() != 0 ) { | 597 | if ( !str.isEmpty() && str.toInt() != 0 ) { |
598 | if ( str.toInt() == 1 ) | 598 | if ( str.toInt() == 1 ) |
599 | str = QObject::tr( "Male" ); | 599 | str = QObject::tr( "Male" ); |
600 | else if ( str.toInt() == 2 ) | 600 | else if ( str.toInt() == 2 ) |
601 | str = QObject::tr( "Female" ); | 601 | str = QObject::tr( "Female" ); |
602 | text += "<b>" + QObject::tr("Gender: ") + "</b>" + str + "<br>"; | 602 | text += "<b>" + QObject::tr("Gender: ") + "</b>" + str + "<br>"; |
603 | } | 603 | } |
604 | str = spouse(); | 604 | str = spouse(); |
605 | if ( !str.isEmpty() ) | 605 | if ( !str.isEmpty() ) |
606 | text += "<b>" + QObject::tr("Spouse: ") + "</b>" | 606 | text += "<b>" + QObject::tr("Spouse: ") + "</b>" |
607 | + Qtopia::escapeString(str) + "<br>"; | 607 | + Qtopia::escapeString(str) + "<br>"; |
608 | if ( birthday().isValid() ){ | 608 | if ( birthday().isValid() ){ |
609 | str = TimeString::numberDateString( birthday() ); | 609 | str = TimeString::numberDateString( birthday() ); |
610 | text += "<b>" + QObject::tr("Birthday: ") + "</b>" | 610 | text += "<b>" + QObject::tr("Birthday: ") + "</b>" |
611 | + Qtopia::escapeString(str) + "<br>"; | 611 | + Qtopia::escapeString(str) + "<br>"; |
612 | } | 612 | } |
613 | if ( anniversary().isValid() ){ | 613 | if ( anniversary().isValid() ){ |
614 | str = TimeString::numberDateString( anniversary() ); | 614 | str = TimeString::numberDateString( anniversary() ); |
615 | text += "<b>" + QObject::tr("Anniversary: ") + "</b>" | 615 | text += "<b>" + QObject::tr("Anniversary: ") + "</b>" |
616 | + Qtopia::escapeString(str) + "<br>"; | 616 | + Qtopia::escapeString(str) + "<br>"; |
617 | } | 617 | } |
618 | str = children(); | 618 | str = children(); |
619 | if ( !str.isEmpty() ) | 619 | if ( !str.isEmpty() ) |
620 | text += "<b>" + QObject::tr("Children: ") + "</b>" | 620 | text += "<b>" + QObject::tr("Children: ") + "</b>" |
621 | + Qtopia::escapeString(str) + "<br>"; | 621 | + Qtopia::escapeString(str) + "<br>"; |
622 | 622 | ||
623 | str = nickname(); | 623 | str = nickname(); |
624 | if ( !str.isEmpty() ) | 624 | if ( !str.isEmpty() ) |
625 | text += "<b>" + QObject::tr("Nickname: ") + "</b>" | 625 | text += "<b>" + QObject::tr("Nickname: ") + "</b>" |
626 | + Qtopia::escapeString(str) + "<br>"; | 626 | + Qtopia::escapeString(str) + "<br>"; |
627 | 627 | ||
628 | if ( categoryNames("Contacts").count() ){ | 628 | if ( categoryNames("Contacts").count() ){ |
629 | text += "<b>" + QObject::tr( "Category:") + "</b> "; | 629 | text += "<b>" + QObject::tr( "Category:") + "</b> "; |
630 | text += categoryNames("Contacts").join(", "); | 630 | text += categoryNames("Contacts").join(", "); |
631 | text += "<br>"; | 631 | text += "<br>"; |
632 | } | 632 | } |
633 | 633 | ||
634 | // notes last | 634 | // notes last |
635 | if ( !(value = notes()).isEmpty() ) { | 635 | if ( !(value = notes()).isEmpty() ) { |
636 | text += "<br><hr><b>" + QObject::tr( "Notes:") + "</b> "; | 636 | text += "<br><hr><b>" + QObject::tr( "Notes:") + "</b> "; |
637 | QRegExp reg("\n"); | 637 | QRegExp reg("\n"); |
638 | 638 | ||
639 | //QString tmp = Qtopia::escapeString(value); | 639 | //QString tmp = Qtopia::escapeString(value); |
640 | QString tmp = QStyleSheet::convertFromPlainText(value); | 640 | QString tmp = QStyleSheet::convertFromPlainText(value); |
641 | //tmp.replace( reg, "<br>" ); | 641 | //tmp.replace( reg, "<br>" ); |
642 | text += "<br>" + tmp + "<br>"; | 642 | text += "<br>" + tmp + "<br>"; |
643 | } | 643 | } |
644 | return text; | 644 | return text; |
645 | } | 645 | } |
646 | 646 | ||
647 | /*! | 647 | /*! |
648 | \internal | 648 | \internal |
649 | */ | 649 | */ |
650 | void OContact::insert( int key, const QString &v ) | 650 | void OContact::insert( int key, const QString &v ) |
651 | { | 651 | { |
652 | QString value = v.stripWhiteSpace(); | 652 | QString value = v.stripWhiteSpace(); |
653 | if ( value.isEmpty() ) | 653 | if ( value.isEmpty() ) |
654 | mMap.remove( key ); | 654 | mMap.remove( key ); |
655 | else | 655 | else |
656 | mMap.insert( key, value ); | 656 | mMap.insert( key, value ); |
657 | } | 657 | } |
658 | 658 | ||
659 | /*! | 659 | /*! |
660 | \internal | 660 | \internal |
661 | */ | 661 | */ |
662 | void OContact::replace( int key, const QString & v ) | 662 | void OContact::replace( int key, const QString & v ) |
663 | { | 663 | { |
664 | QString value = v.stripWhiteSpace(); | 664 | QString value = v.stripWhiteSpace(); |
665 | if ( value.isEmpty() ) | 665 | if ( value.isEmpty() ) |
666 | mMap.remove( key ); | 666 | mMap.remove( key ); |
667 | else | 667 | else |
668 | mMap.replace( key, value ); | 668 | mMap.replace( key, value ); |
669 | } | 669 | } |
670 | 670 | ||
671 | /*! | 671 | /*! |
672 | \internal | 672 | \internal |
673 | */ | 673 | */ |
674 | QString OContact::find( int key ) const | 674 | QString OContact::find( int key ) const |
675 | { | 675 | { |
676 | return mMap[key]; | 676 | return mMap[key]; |
677 | } | 677 | } |
678 | 678 | ||
679 | /*! | 679 | /*! |
680 | \internal | 680 | \internal |
681 | */ | 681 | */ |
682 | QString OContact::displayAddress( const QString &street, | 682 | QString OContact::displayAddress( const QString &street, |
683 | const QString &city, | 683 | const QString &city, |
684 | const QString &state, | 684 | const QString &state, |
685 | const QString &zip, | 685 | const QString &zip, |
686 | const QString &country ) const | 686 | const QString &country ) const |
687 | { | 687 | { |
688 | QString s = street; | 688 | QString s = street; |
689 | if ( !street.isEmpty() ) | 689 | if ( !street.isEmpty() ) |
690 | s+= "\n"; | 690 | s+= "\n"; |
691 | s += city; | 691 | s += city; |
692 | if ( !city.isEmpty() && !state.isEmpty() ) | 692 | if ( !city.isEmpty() && !state.isEmpty() ) |
693 | s += ", "; | 693 | s += ", "; |
694 | s += state; | 694 | s += state; |
695 | if ( !state.isEmpty() && !zip.isEmpty() ) | 695 | if ( !state.isEmpty() && !zip.isEmpty() ) |
696 | s += " "; | 696 | s += " "; |
697 | s += zip; | 697 | s += zip; |
698 | if ( !country.isEmpty() && !s.isEmpty() ) | 698 | if ( !country.isEmpty() && !s.isEmpty() ) |
699 | s += "\n"; | 699 | s += "\n"; |
700 | s += country; | 700 | s += country; |
701 | return s; | 701 | return s; |
702 | } | 702 | } |
703 | 703 | ||
704 | /*! | 704 | /*! |
705 | \internal | 705 | \internal |
706 | */ | 706 | */ |
707 | QString OContact::displayBusinessAddress() const | 707 | QString OContact::displayBusinessAddress() const |
708 | { | 708 | { |
709 | return displayAddress( businessStreet(), businessCity(), | 709 | return displayAddress( businessStreet(), businessCity(), |
710 | businessState(), businessZip(), | 710 | businessState(), businessZip(), |
711 | businessCountry() ); | 711 | businessCountry() ); |
712 | } | 712 | } |
713 | 713 | ||
714 | /*! | 714 | /*! |
715 | \internal | 715 | \internal |
716 | */ | 716 | */ |
717 | QString OContact::displayHomeAddress() const | 717 | QString OContact::displayHomeAddress() const |
718 | { | 718 | { |
719 | return displayAddress( homeStreet(), homeCity(), | 719 | return displayAddress( homeStreet(), homeCity(), |
720 | homeState(), homeZip(), | 720 | homeState(), homeZip(), |
721 | homeCountry() ); | 721 | homeCountry() ); |
722 | } | 722 | } |
723 | 723 | ||
724 | /*! | 724 | /*! |
725 | Returns the full name of the contact | 725 | Returns the full name of the contact |
726 | */ | 726 | */ |
727 | QString OContact::fullName() const | 727 | QString OContact::fullName() const |
728 | { | 728 | { |
729 | QString title = find( Qtopia::Title ); | 729 | QString title = find( Qtopia::Title ); |
730 | QString firstName = find( Qtopia::FirstName ); | 730 | QString firstName = find( Qtopia::FirstName ); |
731 | QString middleName = find( Qtopia::MiddleName ); | 731 | QString middleName = find( Qtopia::MiddleName ); |
732 | QString lastName = find( Qtopia::LastName ); | 732 | QString lastName = find( Qtopia::LastName ); |
733 | QString suffix = find( Qtopia::Suffix ); | 733 | QString suffix = find( Qtopia::Suffix ); |
734 | 734 | ||
735 | QString name = title; | 735 | QString name = title; |
736 | if ( !firstName.isEmpty() ) { | 736 | if ( !firstName.isEmpty() ) { |
737 | if ( !name.isEmpty() ) | 737 | if ( !name.isEmpty() ) |
738 | name += " "; | 738 | name += " "; |
739 | name += firstName; | 739 | name += firstName; |
740 | } | 740 | } |
741 | if ( !middleName.isEmpty() ) { | 741 | if ( !middleName.isEmpty() ) { |
742 | if ( !name.isEmpty() ) | 742 | if ( !name.isEmpty() ) |
743 | name += " "; | 743 | name += " "; |
744 | name += middleName; | 744 | name += middleName; |
745 | } | 745 | } |
746 | if ( !lastName.isEmpty() ) { | 746 | if ( !lastName.isEmpty() ) { |
747 | if ( !name.isEmpty() ) | 747 | if ( !name.isEmpty() ) |
748 | name += " "; | 748 | name += " "; |
749 | name += lastName; | 749 | name += lastName; |
750 | } | 750 | } |
751 | if ( !suffix.isEmpty() ) { | 751 | if ( !suffix.isEmpty() ) { |
752 | if ( !name.isEmpty() ) | 752 | if ( !name.isEmpty() ) |
753 | name += " "; | 753 | name += " "; |
754 | name += suffix; | 754 | name += suffix; |
755 | } | 755 | } |
756 | return name.simplifyWhiteSpace(); | 756 | return name.simplifyWhiteSpace(); |
757 | } | 757 | } |
758 | 758 | ||
759 | /*! | 759 | /*! |
760 | Returns a list of the names of the children of the contact. | 760 | Returns a list of the names of the children of the contact. |
761 | */ | 761 | */ |
762 | QStringList OContact::childrenList() const | 762 | QStringList OContact::childrenList() const |
763 | { | 763 | { |
764 | return QStringList::split( " ", find( Qtopia::Children ) ); | 764 | return QStringList::split( " ", find( Qtopia::Children ) ); |
765 | } | 765 | } |
766 | 766 | ||
767 | /*! \fn void OContact::insertEmail( const QString &email ) | 767 | /*! \fn void OContact::insertEmail( const QString &email ) |
768 | 768 | ||
769 | Insert \a email into the email list. Ensures \a email can only be added | 769 | Insert \a email into the email list. Ensures \a email can only be added |
770 | once. If there is no default email address set, it sets it to the \a email. | 770 | once. If there is no default email address set, it sets it to the \a email. |
771 | */ | 771 | */ |
772 | 772 | ||
773 | /*! \fn void OContact::removeEmail( const QString &email ) | 773 | /*! \fn void OContact::removeEmail( const QString &email ) |
774 | 774 | ||
775 | Removes the \a email from the email list. If the default email was \a email, | 775 | Removes the \a email from the email list. If the default email was \a email, |
776 | then the default email address is assigned to the first email in the | 776 | then the default email address is assigned to the first email in the |
777 | email list | 777 | email list |
778 | */ | 778 | */ |
779 | 779 | ||
780 | /*! \fn void OContact::clearEmails() | 780 | /*! \fn void OContact::clearEmails() |
781 | 781 | ||
782 | Clears the email list. | 782 | Clears the email list. |
783 | */ | 783 | */ |
784 | 784 | ||
785 | /*! \fn void OContact::insertEmails( const QStringList &emailList ) | 785 | /*! \fn void OContact::insertEmails( const QStringList &emailList ) |
786 | 786 | ||
787 | Appends the \a emailList to the exiting email list | 787 | Appends the \a emailList to the exiting email list |
788 | */ | 788 | */ |
789 | 789 | ||
790 | /*! | 790 | /*! |
791 | Returns a list of email addresses belonging to the contact, including | 791 | Returns a list of email addresses belonging to the contact, including |
792 | the default email address. | 792 | the default email address. |
793 | */ | 793 | */ |
794 | QStringList OContact::emailList() const | 794 | QStringList OContact::emailList() const |
795 | { | 795 | { |
796 | QString emailStr = emails(); | 796 | QString emailStr = emails(); |
797 | 797 | ||
798 | QStringList r; | 798 | QStringList r; |
799 | if ( !emailStr.isEmpty() ) { | 799 | if ( !emailStr.isEmpty() ) { |
800 | qDebug(" emailstr "); | 800 | qDebug(" emailstr "); |
801 | QStringList l = QStringList::split( emailSeparator(), emailStr ); | 801 | QStringList l = QStringList::split( emailSeparator(), emailStr ); |
802 | for ( QStringList::ConstIterator it = l.begin();it != l.end();++it ) | 802 | for ( QStringList::ConstIterator it = l.begin();it != l.end();++it ) |
803 | r += (*it).simplifyWhiteSpace(); | 803 | r += (*it).simplifyWhiteSpace(); |
804 | } | 804 | } |
805 | 805 | ||
806 | return r; | 806 | return r; |
807 | } | 807 | } |
808 | 808 | ||
809 | /*! | 809 | /*! |
810 | \overload | 810 | \overload |
811 | 811 | ||
812 | Generates the string for the contact to be filed as from the first, | 812 | Generates the string for the contact to be filed as from the first, |
813 | middle and last name of the contact. | 813 | middle and last name of the contact. |
814 | */ | 814 | */ |
815 | void OContact::setFileAs() | 815 | void OContact::setFileAs() |
816 | { | 816 | { |
817 | QString lastName, firstName, middleName, fileas; | 817 | QString lastName, firstName, middleName, fileas; |
818 | 818 | ||
819 | lastName = find( Qtopia::LastName ); | 819 | lastName = find( Qtopia::LastName ); |
820 | firstName = find( Qtopia::FirstName ); | 820 | firstName = find( Qtopia::FirstName ); |
821 | middleName = find( Qtopia::MiddleName ); | 821 | middleName = find( Qtopia::MiddleName ); |
822 | if ( !lastName.isEmpty() && !firstName.isEmpty() | 822 | if ( !lastName.isEmpty() && !firstName.isEmpty() |
823 | && !middleName.isEmpty() ) | 823 | && !middleName.isEmpty() ) |
824 | fileas = lastName + ", " + firstName + " " + middleName; | 824 | fileas = lastName + ", " + firstName + " " + middleName; |
825 | else if ( !lastName.isEmpty() && !firstName.isEmpty() ) | 825 | else if ( !lastName.isEmpty() && !firstName.isEmpty() ) |
826 | fileas = lastName + ", " + firstName; | 826 | fileas = lastName + ", " + firstName; |
827 | else if ( !lastName.isEmpty() || !firstName.isEmpty() || | 827 | else if ( !lastName.isEmpty() || !firstName.isEmpty() || |
828 | !middleName.isEmpty() ) | 828 | !middleName.isEmpty() ) |
829 | fileas = firstName + ( firstName.isEmpty() ? "" : " " ) | 829 | fileas = firstName + ( firstName.isEmpty() ? "" : " " ) |
830 | + middleName + ( middleName.isEmpty() ? "" : " " ) | 830 | + middleName + ( middleName.isEmpty() ? "" : " " ) |
831 | + lastName; | 831 | + lastName; |
832 | 832 | ||
833 | replace( Qtopia::FileAs, fileas ); | 833 | replace( Qtopia::FileAs, fileas ); |
834 | } | 834 | } |
835 | 835 | ||
836 | /*! | 836 | /*! |
837 | \internal | 837 | \internal |
838 | Appends the contact information to \a buf. | 838 | Appends the contact information to \a buf. |
839 | */ | 839 | */ |
840 | void OContact::save( QString &buf ) const | 840 | void OContact::save( QString &buf ) const |
841 | { | 841 | { |
842 | static const QStringList SLFIELDS = fields(); | 842 | static const QStringList SLFIELDS = fields(); |
843 | // I'm expecting "<Contact " in front of this... | 843 | // I'm expecting "<Contact " in front of this... |
844 | for ( QMap<int, QString>::ConstIterator it = mMap.begin(); | 844 | for ( QMap<int, QString>::ConstIterator it = mMap.begin(); |
845 | it != mMap.end(); ++it ) { | 845 | it != mMap.end(); ++it ) { |
846 | const QString &value = it.data(); | 846 | const QString &value = it.data(); |
847 | int key = it.key(); | 847 | int key = it.key(); |
848 | if ( !value.isEmpty() ) { | 848 | if ( !value.isEmpty() ) { |
849 | if ( key == Qtopia::AddressCategory || key == Qtopia::AddressUid) | 849 | if ( key == Qtopia::AddressCategory || key == Qtopia::AddressUid) |
850 | continue; | 850 | continue; |
851 | 851 | ||
852 | key -= Qtopia::AddressCategory+1; | 852 | key -= Qtopia::AddressCategory+1; |
853 | buf += SLFIELDS[key]; | 853 | buf += SLFIELDS[key]; |
854 | buf += "=\"" + Qtopia::escapeString(value) + "\" "; | 854 | buf += "=\"" + Qtopia::escapeString(value) + "\" "; |
855 | } | 855 | } |
856 | } | 856 | } |
857 | buf += customToXml(); | 857 | buf += customToXml(); |
858 | if ( categories().count() > 0 ) | 858 | if ( categories().count() > 0 ) |
859 | buf += "Categories=\"" + idsToString( categories() ) + "\" "; | 859 | buf += "Categories=\"" + idsToString( categories() ) + "\" "; |
860 | buf += "Uid=\"" + QString::number( uid() ) + "\" "; | 860 | buf += "Uid=\"" + QString::number( uid() ) + "\" "; |
861 | // You need to close this yourself | 861 | // You need to close this yourself |
862 | } | 862 | } |
863 | 863 | ||
864 | 864 | ||
865 | /*! | 865 | /*! |
866 | \internal | 866 | \internal |
867 | Returns the list of fields belonging to a contact | 867 | Returns the list of fields belonging to a contact |
868 | Never change order of this list ! It has to be regarding | 868 | Never change order of this list ! It has to be regarding |
869 | enum AddressBookFields !! | 869 | enum AddressBookFields !! |
870 | */ | 870 | */ |
871 | QStringList OContact::fields() | 871 | QStringList OContact::fields() |
872 | { | 872 | { |
873 | QStringList list; | 873 | QStringList list; |
874 | 874 | ||
875 | list.append( "Title" ); // Not Used! | 875 | list.append( "Title" ); // Not Used! |
876 | list.append( "FirstName" ); | 876 | list.append( "FirstName" ); |
877 | list.append( "MiddleName" ); | 877 | list.append( "MiddleName" ); |
878 | list.append( "LastName" ); | 878 | list.append( "LastName" ); |
879 | list.append( "Suffix" ); | 879 | list.append( "Suffix" ); |
880 | list.append( "FileAs" ); | 880 | list.append( "FileAs" ); |
881 | 881 | ||
882 | list.append( "JobTitle" ); | 882 | list.append( "JobTitle" ); |
883 | list.append( "Department" ); | 883 | list.append( "Department" ); |
884 | list.append( "Company" ); | 884 | list.append( "Company" ); |
885 | list.append( "BusinessPhone" ); | 885 | list.append( "BusinessPhone" ); |
886 | list.append( "BusinessFax" ); | 886 | list.append( "BusinessFax" ); |
887 | list.append( "BusinessMobile" ); | 887 | list.append( "BusinessMobile" ); |
888 | 888 | ||
889 | list.append( "DefaultEmail" ); | 889 | list.append( "DefaultEmail" ); |
890 | list.append( "Emails" ); | 890 | list.append( "Emails" ); |
891 | 891 | ||
892 | list.append( "HomePhone" ); | 892 | list.append( "HomePhone" ); |
893 | list.append( "HomeFax" ); | 893 | list.append( "HomeFax" ); |
894 | list.append( "HomeMobile" ); | 894 | list.append( "HomeMobile" ); |
895 | 895 | ||
896 | list.append( "BusinessStreet" ); | 896 | list.append( "BusinessStreet" ); |
897 | list.append( "BusinessCity" ); | 897 | list.append( "BusinessCity" ); |
898 | list.append( "BusinessState" ); | 898 | list.append( "BusinessState" ); |
899 | list.append( "BusinessZip" ); | 899 | list.append( "BusinessZip" ); |
900 | list.append( "BusinessCountry" ); | 900 | list.append( "BusinessCountry" ); |
901 | list.append( "BusinessPager" ); | 901 | list.append( "BusinessPager" ); |
902 | list.append( "BusinessWebPage" ); | 902 | list.append( "BusinessWebPage" ); |
903 | 903 | ||
904 | list.append( "Office" ); | 904 | list.append( "Office" ); |
905 | list.append( "Profession" ); | 905 | list.append( "Profession" ); |
906 | list.append( "Assistant" ); | 906 | list.append( "Assistant" ); |
907 | list.append( "Manager" ); | 907 | list.append( "Manager" ); |
908 | 908 | ||
909 | list.append( "HomeStreet" ); | 909 | list.append( "HomeStreet" ); |
910 | list.append( "HomeCity" ); | 910 | list.append( "HomeCity" ); |
911 | list.append( "HomeState" ); | 911 | list.append( "HomeState" ); |
912 | list.append( "HomeZip" ); | 912 | list.append( "HomeZip" ); |
913 | list.append( "HomeCountry" ); | 913 | list.append( "HomeCountry" ); |
914 | list.append( "HomeWebPage" ); | 914 | list.append( "HomeWebPage" ); |
915 | 915 | ||
916 | list.append( "Spouse" ); | 916 | list.append( "Spouse" ); |
917 | list.append( "Gender" ); | 917 | list.append( "Gender" ); |
918 | list.append( "Birthday" ); | 918 | list.append( "Birthday" ); |
919 | list.append( "Anniversary" ); | 919 | list.append( "Anniversary" ); |
920 | list.append( "Nickname" ); | 920 | list.append( "Nickname" ); |
921 | list.append( "Children" ); | 921 | list.append( "Children" ); |
922 | 922 | ||
923 | list.append( "Notes" ); | 923 | list.append( "Notes" ); |
924 | list.append( "Groups" ); | 924 | list.append( "Groups" ); |
925 | 925 | ||
926 | return list; | 926 | return list; |
927 | } | 927 | } |
928 | 928 | ||
929 | 929 | ||
930 | /*! | 930 | /*! |
931 | Sets the list of email address for contact to those contained in \a str. | 931 | Sets the list of email address for contact to those contained in \a str. |
932 | Email address should be separated by ';'s. | 932 | Email address should be separated by ';'s. |
933 | */ | 933 | */ |
934 | void OContact::setEmails( const QString &str ) | 934 | void OContact::setEmails( const QString &str ) |
935 | { | 935 | { |
936 | replace( Qtopia::Emails, str ); | 936 | replace( Qtopia::Emails, str ); |
937 | if ( str.isEmpty() ) | 937 | if ( str.isEmpty() ) |
938 | setDefaultEmail( QString::null ); | 938 | setDefaultEmail( QString::null ); |
939 | } | 939 | } |
940 | 940 | ||
941 | /*! | 941 | /*! |
942 | Sets the list of children for the contact to those contained in \a str. | 942 | Sets the list of children for the contact to those contained in \a str. |
943 | */ | 943 | */ |
944 | void OContact::setChildren( const QString &str ) | 944 | void OContact::setChildren( const QString &str ) |
945 | { | 945 | { |
946 | replace( Qtopia::Children, str ); | 946 | replace( Qtopia::Children, str ); |
947 | } | 947 | } |
948 | 948 | ||
949 | /*! | 949 | /*! |
950 | \overload | 950 | \overload |
951 | Returns TRUE if the contact matches the regular expression \a regexp. | 951 | Returns TRUE if the contact matches the regular expression \a regexp. |
952 | Otherwise returns FALSE. | 952 | Otherwise returns FALSE. |
953 | */ | 953 | */ |
954 | bool OContact::match( const QRegExp &r ) const | 954 | bool OContact::match( const QRegExp &r ) const |
955 | { | 955 | { |
956 | setLastHitField( -1 ); | ||
956 | bool match; | 957 | bool match; |
957 | match = false; | 958 | match = false; |
958 | QMap<int, QString>::ConstIterator it; | 959 | QMap<int, QString>::ConstIterator it; |
959 | for ( it = mMap.begin(); it != mMap.end(); ++it ) { | 960 | for ( it = mMap.begin(); it != mMap.end(); ++it ) { |
960 | if ( (*it).find( r ) > -1 ) { | 961 | if ( (*it).find( r ) > -1 ) { |
961 | setLastHitField( it.key() ); | 962 | setLastHitField( it.key() ); |
962 | match = true; | 963 | match = true; |
963 | break; | 964 | break; |
964 | } | 965 | } |
965 | } | 966 | } |
966 | return match; | 967 | return match; |
967 | } | 968 | } |
968 | 969 | ||
969 | 970 | ||
970 | QString OContact::toShortText() const | 971 | QString OContact::toShortText() const |
971 | { | 972 | { |
972 | return ( fullName() ); | 973 | return ( fullName() ); |
973 | } | 974 | } |
974 | QString OContact::type() const | 975 | QString OContact::type() const |
975 | { | 976 | { |
976 | return QString::fromLatin1( "OContact" ); | 977 | return QString::fromLatin1( "OContact" ); |
977 | } | 978 | } |
978 | 979 | ||
979 | // Definition is missing ! (se) | 980 | // Definition is missing ! (se) |
980 | QMap<QString,QString> OContact::toExtraMap() const | 981 | QMap<QString,QString> OContact::toExtraMap() const |
981 | { | 982 | { |
982 | qWarning ("Function not implemented: OContact::toExtraMap()"); | 983 | qWarning ("Function not implemented: OContact::toExtraMap()"); |
983 | QMap <QString,QString> useless; | 984 | QMap <QString,QString> useless; |
984 | return useless; | 985 | return useless; |
985 | } | 986 | } |
986 | 987 | ||
987 | class QString OContact::recordField( int pos ) const | 988 | class QString OContact::recordField( int pos ) const |
988 | { | 989 | { |
989 | QStringList SLFIELDS = fields(); // ?? why this ? (se) | 990 | QStringList SLFIELDS = fields(); // ?? why this ? (se) |
990 | return SLFIELDS[pos]; | 991 | return SLFIELDS[pos]; |
991 | } | 992 | } |
992 | 993 | ||
993 | // In future releases, we should store birthday and anniversary | 994 | // In future releases, we should store birthday and anniversary |
994 | // internally as QDate instead of QString ! | 995 | // internally as QDate instead of QString ! |
995 | // QString is always too complicate to interprete (DD.MM.YY, DD/MM/YY, MM/DD/YY, etc..)(se) | 996 | // QString is always too complicate to interprete (DD.MM.YY, DD/MM/YY, MM/DD/YY, etc..)(se) |
996 | 997 | ||
997 | /*! \fn void OContact::setBirthday( const QDate& date ) | 998 | /*! \fn void OContact::setBirthday( const QDate& date ) |
998 | Sets the birthday for the contact to \a date. If date is null | 999 | Sets the birthday for the contact to \a date. If date is null |
999 | the current stored date will be removed. | 1000 | the current stored date will be removed. |
1000 | */ | 1001 | */ |
1001 | void OContact::setBirthday( const QDate &v ) | 1002 | void OContact::setBirthday( const QDate &v ) |
1002 | { | 1003 | { |
1003 | if ( v.isNull() ){ | 1004 | if ( v.isNull() ){ |
1004 | qWarning( "Remove Birthday"); | 1005 | qWarning( "Remove Birthday"); |
1005 | replace( Qtopia::Birthday, QString::null ); | 1006 | replace( Qtopia::Birthday, QString::null ); |
1006 | return; | 1007 | return; |
1007 | } | 1008 | } |
1008 | 1009 | ||
1009 | if ( v.isValid() ) | 1010 | if ( v.isValid() ) |
1010 | replace( Qtopia::Birthday, OConversion::dateToString( v ) ); | 1011 | replace( Qtopia::Birthday, OConversion::dateToString( v ) ); |
1011 | 1012 | ||
1012 | } | 1013 | } |
1013 | 1014 | ||
1014 | 1015 | ||
1015 | /*! \fn void OContact::setAnniversary( const QDate &date ) | 1016 | /*! \fn void OContact::setAnniversary( const QDate &date ) |
1016 | Sets the anniversary of the contact to \a date. If date is | 1017 | Sets the anniversary of the contact to \a date. If date is |
1017 | null, the current stored date will be removed. | 1018 | null, the current stored date will be removed. |
1018 | */ | 1019 | */ |
1019 | void OContact::setAnniversary( const QDate &v ) | 1020 | void OContact::setAnniversary( const QDate &v ) |
1020 | { | 1021 | { |
1021 | if ( v.isNull() ){ | 1022 | if ( v.isNull() ){ |
1022 | qWarning( "Remove Anniversary"); | 1023 | qWarning( "Remove Anniversary"); |
1023 | replace( Qtopia::Anniversary, QString::null ); | 1024 | replace( Qtopia::Anniversary, QString::null ); |
1024 | return; | 1025 | return; |
1025 | } | 1026 | } |
1026 | 1027 | ||
1027 | if ( v.isValid() ) | 1028 | if ( v.isValid() ) |
1028 | replace( Qtopia::Anniversary, OConversion::dateToString( v ) ); | 1029 | replace( Qtopia::Anniversary, OConversion::dateToString( v ) ); |
1029 | } | 1030 | } |
1030 | 1031 | ||
1031 | /*! \fn QDate OContact::birthday() const | 1032 | /*! \fn QDate OContact::birthday() const |
1032 | Returns the birthday of the contact. | 1033 | Returns the birthday of the contact. |
1033 | */ | 1034 | */ |
1034 | QDate OContact::birthday() const | 1035 | QDate OContact::birthday() const |
1035 | { | 1036 | { |
1036 | QString str = find( Qtopia::Birthday ); | 1037 | QString str = find( Qtopia::Birthday ); |
1037 | qWarning ("Birthday %s", str.latin1() ); | 1038 | qWarning ("Birthday %s", str.latin1() ); |
1038 | if ( !str.isEmpty() ) | 1039 | if ( !str.isEmpty() ) |
1039 | return OConversion::dateFromString ( str ); | 1040 | return OConversion::dateFromString ( str ); |
1040 | else | 1041 | else |
1041 | return QDate(); | 1042 | return QDate(); |
1042 | } | 1043 | } |
1043 | 1044 | ||
1044 | 1045 | ||
1045 | /*! \fn QDate OContact::anniversary() const | 1046 | /*! \fn QDate OContact::anniversary() const |
1046 | Returns the anniversary of the contact. | 1047 | Returns the anniversary of the contact. |
1047 | */ | 1048 | */ |
1048 | QDate OContact::anniversary() const | 1049 | QDate OContact::anniversary() const |
1049 | { | 1050 | { |
1050 | QDate empty; | 1051 | QDate empty; |
1051 | QString str = find( Qtopia::Anniversary ); | 1052 | QString str = find( Qtopia::Anniversary ); |
1052 | qWarning ("Anniversary %s", str.latin1() ); | 1053 | qWarning ("Anniversary %s", str.latin1() ); |
1053 | if ( !str.isEmpty() ) | 1054 | if ( !str.isEmpty() ) |
1054 | return OConversion::dateFromString ( str ); | 1055 | return OConversion::dateFromString ( str ); |
1055 | else | 1056 | else |
1056 | return empty; | 1057 | return empty; |
1057 | } | 1058 | } |
1058 | 1059 | ||
1059 | 1060 | ||
1060 | void OContact::insertEmail( const QString &v ) | 1061 | void OContact::insertEmail( const QString &v ) |
1061 | { | 1062 | { |
1062 | //qDebug("insertEmail %s", v.latin1()); | 1063 | //qDebug("insertEmail %s", v.latin1()); |
1063 | QString e = v.simplifyWhiteSpace(); | 1064 | QString e = v.simplifyWhiteSpace(); |
1064 | QString def = defaultEmail(); | 1065 | QString def = defaultEmail(); |
1065 | 1066 | ||
1066 | // if no default, set it as the default email and don't insert | 1067 | // if no default, set it as the default email and don't insert |
1067 | if ( def.isEmpty() ) { | 1068 | if ( def.isEmpty() ) { |
1068 | setDefaultEmail( e ); // will insert into the list for us | 1069 | setDefaultEmail( e ); // will insert into the list for us |
1069 | return; | 1070 | return; |
1070 | } | 1071 | } |
1071 | 1072 | ||
1072 | // otherwise, insert assuming doesn't already exist | 1073 | // otherwise, insert assuming doesn't already exist |
1073 | QString emailsStr = find( Qtopia::Emails ); | 1074 | QString emailsStr = find( Qtopia::Emails ); |
1074 | if ( emailsStr.contains( e )) | 1075 | if ( emailsStr.contains( e )) |
1075 | return; | 1076 | return; |
1076 | if ( !emailsStr.isEmpty() ) | 1077 | if ( !emailsStr.isEmpty() ) |
1077 | emailsStr += emailSeparator(); | 1078 | emailsStr += emailSeparator(); |
1078 | emailsStr += e; | 1079 | emailsStr += e; |
1079 | replace( Qtopia::Emails, emailsStr ); | 1080 | replace( Qtopia::Emails, emailsStr ); |
1080 | } | 1081 | } |
1081 | 1082 | ||
1082 | void OContact::removeEmail( const QString &v ) | 1083 | void OContact::removeEmail( const QString &v ) |
1083 | { | 1084 | { |
1084 | QString e = v.simplifyWhiteSpace(); | 1085 | QString e = v.simplifyWhiteSpace(); |
1085 | QString def = defaultEmail(); | 1086 | QString def = defaultEmail(); |
1086 | QString emailsStr = find( Qtopia::Emails ); | 1087 | QString emailsStr = find( Qtopia::Emails ); |
1087 | QStringList emails = emailList(); | 1088 | QStringList emails = emailList(); |
1088 | 1089 | ||
1089 | // otherwise, must first contain it | 1090 | // otherwise, must first contain it |
1090 | if ( !emailsStr.contains( e ) ) | 1091 | if ( !emailsStr.contains( e ) ) |
1091 | return; | 1092 | return; |
1092 | 1093 | ||
1093 | // remove it | 1094 | // remove it |
1094 | //qDebug(" removing email from list %s", e.latin1()); | 1095 | //qDebug(" removing email from list %s", e.latin1()); |
1095 | emails.remove( e ); | 1096 | emails.remove( e ); |
1096 | // reset the string | 1097 | // reset the string |
1097 | emailsStr = emails.join(emailSeparator()); // Sharp's brain dead separator | 1098 | emailsStr = emails.join(emailSeparator()); // Sharp's brain dead separator |
1098 | replace( Qtopia::Emails, emailsStr ); | 1099 | replace( Qtopia::Emails, emailsStr ); |
1099 | 1100 | ||
1100 | // if default, then replace the default email with the first one | 1101 | // if default, then replace the default email with the first one |
1101 | if ( def == e ) { | 1102 | if ( def == e ) { |
1102 | //qDebug("removeEmail is default; setting new default"); | 1103 | //qDebug("removeEmail is default; setting new default"); |
1103 | if ( !emails.count() ) | 1104 | if ( !emails.count() ) |
1104 | clearEmails(); | 1105 | clearEmails(); |
1105 | else // setDefaultEmail will remove e from the list | 1106 | else // setDefaultEmail will remove e from the list |
1106 | setDefaultEmail( emails.first() ); | 1107 | setDefaultEmail( emails.first() ); |
1107 | } | 1108 | } |
1108 | } | 1109 | } |
1109 | void OContact::clearEmails() | 1110 | void OContact::clearEmails() |
1110 | { | 1111 | { |
1111 | mMap.remove( Qtopia::DefaultEmail ); | 1112 | mMap.remove( Qtopia::DefaultEmail ); |
1112 | mMap.remove( Qtopia::Emails ); | 1113 | mMap.remove( Qtopia::Emails ); |
1113 | } | 1114 | } |
1114 | void OContact::setDefaultEmail( const QString &v ) | 1115 | void OContact::setDefaultEmail( const QString &v ) |
1115 | { | 1116 | { |
1116 | QString e = v.simplifyWhiteSpace(); | 1117 | QString e = v.simplifyWhiteSpace(); |
1117 | 1118 | ||
1118 | //qDebug("OContact::setDefaultEmail %s", e.latin1()); | 1119 | //qDebug("OContact::setDefaultEmail %s", e.latin1()); |
1119 | replace( Qtopia::DefaultEmail, e ); | 1120 | replace( Qtopia::DefaultEmail, e ); |
1120 | 1121 | ||
1121 | if ( !e.isEmpty() ) | 1122 | if ( !e.isEmpty() ) |
1122 | insertEmail( e ); | 1123 | insertEmail( e ); |
1123 | 1124 | ||
1124 | } | 1125 | } |
1125 | 1126 | ||
1126 | void OContact::insertEmails( const QStringList &v ) | 1127 | void OContact::insertEmails( const QStringList &v ) |
1127 | { | 1128 | { |
1128 | for ( QStringList::ConstIterator it = v.begin(); it != v.end(); ++it ) | 1129 | for ( QStringList::ConstIterator it = v.begin(); it != v.end(); ++it ) |
1129 | insertEmail( *it ); | 1130 | insertEmail( *it ); |
1130 | } | 1131 | } |
1131 | int OContact::rtti() { | 1132 | int OContact::rtti() { |
1132 | return OPimResolver::AddressBook; | 1133 | return OPimResolver::AddressBook; |
1133 | } | 1134 | } |
1134 | void OContact::setUid( int i ) | 1135 | void OContact::setUid( int i ) |
1135 | { | 1136 | { |
1136 | OPimRecord::setUid(i); | 1137 | OPimRecord::setUid(i); |
1137 | replace( Qtopia::AddressUid , QString::number(i)); | 1138 | replace( Qtopia::AddressUid , QString::number(i)); |
1138 | } | 1139 | } |
diff --git a/libopie/pim/ocontact.h b/libopie/pim/ocontact.h index f79f0f3..dd2de17 100644 --- a/libopie/pim/ocontact.h +++ b/libopie/pim/ocontact.h | |||
@@ -1,244 +1,240 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** Copyright (C) 2002-2003 by Stefan Eilers (eilers.stefan@epost.de) | 3 | ** Copyright (C) 2002-2003 by Stefan Eilers (eilers.stefan@epost.de) |
4 | ** | 4 | ** |
5 | ** This file may be distributed and/or modified under the terms of the | 5 | ** This file may be distributed and/or modified under the terms of the |
6 | ** GNU General Public License version 2 as published by the Free Software | 6 | ** GNU General Public License version 2 as published by the Free Software |
7 | ** Foundation and appearing in the file LICENSE.GPL included in the | 7 | ** Foundation and appearing in the file LICENSE.GPL included in the |
8 | ** packaging of this file. | 8 | ** packaging of this file. |
9 | ** | 9 | ** |
10 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 10 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
11 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 11 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
12 | ** | 12 | ** |
13 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 13 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
14 | ** | 14 | ** |
15 | ** Contact info@trolltech.com if any conditions of this licensing are | 15 | ** Contact info@trolltech.com if any conditions of this licensing are |
16 | ** not clear to you. | 16 | ** not clear to you. |
17 | ** | 17 | ** |
18 | **********************************************************************/ | 18 | **********************************************************************/ |
19 | 19 | ||
20 | #ifndef __OCONTACT_H__ | 20 | #ifndef __OCONTACT_H__ |
21 | #define __OCONTACT_H__ | 21 | #define __OCONTACT_H__ |
22 | 22 | ||
23 | #include <opie/opimrecord.h> | 23 | #include <opie/opimrecord.h> |
24 | #include <qpe/recordfields.h> | 24 | #include <qpe/recordfields.h> |
25 | 25 | ||
26 | #include <qdatetime.h> | 26 | #include <qdatetime.h> |
27 | #include <qstringlist.h> | 27 | #include <qstringlist.h> |
28 | 28 | ||
29 | #if defined(QPC_TEMPLATEDLL) | 29 | #if defined(QPC_TEMPLATEDLL) |
30 | // MOC_SKIP_BEGIN | 30 | // MOC_SKIP_BEGIN |
31 | QPC_TEMPLATEEXTERN template class QPC_EXPORT QMap<int, QString>; | 31 | QPC_TEMPLATEEXTERN template class QPC_EXPORT QMap<int, QString>; |
32 | // MOC_SKIP_END | 32 | // MOC_SKIP_END |
33 | #endif | 33 | #endif |
34 | 34 | ||
35 | class ContactPrivate; | 35 | class ContactPrivate; |
36 | 36 | ||
37 | /** | 37 | /** |
38 | * OContact class represents a specialised PIM Record for contacts. | 38 | * OContact class represents a specialised PIM Record for contacts. |
39 | * It does store all kind of persopn related information. | 39 | * It does store all kind of persopn related information. |
40 | * | 40 | * |
41 | * @short Contact Container | 41 | * @short Contact Container |
42 | * @author TT, Stefan Eiler, Holger Freyther | 42 | * @author TT, Stefan Eiler, Holger Freyther |
43 | */ | 43 | */ |
44 | class QPC_EXPORT OContact : public OPimRecord | 44 | class QPC_EXPORT OContact : public OPimRecord |
45 | { | 45 | { |
46 | friend class DataSet; | 46 | friend class DataSet; |
47 | public: | 47 | public: |
48 | OContact(); | 48 | OContact(); |
49 | OContact( const QMap<int, QString> &fromMap ); | 49 | OContact( const QMap<int, QString> &fromMap ); |
50 | virtual ~OContact(); | 50 | virtual ~OContact(); |
51 | 51 | ||
52 | /* | 52 | /* |
53 | * do we need to inline them | 53 | * do we need to inline them |
54 | * if yes do we need to inline them this way? | 54 | * if yes do we need to inline them this way? |
55 | * -zecke | 55 | * -zecke |
56 | */ | 56 | */ |
57 | void setTitle( const QString &v ) { replace( Qtopia::Title, v ); } | 57 | void setTitle( const QString &v ) { replace( Qtopia::Title, v ); } |
58 | void setFirstName( const QString &v ) { replace( Qtopia::FirstName, v ); } | 58 | void setFirstName( const QString &v ) { replace( Qtopia::FirstName, v ); } |
59 | void setMiddleName( const QString &v ) { replace( Qtopia::MiddleName, v ); } | 59 | void setMiddleName( const QString &v ) { replace( Qtopia::MiddleName, v ); } |
60 | void setLastName( const QString &v ) { replace( Qtopia::LastName, v ); } | 60 | void setLastName( const QString &v ) { replace( Qtopia::LastName, v ); } |
61 | void setSuffix( const QString &v ) { replace( Qtopia::Suffix, v ); } | 61 | void setSuffix( const QString &v ) { replace( Qtopia::Suffix, v ); } |
62 | void setFileAs( const QString &v ) { replace( Qtopia::FileAs, v ); } | 62 | void setFileAs( const QString &v ) { replace( Qtopia::FileAs, v ); } |
63 | void setFileAs(); | 63 | void setFileAs(); |
64 | 64 | ||
65 | // default email address | 65 | // default email address |
66 | void setDefaultEmail( const QString &v ); | 66 | void setDefaultEmail( const QString &v ); |
67 | // inserts email to list and ensure's doesn't already exist | 67 | // inserts email to list and ensure's doesn't already exist |
68 | void insertEmail( const QString &v ); | 68 | void insertEmail( const QString &v ); |
69 | void removeEmail( const QString &v ); | 69 | void removeEmail( const QString &v ); |
70 | void clearEmails(); | 70 | void clearEmails(); |
71 | void insertEmails( const QStringList &v ); | 71 | void insertEmails( const QStringList &v ); |
72 | 72 | ||
73 | // home | 73 | // home |
74 | void setHomeStreet( const QString &v ) { replace( Qtopia::HomeStreet, v ); } | 74 | void setHomeStreet( const QString &v ) { replace( Qtopia::HomeStreet, v ); } |
75 | void setHomeCity( const QString &v ) { replace( Qtopia::HomeCity, v ); } | 75 | void setHomeCity( const QString &v ) { replace( Qtopia::HomeCity, v ); } |
76 | void setHomeState( const QString &v ) { replace( Qtopia::HomeState, v ); } | 76 | void setHomeState( const QString &v ) { replace( Qtopia::HomeState, v ); } |
77 | void setHomeZip( const QString &v ) { replace( Qtopia::HomeZip, v ); } | 77 | void setHomeZip( const QString &v ) { replace( Qtopia::HomeZip, v ); } |
78 | void setHomeCountry( const QString &v ) { replace( Qtopia::HomeCountry, v ); } | 78 | void setHomeCountry( const QString &v ) { replace( Qtopia::HomeCountry, v ); } |
79 | void setHomePhone( const QString &v ) { replace( Qtopia::HomePhone, v ); } | 79 | void setHomePhone( const QString &v ) { replace( Qtopia::HomePhone, v ); } |
80 | void setHomeFax( const QString &v ) { replace( Qtopia::HomeFax, v ); } | 80 | void setHomeFax( const QString &v ) { replace( Qtopia::HomeFax, v ); } |
81 | void setHomeMobile( const QString &v ) { replace( Qtopia::HomeMobile, v ); } | 81 | void setHomeMobile( const QString &v ) { replace( Qtopia::HomeMobile, v ); } |
82 | void setHomeWebpage( const QString &v ) { replace( Qtopia::HomeWebPage, v ); } | 82 | void setHomeWebpage( const QString &v ) { replace( Qtopia::HomeWebPage, v ); } |
83 | 83 | ||
84 | // business | 84 | // business |
85 | void setCompany( const QString &v ) { replace( Qtopia::Company, v ); } | 85 | void setCompany( const QString &v ) { replace( Qtopia::Company, v ); } |
86 | void setBusinessStreet( const QString &v ) { replace( Qtopia::BusinessStreet, v ); } | 86 | void setBusinessStreet( const QString &v ) { replace( Qtopia::BusinessStreet, v ); } |
87 | void setBusinessCity( const QString &v ) { replace( Qtopia::BusinessCity, v ); } | 87 | void setBusinessCity( const QString &v ) { replace( Qtopia::BusinessCity, v ); } |
88 | void setBusinessState( const QString &v ) { replace( Qtopia::BusinessState, v ); } | 88 | void setBusinessState( const QString &v ) { replace( Qtopia::BusinessState, v ); } |
89 | void setBusinessZip( const QString &v ) { replace( Qtopia::BusinessZip, v ); } | 89 | void setBusinessZip( const QString &v ) { replace( Qtopia::BusinessZip, v ); } |
90 | void setBusinessCountry( const QString &v ) { replace( Qtopia::BusinessCountry, v ); } | 90 | void setBusinessCountry( const QString &v ) { replace( Qtopia::BusinessCountry, v ); } |
91 | void setBusinessWebpage( const QString &v ) { replace( Qtopia::BusinessWebPage, v ); } | 91 | void setBusinessWebpage( const QString &v ) { replace( Qtopia::BusinessWebPage, v ); } |
92 | void setJobTitle( const QString &v ) { replace( Qtopia::JobTitle, v ); } | 92 | void setJobTitle( const QString &v ) { replace( Qtopia::JobTitle, v ); } |
93 | void setDepartment( const QString &v ) { replace( Qtopia::Department, v ); } | 93 | void setDepartment( const QString &v ) { replace( Qtopia::Department, v ); } |
94 | void setOffice( const QString &v ) { replace( Qtopia::Office, v ); } | 94 | void setOffice( const QString &v ) { replace( Qtopia::Office, v ); } |
95 | void setBusinessPhone( const QString &v ) { replace( Qtopia::BusinessPhone, v ); } | 95 | void setBusinessPhone( const QString &v ) { replace( Qtopia::BusinessPhone, v ); } |
96 | void setBusinessFax( const QString &v ) { replace( Qtopia::BusinessFax, v ); } | 96 | void setBusinessFax( const QString &v ) { replace( Qtopia::BusinessFax, v ); } |
97 | void setBusinessMobile( const QString &v ) { replace( Qtopia::BusinessMobile, v ); } | 97 | void setBusinessMobile( const QString &v ) { replace( Qtopia::BusinessMobile, v ); } |
98 | void setBusinessPager( const QString &v ) { replace( Qtopia::BusinessPager, v ); } | 98 | void setBusinessPager( const QString &v ) { replace( Qtopia::BusinessPager, v ); } |
99 | void setProfession( const QString &v ) { replace( Qtopia::Profession, v ); } | 99 | void setProfession( const QString &v ) { replace( Qtopia::Profession, v ); } |
100 | void setAssistant( const QString &v ) { replace( Qtopia::Assistant, v ); } | 100 | void setAssistant( const QString &v ) { replace( Qtopia::Assistant, v ); } |
101 | void setManager( const QString &v ) { replace( Qtopia::Manager, v ); } | 101 | void setManager( const QString &v ) { replace( Qtopia::Manager, v ); } |
102 | 102 | ||
103 | // personal | 103 | // personal |
104 | void setSpouse( const QString &v ) { replace( Qtopia::Spouse, v ); } | 104 | void setSpouse( const QString &v ) { replace( Qtopia::Spouse, v ); } |
105 | void setGender( const QString &v ) { replace( Qtopia::Gender, v ); } | 105 | void setGender( const QString &v ) { replace( Qtopia::Gender, v ); } |
106 | void setBirthday( const QDate &v ); | 106 | void setBirthday( const QDate &v ); |
107 | void setAnniversary( const QDate &v ); | 107 | void setAnniversary( const QDate &v ); |
108 | void setNickname( const QString &v ) { replace( Qtopia::Nickname, v ); } | 108 | void setNickname( const QString &v ) { replace( Qtopia::Nickname, v ); } |
109 | void setChildren( const QString &v ); | 109 | void setChildren( const QString &v ); |
110 | 110 | ||
111 | // other | 111 | // other |
112 | void setNotes( const QString &v ) { replace( Qtopia::Notes, v); } | 112 | void setNotes( const QString &v ) { replace( Qtopia::Notes, v); } |
113 | 113 | ||
114 | virtual bool match( const QRegExp ®exp ) const; | 114 | virtual bool match( const QRegExp ®exp ) const; |
115 | 115 | ||
116 | // // custom | 116 | // // custom |
117 | // void setCustomField( const QString &key, const QString &v ) | 117 | // void setCustomField( const QString &key, const QString &v ) |
118 | // { replace(Custom- + key, v ); } | 118 | // { replace(Custom- + key, v ); } |
119 | 119 | ||
120 | // name | 120 | // name |
121 | QString fullName() const; | 121 | QString fullName() const; |
122 | QString title() const { return find( Qtopia::Title ); } | 122 | QString title() const { return find( Qtopia::Title ); } |
123 | QString firstName() const { return find( Qtopia::FirstName ); } | 123 | QString firstName() const { return find( Qtopia::FirstName ); } |
124 | QString middleName() const { return find( Qtopia::MiddleName ); } | 124 | QString middleName() const { return find( Qtopia::MiddleName ); } |
125 | QString lastName() const { return find( Qtopia::LastName ); } | 125 | QString lastName() const { return find( Qtopia::LastName ); } |
126 | QString suffix() const { return find( Qtopia::Suffix ); } | 126 | QString suffix() const { return find( Qtopia::Suffix ); } |
127 | QString fileAs() const { return find( Qtopia::FileAs ); } | 127 | QString fileAs() const { return find( Qtopia::FileAs ); } |
128 | 128 | ||
129 | 129 | ||
130 | QString defaultEmail() const { return find( Qtopia::DefaultEmail ); } | 130 | QString defaultEmail() const { return find( Qtopia::DefaultEmail ); } |
131 | QStringList emailList() const; | 131 | QStringList emailList() const; |
132 | 132 | ||
133 | // home | 133 | // home |
134 | /* | 134 | /* |
135 | * OPimAddress address(enum Location)const; | 135 | * OPimAddress address(enum Location)const; |
136 | * would be some how nicer... | 136 | * would be some how nicer... |
137 | * -zecke | 137 | * -zecke |
138 | */ | 138 | */ |
139 | QString homeStreet() const { return find( Qtopia::HomeStreet ); } | 139 | QString homeStreet() const { return find( Qtopia::HomeStreet ); } |
140 | QString homeCity() const { return find( Qtopia::HomeCity ); } | 140 | QString homeCity() const { return find( Qtopia::HomeCity ); } |
141 | QString homeState() const { return find( Qtopia::HomeState ); } | 141 | QString homeState() const { return find( Qtopia::HomeState ); } |
142 | QString homeZip() const { return find( Qtopia::HomeZip ); } | 142 | QString homeZip() const { return find( Qtopia::HomeZip ); } |
143 | QString homeCountry() const { return find( Qtopia::HomeCountry ); } | 143 | QString homeCountry() const { return find( Qtopia::HomeCountry ); } |
144 | QString homePhone() const { return find( Qtopia::HomePhone ); } | 144 | QString homePhone() const { return find( Qtopia::HomePhone ); } |
145 | QString homeFax() const { return find( Qtopia::HomeFax ); } | 145 | QString homeFax() const { return find( Qtopia::HomeFax ); } |
146 | QString homeMobile() const { return find( Qtopia::HomeMobile ); } | 146 | QString homeMobile() const { return find( Qtopia::HomeMobile ); } |
147 | QString homeWebpage() const { return find( Qtopia::HomeWebPage ); } | 147 | QString homeWebpage() const { return find( Qtopia::HomeWebPage ); } |
148 | /** Multi line string containing all non-empty address info in the form | 148 | /** Multi line string containing all non-empty address info in the form |
149 | * Street | 149 | * Street |
150 | * City, State Zip | 150 | * City, State Zip |
151 | * Country | 151 | * Country |
152 | */ | 152 | */ |
153 | QString displayHomeAddress() const; | 153 | QString displayHomeAddress() const; |
154 | 154 | ||
155 | // business | 155 | // business |
156 | QString company() const { return find( Qtopia::Company ); } | 156 | QString company() const { return find( Qtopia::Company ); } |
157 | QString businessStreet() const { return find( Qtopia::BusinessStreet ); } | 157 | QString businessStreet() const { return find( Qtopia::BusinessStreet ); } |
158 | QString businessCity() const { return find( Qtopia::BusinessCity ); } | 158 | QString businessCity() const { return find( Qtopia::BusinessCity ); } |
159 | QString businessState() const { return find( Qtopia::BusinessState ); } | 159 | QString businessState() const { return find( Qtopia::BusinessState ); } |
160 | QString businessZip() const { return find( Qtopia::BusinessZip ); } | 160 | QString businessZip() const { return find( Qtopia::BusinessZip ); } |
161 | QString businessCountry() const { return find( Qtopia::BusinessCountry ); } | 161 | QString businessCountry() const { return find( Qtopia::BusinessCountry ); } |
162 | QString businessWebpage() const { return find( Qtopia::BusinessWebPage ); } | 162 | QString businessWebpage() const { return find( Qtopia::BusinessWebPage ); } |
163 | QString jobTitle() const { return find( Qtopia::JobTitle ); } | 163 | QString jobTitle() const { return find( Qtopia::JobTitle ); } |
164 | QString department() const { return find( Qtopia::Department ); } | 164 | QString department() const { return find( Qtopia::Department ); } |
165 | QString office() const { return find( Qtopia::Office ); } | 165 | QString office() const { return find( Qtopia::Office ); } |
166 | QString businessPhone() const { return find( Qtopia::BusinessPhone ); } | 166 | QString businessPhone() const { return find( Qtopia::BusinessPhone ); } |
167 | QString businessFax() const { return find( Qtopia::BusinessFax ); } | 167 | QString businessFax() const { return find( Qtopia::BusinessFax ); } |
168 | QString businessMobile() const { return find( Qtopia::BusinessMobile ); } | 168 | QString businessMobile() const { return find( Qtopia::BusinessMobile ); } |
169 | QString businessPager() const { return find( Qtopia::BusinessPager ); } | 169 | QString businessPager() const { return find( Qtopia::BusinessPager ); } |
170 | QString profession() const { return find( Qtopia::Profession ); } | 170 | QString profession() const { return find( Qtopia::Profession ); } |
171 | QString assistant() const { return find( Qtopia::Assistant ); } | 171 | QString assistant() const { return find( Qtopia::Assistant ); } |
172 | QString manager() const { return find( Qtopia::Manager ); } | 172 | QString manager() const { return find( Qtopia::Manager ); } |
173 | /** Multi line string containing all non-empty address info in the form | 173 | /** Multi line string containing all non-empty address info in the form |
174 | * Street | 174 | * Street |
175 | * City, State Zip | 175 | * City, State Zip |
176 | * Country | 176 | * Country |
177 | */ | 177 | */ |
178 | QString displayBusinessAddress() const; | 178 | QString displayBusinessAddress() const; |
179 | 179 | ||
180 | //personal | 180 | //personal |
181 | QString spouse() const { return find( Qtopia::Spouse ); } | 181 | QString spouse() const { return find( Qtopia::Spouse ); } |
182 | QString gender() const { return find( Qtopia::Gender ); } | 182 | QString gender() const { return find( Qtopia::Gender ); } |
183 | QDate birthday() const; | 183 | QDate birthday() const; |
184 | QDate anniversary() const; | 184 | QDate anniversary() const; |
185 | QString nickname() const { return find( Qtopia::Nickname ); } | 185 | QString nickname() const { return find( Qtopia::Nickname ); } |
186 | QString children() const { return find( Qtopia::Children ); } | 186 | QString children() const { return find( Qtopia::Children ); } |
187 | QStringList childrenList() const; | 187 | QStringList childrenList() const; |
188 | 188 | ||
189 | // other | 189 | // other |
190 | QString notes() const { return find( Qtopia::Notes ); } | 190 | QString notes() const { return find( Qtopia::Notes ); } |
191 | QString groups() const { return find( Qtopia::Groups ); } | 191 | QString groups() const { return find( Qtopia::Groups ); } |
192 | QStringList groupList() const; | 192 | QStringList groupList() const; |
193 | 193 | ||
194 | // // custom | 194 | // // custom |
195 | // const QString &customField( const QString &key ) | 195 | // const QString &customField( const QString &key ) |
196 | // { return find( Custom- + key ); } | 196 | // { return find( Custom- + key ); } |
197 | 197 | ||
198 | 198 | ||
199 | QString toRichText() const; | 199 | QString toRichText() const; |
200 | QMap<int, QString> toMap() const; | 200 | QMap<int, QString> toMap() const; |
201 | QString field( int key ) const { return find( key ); } | 201 | QString field( int key ) const { return find( key ); } |
202 | 202 | ||
203 | 203 | ||
204 | void setUid( int i ); | 204 | void setUid( int i ); |
205 | 205 | ||
206 | QString toShortText()const; | 206 | QString toShortText()const; |
207 | QString OContact::type()const; | 207 | QString OContact::type()const; |
208 | QMap<QString,QString> OContact::toExtraMap() const; | 208 | QMap<QString,QString> OContact::toExtraMap() const; |
209 | class QString OContact::recordField(int) const; | 209 | class QString OContact::recordField(int) const; |
210 | 210 | ||
211 | // Why private ? (eilers,se) | 211 | // Why private ? (eilers,se) |
212 | QString emailSeparator() const { return " "; } | 212 | QString emailSeparator() const { return " "; } |
213 | // the emails should be seperated by a comma | 213 | // the emails should be seperated by a comma |
214 | void setEmails( const QString &v ); | 214 | void setEmails( const QString &v ); |
215 | QString emails() const { return find( Qtopia::Emails ); } | 215 | QString emails() const { return find( Qtopia::Emails ); } |
216 | static int rtti(); | 216 | static int rtti(); |
217 | int lastHitField() const {return m_lastHitField;}; | ||
218 | protected: | ||
219 | mutable int m_lastHitField; | ||
220 | void setLastHitField(int i) const { m_lastHitField = i; }; | ||
221 | 217 | ||
222 | private: | 218 | private: |
223 | // The XML-Backend needs some access to the private functions | 219 | // The XML-Backend needs some access to the private functions |
224 | friend class OContactAccessBackend_XML; | 220 | friend class OContactAccessBackend_XML; |
225 | 221 | ||
226 | void insert( int key, const QString &value ); | 222 | void insert( int key, const QString &value ); |
227 | void replace( int key, const QString &value ); | 223 | void replace( int key, const QString &value ); |
228 | QString find( int key ) const; | 224 | QString find( int key ) const; |
229 | static QStringList fields(); | 225 | static QStringList fields(); |
230 | 226 | ||
231 | void save( QString &buf ) const; | 227 | void save( QString &buf ) const; |
232 | 228 | ||
233 | QString displayAddress( const QString &street, | 229 | QString displayAddress( const QString &street, |
234 | const QString &city, | 230 | const QString &city, |
235 | const QString &state, | 231 | const QString &state, |
236 | const QString &zip, | 232 | const QString &zip, |
237 | const QString &country ) const; | 233 | const QString &country ) const; |
238 | 234 | ||
239 | QMap<int, QString> mMap; | 235 | QMap<int, QString> mMap; |
240 | ContactPrivate *d; | 236 | ContactPrivate *d; |
241 | }; | 237 | }; |
242 | 238 | ||
243 | 239 | ||
244 | #endif | 240 | #endif |
diff --git a/libopie/pim/opimrecord.cpp b/libopie/pim/opimrecord.cpp index d45417a..9510357 100644 --- a/libopie/pim/opimrecord.cpp +++ b/libopie/pim/opimrecord.cpp | |||
@@ -1,166 +1,174 @@ | |||
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 | m_lastHit = -1; | ||
14 | setUid( uid ); | 15 | setUid( uid ); |
15 | } | 16 | } |
16 | OPimRecord::~OPimRecord() { | 17 | OPimRecord::~OPimRecord() { |
17 | } | 18 | } |
18 | OPimRecord::OPimRecord( const OPimRecord& rec ) | 19 | OPimRecord::OPimRecord( const OPimRecord& rec ) |
19 | : Qtopia::Record( rec ) | 20 | : Qtopia::Record( rec ) |
20 | { | 21 | { |
21 | (*this) = rec; | 22 | (*this) = rec; |
22 | } | 23 | } |
23 | 24 | ||
24 | OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { | 25 | OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { |
25 | Qtopia::Record::operator=( rec ); | 26 | Qtopia::Record::operator=( rec ); |
26 | m_xrefman = rec.m_xrefman; | 27 | m_xrefman = rec.m_xrefman; |
28 | m_lastHit = rec.m_lastHit; | ||
27 | 29 | ||
28 | return *this; | 30 | return *this; |
29 | } | 31 | } |
30 | /* | 32 | /* |
31 | * category names | 33 | * category names |
32 | */ | 34 | */ |
33 | QStringList OPimRecord::categoryNames( const QString& appname ) const { | 35 | QStringList OPimRecord::categoryNames( const QString& appname ) const { |
34 | QStringList list; | 36 | QStringList list; |
35 | QArray<int> cats = categories(); | 37 | QArray<int> cats = categories(); |
36 | Categories catDB; | 38 | Categories catDB; |
37 | catDB.load( categoryFileName() ); | 39 | catDB.load( categoryFileName() ); |
38 | 40 | ||
39 | for (uint i = 0; i < cats.count(); i++ ) { | 41 | for (uint i = 0; i < cats.count(); i++ ) { |
40 | list << catDB.label( appname, cats[i] ); | 42 | list << catDB.label( appname, cats[i] ); |
41 | } | 43 | } |
42 | 44 | ||
43 | return list; | 45 | return list; |
44 | } | 46 | } |
45 | void OPimRecord::setCategoryNames( const QStringList& ) { | 47 | void OPimRecord::setCategoryNames( const QStringList& ) { |
46 | 48 | ||
47 | } | 49 | } |
48 | void OPimRecord::addCategoryName( const QString& ) { | 50 | void OPimRecord::addCategoryName( const QString& ) { |
49 | Categories catDB; | 51 | Categories catDB; |
50 | catDB.load( categoryFileName() ); | 52 | catDB.load( categoryFileName() ); |
51 | 53 | ||
52 | 54 | ||
53 | } | 55 | } |
54 | bool OPimRecord::isEmpty()const { | 56 | bool OPimRecord::isEmpty()const { |
55 | return ( uid() == 0 ); | 57 | return ( uid() == 0 ); |
56 | } | 58 | } |
57 | /*QString OPimRecord::crossToString()const { | 59 | /*QString OPimRecord::crossToString()const { |
58 | QString str; | 60 | QString str; |
59 | QMap<QString, QArray<int> >::ConstIterator it; | 61 | QMap<QString, QArray<int> >::ConstIterator it; |
60 | for (it = m_relations.begin(); it != m_relations.end(); ++it ) { | 62 | for (it = m_relations.begin(); it != m_relations.end(); ++it ) { |
61 | QArray<int> id = it.data(); | 63 | QArray<int> id = it.data(); |
62 | for ( uint i = 0; i < id.size(); ++i ) { | 64 | for ( uint i = 0; i < id.size(); ++i ) { |
63 | str += it.key() + "," + QString::number( i ) + ";"; | 65 | str += it.key() + "," + QString::number( i ) + ";"; |
64 | } | 66 | } |
65 | } | 67 | } |
66 | str = str.remove( str.length()-1, 1); // strip the ; | 68 | str = str.remove( str.length()-1, 1); // strip the ; |
67 | //qWarning("IDS " + str ); | 69 | //qWarning("IDS " + str ); |
68 | 70 | ||
69 | return str; | 71 | return str; |
70 | }*/ | 72 | }*/ |
71 | /* if uid = 1 assign a new one */ | 73 | /* if uid = 1 assign a new one */ |
72 | void OPimRecord::setUid( int uid ) { | 74 | void OPimRecord::setUid( int uid ) { |
73 | if ( uid == 1) | 75 | if ( uid == 1) |
74 | uid = uidGen().generate(); | 76 | uid = uidGen().generate(); |
75 | 77 | ||
76 | Qtopia::Record::setUid( uid ); | 78 | Qtopia::Record::setUid( uid ); |
77 | }; | 79 | }; |
78 | Qtopia::UidGen &OPimRecord::uidGen() { | 80 | Qtopia::UidGen &OPimRecord::uidGen() { |
79 | return m_uidGen; | 81 | return m_uidGen; |
80 | } | 82 | } |
81 | OPimXRefManager &OPimRecord::xrefmanager() { | 83 | OPimXRefManager &OPimRecord::xrefmanager() { |
82 | return m_xrefman; | 84 | return m_xrefman; |
83 | } | 85 | } |
84 | int OPimRecord::rtti(){ | 86 | int OPimRecord::rtti(){ |
85 | return 0; | 87 | return 0; |
86 | } | 88 | } |
87 | 89 | ||
88 | /** | 90 | /** |
89 | * now let's put our data into the stream | 91 | * now let's put our data into the stream |
90 | */ | 92 | */ |
91 | /* | 93 | /* |
92 | * First read UID | 94 | * First read UID |
93 | * Categories | 95 | * Categories |
94 | * XRef | 96 | * XRef |
95 | */ | 97 | */ |
96 | bool OPimRecord::loadFromStream( QDataStream& stream ) { | 98 | bool OPimRecord::loadFromStream( QDataStream& stream ) { |
97 | int Int; | 99 | int Int; |
98 | uint UInt; | 100 | uint UInt; |
99 | stream >> Int; | 101 | stream >> Int; |
100 | setUid(Int); | 102 | setUid(Int); |
101 | 103 | ||
102 | /** Categories */ | 104 | /** Categories */ |
103 | stream >> UInt; | 105 | stream >> UInt; |
104 | QArray<int> array(UInt); | 106 | QArray<int> array(UInt); |
105 | for (uint i = 0; i < UInt; i++ ) { | 107 | for (uint i = 0; i < UInt; i++ ) { |
106 | stream >> array[i]; | 108 | stream >> array[i]; |
107 | } | 109 | } |
108 | setCategories( array ); | 110 | setCategories( array ); |
109 | 111 | ||
110 | /* | 112 | /* |
111 | * now we do the X-Ref stuff | 113 | * now we do the X-Ref stuff |
112 | */ | 114 | */ |
113 | OPimXRef xref; | 115 | OPimXRef xref; |
114 | stream >> UInt; | 116 | stream >> UInt; |
115 | for ( uint i = 0; i < UInt; i++ ) { | 117 | for ( uint i = 0; i < UInt; i++ ) { |
116 | xref.setPartner( OPimXRef::One, partner( stream ) ); | 118 | xref.setPartner( OPimXRef::One, partner( stream ) ); |
117 | xref.setPartner( OPimXRef::Two, partner( stream ) ); | 119 | xref.setPartner( OPimXRef::Two, partner( stream ) ); |
118 | m_xrefman.add( xref ); | 120 | m_xrefman.add( xref ); |
119 | } | 121 | } |
120 | 122 | ||
121 | return true; | 123 | return true; |
122 | } | 124 | } |
123 | bool OPimRecord::saveToStream( QDataStream& stream )const { | 125 | bool OPimRecord::saveToStream( QDataStream& stream )const { |
124 | /** UIDs */ | 126 | /** UIDs */ |
125 | 127 | ||
126 | stream << uid(); | 128 | stream << uid(); |
127 | 129 | ||
128 | /** Categories */ | 130 | /** Categories */ |
129 | stream << categories().count(); | 131 | stream << categories().count(); |
130 | for ( uint i = 0; i < categories().count(); i++ ) { | 132 | for ( uint i = 0; i < categories().count(); i++ ) { |
131 | stream << categories()[i]; | 133 | stream << categories()[i]; |
132 | } | 134 | } |
133 | 135 | ||
134 | /* | 136 | /* |
135 | * first the XRef count | 137 | * first the XRef count |
136 | * then the xrefs | 138 | * then the xrefs |
137 | */ | 139 | */ |
138 | stream << m_xrefman.list().count(); | 140 | stream << m_xrefman.list().count(); |
139 | for ( OPimXRef::ValueList::ConstIterator it = m_xrefman.list().begin(); | 141 | for ( OPimXRef::ValueList::ConstIterator it = m_xrefman.list().begin(); |
140 | it != m_xrefman.list().end(); ++it ) { | 142 | it != m_xrefman.list().end(); ++it ) { |
141 | flush( (*it).partner( OPimXRef::One), stream ); | 143 | flush( (*it).partner( OPimXRef::One), stream ); |
142 | flush( (*it).partner( OPimXRef::Two), stream ); | 144 | flush( (*it).partner( OPimXRef::Two), stream ); |
143 | } | 145 | } |
144 | return true; | 146 | return true; |
145 | } | 147 | } |
146 | void OPimRecord::flush( const OPimXRefPartner& par, QDataStream& str ) const{ | 148 | void OPimRecord::flush( const OPimXRefPartner& par, QDataStream& str ) const{ |
147 | str << par.service(); | 149 | str << par.service(); |
148 | str << par.uid(); | 150 | str << par.uid(); |
149 | str << par.field(); | 151 | str << par.field(); |
150 | } | 152 | } |
151 | OPimXRefPartner OPimRecord::partner( QDataStream& stream ) { | 153 | OPimXRefPartner OPimRecord::partner( QDataStream& stream ) { |
152 | OPimXRefPartner par; | 154 | OPimXRefPartner par; |
153 | QString str; | 155 | QString str; |
154 | int i; | 156 | int i; |
155 | 157 | ||
156 | stream >> str; | 158 | stream >> str; |
157 | par.setService( str ); | 159 | par.setService( str ); |
158 | 160 | ||
159 | stream >> i; | 161 | stream >> i; |
160 | par.setUid( i ); | 162 | par.setUid( i ); |
161 | 163 | ||
162 | stream >> i ; | 164 | stream >> i ; |
163 | par.setField( i ); | 165 | par.setField( i ); |
164 | 166 | ||
165 | return par; | 167 | return par; |
166 | } | 168 | } |
169 | void OPimRecord::setLastHitField( int lastHit )const { | ||
170 | m_lastHit = lastHit; | ||
171 | } | ||
172 | int OPimRecord::lastHitField()const{ | ||
173 | return m_lastHit; | ||
174 | } | ||
diff --git a/libopie/pim/opimrecord.h b/libopie/pim/opimrecord.h index 6e7c0da..494c78e 100644 --- a/libopie/pim/opimrecord.h +++ b/libopie/pim/opimrecord.h | |||
@@ -1,140 +1,151 @@ | |||
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 QString& appname )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 | * matches the Records the regular expression? | 76 | * matches the Records the regular expression? |
77 | */ | 77 | */ |
78 | virtual bool match( const QString ®exp ) const | 78 | virtual bool match( const QString ®exp ) const |
79 | {return Qtopia::Record::match(QRegExp(regexp));}; | 79 | {setLastHitField( -1 ); |
80 | return Qtopia::Record::match(QRegExp(regexp));}; | ||
81 | |||
82 | /** | ||
83 | * if implemented this function returns which item has been | ||
84 | * last hit by the match() function. | ||
85 | * or -1 if not implemented or no hit has occured | ||
86 | */ | ||
87 | int lastHitField()const; | ||
80 | 88 | ||
81 | /** | 89 | /** |
82 | * converts the internal structure to a map | 90 | * converts the internal structure to a map |
83 | */ | 91 | */ |
84 | virtual QMap<int, QString> toMap()const = 0; | 92 | virtual QMap<int, QString> toMap()const = 0; |
85 | 93 | ||
86 | /** | 94 | /** |
87 | * key value representation of extra items | 95 | * key value representation of extra items |
88 | */ | 96 | */ |
89 | virtual QMap<QString, QString> toExtraMap()const = 0; | 97 | virtual QMap<QString, QString> toExtraMap()const = 0; |
90 | 98 | ||
91 | /** | 99 | /** |
92 | * the name for a recordField | 100 | * the name for a recordField |
93 | */ | 101 | */ |
94 | virtual QString recordField(int)const = 0; | 102 | virtual QString recordField(int)const = 0; |
95 | 103 | ||
96 | /** | 104 | /** |
97 | * returns a reference of the | 105 | * returns a reference of the |
98 | * Cross Reference Manager | 106 | * Cross Reference Manager |
99 | * Partner 'One' is THIS PIM RECORD! | 107 | * Partner 'One' is THIS PIM RECORD! |
100 | * 'Two' is the Partner where we link to | 108 | * 'Two' is the Partner where we link to |
101 | */ | 109 | */ |
102 | OPimXRefManager& xrefmanager(); | 110 | OPimXRefManager& xrefmanager(); |
103 | 111 | ||
104 | /** | 112 | /** |
105 | * set the uid | 113 | * set the uid |
106 | */ | 114 | */ |
107 | virtual void setUid( int uid ); | 115 | virtual void setUid( int uid ); |
108 | 116 | ||
109 | /* | 117 | /* |
110 | * used inside the Templates for casting | 118 | * used inside the Templates for casting |
111 | * REIMPLEMENT in your .... | 119 | * REIMPLEMENT in your .... |
112 | */ | 120 | */ |
113 | static int rtti(); | 121 | static int rtti(); |
114 | 122 | ||
115 | /** | 123 | /** |
116 | * some marshalling and de marshalling code | 124 | * some marshalling and de marshalling code |
117 | * saves the OPimRecord | 125 | * saves the OPimRecord |
118 | * to and from a DataStream | 126 | * to and from a DataStream |
119 | */ | 127 | */ |
120 | virtual bool loadFromStream(QDataStream& ); | 128 | virtual bool loadFromStream(QDataStream& ); |
121 | virtual bool saveToStream( QDataStream& stream )const; | 129 | virtual bool saveToStream( QDataStream& stream )const; |
122 | 130 | ||
123 | protected: | 131 | protected: |
132 | // need to be const cause it is called from const methods | ||
133 | mutable int m_lastHit; | ||
134 | void setLastHitField( int lastHit )const; | ||
124 | Qtopia::UidGen &uidGen(); | 135 | Qtopia::UidGen &uidGen(); |
125 | // QString crossToString()const; | 136 | // QString crossToString()const; |
126 | 137 | ||
127 | private: | 138 | private: |
128 | class OPimRecordPrivate; | 139 | class OPimRecordPrivate; |
129 | OPimRecordPrivate *d; | 140 | OPimRecordPrivate *d; |
130 | OPimXRefManager m_xrefman; | 141 | OPimXRefManager m_xrefman; |
131 | static Qtopia::UidGen m_uidGen; | 142 | static Qtopia::UidGen m_uidGen; |
132 | 143 | ||
133 | private: | 144 | private: |
134 | void flush( const OPimXRefPartner&, QDataStream& stream )const; | 145 | void flush( const OPimXRefPartner&, QDataStream& stream )const; |
135 | OPimXRefPartner partner( QDataStream& ); | 146 | OPimXRefPartner partner( QDataStream& ); |
136 | }; | 147 | }; |
137 | 148 | ||
138 | 149 | ||
139 | 150 | ||
140 | #endif | 151 | #endif |
diff --git a/libopie2/opiepim/core/opimrecord.cpp b/libopie2/opiepim/core/opimrecord.cpp index d45417a..9510357 100644 --- a/libopie2/opiepim/core/opimrecord.cpp +++ b/libopie2/opiepim/core/opimrecord.cpp | |||
@@ -1,166 +1,174 @@ | |||
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 | m_lastHit = -1; | ||
14 | setUid( uid ); | 15 | setUid( uid ); |
15 | } | 16 | } |
16 | OPimRecord::~OPimRecord() { | 17 | OPimRecord::~OPimRecord() { |
17 | } | 18 | } |
18 | OPimRecord::OPimRecord( const OPimRecord& rec ) | 19 | OPimRecord::OPimRecord( const OPimRecord& rec ) |
19 | : Qtopia::Record( rec ) | 20 | : Qtopia::Record( rec ) |
20 | { | 21 | { |
21 | (*this) = rec; | 22 | (*this) = rec; |
22 | } | 23 | } |
23 | 24 | ||
24 | OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { | 25 | OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { |
25 | Qtopia::Record::operator=( rec ); | 26 | Qtopia::Record::operator=( rec ); |
26 | m_xrefman = rec.m_xrefman; | 27 | m_xrefman = rec.m_xrefman; |
28 | m_lastHit = rec.m_lastHit; | ||
27 | 29 | ||
28 | return *this; | 30 | return *this; |
29 | } | 31 | } |
30 | /* | 32 | /* |
31 | * category names | 33 | * category names |
32 | */ | 34 | */ |
33 | QStringList OPimRecord::categoryNames( const QString& appname ) const { | 35 | QStringList OPimRecord::categoryNames( const QString& appname ) const { |
34 | QStringList list; | 36 | QStringList list; |
35 | QArray<int> cats = categories(); | 37 | QArray<int> cats = categories(); |
36 | Categories catDB; | 38 | Categories catDB; |
37 | catDB.load( categoryFileName() ); | 39 | catDB.load( categoryFileName() ); |
38 | 40 | ||
39 | for (uint i = 0; i < cats.count(); i++ ) { | 41 | for (uint i = 0; i < cats.count(); i++ ) { |
40 | list << catDB.label( appname, cats[i] ); | 42 | list << catDB.label( appname, cats[i] ); |
41 | } | 43 | } |
42 | 44 | ||
43 | return list; | 45 | return list; |
44 | } | 46 | } |
45 | void OPimRecord::setCategoryNames( const QStringList& ) { | 47 | void OPimRecord::setCategoryNames( const QStringList& ) { |
46 | 48 | ||
47 | } | 49 | } |
48 | void OPimRecord::addCategoryName( const QString& ) { | 50 | void OPimRecord::addCategoryName( const QString& ) { |
49 | Categories catDB; | 51 | Categories catDB; |
50 | catDB.load( categoryFileName() ); | 52 | catDB.load( categoryFileName() ); |
51 | 53 | ||
52 | 54 | ||
53 | } | 55 | } |
54 | bool OPimRecord::isEmpty()const { | 56 | bool OPimRecord::isEmpty()const { |
55 | return ( uid() == 0 ); | 57 | return ( uid() == 0 ); |
56 | } | 58 | } |
57 | /*QString OPimRecord::crossToString()const { | 59 | /*QString OPimRecord::crossToString()const { |
58 | QString str; | 60 | QString str; |
59 | QMap<QString, QArray<int> >::ConstIterator it; | 61 | QMap<QString, QArray<int> >::ConstIterator it; |
60 | for (it = m_relations.begin(); it != m_relations.end(); ++it ) { | 62 | for (it = m_relations.begin(); it != m_relations.end(); ++it ) { |
61 | QArray<int> id = it.data(); | 63 | QArray<int> id = it.data(); |
62 | for ( uint i = 0; i < id.size(); ++i ) { | 64 | for ( uint i = 0; i < id.size(); ++i ) { |
63 | str += it.key() + "," + QString::number( i ) + ";"; | 65 | str += it.key() + "," + QString::number( i ) + ";"; |
64 | } | 66 | } |
65 | } | 67 | } |
66 | str = str.remove( str.length()-1, 1); // strip the ; | 68 | str = str.remove( str.length()-1, 1); // strip the ; |
67 | //qWarning("IDS " + str ); | 69 | //qWarning("IDS " + str ); |
68 | 70 | ||
69 | return str; | 71 | return str; |
70 | }*/ | 72 | }*/ |
71 | /* if uid = 1 assign a new one */ | 73 | /* if uid = 1 assign a new one */ |
72 | void OPimRecord::setUid( int uid ) { | 74 | void OPimRecord::setUid( int uid ) { |
73 | if ( uid == 1) | 75 | if ( uid == 1) |
74 | uid = uidGen().generate(); | 76 | uid = uidGen().generate(); |
75 | 77 | ||
76 | Qtopia::Record::setUid( uid ); | 78 | Qtopia::Record::setUid( uid ); |
77 | }; | 79 | }; |
78 | Qtopia::UidGen &OPimRecord::uidGen() { | 80 | Qtopia::UidGen &OPimRecord::uidGen() { |
79 | return m_uidGen; | 81 | return m_uidGen; |
80 | } | 82 | } |
81 | OPimXRefManager &OPimRecord::xrefmanager() { | 83 | OPimXRefManager &OPimRecord::xrefmanager() { |
82 | return m_xrefman; | 84 | return m_xrefman; |
83 | } | 85 | } |
84 | int OPimRecord::rtti(){ | 86 | int OPimRecord::rtti(){ |
85 | return 0; | 87 | return 0; |
86 | } | 88 | } |
87 | 89 | ||
88 | /** | 90 | /** |
89 | * now let's put our data into the stream | 91 | * now let's put our data into the stream |
90 | */ | 92 | */ |
91 | /* | 93 | /* |
92 | * First read UID | 94 | * First read UID |
93 | * Categories | 95 | * Categories |
94 | * XRef | 96 | * XRef |
95 | */ | 97 | */ |
96 | bool OPimRecord::loadFromStream( QDataStream& stream ) { | 98 | bool OPimRecord::loadFromStream( QDataStream& stream ) { |
97 | int Int; | 99 | int Int; |
98 | uint UInt; | 100 | uint UInt; |
99 | stream >> Int; | 101 | stream >> Int; |
100 | setUid(Int); | 102 | setUid(Int); |
101 | 103 | ||
102 | /** Categories */ | 104 | /** Categories */ |
103 | stream >> UInt; | 105 | stream >> UInt; |
104 | QArray<int> array(UInt); | 106 | QArray<int> array(UInt); |
105 | for (uint i = 0; i < UInt; i++ ) { | 107 | for (uint i = 0; i < UInt; i++ ) { |
106 | stream >> array[i]; | 108 | stream >> array[i]; |
107 | } | 109 | } |
108 | setCategories( array ); | 110 | setCategories( array ); |
109 | 111 | ||
110 | /* | 112 | /* |
111 | * now we do the X-Ref stuff | 113 | * now we do the X-Ref stuff |
112 | */ | 114 | */ |
113 | OPimXRef xref; | 115 | OPimXRef xref; |
114 | stream >> UInt; | 116 | stream >> UInt; |
115 | for ( uint i = 0; i < UInt; i++ ) { | 117 | for ( uint i = 0; i < UInt; i++ ) { |
116 | xref.setPartner( OPimXRef::One, partner( stream ) ); | 118 | xref.setPartner( OPimXRef::One, partner( stream ) ); |
117 | xref.setPartner( OPimXRef::Two, partner( stream ) ); | 119 | xref.setPartner( OPimXRef::Two, partner( stream ) ); |
118 | m_xrefman.add( xref ); | 120 | m_xrefman.add( xref ); |
119 | } | 121 | } |
120 | 122 | ||
121 | return true; | 123 | return true; |
122 | } | 124 | } |
123 | bool OPimRecord::saveToStream( QDataStream& stream )const { | 125 | bool OPimRecord::saveToStream( QDataStream& stream )const { |
124 | /** UIDs */ | 126 | /** UIDs */ |
125 | 127 | ||
126 | stream << uid(); | 128 | stream << uid(); |
127 | 129 | ||
128 | /** Categories */ | 130 | /** Categories */ |
129 | stream << categories().count(); | 131 | stream << categories().count(); |
130 | for ( uint i = 0; i < categories().count(); i++ ) { | 132 | for ( uint i = 0; i < categories().count(); i++ ) { |
131 | stream << categories()[i]; | 133 | stream << categories()[i]; |
132 | } | 134 | } |
133 | 135 | ||
134 | /* | 136 | /* |
135 | * first the XRef count | 137 | * first the XRef count |
136 | * then the xrefs | 138 | * then the xrefs |
137 | */ | 139 | */ |
138 | stream << m_xrefman.list().count(); | 140 | stream << m_xrefman.list().count(); |
139 | for ( OPimXRef::ValueList::ConstIterator it = m_xrefman.list().begin(); | 141 | for ( OPimXRef::ValueList::ConstIterator it = m_xrefman.list().begin(); |
140 | it != m_xrefman.list().end(); ++it ) { | 142 | it != m_xrefman.list().end(); ++it ) { |
141 | flush( (*it).partner( OPimXRef::One), stream ); | 143 | flush( (*it).partner( OPimXRef::One), stream ); |
142 | flush( (*it).partner( OPimXRef::Two), stream ); | 144 | flush( (*it).partner( OPimXRef::Two), stream ); |
143 | } | 145 | } |
144 | return true; | 146 | return true; |
145 | } | 147 | } |
146 | void OPimRecord::flush( const OPimXRefPartner& par, QDataStream& str ) const{ | 148 | void OPimRecord::flush( const OPimXRefPartner& par, QDataStream& str ) const{ |
147 | str << par.service(); | 149 | str << par.service(); |
148 | str << par.uid(); | 150 | str << par.uid(); |
149 | str << par.field(); | 151 | str << par.field(); |
150 | } | 152 | } |
151 | OPimXRefPartner OPimRecord::partner( QDataStream& stream ) { | 153 | OPimXRefPartner OPimRecord::partner( QDataStream& stream ) { |
152 | OPimXRefPartner par; | 154 | OPimXRefPartner par; |
153 | QString str; | 155 | QString str; |
154 | int i; | 156 | int i; |
155 | 157 | ||
156 | stream >> str; | 158 | stream >> str; |
157 | par.setService( str ); | 159 | par.setService( str ); |
158 | 160 | ||
159 | stream >> i; | 161 | stream >> i; |
160 | par.setUid( i ); | 162 | par.setUid( i ); |
161 | 163 | ||
162 | stream >> i ; | 164 | stream >> i ; |
163 | par.setField( i ); | 165 | par.setField( i ); |
164 | 166 | ||
165 | return par; | 167 | return par; |
166 | } | 168 | } |
169 | void OPimRecord::setLastHitField( int lastHit )const { | ||
170 | m_lastHit = lastHit; | ||
171 | } | ||
172 | int OPimRecord::lastHitField()const{ | ||
173 | return m_lastHit; | ||
174 | } | ||
diff --git a/libopie2/opiepim/core/opimrecord.h b/libopie2/opiepim/core/opimrecord.h index 6e7c0da..494c78e 100644 --- a/libopie2/opiepim/core/opimrecord.h +++ b/libopie2/opiepim/core/opimrecord.h | |||
@@ -1,140 +1,151 @@ | |||
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 QString& appname )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 | * matches the Records the regular expression? | 76 | * matches the Records the regular expression? |
77 | */ | 77 | */ |
78 | virtual bool match( const QString ®exp ) const | 78 | virtual bool match( const QString ®exp ) const |
79 | {return Qtopia::Record::match(QRegExp(regexp));}; | 79 | {setLastHitField( -1 ); |
80 | return Qtopia::Record::match(QRegExp(regexp));}; | ||
81 | |||
82 | /** | ||
83 | * if implemented this function returns which item has been | ||
84 | * last hit by the match() function. | ||
85 | * or -1 if not implemented or no hit has occured | ||
86 | */ | ||
87 | int lastHitField()const; | ||
80 | 88 | ||
81 | /** | 89 | /** |
82 | * converts the internal structure to a map | 90 | * converts the internal structure to a map |
83 | */ | 91 | */ |
84 | virtual QMap<int, QString> toMap()const = 0; | 92 | virtual QMap<int, QString> toMap()const = 0; |
85 | 93 | ||
86 | /** | 94 | /** |
87 | * key value representation of extra items | 95 | * key value representation of extra items |
88 | */ | 96 | */ |
89 | virtual QMap<QString, QString> toExtraMap()const = 0; | 97 | virtual QMap<QString, QString> toExtraMap()const = 0; |
90 | 98 | ||
91 | /** | 99 | /** |
92 | * the name for a recordField | 100 | * the name for a recordField |
93 | */ | 101 | */ |
94 | virtual QString recordField(int)const = 0; | 102 | virtual QString recordField(int)const = 0; |
95 | 103 | ||
96 | /** | 104 | /** |
97 | * returns a reference of the | 105 | * returns a reference of the |
98 | * Cross Reference Manager | 106 | * Cross Reference Manager |
99 | * Partner 'One' is THIS PIM RECORD! | 107 | * Partner 'One' is THIS PIM RECORD! |
100 | * 'Two' is the Partner where we link to | 108 | * 'Two' is the Partner where we link to |
101 | */ | 109 | */ |
102 | OPimXRefManager& xrefmanager(); | 110 | OPimXRefManager& xrefmanager(); |
103 | 111 | ||
104 | /** | 112 | /** |
105 | * set the uid | 113 | * set the uid |
106 | */ | 114 | */ |
107 | virtual void setUid( int uid ); | 115 | virtual void setUid( int uid ); |
108 | 116 | ||
109 | /* | 117 | /* |
110 | * used inside the Templates for casting | 118 | * used inside the Templates for casting |
111 | * REIMPLEMENT in your .... | 119 | * REIMPLEMENT in your .... |
112 | */ | 120 | */ |
113 | static int rtti(); | 121 | static int rtti(); |
114 | 122 | ||
115 | /** | 123 | /** |
116 | * some marshalling and de marshalling code | 124 | * some marshalling and de marshalling code |
117 | * saves the OPimRecord | 125 | * saves the OPimRecord |
118 | * to and from a DataStream | 126 | * to and from a DataStream |
119 | */ | 127 | */ |
120 | virtual bool loadFromStream(QDataStream& ); | 128 | virtual bool loadFromStream(QDataStream& ); |
121 | virtual bool saveToStream( QDataStream& stream )const; | 129 | virtual bool saveToStream( QDataStream& stream )const; |
122 | 130 | ||
123 | protected: | 131 | protected: |
132 | // need to be const cause it is called from const methods | ||
133 | mutable int m_lastHit; | ||
134 | void setLastHitField( int lastHit )const; | ||
124 | Qtopia::UidGen &uidGen(); | 135 | Qtopia::UidGen &uidGen(); |
125 | // QString crossToString()const; | 136 | // QString crossToString()const; |
126 | 137 | ||
127 | private: | 138 | private: |
128 | class OPimRecordPrivate; | 139 | class OPimRecordPrivate; |
129 | OPimRecordPrivate *d; | 140 | OPimRecordPrivate *d; |
130 | OPimXRefManager m_xrefman; | 141 | OPimXRefManager m_xrefman; |
131 | static Qtopia::UidGen m_uidGen; | 142 | static Qtopia::UidGen m_uidGen; |
132 | 143 | ||
133 | private: | 144 | private: |
134 | void flush( const OPimXRefPartner&, QDataStream& stream )const; | 145 | void flush( const OPimXRefPartner&, QDataStream& stream )const; |
135 | OPimXRefPartner partner( QDataStream& ); | 146 | OPimXRefPartner partner( QDataStream& ); |
136 | }; | 147 | }; |
137 | 148 | ||
138 | 149 | ||
139 | 150 | ||
140 | #endif | 151 | #endif |
diff --git a/libopie2/opiepim/ocontact.cpp b/libopie2/opiepim/ocontact.cpp index aeb69ee..a7ca975 100644 --- a/libopie2/opiepim/ocontact.cpp +++ b/libopie2/opiepim/ocontact.cpp | |||
@@ -572,567 +572,568 @@ QString OContact::toRichText() const | |||
572 | text += "<b>" + QObject::tr("Home Mobile: ") + "</b>" | 572 | text += "<b>" + QObject::tr("Home Mobile: ") + "</b>" |
573 | + Qtopia::escapeString(str) + "<br>"; | 573 | + Qtopia::escapeString(str) + "<br>"; |
574 | marker = true; | 574 | marker = true; |
575 | } | 575 | } |
576 | 576 | ||
577 | if ( marker ) | 577 | if ( marker ) |
578 | text += "<br><hr><br>"; | 578 | text += "<br><hr><br>"; |
579 | // the others... | 579 | // the others... |
580 | str = emails(); | 580 | str = emails(); |
581 | if ( !str.isEmpty() && ( str != defEmail ) ) | 581 | if ( !str.isEmpty() && ( str != defEmail ) ) |
582 | text += "<b>" + QObject::tr("All Emails: ") + "</b>" | 582 | text += "<b>" + QObject::tr("All Emails: ") + "</b>" |
583 | + Qtopia::escapeString(str) + "<br>"; | 583 | + Qtopia::escapeString(str) + "<br>"; |
584 | str = profession(); | 584 | str = profession(); |
585 | if ( !str.isEmpty() ) | 585 | if ( !str.isEmpty() ) |
586 | text += "<b>" + QObject::tr("Profession: ") + "</b>" | 586 | text += "<b>" + QObject::tr("Profession: ") + "</b>" |
587 | + Qtopia::escapeString(str) + "<br>"; | 587 | + Qtopia::escapeString(str) + "<br>"; |
588 | str = assistant(); | 588 | str = assistant(); |
589 | if ( !str.isEmpty() ) | 589 | if ( !str.isEmpty() ) |
590 | text += "<b>" + QObject::tr("Assistant: ") + "</b>" | 590 | text += "<b>" + QObject::tr("Assistant: ") + "</b>" |
591 | + Qtopia::escapeString(str) + "<br>"; | 591 | + Qtopia::escapeString(str) + "<br>"; |
592 | str = manager(); | 592 | str = manager(); |
593 | if ( !str.isEmpty() ) | 593 | if ( !str.isEmpty() ) |
594 | text += "<b>" + QObject::tr("Manager: ") + "</b>" | 594 | text += "<b>" + QObject::tr("Manager: ") + "</b>" |
595 | + Qtopia::escapeString(str) + "<br>"; | 595 | + Qtopia::escapeString(str) + "<br>"; |
596 | str = gender(); | 596 | str = gender(); |
597 | if ( !str.isEmpty() && str.toInt() != 0 ) { | 597 | if ( !str.isEmpty() && str.toInt() != 0 ) { |
598 | if ( str.toInt() == 1 ) | 598 | if ( str.toInt() == 1 ) |
599 | str = QObject::tr( "Male" ); | 599 | str = QObject::tr( "Male" ); |
600 | else if ( str.toInt() == 2 ) | 600 | else if ( str.toInt() == 2 ) |
601 | str = QObject::tr( "Female" ); | 601 | str = QObject::tr( "Female" ); |
602 | text += "<b>" + QObject::tr("Gender: ") + "</b>" + str + "<br>"; | 602 | text += "<b>" + QObject::tr("Gender: ") + "</b>" + str + "<br>"; |
603 | } | 603 | } |
604 | str = spouse(); | 604 | str = spouse(); |
605 | if ( !str.isEmpty() ) | 605 | if ( !str.isEmpty() ) |
606 | text += "<b>" + QObject::tr("Spouse: ") + "</b>" | 606 | text += "<b>" + QObject::tr("Spouse: ") + "</b>" |
607 | + Qtopia::escapeString(str) + "<br>"; | 607 | + Qtopia::escapeString(str) + "<br>"; |
608 | if ( birthday().isValid() ){ | 608 | if ( birthday().isValid() ){ |
609 | str = TimeString::numberDateString( birthday() ); | 609 | str = TimeString::numberDateString( birthday() ); |
610 | text += "<b>" + QObject::tr("Birthday: ") + "</b>" | 610 | text += "<b>" + QObject::tr("Birthday: ") + "</b>" |
611 | + Qtopia::escapeString(str) + "<br>"; | 611 | + Qtopia::escapeString(str) + "<br>"; |
612 | } | 612 | } |
613 | if ( anniversary().isValid() ){ | 613 | if ( anniversary().isValid() ){ |
614 | str = TimeString::numberDateString( anniversary() ); | 614 | str = TimeString::numberDateString( anniversary() ); |
615 | text += "<b>" + QObject::tr("Anniversary: ") + "</b>" | 615 | text += "<b>" + QObject::tr("Anniversary: ") + "</b>" |
616 | + Qtopia::escapeString(str) + "<br>"; | 616 | + Qtopia::escapeString(str) + "<br>"; |
617 | } | 617 | } |
618 | str = children(); | 618 | str = children(); |
619 | if ( !str.isEmpty() ) | 619 | if ( !str.isEmpty() ) |
620 | text += "<b>" + QObject::tr("Children: ") + "</b>" | 620 | text += "<b>" + QObject::tr("Children: ") + "</b>" |
621 | + Qtopia::escapeString(str) + "<br>"; | 621 | + Qtopia::escapeString(str) + "<br>"; |
622 | 622 | ||
623 | str = nickname(); | 623 | str = nickname(); |
624 | if ( !str.isEmpty() ) | 624 | if ( !str.isEmpty() ) |
625 | text += "<b>" + QObject::tr("Nickname: ") + "</b>" | 625 | text += "<b>" + QObject::tr("Nickname: ") + "</b>" |
626 | + Qtopia::escapeString(str) + "<br>"; | 626 | + Qtopia::escapeString(str) + "<br>"; |
627 | 627 | ||
628 | if ( categoryNames("Contacts").count() ){ | 628 | if ( categoryNames("Contacts").count() ){ |
629 | text += "<b>" + QObject::tr( "Category:") + "</b> "; | 629 | text += "<b>" + QObject::tr( "Category:") + "</b> "; |
630 | text += categoryNames("Contacts").join(", "); | 630 | text += categoryNames("Contacts").join(", "); |
631 | text += "<br>"; | 631 | text += "<br>"; |
632 | } | 632 | } |
633 | 633 | ||
634 | // notes last | 634 | // notes last |
635 | if ( !(value = notes()).isEmpty() ) { | 635 | if ( !(value = notes()).isEmpty() ) { |
636 | text += "<br><hr><b>" + QObject::tr( "Notes:") + "</b> "; | 636 | text += "<br><hr><b>" + QObject::tr( "Notes:") + "</b> "; |
637 | QRegExp reg("\n"); | 637 | QRegExp reg("\n"); |
638 | 638 | ||
639 | //QString tmp = Qtopia::escapeString(value); | 639 | //QString tmp = Qtopia::escapeString(value); |
640 | QString tmp = QStyleSheet::convertFromPlainText(value); | 640 | QString tmp = QStyleSheet::convertFromPlainText(value); |
641 | //tmp.replace( reg, "<br>" ); | 641 | //tmp.replace( reg, "<br>" ); |
642 | text += "<br>" + tmp + "<br>"; | 642 | text += "<br>" + tmp + "<br>"; |
643 | } | 643 | } |
644 | return text; | 644 | return text; |
645 | } | 645 | } |
646 | 646 | ||
647 | /*! | 647 | /*! |
648 | \internal | 648 | \internal |
649 | */ | 649 | */ |
650 | void OContact::insert( int key, const QString &v ) | 650 | void OContact::insert( int key, const QString &v ) |
651 | { | 651 | { |
652 | QString value = v.stripWhiteSpace(); | 652 | QString value = v.stripWhiteSpace(); |
653 | if ( value.isEmpty() ) | 653 | if ( value.isEmpty() ) |
654 | mMap.remove( key ); | 654 | mMap.remove( key ); |
655 | else | 655 | else |
656 | mMap.insert( key, value ); | 656 | mMap.insert( key, value ); |
657 | } | 657 | } |
658 | 658 | ||
659 | /*! | 659 | /*! |
660 | \internal | 660 | \internal |
661 | */ | 661 | */ |
662 | void OContact::replace( int key, const QString & v ) | 662 | void OContact::replace( int key, const QString & v ) |
663 | { | 663 | { |
664 | QString value = v.stripWhiteSpace(); | 664 | QString value = v.stripWhiteSpace(); |
665 | if ( value.isEmpty() ) | 665 | if ( value.isEmpty() ) |
666 | mMap.remove( key ); | 666 | mMap.remove( key ); |
667 | else | 667 | else |
668 | mMap.replace( key, value ); | 668 | mMap.replace( key, value ); |
669 | } | 669 | } |
670 | 670 | ||
671 | /*! | 671 | /*! |
672 | \internal | 672 | \internal |
673 | */ | 673 | */ |
674 | QString OContact::find( int key ) const | 674 | QString OContact::find( int key ) const |
675 | { | 675 | { |
676 | return mMap[key]; | 676 | return mMap[key]; |
677 | } | 677 | } |
678 | 678 | ||
679 | /*! | 679 | /*! |
680 | \internal | 680 | \internal |
681 | */ | 681 | */ |
682 | QString OContact::displayAddress( const QString &street, | 682 | QString OContact::displayAddress( const QString &street, |
683 | const QString &city, | 683 | const QString &city, |
684 | const QString &state, | 684 | const QString &state, |
685 | const QString &zip, | 685 | const QString &zip, |
686 | const QString &country ) const | 686 | const QString &country ) const |
687 | { | 687 | { |
688 | QString s = street; | 688 | QString s = street; |
689 | if ( !street.isEmpty() ) | 689 | if ( !street.isEmpty() ) |
690 | s+= "\n"; | 690 | s+= "\n"; |
691 | s += city; | 691 | s += city; |
692 | if ( !city.isEmpty() && !state.isEmpty() ) | 692 | if ( !city.isEmpty() && !state.isEmpty() ) |
693 | s += ", "; | 693 | s += ", "; |
694 | s += state; | 694 | s += state; |
695 | if ( !state.isEmpty() && !zip.isEmpty() ) | 695 | if ( !state.isEmpty() && !zip.isEmpty() ) |
696 | s += " "; | 696 | s += " "; |
697 | s += zip; | 697 | s += zip; |
698 | if ( !country.isEmpty() && !s.isEmpty() ) | 698 | if ( !country.isEmpty() && !s.isEmpty() ) |
699 | s += "\n"; | 699 | s += "\n"; |
700 | s += country; | 700 | s += country; |
701 | return s; | 701 | return s; |
702 | } | 702 | } |
703 | 703 | ||
704 | /*! | 704 | /*! |
705 | \internal | 705 | \internal |
706 | */ | 706 | */ |
707 | QString OContact::displayBusinessAddress() const | 707 | QString OContact::displayBusinessAddress() const |
708 | { | 708 | { |
709 | return displayAddress( businessStreet(), businessCity(), | 709 | return displayAddress( businessStreet(), businessCity(), |
710 | businessState(), businessZip(), | 710 | businessState(), businessZip(), |
711 | businessCountry() ); | 711 | businessCountry() ); |
712 | } | 712 | } |
713 | 713 | ||
714 | /*! | 714 | /*! |
715 | \internal | 715 | \internal |
716 | */ | 716 | */ |
717 | QString OContact::displayHomeAddress() const | 717 | QString OContact::displayHomeAddress() const |
718 | { | 718 | { |
719 | return displayAddress( homeStreet(), homeCity(), | 719 | return displayAddress( homeStreet(), homeCity(), |
720 | homeState(), homeZip(), | 720 | homeState(), homeZip(), |
721 | homeCountry() ); | 721 | homeCountry() ); |
722 | } | 722 | } |
723 | 723 | ||
724 | /*! | 724 | /*! |
725 | Returns the full name of the contact | 725 | Returns the full name of the contact |
726 | */ | 726 | */ |
727 | QString OContact::fullName() const | 727 | QString OContact::fullName() const |
728 | { | 728 | { |
729 | QString title = find( Qtopia::Title ); | 729 | QString title = find( Qtopia::Title ); |
730 | QString firstName = find( Qtopia::FirstName ); | 730 | QString firstName = find( Qtopia::FirstName ); |
731 | QString middleName = find( Qtopia::MiddleName ); | 731 | QString middleName = find( Qtopia::MiddleName ); |
732 | QString lastName = find( Qtopia::LastName ); | 732 | QString lastName = find( Qtopia::LastName ); |
733 | QString suffix = find( Qtopia::Suffix ); | 733 | QString suffix = find( Qtopia::Suffix ); |
734 | 734 | ||
735 | QString name = title; | 735 | QString name = title; |
736 | if ( !firstName.isEmpty() ) { | 736 | if ( !firstName.isEmpty() ) { |
737 | if ( !name.isEmpty() ) | 737 | if ( !name.isEmpty() ) |
738 | name += " "; | 738 | name += " "; |
739 | name += firstName; | 739 | name += firstName; |
740 | } | 740 | } |
741 | if ( !middleName.isEmpty() ) { | 741 | if ( !middleName.isEmpty() ) { |
742 | if ( !name.isEmpty() ) | 742 | if ( !name.isEmpty() ) |
743 | name += " "; | 743 | name += " "; |
744 | name += middleName; | 744 | name += middleName; |
745 | } | 745 | } |
746 | if ( !lastName.isEmpty() ) { | 746 | if ( !lastName.isEmpty() ) { |
747 | if ( !name.isEmpty() ) | 747 | if ( !name.isEmpty() ) |
748 | name += " "; | 748 | name += " "; |
749 | name += lastName; | 749 | name += lastName; |
750 | } | 750 | } |
751 | if ( !suffix.isEmpty() ) { | 751 | if ( !suffix.isEmpty() ) { |
752 | if ( !name.isEmpty() ) | 752 | if ( !name.isEmpty() ) |
753 | name += " "; | 753 | name += " "; |
754 | name += suffix; | 754 | name += suffix; |
755 | } | 755 | } |
756 | return name.simplifyWhiteSpace(); | 756 | return name.simplifyWhiteSpace(); |
757 | } | 757 | } |
758 | 758 | ||
759 | /*! | 759 | /*! |
760 | Returns a list of the names of the children of the contact. | 760 | Returns a list of the names of the children of the contact. |
761 | */ | 761 | */ |
762 | QStringList OContact::childrenList() const | 762 | QStringList OContact::childrenList() const |
763 | { | 763 | { |
764 | return QStringList::split( " ", find( Qtopia::Children ) ); | 764 | return QStringList::split( " ", find( Qtopia::Children ) ); |
765 | } | 765 | } |
766 | 766 | ||
767 | /*! \fn void OContact::insertEmail( const QString &email ) | 767 | /*! \fn void OContact::insertEmail( const QString &email ) |
768 | 768 | ||
769 | Insert \a email into the email list. Ensures \a email can only be added | 769 | Insert \a email into the email list. Ensures \a email can only be added |
770 | once. If there is no default email address set, it sets it to the \a email. | 770 | once. If there is no default email address set, it sets it to the \a email. |
771 | */ | 771 | */ |
772 | 772 | ||
773 | /*! \fn void OContact::removeEmail( const QString &email ) | 773 | /*! \fn void OContact::removeEmail( const QString &email ) |
774 | 774 | ||
775 | Removes the \a email from the email list. If the default email was \a email, | 775 | Removes the \a email from the email list. If the default email was \a email, |
776 | then the default email address is assigned to the first email in the | 776 | then the default email address is assigned to the first email in the |
777 | email list | 777 | email list |
778 | */ | 778 | */ |
779 | 779 | ||
780 | /*! \fn void OContact::clearEmails() | 780 | /*! \fn void OContact::clearEmails() |
781 | 781 | ||
782 | Clears the email list. | 782 | Clears the email list. |
783 | */ | 783 | */ |
784 | 784 | ||
785 | /*! \fn void OContact::insertEmails( const QStringList &emailList ) | 785 | /*! \fn void OContact::insertEmails( const QStringList &emailList ) |
786 | 786 | ||
787 | Appends the \a emailList to the exiting email list | 787 | Appends the \a emailList to the exiting email list |
788 | */ | 788 | */ |
789 | 789 | ||
790 | /*! | 790 | /*! |
791 | Returns a list of email addresses belonging to the contact, including | 791 | Returns a list of email addresses belonging to the contact, including |
792 | the default email address. | 792 | the default email address. |
793 | */ | 793 | */ |
794 | QStringList OContact::emailList() const | 794 | QStringList OContact::emailList() const |
795 | { | 795 | { |
796 | QString emailStr = emails(); | 796 | QString emailStr = emails(); |
797 | 797 | ||
798 | QStringList r; | 798 | QStringList r; |
799 | if ( !emailStr.isEmpty() ) { | 799 | if ( !emailStr.isEmpty() ) { |
800 | qDebug(" emailstr "); | 800 | qDebug(" emailstr "); |
801 | QStringList l = QStringList::split( emailSeparator(), emailStr ); | 801 | QStringList l = QStringList::split( emailSeparator(), emailStr ); |
802 | for ( QStringList::ConstIterator it = l.begin();it != l.end();++it ) | 802 | for ( QStringList::ConstIterator it = l.begin();it != l.end();++it ) |
803 | r += (*it).simplifyWhiteSpace(); | 803 | r += (*it).simplifyWhiteSpace(); |
804 | } | 804 | } |
805 | 805 | ||
806 | return r; | 806 | return r; |
807 | } | 807 | } |
808 | 808 | ||
809 | /*! | 809 | /*! |
810 | \overload | 810 | \overload |
811 | 811 | ||
812 | Generates the string for the contact to be filed as from the first, | 812 | Generates the string for the contact to be filed as from the first, |
813 | middle and last name of the contact. | 813 | middle and last name of the contact. |
814 | */ | 814 | */ |
815 | void OContact::setFileAs() | 815 | void OContact::setFileAs() |
816 | { | 816 | { |
817 | QString lastName, firstName, middleName, fileas; | 817 | QString lastName, firstName, middleName, fileas; |
818 | 818 | ||
819 | lastName = find( Qtopia::LastName ); | 819 | lastName = find( Qtopia::LastName ); |
820 | firstName = find( Qtopia::FirstName ); | 820 | firstName = find( Qtopia::FirstName ); |
821 | middleName = find( Qtopia::MiddleName ); | 821 | middleName = find( Qtopia::MiddleName ); |
822 | if ( !lastName.isEmpty() && !firstName.isEmpty() | 822 | if ( !lastName.isEmpty() && !firstName.isEmpty() |
823 | && !middleName.isEmpty() ) | 823 | && !middleName.isEmpty() ) |
824 | fileas = lastName + ", " + firstName + " " + middleName; | 824 | fileas = lastName + ", " + firstName + " " + middleName; |
825 | else if ( !lastName.isEmpty() && !firstName.isEmpty() ) | 825 | else if ( !lastName.isEmpty() && !firstName.isEmpty() ) |
826 | fileas = lastName + ", " + firstName; | 826 | fileas = lastName + ", " + firstName; |
827 | else if ( !lastName.isEmpty() || !firstName.isEmpty() || | 827 | else if ( !lastName.isEmpty() || !firstName.isEmpty() || |
828 | !middleName.isEmpty() ) | 828 | !middleName.isEmpty() ) |
829 | fileas = firstName + ( firstName.isEmpty() ? "" : " " ) | 829 | fileas = firstName + ( firstName.isEmpty() ? "" : " " ) |
830 | + middleName + ( middleName.isEmpty() ? "" : " " ) | 830 | + middleName + ( middleName.isEmpty() ? "" : " " ) |
831 | + lastName; | 831 | + lastName; |
832 | 832 | ||
833 | replace( Qtopia::FileAs, fileas ); | 833 | replace( Qtopia::FileAs, fileas ); |
834 | } | 834 | } |
835 | 835 | ||
836 | /*! | 836 | /*! |
837 | \internal | 837 | \internal |
838 | Appends the contact information to \a buf. | 838 | Appends the contact information to \a buf. |
839 | */ | 839 | */ |
840 | void OContact::save( QString &buf ) const | 840 | void OContact::save( QString &buf ) const |
841 | { | 841 | { |
842 | static const QStringList SLFIELDS = fields(); | 842 | static const QStringList SLFIELDS = fields(); |
843 | // I'm expecting "<Contact " in front of this... | 843 | // I'm expecting "<Contact " in front of this... |
844 | for ( QMap<int, QString>::ConstIterator it = mMap.begin(); | 844 | for ( QMap<int, QString>::ConstIterator it = mMap.begin(); |
845 | it != mMap.end(); ++it ) { | 845 | it != mMap.end(); ++it ) { |
846 | const QString &value = it.data(); | 846 | const QString &value = it.data(); |
847 | int key = it.key(); | 847 | int key = it.key(); |
848 | if ( !value.isEmpty() ) { | 848 | if ( !value.isEmpty() ) { |
849 | if ( key == Qtopia::AddressCategory || key == Qtopia::AddressUid) | 849 | if ( key == Qtopia::AddressCategory || key == Qtopia::AddressUid) |
850 | continue; | 850 | continue; |
851 | 851 | ||
852 | key -= Qtopia::AddressCategory+1; | 852 | key -= Qtopia::AddressCategory+1; |
853 | buf += SLFIELDS[key]; | 853 | buf += SLFIELDS[key]; |
854 | buf += "=\"" + Qtopia::escapeString(value) + "\" "; | 854 | buf += "=\"" + Qtopia::escapeString(value) + "\" "; |
855 | } | 855 | } |
856 | } | 856 | } |
857 | buf += customToXml(); | 857 | buf += customToXml(); |
858 | if ( categories().count() > 0 ) | 858 | if ( categories().count() > 0 ) |
859 | buf += "Categories=\"" + idsToString( categories() ) + "\" "; | 859 | buf += "Categories=\"" + idsToString( categories() ) + "\" "; |
860 | buf += "Uid=\"" + QString::number( uid() ) + "\" "; | 860 | buf += "Uid=\"" + QString::number( uid() ) + "\" "; |
861 | // You need to close this yourself | 861 | // You need to close this yourself |
862 | } | 862 | } |
863 | 863 | ||
864 | 864 | ||
865 | /*! | 865 | /*! |
866 | \internal | 866 | \internal |
867 | Returns the list of fields belonging to a contact | 867 | Returns the list of fields belonging to a contact |
868 | Never change order of this list ! It has to be regarding | 868 | Never change order of this list ! It has to be regarding |
869 | enum AddressBookFields !! | 869 | enum AddressBookFields !! |
870 | */ | 870 | */ |
871 | QStringList OContact::fields() | 871 | QStringList OContact::fields() |
872 | { | 872 | { |
873 | QStringList list; | 873 | QStringList list; |
874 | 874 | ||
875 | list.append( "Title" ); // Not Used! | 875 | list.append( "Title" ); // Not Used! |
876 | list.append( "FirstName" ); | 876 | list.append( "FirstName" ); |
877 | list.append( "MiddleName" ); | 877 | list.append( "MiddleName" ); |
878 | list.append( "LastName" ); | 878 | list.append( "LastName" ); |
879 | list.append( "Suffix" ); | 879 | list.append( "Suffix" ); |
880 | list.append( "FileAs" ); | 880 | list.append( "FileAs" ); |
881 | 881 | ||
882 | list.append( "JobTitle" ); | 882 | list.append( "JobTitle" ); |
883 | list.append( "Department" ); | 883 | list.append( "Department" ); |
884 | list.append( "Company" ); | 884 | list.append( "Company" ); |
885 | list.append( "BusinessPhone" ); | 885 | list.append( "BusinessPhone" ); |
886 | list.append( "BusinessFax" ); | 886 | list.append( "BusinessFax" ); |
887 | list.append( "BusinessMobile" ); | 887 | list.append( "BusinessMobile" ); |
888 | 888 | ||
889 | list.append( "DefaultEmail" ); | 889 | list.append( "DefaultEmail" ); |
890 | list.append( "Emails" ); | 890 | list.append( "Emails" ); |
891 | 891 | ||
892 | list.append( "HomePhone" ); | 892 | list.append( "HomePhone" ); |
893 | list.append( "HomeFax" ); | 893 | list.append( "HomeFax" ); |
894 | list.append( "HomeMobile" ); | 894 | list.append( "HomeMobile" ); |
895 | 895 | ||
896 | list.append( "BusinessStreet" ); | 896 | list.append( "BusinessStreet" ); |
897 | list.append( "BusinessCity" ); | 897 | list.append( "BusinessCity" ); |
898 | list.append( "BusinessState" ); | 898 | list.append( "BusinessState" ); |
899 | list.append( "BusinessZip" ); | 899 | list.append( "BusinessZip" ); |
900 | list.append( "BusinessCountry" ); | 900 | list.append( "BusinessCountry" ); |
901 | list.append( "BusinessPager" ); | 901 | list.append( "BusinessPager" ); |
902 | list.append( "BusinessWebPage" ); | 902 | list.append( "BusinessWebPage" ); |
903 | 903 | ||
904 | list.append( "Office" ); | 904 | list.append( "Office" ); |
905 | list.append( "Profession" ); | 905 | list.append( "Profession" ); |
906 | list.append( "Assistant" ); | 906 | list.append( "Assistant" ); |
907 | list.append( "Manager" ); | 907 | list.append( "Manager" ); |
908 | 908 | ||
909 | list.append( "HomeStreet" ); | 909 | list.append( "HomeStreet" ); |
910 | list.append( "HomeCity" ); | 910 | list.append( "HomeCity" ); |
911 | list.append( "HomeState" ); | 911 | list.append( "HomeState" ); |
912 | list.append( "HomeZip" ); | 912 | list.append( "HomeZip" ); |
913 | list.append( "HomeCountry" ); | 913 | list.append( "HomeCountry" ); |
914 | list.append( "HomeWebPage" ); | 914 | list.append( "HomeWebPage" ); |
915 | 915 | ||
916 | list.append( "Spouse" ); | 916 | list.append( "Spouse" ); |
917 | list.append( "Gender" ); | 917 | list.append( "Gender" ); |
918 | list.append( "Birthday" ); | 918 | list.append( "Birthday" ); |
919 | list.append( "Anniversary" ); | 919 | list.append( "Anniversary" ); |
920 | list.append( "Nickname" ); | 920 | list.append( "Nickname" ); |
921 | list.append( "Children" ); | 921 | list.append( "Children" ); |
922 | 922 | ||
923 | list.append( "Notes" ); | 923 | list.append( "Notes" ); |
924 | list.append( "Groups" ); | 924 | list.append( "Groups" ); |
925 | 925 | ||
926 | return list; | 926 | return list; |
927 | } | 927 | } |
928 | 928 | ||
929 | 929 | ||
930 | /*! | 930 | /*! |
931 | Sets the list of email address for contact to those contained in \a str. | 931 | Sets the list of email address for contact to those contained in \a str. |
932 | Email address should be separated by ';'s. | 932 | Email address should be separated by ';'s. |
933 | */ | 933 | */ |
934 | void OContact::setEmails( const QString &str ) | 934 | void OContact::setEmails( const QString &str ) |
935 | { | 935 | { |
936 | replace( Qtopia::Emails, str ); | 936 | replace( Qtopia::Emails, str ); |
937 | if ( str.isEmpty() ) | 937 | if ( str.isEmpty() ) |
938 | setDefaultEmail( QString::null ); | 938 | setDefaultEmail( QString::null ); |
939 | } | 939 | } |
940 | 940 | ||
941 | /*! | 941 | /*! |
942 | Sets the list of children for the contact to those contained in \a str. | 942 | Sets the list of children for the contact to those contained in \a str. |
943 | */ | 943 | */ |
944 | void OContact::setChildren( const QString &str ) | 944 | void OContact::setChildren( const QString &str ) |
945 | { | 945 | { |
946 | replace( Qtopia::Children, str ); | 946 | replace( Qtopia::Children, str ); |
947 | } | 947 | } |
948 | 948 | ||
949 | /*! | 949 | /*! |
950 | \overload | 950 | \overload |
951 | Returns TRUE if the contact matches the regular expression \a regexp. | 951 | Returns TRUE if the contact matches the regular expression \a regexp. |
952 | Otherwise returns FALSE. | 952 | Otherwise returns FALSE. |
953 | */ | 953 | */ |
954 | bool OContact::match( const QRegExp &r ) const | 954 | bool OContact::match( const QRegExp &r ) const |
955 | { | 955 | { |
956 | setLastHitField( -1 ); | ||
956 | bool match; | 957 | bool match; |
957 | match = false; | 958 | match = false; |
958 | QMap<int, QString>::ConstIterator it; | 959 | QMap<int, QString>::ConstIterator it; |
959 | for ( it = mMap.begin(); it != mMap.end(); ++it ) { | 960 | for ( it = mMap.begin(); it != mMap.end(); ++it ) { |
960 | if ( (*it).find( r ) > -1 ) { | 961 | if ( (*it).find( r ) > -1 ) { |
961 | setLastHitField( it.key() ); | 962 | setLastHitField( it.key() ); |
962 | match = true; | 963 | match = true; |
963 | break; | 964 | break; |
964 | } | 965 | } |
965 | } | 966 | } |
966 | return match; | 967 | return match; |
967 | } | 968 | } |
968 | 969 | ||
969 | 970 | ||
970 | QString OContact::toShortText() const | 971 | QString OContact::toShortText() const |
971 | { | 972 | { |
972 | return ( fullName() ); | 973 | return ( fullName() ); |
973 | } | 974 | } |
974 | QString OContact::type() const | 975 | QString OContact::type() const |
975 | { | 976 | { |
976 | return QString::fromLatin1( "OContact" ); | 977 | return QString::fromLatin1( "OContact" ); |
977 | } | 978 | } |
978 | 979 | ||
979 | // Definition is missing ! (se) | 980 | // Definition is missing ! (se) |
980 | QMap<QString,QString> OContact::toExtraMap() const | 981 | QMap<QString,QString> OContact::toExtraMap() const |
981 | { | 982 | { |
982 | qWarning ("Function not implemented: OContact::toExtraMap()"); | 983 | qWarning ("Function not implemented: OContact::toExtraMap()"); |
983 | QMap <QString,QString> useless; | 984 | QMap <QString,QString> useless; |
984 | return useless; | 985 | return useless; |
985 | } | 986 | } |
986 | 987 | ||
987 | class QString OContact::recordField( int pos ) const | 988 | class QString OContact::recordField( int pos ) const |
988 | { | 989 | { |
989 | QStringList SLFIELDS = fields(); // ?? why this ? (se) | 990 | QStringList SLFIELDS = fields(); // ?? why this ? (se) |
990 | return SLFIELDS[pos]; | 991 | return SLFIELDS[pos]; |
991 | } | 992 | } |
992 | 993 | ||
993 | // In future releases, we should store birthday and anniversary | 994 | // In future releases, we should store birthday and anniversary |
994 | // internally as QDate instead of QString ! | 995 | // internally as QDate instead of QString ! |
995 | // QString is always too complicate to interprete (DD.MM.YY, DD/MM/YY, MM/DD/YY, etc..)(se) | 996 | // QString is always too complicate to interprete (DD.MM.YY, DD/MM/YY, MM/DD/YY, etc..)(se) |
996 | 997 | ||
997 | /*! \fn void OContact::setBirthday( const QDate& date ) | 998 | /*! \fn void OContact::setBirthday( const QDate& date ) |
998 | Sets the birthday for the contact to \a date. If date is null | 999 | Sets the birthday for the contact to \a date. If date is null |
999 | the current stored date will be removed. | 1000 | the current stored date will be removed. |
1000 | */ | 1001 | */ |
1001 | void OContact::setBirthday( const QDate &v ) | 1002 | void OContact::setBirthday( const QDate &v ) |
1002 | { | 1003 | { |
1003 | if ( v.isNull() ){ | 1004 | if ( v.isNull() ){ |
1004 | qWarning( "Remove Birthday"); | 1005 | qWarning( "Remove Birthday"); |
1005 | replace( Qtopia::Birthday, QString::null ); | 1006 | replace( Qtopia::Birthday, QString::null ); |
1006 | return; | 1007 | return; |
1007 | } | 1008 | } |
1008 | 1009 | ||
1009 | if ( v.isValid() ) | 1010 | if ( v.isValid() ) |
1010 | replace( Qtopia::Birthday, OConversion::dateToString( v ) ); | 1011 | replace( Qtopia::Birthday, OConversion::dateToString( v ) ); |
1011 | 1012 | ||
1012 | } | 1013 | } |
1013 | 1014 | ||
1014 | 1015 | ||
1015 | /*! \fn void OContact::setAnniversary( const QDate &date ) | 1016 | /*! \fn void OContact::setAnniversary( const QDate &date ) |
1016 | Sets the anniversary of the contact to \a date. If date is | 1017 | Sets the anniversary of the contact to \a date. If date is |
1017 | null, the current stored date will be removed. | 1018 | null, the current stored date will be removed. |
1018 | */ | 1019 | */ |
1019 | void OContact::setAnniversary( const QDate &v ) | 1020 | void OContact::setAnniversary( const QDate &v ) |
1020 | { | 1021 | { |
1021 | if ( v.isNull() ){ | 1022 | if ( v.isNull() ){ |
1022 | qWarning( "Remove Anniversary"); | 1023 | qWarning( "Remove Anniversary"); |
1023 | replace( Qtopia::Anniversary, QString::null ); | 1024 | replace( Qtopia::Anniversary, QString::null ); |
1024 | return; | 1025 | return; |
1025 | } | 1026 | } |
1026 | 1027 | ||
1027 | if ( v.isValid() ) | 1028 | if ( v.isValid() ) |
1028 | replace( Qtopia::Anniversary, OConversion::dateToString( v ) ); | 1029 | replace( Qtopia::Anniversary, OConversion::dateToString( v ) ); |
1029 | } | 1030 | } |
1030 | 1031 | ||
1031 | /*! \fn QDate OContact::birthday() const | 1032 | /*! \fn QDate OContact::birthday() const |
1032 | Returns the birthday of the contact. | 1033 | Returns the birthday of the contact. |
1033 | */ | 1034 | */ |
1034 | QDate OContact::birthday() const | 1035 | QDate OContact::birthday() const |
1035 | { | 1036 | { |
1036 | QString str = find( Qtopia::Birthday ); | 1037 | QString str = find( Qtopia::Birthday ); |
1037 | qWarning ("Birthday %s", str.latin1() ); | 1038 | qWarning ("Birthday %s", str.latin1() ); |
1038 | if ( !str.isEmpty() ) | 1039 | if ( !str.isEmpty() ) |
1039 | return OConversion::dateFromString ( str ); | 1040 | return OConversion::dateFromString ( str ); |
1040 | else | 1041 | else |
1041 | return QDate(); | 1042 | return QDate(); |
1042 | } | 1043 | } |
1043 | 1044 | ||
1044 | 1045 | ||
1045 | /*! \fn QDate OContact::anniversary() const | 1046 | /*! \fn QDate OContact::anniversary() const |
1046 | Returns the anniversary of the contact. | 1047 | Returns the anniversary of the contact. |
1047 | */ | 1048 | */ |
1048 | QDate OContact::anniversary() const | 1049 | QDate OContact::anniversary() const |
1049 | { | 1050 | { |
1050 | QDate empty; | 1051 | QDate empty; |
1051 | QString str = find( Qtopia::Anniversary ); | 1052 | QString str = find( Qtopia::Anniversary ); |
1052 | qWarning ("Anniversary %s", str.latin1() ); | 1053 | qWarning ("Anniversary %s", str.latin1() ); |
1053 | if ( !str.isEmpty() ) | 1054 | if ( !str.isEmpty() ) |
1054 | return OConversion::dateFromString ( str ); | 1055 | return OConversion::dateFromString ( str ); |
1055 | else | 1056 | else |
1056 | return empty; | 1057 | return empty; |
1057 | } | 1058 | } |
1058 | 1059 | ||
1059 | 1060 | ||
1060 | void OContact::insertEmail( const QString &v ) | 1061 | void OContact::insertEmail( const QString &v ) |
1061 | { | 1062 | { |
1062 | //qDebug("insertEmail %s", v.latin1()); | 1063 | //qDebug("insertEmail %s", v.latin1()); |
1063 | QString e = v.simplifyWhiteSpace(); | 1064 | QString e = v.simplifyWhiteSpace(); |
1064 | QString def = defaultEmail(); | 1065 | QString def = defaultEmail(); |
1065 | 1066 | ||
1066 | // if no default, set it as the default email and don't insert | 1067 | // if no default, set it as the default email and don't insert |
1067 | if ( def.isEmpty() ) { | 1068 | if ( def.isEmpty() ) { |
1068 | setDefaultEmail( e ); // will insert into the list for us | 1069 | setDefaultEmail( e ); // will insert into the list for us |
1069 | return; | 1070 | return; |
1070 | } | 1071 | } |
1071 | 1072 | ||
1072 | // otherwise, insert assuming doesn't already exist | 1073 | // otherwise, insert assuming doesn't already exist |
1073 | QString emailsStr = find( Qtopia::Emails ); | 1074 | QString emailsStr = find( Qtopia::Emails ); |
1074 | if ( emailsStr.contains( e )) | 1075 | if ( emailsStr.contains( e )) |
1075 | return; | 1076 | return; |
1076 | if ( !emailsStr.isEmpty() ) | 1077 | if ( !emailsStr.isEmpty() ) |
1077 | emailsStr += emailSeparator(); | 1078 | emailsStr += emailSeparator(); |
1078 | emailsStr += e; | 1079 | emailsStr += e; |
1079 | replace( Qtopia::Emails, emailsStr ); | 1080 | replace( Qtopia::Emails, emailsStr ); |
1080 | } | 1081 | } |
1081 | 1082 | ||
1082 | void OContact::removeEmail( const QString &v ) | 1083 | void OContact::removeEmail( const QString &v ) |
1083 | { | 1084 | { |
1084 | QString e = v.simplifyWhiteSpace(); | 1085 | QString e = v.simplifyWhiteSpace(); |
1085 | QString def = defaultEmail(); | 1086 | QString def = defaultEmail(); |
1086 | QString emailsStr = find( Qtopia::Emails ); | 1087 | QString emailsStr = find( Qtopia::Emails ); |
1087 | QStringList emails = emailList(); | 1088 | QStringList emails = emailList(); |
1088 | 1089 | ||
1089 | // otherwise, must first contain it | 1090 | // otherwise, must first contain it |
1090 | if ( !emailsStr.contains( e ) ) | 1091 | if ( !emailsStr.contains( e ) ) |
1091 | return; | 1092 | return; |
1092 | 1093 | ||
1093 | // remove it | 1094 | // remove it |
1094 | //qDebug(" removing email from list %s", e.latin1()); | 1095 | //qDebug(" removing email from list %s", e.latin1()); |
1095 | emails.remove( e ); | 1096 | emails.remove( e ); |
1096 | // reset the string | 1097 | // reset the string |
1097 | emailsStr = emails.join(emailSeparator()); // Sharp's brain dead separator | 1098 | emailsStr = emails.join(emailSeparator()); // Sharp's brain dead separator |
1098 | replace( Qtopia::Emails, emailsStr ); | 1099 | replace( Qtopia::Emails, emailsStr ); |
1099 | 1100 | ||
1100 | // if default, then replace the default email with the first one | 1101 | // if default, then replace the default email with the first one |
1101 | if ( def == e ) { | 1102 | if ( def == e ) { |
1102 | //qDebug("removeEmail is default; setting new default"); | 1103 | //qDebug("removeEmail is default; setting new default"); |
1103 | if ( !emails.count() ) | 1104 | if ( !emails.count() ) |
1104 | clearEmails(); | 1105 | clearEmails(); |
1105 | else // setDefaultEmail will remove e from the list | 1106 | else // setDefaultEmail will remove e from the list |
1106 | setDefaultEmail( emails.first() ); | 1107 | setDefaultEmail( emails.first() ); |
1107 | } | 1108 | } |
1108 | } | 1109 | } |
1109 | void OContact::clearEmails() | 1110 | void OContact::clearEmails() |
1110 | { | 1111 | { |
1111 | mMap.remove( Qtopia::DefaultEmail ); | 1112 | mMap.remove( Qtopia::DefaultEmail ); |
1112 | mMap.remove( Qtopia::Emails ); | 1113 | mMap.remove( Qtopia::Emails ); |
1113 | } | 1114 | } |
1114 | void OContact::setDefaultEmail( const QString &v ) | 1115 | void OContact::setDefaultEmail( const QString &v ) |
1115 | { | 1116 | { |
1116 | QString e = v.simplifyWhiteSpace(); | 1117 | QString e = v.simplifyWhiteSpace(); |
1117 | 1118 | ||
1118 | //qDebug("OContact::setDefaultEmail %s", e.latin1()); | 1119 | //qDebug("OContact::setDefaultEmail %s", e.latin1()); |
1119 | replace( Qtopia::DefaultEmail, e ); | 1120 | replace( Qtopia::DefaultEmail, e ); |
1120 | 1121 | ||
1121 | if ( !e.isEmpty() ) | 1122 | if ( !e.isEmpty() ) |
1122 | insertEmail( e ); | 1123 | insertEmail( e ); |
1123 | 1124 | ||
1124 | } | 1125 | } |
1125 | 1126 | ||
1126 | void OContact::insertEmails( const QStringList &v ) | 1127 | void OContact::insertEmails( const QStringList &v ) |
1127 | { | 1128 | { |
1128 | for ( QStringList::ConstIterator it = v.begin(); it != v.end(); ++it ) | 1129 | for ( QStringList::ConstIterator it = v.begin(); it != v.end(); ++it ) |
1129 | insertEmail( *it ); | 1130 | insertEmail( *it ); |
1130 | } | 1131 | } |
1131 | int OContact::rtti() { | 1132 | int OContact::rtti() { |
1132 | return OPimResolver::AddressBook; | 1133 | return OPimResolver::AddressBook; |
1133 | } | 1134 | } |
1134 | void OContact::setUid( int i ) | 1135 | void OContact::setUid( int i ) |
1135 | { | 1136 | { |
1136 | OPimRecord::setUid(i); | 1137 | OPimRecord::setUid(i); |
1137 | replace( Qtopia::AddressUid , QString::number(i)); | 1138 | replace( Qtopia::AddressUid , QString::number(i)); |
1138 | } | 1139 | } |
diff --git a/libopie2/opiepim/ocontact.h b/libopie2/opiepim/ocontact.h index f79f0f3..dd2de17 100644 --- a/libopie2/opiepim/ocontact.h +++ b/libopie2/opiepim/ocontact.h | |||
@@ -1,244 +1,240 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** Copyright (C) 2002-2003 by Stefan Eilers (eilers.stefan@epost.de) | 3 | ** Copyright (C) 2002-2003 by Stefan Eilers (eilers.stefan@epost.de) |
4 | ** | 4 | ** |
5 | ** This file may be distributed and/or modified under the terms of the | 5 | ** This file may be distributed and/or modified under the terms of the |
6 | ** GNU General Public License version 2 as published by the Free Software | 6 | ** GNU General Public License version 2 as published by the Free Software |
7 | ** Foundation and appearing in the file LICENSE.GPL included in the | 7 | ** Foundation and appearing in the file LICENSE.GPL included in the |
8 | ** packaging of this file. | 8 | ** packaging of this file. |
9 | ** | 9 | ** |
10 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 10 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
11 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 11 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
12 | ** | 12 | ** |
13 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 13 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
14 | ** | 14 | ** |
15 | ** Contact info@trolltech.com if any conditions of this licensing are | 15 | ** Contact info@trolltech.com if any conditions of this licensing are |
16 | ** not clear to you. | 16 | ** not clear to you. |
17 | ** | 17 | ** |
18 | **********************************************************************/ | 18 | **********************************************************************/ |
19 | 19 | ||
20 | #ifndef __OCONTACT_H__ | 20 | #ifndef __OCONTACT_H__ |
21 | #define __OCONTACT_H__ | 21 | #define __OCONTACT_H__ |
22 | 22 | ||
23 | #include <opie/opimrecord.h> | 23 | #include <opie/opimrecord.h> |
24 | #include <qpe/recordfields.h> | 24 | #include <qpe/recordfields.h> |
25 | 25 | ||
26 | #include <qdatetime.h> | 26 | #include <qdatetime.h> |
27 | #include <qstringlist.h> | 27 | #include <qstringlist.h> |
28 | 28 | ||
29 | #if defined(QPC_TEMPLATEDLL) | 29 | #if defined(QPC_TEMPLATEDLL) |
30 | // MOC_SKIP_BEGIN | 30 | // MOC_SKIP_BEGIN |
31 | QPC_TEMPLATEEXTERN template class QPC_EXPORT QMap<int, QString>; | 31 | QPC_TEMPLATEEXTERN template class QPC_EXPORT QMap<int, QString>; |
32 | // MOC_SKIP_END | 32 | // MOC_SKIP_END |
33 | #endif | 33 | #endif |
34 | 34 | ||
35 | class ContactPrivate; | 35 | class ContactPrivate; |
36 | 36 | ||
37 | /** | 37 | /** |
38 | * OContact class represents a specialised PIM Record for contacts. | 38 | * OContact class represents a specialised PIM Record for contacts. |
39 | * It does store all kind of persopn related information. | 39 | * It does store all kind of persopn related information. |
40 | * | 40 | * |
41 | * @short Contact Container | 41 | * @short Contact Container |
42 | * @author TT, Stefan Eiler, Holger Freyther | 42 | * @author TT, Stefan Eiler, Holger Freyther |
43 | */ | 43 | */ |
44 | class QPC_EXPORT OContact : public OPimRecord | 44 | class QPC_EXPORT OContact : public OPimRecord |
45 | { | 45 | { |
46 | friend class DataSet; | 46 | friend class DataSet; |
47 | public: | 47 | public: |
48 | OContact(); | 48 | OContact(); |
49 | OContact( const QMap<int, QString> &fromMap ); | 49 | OContact( const QMap<int, QString> &fromMap ); |
50 | virtual ~OContact(); | 50 | virtual ~OContact(); |
51 | 51 | ||
52 | /* | 52 | /* |
53 | * do we need to inline them | 53 | * do we need to inline them |
54 | * if yes do we need to inline them this way? | 54 | * if yes do we need to inline them this way? |
55 | * -zecke | 55 | * -zecke |
56 | */ | 56 | */ |
57 | void setTitle( const QString &v ) { replace( Qtopia::Title, v ); } | 57 | void setTitle( const QString &v ) { replace( Qtopia::Title, v ); } |
58 | void setFirstName( const QString &v ) { replace( Qtopia::FirstName, v ); } | 58 | void setFirstName( const QString &v ) { replace( Qtopia::FirstName, v ); } |
59 | void setMiddleName( const QString &v ) { replace( Qtopia::MiddleName, v ); } | 59 | void setMiddleName( const QString &v ) { replace( Qtopia::MiddleName, v ); } |
60 | void setLastName( const QString &v ) { replace( Qtopia::LastName, v ); } | 60 | void setLastName( const QString &v ) { replace( Qtopia::LastName, v ); } |
61 | void setSuffix( const QString &v ) { replace( Qtopia::Suffix, v ); } | 61 | void setSuffix( const QString &v ) { replace( Qtopia::Suffix, v ); } |
62 | void setFileAs( const QString &v ) { replace( Qtopia::FileAs, v ); } | 62 | void setFileAs( const QString &v ) { replace( Qtopia::FileAs, v ); } |
63 | void setFileAs(); | 63 | void setFileAs(); |
64 | 64 | ||
65 | // default email address | 65 | // default email address |
66 | void setDefaultEmail( const QString &v ); | 66 | void setDefaultEmail( const QString &v ); |
67 | // inserts email to list and ensure's doesn't already exist | 67 | // inserts email to list and ensure's doesn't already exist |
68 | void insertEmail( const QString &v ); | 68 | void insertEmail( const QString &v ); |
69 | void removeEmail( const QString &v ); | 69 | void removeEmail( const QString &v ); |
70 | void clearEmails(); | 70 | void clearEmails(); |
71 | void insertEmails( const QStringList &v ); | 71 | void insertEmails( const QStringList &v ); |
72 | 72 | ||
73 | // home | 73 | // home |
74 | void setHomeStreet( const QString &v ) { replace( Qtopia::HomeStreet, v ); } | 74 | void setHomeStreet( const QString &v ) { replace( Qtopia::HomeStreet, v ); } |
75 | void setHomeCity( const QString &v ) { replace( Qtopia::HomeCity, v ); } | 75 | void setHomeCity( const QString &v ) { replace( Qtopia::HomeCity, v ); } |
76 | void setHomeState( const QString &v ) { replace( Qtopia::HomeState, v ); } | 76 | void setHomeState( const QString &v ) { replace( Qtopia::HomeState, v ); } |
77 | void setHomeZip( const QString &v ) { replace( Qtopia::HomeZip, v ); } | 77 | void setHomeZip( const QString &v ) { replace( Qtopia::HomeZip, v ); } |
78 | void setHomeCountry( const QString &v ) { replace( Qtopia::HomeCountry, v ); } | 78 | void setHomeCountry( const QString &v ) { replace( Qtopia::HomeCountry, v ); } |
79 | void setHomePhone( const QString &v ) { replace( Qtopia::HomePhone, v ); } | 79 | void setHomePhone( const QString &v ) { replace( Qtopia::HomePhone, v ); } |
80 | void setHomeFax( const QString &v ) { replace( Qtopia::HomeFax, v ); } | 80 | void setHomeFax( const QString &v ) { replace( Qtopia::HomeFax, v ); } |
81 | void setHomeMobile( const QString &v ) { replace( Qtopia::HomeMobile, v ); } | 81 | void setHomeMobile( const QString &v ) { replace( Qtopia::HomeMobile, v ); } |
82 | void setHomeWebpage( const QString &v ) { replace( Qtopia::HomeWebPage, v ); } | 82 | void setHomeWebpage( const QString &v ) { replace( Qtopia::HomeWebPage, v ); } |
83 | 83 | ||
84 | // business | 84 | // business |
85 | void setCompany( const QString &v ) { replace( Qtopia::Company, v ); } | 85 | void setCompany( const QString &v ) { replace( Qtopia::Company, v ); } |
86 | void setBusinessStreet( const QString &v ) { replace( Qtopia::BusinessStreet, v ); } | 86 | void setBusinessStreet( const QString &v ) { replace( Qtopia::BusinessStreet, v ); } |
87 | void setBusinessCity( const QString &v ) { replace( Qtopia::BusinessCity, v ); } | 87 | void setBusinessCity( const QString &v ) { replace( Qtopia::BusinessCity, v ); } |
88 | void setBusinessState( const QString &v ) { replace( Qtopia::BusinessState, v ); } | 88 | void setBusinessState( const QString &v ) { replace( Qtopia::BusinessState, v ); } |
89 | void setBusinessZip( const QString &v ) { replace( Qtopia::BusinessZip, v ); } | 89 | void setBusinessZip( const QString &v ) { replace( Qtopia::BusinessZip, v ); } |
90 | void setBusinessCountry( const QString &v ) { replace( Qtopia::BusinessCountry, v ); } | 90 | void setBusinessCountry( const QString &v ) { replace( Qtopia::BusinessCountry, v ); } |
91 | void setBusinessWebpage( const QString &v ) { replace( Qtopia::BusinessWebPage, v ); } | 91 | void setBusinessWebpage( const QString &v ) { replace( Qtopia::BusinessWebPage, v ); } |
92 | void setJobTitle( const QString &v ) { replace( Qtopia::JobTitle, v ); } | 92 | void setJobTitle( const QString &v ) { replace( Qtopia::JobTitle, v ); } |
93 | void setDepartment( const QString &v ) { replace( Qtopia::Department, v ); } | 93 | void setDepartment( const QString &v ) { replace( Qtopia::Department, v ); } |
94 | void setOffice( const QString &v ) { replace( Qtopia::Office, v ); } | 94 | void setOffice( const QString &v ) { replace( Qtopia::Office, v ); } |
95 | void setBusinessPhone( const QString &v ) { replace( Qtopia::BusinessPhone, v ); } | 95 | void setBusinessPhone( const QString &v ) { replace( Qtopia::BusinessPhone, v ); } |
96 | void setBusinessFax( const QString &v ) { replace( Qtopia::BusinessFax, v ); } | 96 | void setBusinessFax( const QString &v ) { replace( Qtopia::BusinessFax, v ); } |
97 | void setBusinessMobile( const QString &v ) { replace( Qtopia::BusinessMobile, v ); } | 97 | void setBusinessMobile( const QString &v ) { replace( Qtopia::BusinessMobile, v ); } |
98 | void setBusinessPager( const QString &v ) { replace( Qtopia::BusinessPager, v ); } | 98 | void setBusinessPager( const QString &v ) { replace( Qtopia::BusinessPager, v ); } |
99 | void setProfession( const QString &v ) { replace( Qtopia::Profession, v ); } | 99 | void setProfession( const QString &v ) { replace( Qtopia::Profession, v ); } |
100 | void setAssistant( const QString &v ) { replace( Qtopia::Assistant, v ); } | 100 | void setAssistant( const QString &v ) { replace( Qtopia::Assistant, v ); } |
101 | void setManager( const QString &v ) { replace( Qtopia::Manager, v ); } | 101 | void setManager( const QString &v ) { replace( Qtopia::Manager, v ); } |
102 | 102 | ||
103 | // personal | 103 | // personal |
104 | void setSpouse( const QString &v ) { replace( Qtopia::Spouse, v ); } | 104 | void setSpouse( const QString &v ) { replace( Qtopia::Spouse, v ); } |
105 | void setGender( const QString &v ) { replace( Qtopia::Gender, v ); } | 105 | void setGender( const QString &v ) { replace( Qtopia::Gender, v ); } |
106 | void setBirthday( const QDate &v ); | 106 | void setBirthday( const QDate &v ); |
107 | void setAnniversary( const QDate &v ); | 107 | void setAnniversary( const QDate &v ); |
108 | void setNickname( const QString &v ) { replace( Qtopia::Nickname, v ); } | 108 | void setNickname( const QString &v ) { replace( Qtopia::Nickname, v ); } |
109 | void setChildren( const QString &v ); | 109 | void setChildren( const QString &v ); |
110 | 110 | ||
111 | // other | 111 | // other |
112 | void setNotes( const QString &v ) { replace( Qtopia::Notes, v); } | 112 | void setNotes( const QString &v ) { replace( Qtopia::Notes, v); } |
113 | 113 | ||
114 | virtual bool match( const QRegExp ®exp ) const; | 114 | virtual bool match( const QRegExp ®exp ) const; |
115 | 115 | ||
116 | // // custom | 116 | // // custom |
117 | // void setCustomField( const QString &key, const QString &v ) | 117 | // void setCustomField( const QString &key, const QString &v ) |
118 | // { replace(Custom- + key, v ); } | 118 | // { replace(Custom- + key, v ); } |
119 | 119 | ||
120 | // name | 120 | // name |
121 | QString fullName() const; | 121 | QString fullName() const; |
122 | QString title() const { return find( Qtopia::Title ); } | 122 | QString title() const { return find( Qtopia::Title ); } |
123 | QString firstName() const { return find( Qtopia::FirstName ); } | 123 | QString firstName() const { return find( Qtopia::FirstName ); } |
124 | QString middleName() const { return find( Qtopia::MiddleName ); } | 124 | QString middleName() const { return find( Qtopia::MiddleName ); } |
125 | QString lastName() const { return find( Qtopia::LastName ); } | 125 | QString lastName() const { return find( Qtopia::LastName ); } |
126 | QString suffix() const { return find( Qtopia::Suffix ); } | 126 | QString suffix() const { return find( Qtopia::Suffix ); } |
127 | QString fileAs() const { return find( Qtopia::FileAs ); } | 127 | QString fileAs() const { return find( Qtopia::FileAs ); } |
128 | 128 | ||
129 | 129 | ||
130 | QString defaultEmail() const { return find( Qtopia::DefaultEmail ); } | 130 | QString defaultEmail() const { return find( Qtopia::DefaultEmail ); } |
131 | QStringList emailList() const; | 131 | QStringList emailList() const; |
132 | 132 | ||
133 | // home | 133 | // home |
134 | /* | 134 | /* |
135 | * OPimAddress address(enum Location)const; | 135 | * OPimAddress address(enum Location)const; |
136 | * would be some how nicer... | 136 | * would be some how nicer... |
137 | * -zecke | 137 | * -zecke |
138 | */ | 138 | */ |
139 | QString homeStreet() const { return find( Qtopia::HomeStreet ); } | 139 | QString homeStreet() const { return find( Qtopia::HomeStreet ); } |
140 | QString homeCity() const { return find( Qtopia::HomeCity ); } | 140 | QString homeCity() const { return find( Qtopia::HomeCity ); } |
141 | QString homeState() const { return find( Qtopia::HomeState ); } | 141 | QString homeState() const { return find( Qtopia::HomeState ); } |
142 | QString homeZip() const { return find( Qtopia::HomeZip ); } | 142 | QString homeZip() const { return find( Qtopia::HomeZip ); } |
143 | QString homeCountry() const { return find( Qtopia::HomeCountry ); } | 143 | QString homeCountry() const { return find( Qtopia::HomeCountry ); } |
144 | QString homePhone() const { return find( Qtopia::HomePhone ); } | 144 | QString homePhone() const { return find( Qtopia::HomePhone ); } |
145 | QString homeFax() const { return find( Qtopia::HomeFax ); } | 145 | QString homeFax() const { return find( Qtopia::HomeFax ); } |
146 | QString homeMobile() const { return find( Qtopia::HomeMobile ); } | 146 | QString homeMobile() const { return find( Qtopia::HomeMobile ); } |
147 | QString homeWebpage() const { return find( Qtopia::HomeWebPage ); } | 147 | QString homeWebpage() const { return find( Qtopia::HomeWebPage ); } |
148 | /** Multi line string containing all non-empty address info in the form | 148 | /** Multi line string containing all non-empty address info in the form |
149 | * Street | 149 | * Street |
150 | * City, State Zip | 150 | * City, State Zip |
151 | * Country | 151 | * Country |
152 | */ | 152 | */ |
153 | QString displayHomeAddress() const; | 153 | QString displayHomeAddress() const; |
154 | 154 | ||
155 | // business | 155 | // business |
156 | QString company() const { return find( Qtopia::Company ); } | 156 | QString company() const { return find( Qtopia::Company ); } |
157 | QString businessStreet() const { return find( Qtopia::BusinessStreet ); } | 157 | QString businessStreet() const { return find( Qtopia::BusinessStreet ); } |
158 | QString businessCity() const { return find( Qtopia::BusinessCity ); } | 158 | QString businessCity() const { return find( Qtopia::BusinessCity ); } |
159 | QString businessState() const { return find( Qtopia::BusinessState ); } | 159 | QString businessState() const { return find( Qtopia::BusinessState ); } |
160 | QString businessZip() const { return find( Qtopia::BusinessZip ); } | 160 | QString businessZip() const { return find( Qtopia::BusinessZip ); } |
161 | QString businessCountry() const { return find( Qtopia::BusinessCountry ); } | 161 | QString businessCountry() const { return find( Qtopia::BusinessCountry ); } |
162 | QString businessWebpage() const { return find( Qtopia::BusinessWebPage ); } | 162 | QString businessWebpage() const { return find( Qtopia::BusinessWebPage ); } |
163 | QString jobTitle() const { return find( Qtopia::JobTitle ); } | 163 | QString jobTitle() const { return find( Qtopia::JobTitle ); } |
164 | QString department() const { return find( Qtopia::Department ); } | 164 | QString department() const { return find( Qtopia::Department ); } |
165 | QString office() const { return find( Qtopia::Office ); } | 165 | QString office() const { return find( Qtopia::Office ); } |
166 | QString businessPhone() const { return find( Qtopia::BusinessPhone ); } | 166 | QString businessPhone() const { return find( Qtopia::BusinessPhone ); } |
167 | QString businessFax() const { return find( Qtopia::BusinessFax ); } | 167 | QString businessFax() const { return find( Qtopia::BusinessFax ); } |
168 | QString businessMobile() const { return find( Qtopia::BusinessMobile ); } | 168 | QString businessMobile() const { return find( Qtopia::BusinessMobile ); } |
169 | QString businessPager() const { return find( Qtopia::BusinessPager ); } | 169 | QString businessPager() const { return find( Qtopia::BusinessPager ); } |
170 | QString profession() const { return find( Qtopia::Profession ); } | 170 | QString profession() const { return find( Qtopia::Profession ); } |
171 | QString assistant() const { return find( Qtopia::Assistant ); } | 171 | QString assistant() const { return find( Qtopia::Assistant ); } |
172 | QString manager() const { return find( Qtopia::Manager ); } | 172 | QString manager() const { return find( Qtopia::Manager ); } |
173 | /** Multi line string containing all non-empty address info in the form | 173 | /** Multi line string containing all non-empty address info in the form |
174 | * Street | 174 | * Street |
175 | * City, State Zip | 175 | * City, State Zip |
176 | * Country | 176 | * Country |
177 | */ | 177 | */ |
178 | QString displayBusinessAddress() const; | 178 | QString displayBusinessAddress() const; |
179 | 179 | ||
180 | //personal | 180 | //personal |
181 | QString spouse() const { return find( Qtopia::Spouse ); } | 181 | QString spouse() const { return find( Qtopia::Spouse ); } |
182 | QString gender() const { return find( Qtopia::Gender ); } | 182 | QString gender() const { return find( Qtopia::Gender ); } |
183 | QDate birthday() const; | 183 | QDate birthday() const; |
184 | QDate anniversary() const; | 184 | QDate anniversary() const; |
185 | QString nickname() const { return find( Qtopia::Nickname ); } | 185 | QString nickname() const { return find( Qtopia::Nickname ); } |
186 | QString children() const { return find( Qtopia::Children ); } | 186 | QString children() const { return find( Qtopia::Children ); } |
187 | QStringList childrenList() const; | 187 | QStringList childrenList() const; |
188 | 188 | ||
189 | // other | 189 | // other |
190 | QString notes() const { return find( Qtopia::Notes ); } | 190 | QString notes() const { return find( Qtopia::Notes ); } |
191 | QString groups() const { return find( Qtopia::Groups ); } | 191 | QString groups() const { return find( Qtopia::Groups ); } |
192 | QStringList groupList() const; | 192 | QStringList groupList() const; |
193 | 193 | ||
194 | // // custom | 194 | // // custom |
195 | // const QString &customField( const QString &key ) | 195 | // const QString &customField( const QString &key ) |
196 | // { return find( Custom- + key ); } | 196 | // { return find( Custom- + key ); } |
197 | 197 | ||
198 | 198 | ||
199 | QString toRichText() const; | 199 | QString toRichText() const; |
200 | QMap<int, QString> toMap() const; | 200 | QMap<int, QString> toMap() const; |
201 | QString field( int key ) const { return find( key ); } | 201 | QString field( int key ) const { return find( key ); } |
202 | 202 | ||
203 | 203 | ||
204 | void setUid( int i ); | 204 | void setUid( int i ); |
205 | 205 | ||
206 | QString toShortText()const; | 206 | QString toShortText()const; |
207 | QString OContact::type()const; | 207 | QString OContact::type()const; |
208 | QMap<QString,QString> OContact::toExtraMap() const; | 208 | QMap<QString,QString> OContact::toExtraMap() const; |
209 | class QString OContact::recordField(int) const; | 209 | class QString OContact::recordField(int) const; |
210 | 210 | ||
211 | // Why private ? (eilers,se) | 211 | // Why private ? (eilers,se) |
212 | QString emailSeparator() const { return " "; } | 212 | QString emailSeparator() const { return " "; } |
213 | // the emails should be seperated by a comma | 213 | // the emails should be seperated by a comma |
214 | void setEmails( const QString &v ); | 214 | void setEmails( const QString &v ); |
215 | QString emails() const { return find( Qtopia::Emails ); } | 215 | QString emails() const { return find( Qtopia::Emails ); } |
216 | static int rtti(); | 216 | static int rtti(); |
217 | int lastHitField() const {return m_lastHitField;}; | ||
218 | protected: | ||
219 | mutable int m_lastHitField; | ||
220 | void setLastHitField(int i) const { m_lastHitField = i; }; | ||
221 | 217 | ||
222 | private: | 218 | private: |
223 | // The XML-Backend needs some access to the private functions | 219 | // The XML-Backend needs some access to the private functions |
224 | friend class OContactAccessBackend_XML; | 220 | friend class OContactAccessBackend_XML; |
225 | 221 | ||
226 | void insert( int key, const QString &value ); | 222 | void insert( int key, const QString &value ); |
227 | void replace( int key, const QString &value ); | 223 | void replace( int key, const QString &value ); |
228 | QString find( int key ) const; | 224 | QString find( int key ) const; |
229 | static QStringList fields(); | 225 | static QStringList fields(); |
230 | 226 | ||
231 | void save( QString &buf ) const; | 227 | void save( QString &buf ) const; |
232 | 228 | ||
233 | QString displayAddress( const QString &street, | 229 | QString displayAddress( const QString &street, |
234 | const QString &city, | 230 | const QString &city, |
235 | const QString &state, | 231 | const QString &state, |
236 | const QString &zip, | 232 | const QString &zip, |
237 | const QString &country ) const; | 233 | const QString &country ) const; |
238 | 234 | ||
239 | QMap<int, QString> mMap; | 235 | QMap<int, QString> mMap; |
240 | ContactPrivate *d; | 236 | ContactPrivate *d; |
241 | }; | 237 | }; |
242 | 238 | ||
243 | 239 | ||
244 | #endif | 240 | #endif |