summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie/pim/ocontact.cpp1
-rw-r--r--libopie/pim/ocontact.h4
-rw-r--r--libopie/pim/opimrecord.cpp8
-rw-r--r--libopie/pim/opimrecord.h15
-rw-r--r--libopie2/opiepim/core/opimrecord.cpp8
-rw-r--r--libopie2/opiepim/core/opimrecord.h15
-rw-r--r--libopie2/opiepim/ocontact.cpp1
-rw-r--r--libopie2/opiepim/ocontact.h4
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*/
650void OContact::insert( int key, const QString &v ) 650void 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*/
662void OContact::replace( int key, const QString & v ) 662void 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*/
674QString OContact::find( int key ) const 674QString 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*/
682QString OContact::displayAddress( const QString &street, 682QString 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*/
707QString OContact::displayBusinessAddress() const 707QString 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*/
717QString OContact::displayHomeAddress() const 717QString 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*/
727QString OContact::fullName() const 727QString 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*/
762QStringList OContact::childrenList() const 762QStringList 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*/
794QStringList OContact::emailList() const 794QStringList 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*/
815void OContact::setFileAs() 815void 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*/
840void OContact::save( QString &buf ) const 840void 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*/
871QStringList OContact::fields() 871QStringList 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*/
934void OContact::setEmails( const QString &str ) 934void 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*/
944void OContact::setChildren( const QString &str ) 944void 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*/
954bool OContact::match( const QRegExp &r ) const 954bool 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
970QString OContact::toShortText() const 971QString OContact::toShortText() const
971{ 972{
972 return ( fullName() ); 973 return ( fullName() );
973} 974}
974QString OContact::type() const 975QString 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)
980QMap<QString,QString> OContact::toExtraMap() const 981QMap<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
987class QString OContact::recordField( int pos ) const 988class 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*/
1001void OContact::setBirthday( const QDate &v ) 1002void 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*/
1019void OContact::setAnniversary( const QDate &v ) 1020void 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*/
1034QDate OContact::birthday() const 1035QDate 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*/
1048QDate OContact::anniversary() const 1049QDate 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
1060void OContact::insertEmail( const QString &v ) 1061void 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
1082void OContact::removeEmail( const QString &v ) 1083void 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}
1109void OContact::clearEmails() 1110void 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}
1114void OContact::setDefaultEmail( const QString &v ) 1115void 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
1126void OContact::insertEmails( const QStringList &v ) 1127void 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}
1131int OContact::rtti() { 1132int OContact::rtti() {
1132 return OPimResolver::AddressBook; 1133 return OPimResolver::AddressBook;
1133} 1134}
1134void OContact::setUid( int i ) 1135void 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
31QPC_TEMPLATEEXTERN template class QPC_EXPORT QMap<int, QString>; 31QPC_TEMPLATEEXTERN template class QPC_EXPORT QMap<int, QString>;
32// MOC_SKIP_END 32// MOC_SKIP_END
33#endif 33#endif
34 34
35class ContactPrivate; 35class 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 */
44class QPC_EXPORT OContact : public OPimRecord 44class QPC_EXPORT OContact : public OPimRecord
45{ 45{
46 friend class DataSet; 46 friend class DataSet;
47public: 47public:
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 &regexp ) const; 114 virtual bool match( const QRegExp &regexp ) 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 // email 129 // email
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;};
218protected:
219 mutable int m_lastHitField;
220 void setLastHitField(int i) const { m_lastHitField = i; };
221 217
222private: 218private:
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
8Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia ); 8Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia );
9 9
10 10
11OPimRecord::OPimRecord( int uid ) 11OPimRecord::OPimRecord( int uid )
12 : Qtopia::Record() { 12 : Qtopia::Record() {
13 13
14 m_lastHit = -1;
14 setUid( uid ); 15 setUid( uid );
15} 16}
16OPimRecord::~OPimRecord() { 17OPimRecord::~OPimRecord() {
17} 18}
18OPimRecord::OPimRecord( const OPimRecord& rec ) 19OPimRecord::OPimRecord( const OPimRecord& rec )
19 : Qtopia::Record( rec ) 20 : Qtopia::Record( rec )
20{ 21{
21 (*this) = rec; 22 (*this) = rec;
22} 23}
23 24
24OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { 25OPimRecord &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 */
33QStringList OPimRecord::categoryNames( const QString& appname ) const { 35QStringList 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}
45void OPimRecord::setCategoryNames( const QStringList& ) { 47void OPimRecord::setCategoryNames( const QStringList& ) {
46 48
47} 49}
48void OPimRecord::addCategoryName( const QString& ) { 50void OPimRecord::addCategoryName( const QString& ) {
49 Categories catDB; 51 Categories catDB;
50 catDB.load( categoryFileName() ); 52 catDB.load( categoryFileName() );
51 53
52 54
53} 55}
54bool OPimRecord::isEmpty()const { 56bool 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 */
72void OPimRecord::setUid( int uid ) { 74void 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};
78Qtopia::UidGen &OPimRecord::uidGen() { 80Qtopia::UidGen &OPimRecord::uidGen() {
79 return m_uidGen; 81 return m_uidGen;
80} 82}
81OPimXRefManager &OPimRecord::xrefmanager() { 83OPimXRefManager &OPimRecord::xrefmanager() {
82 return m_xrefman; 84 return m_xrefman;
83} 85}
84int OPimRecord::rtti(){ 86int 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 */
96bool OPimRecord::loadFromStream( QDataStream& stream ) { 98bool 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}
123bool OPimRecord::saveToStream( QDataStream& stream )const { 125bool 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}
146void OPimRecord::flush( const OPimXRefPartner& par, QDataStream& str ) const{ 148void 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}
151OPimXRefPartner OPimRecord::partner( QDataStream& stream ) { 153OPimXRefPartner 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}
169void OPimRecord::setLastHitField( int lastHit )const {
170 m_lastHit = lastHit;
171}
172int 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 */
18class OPimRecord : public Qtopia::Record { 18class OPimRecord : public Qtopia::Record {
19public: 19public:
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 &regexp ) const 78 virtual bool match( const QString &regexp ) 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
123protected: 131protected:
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
127private: 138private:
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
133private: 144private:
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
8Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia ); 8Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia );
9 9
10 10
11OPimRecord::OPimRecord( int uid ) 11OPimRecord::OPimRecord( int uid )
12 : Qtopia::Record() { 12 : Qtopia::Record() {
13 13
14 m_lastHit = -1;
14 setUid( uid ); 15 setUid( uid );
15} 16}
16OPimRecord::~OPimRecord() { 17OPimRecord::~OPimRecord() {
17} 18}
18OPimRecord::OPimRecord( const OPimRecord& rec ) 19OPimRecord::OPimRecord( const OPimRecord& rec )
19 : Qtopia::Record( rec ) 20 : Qtopia::Record( rec )
20{ 21{
21 (*this) = rec; 22 (*this) = rec;
22} 23}
23 24
24OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { 25OPimRecord &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 */
33QStringList OPimRecord::categoryNames( const QString& appname ) const { 35QStringList 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}
45void OPimRecord::setCategoryNames( const QStringList& ) { 47void OPimRecord::setCategoryNames( const QStringList& ) {
46 48
47} 49}
48void OPimRecord::addCategoryName( const QString& ) { 50void OPimRecord::addCategoryName( const QString& ) {
49 Categories catDB; 51 Categories catDB;
50 catDB.load( categoryFileName() ); 52 catDB.load( categoryFileName() );
51 53
52 54
53} 55}
54bool OPimRecord::isEmpty()const { 56bool 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 */
72void OPimRecord::setUid( int uid ) { 74void 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};
78Qtopia::UidGen &OPimRecord::uidGen() { 80Qtopia::UidGen &OPimRecord::uidGen() {
79 return m_uidGen; 81 return m_uidGen;
80} 82}
81OPimXRefManager &OPimRecord::xrefmanager() { 83OPimXRefManager &OPimRecord::xrefmanager() {
82 return m_xrefman; 84 return m_xrefman;
83} 85}
84int OPimRecord::rtti(){ 86int 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 */
96bool OPimRecord::loadFromStream( QDataStream& stream ) { 98bool 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}
123bool OPimRecord::saveToStream( QDataStream& stream )const { 125bool 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}
146void OPimRecord::flush( const OPimXRefPartner& par, QDataStream& str ) const{ 148void 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}
151OPimXRefPartner OPimRecord::partner( QDataStream& stream ) { 153OPimXRefPartner 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}
169void OPimRecord::setLastHitField( int lastHit )const {
170 m_lastHit = lastHit;
171}
172int 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 */
18class OPimRecord : public Qtopia::Record { 18class OPimRecord : public Qtopia::Record {
19public: 19public:
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 &regexp ) const 78 virtual bool match( const QString &regexp ) 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
123protected: 131protected:
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
127private: 138private:
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
133private: 144private:
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*/
650void OContact::insert( int key, const QString &v ) 650void 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*/
662void OContact::replace( int key, const QString & v ) 662void 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*/
674QString OContact::find( int key ) const 674QString 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*/
682QString OContact::displayAddress( const QString &street, 682QString 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*/
707QString OContact::displayBusinessAddress() const 707QString 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*/
717QString OContact::displayHomeAddress() const 717QString 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*/
727QString OContact::fullName() const 727QString 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*/
762QStringList OContact::childrenList() const 762QStringList 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*/
794QStringList OContact::emailList() const 794QStringList 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*/
815void OContact::setFileAs() 815void 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*/
840void OContact::save( QString &buf ) const 840void 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*/
871QStringList OContact::fields() 871QStringList 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*/
934void OContact::setEmails( const QString &str ) 934void 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*/
944void OContact::setChildren( const QString &str ) 944void 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*/
954bool OContact::match( const QRegExp &r ) const 954bool 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
970QString OContact::toShortText() const 971QString OContact::toShortText() const
971{ 972{
972 return ( fullName() ); 973 return ( fullName() );
973} 974}
974QString OContact::type() const 975QString 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)
980QMap<QString,QString> OContact::toExtraMap() const 981QMap<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
987class QString OContact::recordField( int pos ) const 988class 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*/
1001void OContact::setBirthday( const QDate &v ) 1002void 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*/
1019void OContact::setAnniversary( const QDate &v ) 1020void 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*/
1034QDate OContact::birthday() const 1035QDate 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*/
1048QDate OContact::anniversary() const 1049QDate 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
1060void OContact::insertEmail( const QString &v ) 1061void 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
1082void OContact::removeEmail( const QString &v ) 1083void 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}
1109void OContact::clearEmails() 1110void 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}
1114void OContact::setDefaultEmail( const QString &v ) 1115void 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
1126void OContact::insertEmails( const QStringList &v ) 1127void 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}
1131int OContact::rtti() { 1132int OContact::rtti() {
1132 return OPimResolver::AddressBook; 1133 return OPimResolver::AddressBook;
1133} 1134}
1134void OContact::setUid( int i ) 1135void 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
31QPC_TEMPLATEEXTERN template class QPC_EXPORT QMap<int, QString>; 31QPC_TEMPLATEEXTERN template class QPC_EXPORT QMap<int, QString>;
32// MOC_SKIP_END 32// MOC_SKIP_END
33#endif 33#endif
34 34
35class ContactPrivate; 35class 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 */
44class QPC_EXPORT OContact : public OPimRecord 44class QPC_EXPORT OContact : public OPimRecord
45{ 45{
46 friend class DataSet; 46 friend class DataSet;
47public: 47public:
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 &regexp ) const; 114 virtual bool match( const QRegExp &regexp ) 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 // email 129 // email
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;};
218protected:
219 mutable int m_lastHitField;
220 void setLastHitField(int i) const { m_lastHitField = i; };
221 217
222private: 218private:
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