author | eilers <eilers> | 2003-03-04 17:23:03 (UTC) |
---|---|---|
committer | eilers <eilers> | 2003-03-04 17:23:03 (UTC) |
commit | caad9c7b3e7fc0c9046993f6a152cd37f91fdceb (patch) (unidiff) | |
tree | 189006e4f369cf6a373fd20f277966ff42117b5b | |
parent | 55e5d2c95f70d296c541e4f2564713a593c3851c (diff) | |
download | opie-caad9c7b3e7fc0c9046993f6a152cd37f91fdceb.zip opie-caad9c7b3e7fc0c9046993f6a152cd37f91fdceb.tar.gz opie-caad9c7b3e7fc0c9046993f6a152cd37f91fdceb.tar.bz2 |
Fixing suffix handling
-rw-r--r-- | core/pim/addressbook/contacteditor.cpp | 15 | ||||
-rw-r--r-- | core/pim/addressbook/contacteditor.h | 1 |
2 files changed, 11 insertions, 5 deletions
diff --git a/core/pim/addressbook/contacteditor.cpp b/core/pim/addressbook/contacteditor.cpp index c4a7b10..75dd2c1 100644 --- a/core/pim/addressbook/contacteditor.cpp +++ b/core/pim/addressbook/contacteditor.cpp | |||
@@ -584,128 +584,130 @@ void ContactEditor::init() { | |||
584 | if (((*it) == "Anniversary") || | 584 | if (((*it) == "Anniversary") || |
585 | ((*it) == "Birthday")|| ((*it) == "Gender")) continue; | 585 | ((*it) == "Birthday")|| ((*it) == "Gender")) continue; |
586 | 586 | ||
587 | l = new QLabel( mapIdToStr[mapStrToID[*it]].utf8() , container ); | 587 | l = new QLabel( mapIdToStr[mapStrToID[*it]].utf8() , container ); |
588 | listName.append( l ); | 588 | listName.append( l ); |
589 | gl->addWidget( l, i, 0 ); | 589 | gl->addWidget( l, i, 0 ); |
590 | QLineEdit *e = new QLineEdit( container ); | 590 | QLineEdit *e = new QLineEdit( container ); |
591 | listValue.append( e ); | 591 | listValue.append( e ); |
592 | gl->addWidget( e, i, 1); | 592 | gl->addWidget( e, i, 1); |
593 | } | 593 | } |
594 | // Fill labels with names.. | 594 | // Fill labels with names.. |
595 | //loadFields(); | 595 | //loadFields(); |
596 | 596 | ||
597 | 597 | ||
598 | tabMain->insertTab( tabViewport, tr( "Details" ) ); | 598 | tabMain->insertTab( tabViewport, tr( "Details" ) ); |
599 | 599 | ||
600 | dlgNote = new QDialog( this, "Note Dialog", TRUE ); | 600 | dlgNote = new QDialog( this, "Note Dialog", TRUE ); |
601 | dlgNote->setCaption( tr("Enter Note") ); | 601 | dlgNote->setCaption( tr("Enter Note") ); |
602 | QVBoxLayout *vbNote = new QVBoxLayout( dlgNote ); | 602 | QVBoxLayout *vbNote = new QVBoxLayout( dlgNote ); |
603 | txtNote = new QMultiLineEdit( dlgNote ); | 603 | txtNote = new QMultiLineEdit( dlgNote ); |
604 | vbNote->addWidget( txtNote ); | 604 | vbNote->addWidget( txtNote ); |
605 | connect( btnNote, SIGNAL(clicked()), this, SLOT(slotNote()) ); | 605 | connect( btnNote, SIGNAL(clicked()), this, SLOT(slotNote()) ); |
606 | 606 | ||
607 | dlgName = new QDialog( this, "Name Dialog", TRUE ); | 607 | dlgName = new QDialog( this, "Name Dialog", TRUE ); |
608 | dlgName->setCaption( tr("Edit Name") ); | 608 | dlgName->setCaption( tr("Edit Name") ); |
609 | gl = new QGridLayout( dlgName, 5, 2, 2, 3 ); | 609 | gl = new QGridLayout( dlgName, 5, 2, 2, 3 ); |
610 | 610 | ||
611 | l = new QLabel( tr("First Name"), dlgName ); | 611 | l = new QLabel( tr("First Name"), dlgName ); |
612 | gl->addWidget( l, 0, 0 ); | 612 | gl->addWidget( l, 0, 0 ); |
613 | txtFirstName = new QLineEdit( dlgName ); | 613 | txtFirstName = new QLineEdit( dlgName ); |
614 | gl->addWidget( txtFirstName, 0, 1 ); | 614 | gl->addWidget( txtFirstName, 0, 1 ); |
615 | 615 | ||
616 | l = new QLabel( tr("Middle Name"), dlgName ); | 616 | l = new QLabel( tr("Middle Name"), dlgName ); |
617 | gl->addWidget( l, 1, 0 ); | 617 | gl->addWidget( l, 1, 0 ); |
618 | txtMiddleName = new QLineEdit( dlgName ); | 618 | txtMiddleName = new QLineEdit( dlgName ); |
619 | gl->addWidget( txtMiddleName, 1, 1 ); | 619 | gl->addWidget( txtMiddleName, 1, 1 ); |
620 | 620 | ||
621 | l = new QLabel( tr("Last Name"), dlgName ); | 621 | l = new QLabel( tr("Last Name"), dlgName ); |
622 | gl->addWidget( l, 2, 0 ); | 622 | gl->addWidget( l, 2, 0 ); |
623 | txtLastName = new QLineEdit( dlgName ); | 623 | txtLastName = new QLineEdit( dlgName ); |
624 | gl->addWidget( txtLastName, 2, 1 ); | 624 | gl->addWidget( txtLastName, 2, 1 ); |
625 | 625 | ||
626 | // l = new QLabel( tr("Suffix"), dlgName ); | 626 | // l = new QLabel( tr("Suffix"), dlgName ); |
627 | // gl->addWidget( l, 3, 0 ); | 627 | // gl->addWidget( l, 3, 0 ); |
628 | // txtSuffix = new QLineEdit( dlgName ); | 628 | // txtSuffix = new QLineEdit( dlgName ); |
629 | // gl->addWidget( txtSuffix, 3, 1 ); | 629 | // gl->addWidget( txtSuffix, 3, 1 ); |
630 | space = new QSpacerItem(1,1, | 630 | space = new QSpacerItem(1,1, |
631 | QSizePolicy::Maximum, | 631 | QSizePolicy::Maximum, |
632 | QSizePolicy::MinimumExpanding ); | 632 | QSizePolicy::MinimumExpanding ); |
633 | gl->addItem( space, 4, 0 ); | 633 | gl->addItem( space, 4, 0 ); |
634 | 634 | ||
635 | cmbChooserField1->insertStringList( trlChooserNames ); | 635 | cmbChooserField1->insertStringList( trlChooserNames ); |
636 | cmbChooserField2->insertStringList( trlChooserNames ); | 636 | cmbChooserField2->insertStringList( trlChooserNames ); |
637 | cmbChooserField3->insertStringList( trlChooserNames ); | 637 | cmbChooserField3->insertStringList( trlChooserNames ); |
638 | cmbChooserField4->insertStringList( trlChooserNames ); | 638 | cmbChooserField4->insertStringList( trlChooserNames ); |
639 | 639 | ||
640 | cmbChooserField1->setCurrentItem( 0 ); | 640 | cmbChooserField1->setCurrentItem( 0 ); |
641 | cmbChooserField2->setCurrentItem( 1 ); | 641 | cmbChooserField2->setCurrentItem( 1 ); |
642 | cmbChooserField3->setCurrentItem( 2 ); | 642 | cmbChooserField3->setCurrentItem( 2 ); |
643 | 643 | ||
644 | connect( btnFullName, SIGNAL(clicked()), this, SLOT(slotName()) ); | 644 | connect( btnFullName, SIGNAL(clicked()), this, SLOT(slotName()) ); |
645 | 645 | ||
646 | connect( txtFullName, SIGNAL(textChanged(const QString &)), this, SLOT(slotFullNameChange(const QString &)) ); | 646 | connect( txtFullName, SIGNAL(textChanged(const QString &)), this, SLOT(slotFullNameChange(const QString &)) ); |
647 | 647 | ||
648 | connect( txtSuffix, SIGNAL(textChanged(const QString &)), this, SLOT(slotSuffixChange(const QString &)) ); | ||
649 | |||
648 | connect( txtChooserField1, SIGNAL(textChanged(const QString &)), | 650 | connect( txtChooserField1, SIGNAL(textChanged(const QString &)), |
649 | this, SLOT(slotChooser1Change(const QString &)) ); | 651 | this, SLOT(slotChooser1Change(const QString &)) ); |
650 | connect( txtChooserField2, SIGNAL(textChanged(const QString &)), | 652 | connect( txtChooserField2, SIGNAL(textChanged(const QString &)), |
651 | this, SLOT(slotChooser2Change(const QString &)) ); | 653 | this, SLOT(slotChooser2Change(const QString &)) ); |
652 | connect( txtChooserField3, SIGNAL(textChanged(const QString &)), | 654 | connect( txtChooserField3, SIGNAL(textChanged(const QString &)), |
653 | this, SLOT(slotChooser3Change(const QString &)) ); | 655 | this, SLOT(slotChooser3Change(const QString &)) ); |
654 | connect( txtChooserField4, SIGNAL(textChanged(const QString &)), | 656 | connect( txtChooserField4, SIGNAL(textChanged(const QString &)), |
655 | this, SLOT(slotChooser4Change(const QString &)) ); | 657 | this, SLOT(slotChooser4Change(const QString &)) ); |
656 | connect( txtAddress, SIGNAL(textChanged(const QString &)), | 658 | connect( txtAddress, SIGNAL(textChanged(const QString &)), |
657 | this, SLOT(slotAddressChange(const QString &)) ); | 659 | this, SLOT(slotAddressChange(const QString &)) ); |
658 | connect( txtCity, SIGNAL(textChanged(const QString &)), | 660 | connect( txtCity, SIGNAL(textChanged(const QString &)), |
659 | this, SLOT(slotCityChange(const QString &)) ); | 661 | this, SLOT(slotCityChange(const QString &)) ); |
660 | connect( txtState, SIGNAL(textChanged(const QString &)), | 662 | connect( txtState, SIGNAL(textChanged(const QString &)), |
661 | this, SLOT(slotStateChange(const QString &)) ); | 663 | this, SLOT(slotStateChange(const QString &)) ); |
662 | connect( txtZip, SIGNAL(textChanged(const QString &)), | 664 | connect( txtZip, SIGNAL(textChanged(const QString &)), |
663 | this, SLOT(slotZipChange(const QString &)) ); | 665 | this, SLOT(slotZipChange(const QString &)) ); |
664 | connect( cmbCountry, SIGNAL(textChanged(const QString &)), | 666 | connect( cmbCountry, SIGNAL(textChanged(const QString &)), |
665 | this, SLOT(slotCountryChange(const QString &)) ); | 667 | this, SLOT(slotCountryChange(const QString &)) ); |
666 | connect( cmbCountry, SIGNAL(activated(const QString &)), | 668 | connect( cmbCountry, SIGNAL(activated(const QString &)), |
667 | this, SLOT(slotCountryChange(const QString &)) ); | 669 | this, SLOT(slotCountryChange(const QString &)) ); |
668 | connect( cmbChooserField1, SIGNAL(activated(int)), | 670 | connect( cmbChooserField1, SIGNAL(activated(int)), |
669 | this, SLOT(slotCmbChooser1Change(int)) ); | 671 | this, SLOT(slotCmbChooser1Change(int)) ); |
670 | connect( cmbChooserField2, SIGNAL(activated(int)), | 672 | connect( cmbChooserField2, SIGNAL(activated(int)), |
671 | this, SLOT(slotCmbChooser2Change(int)) ); | 673 | this, SLOT(slotCmbChooser2Change(int)) ); |
672 | connect( cmbChooserField3, SIGNAL(activated(int)), | 674 | connect( cmbChooserField3, SIGNAL(activated(int)), |
673 | this, SLOT(slotCmbChooser3Change(int)) ); | 675 | this, SLOT(slotCmbChooser3Change(int)) ); |
674 | connect( cmbChooserField4, SIGNAL(activated(int)), | 676 | connect( cmbChooserField4, SIGNAL(activated(int)), |
675 | this, SLOT(slotCmbChooser4Change(int)) ); | 677 | this, SLOT(slotCmbChooser4Change(int)) ); |
676 | connect( cmbAddress, SIGNAL(activated(int)), | 678 | connect( cmbAddress, SIGNAL(activated(int)), |
677 | this, SLOT(slotAddressTypeChange(int)) ); | 679 | this, SLOT(slotAddressTypeChange(int)) ); |
678 | 680 | ||
679 | new QPEDialogListener(this); | 681 | new QPEDialogListener(this); |
680 | 682 | ||
681 | setPersonalView ( m_personalView ); | 683 | setPersonalView ( m_personalView ); |
682 | 684 | ||
683 | qWarning("init() END"); | 685 | qWarning("init() END"); |
684 | } | 686 | } |
685 | 687 | ||
686 | void ContactEditor::defaultEmailChanged(int i){ | 688 | void ContactEditor::defaultEmailChanged(int i){ |
687 | qDebug("defaultEmailChanged"); | 689 | qDebug("defaultEmailChanged"); |
688 | 690 | ||
689 | // was sollte das ? (se) | 691 | // was sollte das ? (se) |
690 | // int index = cmbChooserField1->currentItem(); | 692 | // int index = cmbChooserField1->currentItem(); |
691 | // slChooserValues[index] = cmbDefaultEmail->text(i); | 693 | // slChooserValues[index] = cmbDefaultEmail->text(i); |
692 | 694 | ||
693 | defaultEmail = cmbDefaultEmail->text(i); | 695 | defaultEmail = cmbDefaultEmail->text(i); |
694 | qDebug ("Changed to: %s", defaultEmail.latin1()); | 696 | qDebug ("Changed to: %s", defaultEmail.latin1()); |
695 | 697 | ||
696 | } | 698 | } |
697 | 699 | ||
698 | void ContactEditor::populateDefaultEmailCmb(){ | 700 | void ContactEditor::populateDefaultEmailCmb(){ |
699 | 701 | ||
700 | // if the default-email combo was not selected and therfore not created | 702 | // if the default-email combo was not selected and therfore not created |
701 | // we get a lot of trouble.. Therfore create an invisible one.. | 703 | // we get a lot of trouble.. Therfore create an invisible one.. |
702 | if ( !cmbDefaultEmail ){ | 704 | if ( !cmbDefaultEmail ){ |
703 | cmbDefaultEmail = new QComboBox(this); | 705 | cmbDefaultEmail = new QComboBox(this); |
704 | cmbDefaultEmail -> hide(); | 706 | cmbDefaultEmail -> hide(); |
705 | } | 707 | } |
706 | cmbDefaultEmail->clear(); | 708 | cmbDefaultEmail->clear(); |
707 | cmbDefaultEmail->insertStringList( emails ); | 709 | cmbDefaultEmail->insertStringList( emails ); |
708 | // cmbDefaultEmail->show(); | 710 | // cmbDefaultEmail->show(); |
709 | 711 | ||
710 | // Select default email in combo.. | 712 | // Select default email in combo.. |
711 | bool found = false; | 713 | bool found = false; |
@@ -976,279 +978,282 @@ void ContactEditor::slotCmbChooser3Change( int index ) { | |||
976 | 978 | ||
977 | void ContactEditor::slotCmbChooser4Change( int index ) { | 979 | void ContactEditor::slotCmbChooser4Change( int index ) { |
978 | qWarning("ContactEditor::slotCmbChooser4Change( %d )", index); | 980 | qWarning("ContactEditor::slotCmbChooser4Change( %d )", index); |
979 | 981 | ||
980 | if ( !cmbChooserChange( cmbChooserField4->currentItem(), m_widgetStack4, 4) ){ | 982 | if ( !cmbChooserChange( cmbChooserField4->currentItem(), m_widgetStack4, 4) ){ |
981 | 983 | ||
982 | txtChooserField4->setText( slChooserValues[index] ); | 984 | txtChooserField4->setText( slChooserValues[index] ); |
983 | txtChooserField4->setFocus(); | 985 | txtChooserField4->setFocus(); |
984 | 986 | ||
985 | } | 987 | } |
986 | } | 988 | } |
987 | 989 | ||
988 | void ContactEditor::slotAddressTypeChange( int index ) { | 990 | void ContactEditor::slotAddressTypeChange( int index ) { |
989 | 991 | ||
990 | 992 | ||
991 | if ( !initializing ) | 993 | if ( !initializing ) |
992 | contactfields.setFieldOrder( 4, index ); | 994 | contactfields.setFieldOrder( 4, index ); |
993 | 995 | ||
994 | 996 | ||
995 | if ( index == 0 ) { | 997 | if ( index == 0 ) { |
996 | 998 | ||
997 | txtAddress->setText( slBusinessAddress[0] ); | 999 | txtAddress->setText( slBusinessAddress[0] ); |
998 | //txtAddress2->setText( (*slBusinessAddress)[1] ); | 1000 | //txtAddress2->setText( (*slBusinessAddress)[1] ); |
999 | //txtPOBox->setText( (*slBusinessAddress)[2] ); | 1001 | //txtPOBox->setText( (*slBusinessAddress)[2] ); |
1000 | txtCity->setText( slBusinessAddress[3] ); | 1002 | txtCity->setText( slBusinessAddress[3] ); |
1001 | txtState->setText( slBusinessAddress[4] ); | 1003 | txtState->setText( slBusinessAddress[4] ); |
1002 | txtZip->setText( slBusinessAddress[5] ); | 1004 | txtZip->setText( slBusinessAddress[5] ); |
1003 | QLineEdit *txtTmp = cmbCountry->lineEdit(); | 1005 | QLineEdit *txtTmp = cmbCountry->lineEdit(); |
1004 | txtTmp->setText( slBusinessAddress[6] ); | 1006 | txtTmp->setText( slBusinessAddress[6] ); |
1005 | 1007 | ||
1006 | } else { | 1008 | } else { |
1007 | 1009 | ||
1008 | txtAddress->setText( slHomeAddress[0] ); | 1010 | txtAddress->setText( slHomeAddress[0] ); |
1009 | //txtAddress2->setText( (*slHomeAddress)[1] ); | 1011 | //txtAddress2->setText( (*slHomeAddress)[1] ); |
1010 | //txtPOBox->setText( (*slHomeAddress)[2] ); | 1012 | //txtPOBox->setText( (*slHomeAddress)[2] ); |
1011 | txtCity->setText( slHomeAddress[3] ); | 1013 | txtCity->setText( slHomeAddress[3] ); |
1012 | txtState->setText( slHomeAddress[4] ); | 1014 | txtState->setText( slHomeAddress[4] ); |
1013 | txtZip->setText( slHomeAddress[5] ); | 1015 | txtZip->setText( slHomeAddress[5] ); |
1014 | QLineEdit *txtTmp = cmbCountry->lineEdit(); | 1016 | QLineEdit *txtTmp = cmbCountry->lineEdit(); |
1015 | txtTmp->setText( slHomeAddress[6] ); | 1017 | txtTmp->setText( slHomeAddress[6] ); |
1016 | 1018 | ||
1017 | } | 1019 | } |
1018 | 1020 | ||
1019 | } | 1021 | } |
1020 | 1022 | ||
1021 | void ContactEditor::slotFullNameChange( const QString &textChanged ) { | 1023 | void ContactEditor::slotFullNameChange( const QString &textChanged ) { |
1022 | 1024 | ||
1023 | qWarning( "ContactEditor::slotFullNameChange( %s )", textChanged.latin1() ); | 1025 | qWarning( "ContactEditor::slotFullNameChange( %s )", textChanged.latin1() ); |
1024 | 1026 | ||
1025 | int index = cmbFileAs->currentItem(); | 1027 | int index = cmbFileAs->currentItem(); |
1026 | 1028 | ||
1027 | cmbFileAs->clear(); | 1029 | cmbFileAs->clear(); |
1028 | 1030 | ||
1029 | cmbFileAs->insertItem( parseName( textChanged, NAME_LF ) ); | 1031 | cmbFileAs->insertItem( parseName( textChanged, NAME_LF ) ); |
1030 | cmbFileAs->insertItem( parseName( textChanged, NAME_LFM ) ); | 1032 | cmbFileAs->insertItem( parseName( textChanged, NAME_LFM ) ); |
1031 | cmbFileAs->insertItem( parseName( textChanged, NAME_FL ) ); | 1033 | cmbFileAs->insertItem( parseName( textChanged, NAME_FL ) ); |
1032 | cmbFileAs->insertItem( parseName( textChanged, NAME_FMLS ) ); | 1034 | cmbFileAs->insertItem( parseName( textChanged, NAME_FMLS ) ); |
1033 | 1035 | ||
1034 | cmbFileAs->setCurrentItem( index ); | 1036 | cmbFileAs->setCurrentItem( index ); |
1035 | 1037 | ||
1036 | useFullName = true; | 1038 | useFullName = true; |
1037 | 1039 | ||
1038 | } | 1040 | } |
1039 | 1041 | ||
1042 | void ContactEditor::slotSuffixChange( const QString& ) { | ||
1043 | // Just want to update the FileAs combo if the suffix was changed.. | ||
1044 | slotFullNameChange( txtFullName->text() ); | ||
1045 | } | ||
1046 | |||
1040 | void ContactEditor::accept() { | 1047 | void ContactEditor::accept() { |
1041 | 1048 | ||
1042 | if ( isEmpty() ) { | 1049 | if ( isEmpty() ) { |
1043 | cleanupFields(); | 1050 | cleanupFields(); |
1044 | reject(); | 1051 | reject(); |
1045 | } else { | 1052 | } else { |
1046 | saveEntry(); | 1053 | saveEntry(); |
1047 | cleanupFields(); | 1054 | cleanupFields(); |
1048 | QDialog::accept(); | 1055 | QDialog::accept(); |
1049 | } | 1056 | } |
1050 | 1057 | ||
1051 | } | 1058 | } |
1052 | 1059 | ||
1053 | void ContactEditor::slotNote() { | 1060 | void ContactEditor::slotNote() { |
1054 | 1061 | ||
1055 | dlgNote->showMaximized(); | 1062 | dlgNote->showMaximized(); |
1056 | if ( !dlgNote->exec() ) { | 1063 | if ( !dlgNote->exec() ) { |
1057 | txtNote->setText( ent.notes() ); | 1064 | txtNote->setText( ent.notes() ); |
1058 | } | 1065 | } |
1059 | } | 1066 | } |
1060 | 1067 | ||
1061 | void ContactEditor::slotName() { | 1068 | void ContactEditor::slotName() { |
1062 | 1069 | ||
1063 | QString tmpName; | 1070 | QString tmpName; |
1064 | if (useFullName) { | 1071 | if (useFullName) { |
1065 | txtFirstName->setText( parseName(txtFullName->text(), NAME_F) ); | 1072 | txtFirstName->setText( parseName(txtFullName->text(), NAME_F) ); |
1066 | txtMiddleName->setText( parseName(txtFullName->text(), NAME_M) ); | 1073 | txtMiddleName->setText( parseName(txtFullName->text(), NAME_M) ); |
1067 | txtLastName->setText( parseName(txtFullName->text(), NAME_L) ); | 1074 | txtLastName->setText( parseName(txtFullName->text(), NAME_L) ); |
1068 | // txtSuffix->setText( parseName(txtFullName->text(), NAME_S) ); | 1075 | // txtSuffix->setText( parseName(txtFullName->text(), NAME_S) ); |
1069 | } | 1076 | } |
1070 | dlgName->showMaximized(); | 1077 | dlgName->showMaximized(); |
1071 | if ( dlgName->exec() ) { | 1078 | if ( dlgName->exec() ) { |
1072 | 1079 | ||
1073 | tmpName = txtFirstName->text() + " " + txtMiddleName->text() + " " + txtLastName->text() + " " + txtSuffix->text(); | 1080 | tmpName = txtFirstName->text() + " " + txtMiddleName->text() + " " + txtLastName->text(); |
1074 | txtFullName->setText( tmpName.simplifyWhiteSpace() ); | 1081 | txtFullName->setText( tmpName.simplifyWhiteSpace() ); |
1075 | slotFullNameChange( txtFullName->text() ); | 1082 | slotFullNameChange( txtFullName->text() ); |
1076 | useFullName = false; | 1083 | useFullName = false; |
1077 | } | 1084 | } |
1078 | 1085 | ||
1079 | } | 1086 | } |
1080 | 1087 | ||
1081 | void ContactEditor::setNameFocus() { | 1088 | void ContactEditor::setNameFocus() { |
1082 | 1089 | ||
1083 | txtFullName->setFocus(); | 1090 | txtFullName->setFocus(); |
1084 | 1091 | ||
1085 | } | 1092 | } |
1086 | 1093 | ||
1087 | bool ContactEditor::isEmpty() { | 1094 | bool ContactEditor::isEmpty() { |
1088 | // Test and see if the record should be saved. | 1095 | // Test and see if the record should be saved. |
1089 | // More strict than the original qtopia, needs name or fileas to save | 1096 | // More strict than the original qtopia, needs name or fileas to save |
1090 | 1097 | ||
1091 | QString t = txtFullName->text(); | 1098 | QString t = txtFullName->text(); |
1092 | if ( !t.isEmpty() && containsAlphaNum( t ) ) | 1099 | if ( !t.isEmpty() && containsAlphaNum( t ) ) |
1093 | return false; | 1100 | return false; |
1094 | 1101 | ||
1095 | t = cmbFileAs->currentText(); | 1102 | t = cmbFileAs->currentText(); |
1096 | if ( !t.isEmpty() && containsAlphaNum( t ) ) | 1103 | if ( !t.isEmpty() && containsAlphaNum( t ) ) |
1097 | return false; | 1104 | return false; |
1098 | 1105 | ||
1099 | return true; | 1106 | return true; |
1100 | 1107 | ||
1101 | } | 1108 | } |
1102 | 1109 | ||
1103 | QString ContactEditor::parseName( const QString fullName, int type ) { | 1110 | QString ContactEditor::parseName( const QString fullName, int type ) { |
1104 | 1111 | ||
1105 | QString simplifiedName( fullName.simplifyWhiteSpace() ); | 1112 | QString simplifiedName( fullName.simplifyWhiteSpace() ); |
1106 | QString strFirstName; | 1113 | QString strFirstName; |
1107 | QString strMiddleName; | 1114 | QString strMiddleName; |
1108 | QString strLastName; | 1115 | QString strLastName; |
1109 | QString strSuffix; | ||
1110 | QString strTitle; | 1116 | QString strTitle; |
1111 | int commapos; | 1117 | int commapos; |
1112 | bool haveLastName = false; | 1118 | bool haveLastName = false; |
1113 | 1119 | ||
1114 | qWarning("Fullname: %s", simplifiedName.latin1()); | 1120 | qWarning("Fullname: %s", simplifiedName.latin1()); |
1115 | 1121 | ||
1116 | commapos = simplifiedName.find( ',', 0, TRUE); | 1122 | commapos = simplifiedName.find( ',', 0, TRUE); |
1117 | if ( commapos >= 0 ) { | 1123 | if ( commapos >= 0 ) { |
1118 | qWarning(" Commapos: %d", commapos ); | 1124 | qWarning(" Commapos: %d", commapos ); |
1119 | 1125 | ||
1120 | // A comma (",") separates the lastname from one or | 1126 | // A comma (",") separates the lastname from one or |
1121 | // many first names. Thus, remove the lastname from the | 1127 | // many first names. Thus, remove the lastname from the |
1122 | // String and parse the firstnames. | 1128 | // String and parse the firstnames. |
1123 | 1129 | ||
1124 | strLastName = simplifiedName.left( commapos ); | 1130 | strLastName = simplifiedName.left( commapos ); |
1125 | simplifiedName= simplifiedName.mid( commapos + 1 ); | 1131 | simplifiedName= simplifiedName.mid( commapos + 1 ); |
1126 | haveLastName = true; | 1132 | haveLastName = true; |
1127 | qWarning("Fullname without ',': %s", simplifiedName.latin1()); | 1133 | qWarning("Fullname without ',': %s", simplifiedName.latin1()); |
1128 | 1134 | ||
1129 | // If we have any lastname, we should now split all first names. | 1135 | // If we have any lastname, we should now split all first names. |
1130 | // The first one will be the used as first, the rest as "middle names" | 1136 | // The first one will be the used as first, the rest as "middle names" |
1131 | 1137 | ||
1132 | QStringList allFirstNames = QStringList::split(" ", simplifiedName); | 1138 | QStringList allFirstNames = QStringList::split(" ", simplifiedName); |
1133 | QStringList::Iterator it = allFirstNames.begin(); | 1139 | QStringList::Iterator it = allFirstNames.begin(); |
1134 | strFirstName = *it++; | 1140 | strFirstName = *it++; |
1135 | QStringList allSecondNames; | 1141 | QStringList allSecondNames; |
1136 | for ( ; it != allFirstNames.end(); ++it ) | 1142 | for ( ; it != allFirstNames.end(); ++it ) |
1137 | allSecondNames.append( *it ); | 1143 | allSecondNames.append( *it ); |
1138 | 1144 | ||
1139 | strMiddleName = allSecondNames.join(" "); | 1145 | strMiddleName = allSecondNames.join(" "); |
1140 | 1146 | ||
1141 | } else { | 1147 | } else { |
1142 | 1148 | ||
1143 | // No comma separator used: We use the first word as firstname, the | 1149 | // No comma separator used: We use the first word as firstname, the |
1144 | // last as second/lastname and everything in the middle as middlename | 1150 | // last as second/lastname and everything in the middle as middlename |
1145 | 1151 | ||
1146 | QStringList allNames = QStringList::split(" ", simplifiedName); | 1152 | QStringList allNames = QStringList::split(" ", simplifiedName); |
1147 | QStringList::Iterator it = allNames.begin(); | 1153 | QStringList::Iterator it = allNames.begin(); |
1148 | strFirstName = *it++; | 1154 | strFirstName = *it++; |
1149 | QStringList allSecondNames; | 1155 | QStringList allSecondNames; |
1150 | for ( ; it != --allNames.end(); ++it ) | 1156 | for ( ; it != --allNames.end(); ++it ) |
1151 | allSecondNames.append( *it ); | 1157 | allSecondNames.append( *it ); |
1152 | 1158 | ||
1153 | strMiddleName = allSecondNames.join(" "); | 1159 | strMiddleName = allSecondNames.join(" "); |
1154 | strLastName = *(--allNames.end()); | 1160 | strLastName = *(--allNames.end()); |
1155 | 1161 | ||
1156 | } | 1162 | } |
1157 | 1163 | ||
1158 | if ( strFirstName == strLastName ) | 1164 | if ( strFirstName == strLastName ) |
1159 | strFirstName = ""; | 1165 | strFirstName = ""; |
1160 | 1166 | ||
1161 | qWarning(" strFirstName: %s", strFirstName.latin1()); | 1167 | qWarning(" strFirstName: %s", strFirstName.latin1()); |
1162 | qWarning(" strMiddleName: %s", strMiddleName.latin1()); | 1168 | qWarning(" strMiddleName: %s", strMiddleName.latin1()); |
1163 | qWarning(" strLastName: %s", strLastName.latin1()); | 1169 | qWarning(" strLastName: %s", strLastName.latin1()); |
1164 | qWarning(" strSuffix: %s", strSuffix.latin1()); | ||
1165 | qWarning(" strTitle: %s", strTitle.latin1()); | 1170 | qWarning(" strTitle: %s", strTitle.latin1()); |
1166 | 1171 | ||
1167 | switch (type) { | 1172 | switch (type) { |
1168 | case NAME_FL: | 1173 | case NAME_FL: |
1169 | return strFirstName + " " + strLastName; | 1174 | return strFirstName + " " + strLastName; |
1170 | 1175 | ||
1171 | case NAME_LF: | 1176 | case NAME_LF: |
1172 | return strLastName + ", " + strFirstName; | 1177 | return strLastName + ", " + strFirstName; |
1173 | 1178 | ||
1174 | case NAME_LFM: | 1179 | case NAME_LFM: |
1175 | return strLastName + ", " + strFirstName + " " + strMiddleName; | 1180 | return strLastName + ", " + strFirstName + " " + strMiddleName; |
1176 | 1181 | ||
1177 | case NAME_FMLS: | 1182 | case NAME_FMLS: |
1178 | return strFirstName + " " + strMiddleName + " " + strLastName + " " + strSuffix; | 1183 | return strFirstName + " " + strMiddleName + " " + strLastName + " " + txtSuffix->text(); |
1179 | 1184 | ||
1180 | case NAME_F: | 1185 | case NAME_F: |
1181 | return strFirstName; | 1186 | return strFirstName; |
1182 | 1187 | ||
1183 | case NAME_M: | 1188 | case NAME_M: |
1184 | return strMiddleName; | 1189 | return strMiddleName; |
1185 | 1190 | ||
1186 | case NAME_L: | 1191 | case NAME_L: |
1187 | return strLastName; | 1192 | return strLastName; |
1188 | 1193 | ||
1189 | case NAME_S: | 1194 | case NAME_S: |
1190 | return strSuffix; | 1195 | return txtSuffix->text(); |
1191 | 1196 | ||
1192 | } | 1197 | } |
1193 | return QString::null; | 1198 | return QString::null; |
1194 | } | 1199 | } |
1195 | 1200 | ||
1196 | void ContactEditor::cleanupFields() { | 1201 | void ContactEditor::cleanupFields() { |
1197 | QStringList::Iterator it = slChooserValues.begin(); | 1202 | QStringList::Iterator it = slChooserValues.begin(); |
1198 | 1203 | ||
1199 | for ( int i = 0; it != slChooserValues.end(); i++, ++it ) { | 1204 | for ( int i = 0; it != slChooserValues.end(); i++, ++it ) { |
1200 | (*it) = ""; | 1205 | (*it) = ""; |
1201 | } | 1206 | } |
1202 | 1207 | ||
1203 | for ( int i = 0; i < 7; i++ ) { | 1208 | for ( int i = 0; i < 7; i++ ) { |
1204 | slHomeAddress[i] = ""; | 1209 | slHomeAddress[i] = ""; |
1205 | slBusinessAddress[i] = ""; | 1210 | slBusinessAddress[i] = ""; |
1206 | } | 1211 | } |
1207 | 1212 | ||
1208 | QListIterator<QLineEdit> itLV( listValue ); | 1213 | QListIterator<QLineEdit> itLV( listValue ); |
1209 | for ( ; itLV.current(); ++itLV ) { | 1214 | for ( ; itLV.current(); ++itLV ) { |
1210 | (*itLV)->setText( "" ); | 1215 | (*itLV)->setText( "" ); |
1211 | } | 1216 | } |
1212 | 1217 | ||
1213 | txtFirstName->setText(""); | 1218 | txtFirstName->setText(""); |
1214 | txtMiddleName->setText(""); | 1219 | txtMiddleName->setText(""); |
1215 | txtLastName->setText(""); | 1220 | txtLastName->setText(""); |
1216 | txtSuffix->setText(""); | 1221 | txtSuffix->setText(""); |
1217 | txtNote->setText(""); | 1222 | txtNote->setText(""); |
1218 | txtFullName->setText(""); | 1223 | txtFullName->setText(""); |
1219 | txtJobTitle->setText(""); | 1224 | txtJobTitle->setText(""); |
1220 | txtOrganization->setText(""); | 1225 | txtOrganization->setText(""); |
1221 | txtChooserField1->setText(""); | 1226 | txtChooserField1->setText(""); |
1222 | txtChooserField2->setText(""); | 1227 | txtChooserField2->setText(""); |
1223 | txtChooserField3->setText(""); | 1228 | txtChooserField3->setText(""); |
1224 | txtAddress->setText(""); | 1229 | txtAddress->setText(""); |
1225 | txtCity->setText(""); | 1230 | txtCity->setText(""); |
1226 | txtState->setText(""); | 1231 | txtState->setText(""); |
1227 | txtZip->setText(""); | 1232 | txtZip->setText(""); |
1228 | QLineEdit *txtTmp = cmbCountry->lineEdit(); | 1233 | QLineEdit *txtTmp = cmbCountry->lineEdit(); |
1229 | txtTmp->setText(""); | 1234 | txtTmp->setText(""); |
1230 | txtTmp = cmbFileAs->lineEdit(); | 1235 | txtTmp = cmbFileAs->lineEdit(); |
1231 | txtTmp->setText(""); | 1236 | txtTmp->setText(""); |
1232 | 1237 | ||
1233 | } | 1238 | } |
1234 | 1239 | ||
1235 | void ContactEditor::setEntry( const OContact &entry ) { | 1240 | void ContactEditor::setEntry( const OContact &entry ) { |
1236 | 1241 | ||
1237 | initializing = true; | 1242 | initializing = true; |
1238 | 1243 | ||
1239 | cleanupFields(); | 1244 | cleanupFields(); |
1240 | 1245 | ||
1241 | ent = entry; | 1246 | ent = entry; |
1242 | 1247 | ||
1243 | emails = QStringList(ent.emailList()); | 1248 | emails = QStringList(ent.emailList()); |
1244 | defaultEmail = ent.defaultEmail(); | 1249 | defaultEmail = ent.defaultEmail(); |
1245 | if (defaultEmail.isEmpty()) defaultEmail = emails[0]; | 1250 | if (defaultEmail.isEmpty()) defaultEmail = emails[0]; |
1246 | qDebug("default email=%s",defaultEmail.latin1()); | 1251 | qDebug("default email=%s",defaultEmail.latin1()); |
1247 | 1252 | ||
1248 | useFullName = false; | 1253 | useFullName = false; |
1249 | txtFirstName->setText( ent.firstName() ); | 1254 | txtFirstName->setText( ent.firstName() ); |
1250 | txtMiddleName->setText( ent.middleName() ); | 1255 | txtMiddleName->setText( ent.middleName() ); |
1251 | txtLastName->setText( ent.lastName() ); | 1256 | txtLastName->setText( ent.lastName() ); |
1252 | txtSuffix->setText( ent.suffix() ); | 1257 | txtSuffix->setText( ent.suffix() ); |
1253 | 1258 | ||
1254 | // QString *tmpString = new QString; | 1259 | // QString *tmpString = new QString; |
diff --git a/core/pim/addressbook/contacteditor.h b/core/pim/addressbook/contacteditor.h index 703e702..954c77e 100644 --- a/core/pim/addressbook/contacteditor.h +++ b/core/pim/addressbook/contacteditor.h | |||
@@ -39,128 +39,129 @@ const int NAME_FL = 2; | |||
39 | const int NAME_FMLS = 3; | 39 | const int NAME_FMLS = 3; |
40 | 40 | ||
41 | const int NAME_F = 4; | 41 | const int NAME_F = 4; |
42 | const int NAME_M = 5; | 42 | const int NAME_M = 5; |
43 | const int NAME_L = 6; | 43 | const int NAME_L = 6; |
44 | const int NAME_S = 7; | 44 | const int NAME_S = 7; |
45 | 45 | ||
46 | 46 | ||
47 | class QScrollView; | 47 | class QScrollView; |
48 | class QTabWidget; | 48 | class QTabWidget; |
49 | class QMultiLineEdit; | 49 | class QMultiLineEdit; |
50 | class QLineEdit; | 50 | class QLineEdit; |
51 | class QComboBox; | 51 | class QComboBox; |
52 | class QPushButton; | 52 | class QPushButton; |
53 | class CategorySelect; | 53 | class CategorySelect; |
54 | class QLabel; | 54 | class QLabel; |
55 | 55 | ||
56 | class ContactEditor : public QDialog { | 56 | class ContactEditor : public QDialog { |
57 | Q_OBJECT | 57 | Q_OBJECT |
58 | 58 | ||
59 | public: | 59 | public: |
60 | ContactEditor(const OContact &entry, | 60 | ContactEditor(const OContact &entry, |
61 | QWidget *parent = 0, | 61 | QWidget *parent = 0, |
62 | const char *name = 0, | 62 | const char *name = 0, |
63 | WFlags fl = 0 ); | 63 | WFlags fl = 0 ); |
64 | ~ContactEditor(); | 64 | ~ContactEditor(); |
65 | void setNameFocus(); | 65 | void setNameFocus(); |
66 | void setPersonalView( bool personal = true ); | 66 | void setPersonalView( bool personal = true ); |
67 | OContact entry() const { return ent; } | 67 | OContact entry() const { return ent; } |
68 | 68 | ||
69 | public slots: | 69 | public slots: |
70 | void slotNote(); | 70 | void slotNote(); |
71 | void slotName(); | 71 | void slotName(); |
72 | void setEntry(const OContact &entry); | 72 | void setEntry(const OContact &entry); |
73 | 73 | ||
74 | protected slots: | 74 | protected slots: |
75 | void accept(); | 75 | void accept(); |
76 | 76 | ||
77 | private: | 77 | private: |
78 | void init(); | 78 | void init(); |
79 | void saveEntry(); | 79 | void saveEntry(); |
80 | bool isEmpty(); | 80 | bool isEmpty(); |
81 | void cleanupFields(); | 81 | void cleanupFields(); |
82 | void updateDatePicker(); | 82 | void updateDatePicker(); |
83 | QString parseName( QString fullName, int type ); | 83 | QString parseName( QString fullName, int type ); |
84 | void chooserError( int index ); | 84 | void chooserError( int index ); |
85 | private slots: | 85 | private slots: |
86 | void slotChooser1Change( const QString &textChanged ); | 86 | void slotChooser1Change( const QString &textChanged ); |
87 | void slotChooser2Change( const QString &textChanged ); | 87 | void slotChooser2Change( const QString &textChanged ); |
88 | void slotChooser3Change( const QString &textChanged ); | 88 | void slotChooser3Change( const QString &textChanged ); |
89 | void slotChooser4Change( const QString &textChanged ); | 89 | void slotChooser4Change( const QString &textChanged ); |
90 | void slotCmbChooser1Change( int index ); | 90 | void slotCmbChooser1Change( int index ); |
91 | void slotCmbChooser2Change( int index ); | 91 | void slotCmbChooser2Change( int index ); |
92 | void slotCmbChooser3Change( int index ); | 92 | void slotCmbChooser3Change( int index ); |
93 | void slotCmbChooser4Change( int index ); | 93 | void slotCmbChooser4Change( int index ); |
94 | void slotAddressTypeChange( int index ); | 94 | void slotAddressTypeChange( int index ); |
95 | void slotAddressChange( const QString &textChanged ); | 95 | void slotAddressChange( const QString &textChanged ); |
96 | void slotAddress2Change( const QString &textChanged ); | 96 | void slotAddress2Change( const QString &textChanged ); |
97 | void slotPOBoxChange( const QString &textChanged ); | 97 | void slotPOBoxChange( const QString &textChanged ); |
98 | void slotCityChange( const QString &textChanged ); | 98 | void slotCityChange( const QString &textChanged ); |
99 | void slotStateChange( const QString &textChanged ); | 99 | void slotStateChange( const QString &textChanged ); |
100 | void slotZipChange( const QString &textChanged ); | 100 | void slotZipChange( const QString &textChanged ); |
101 | void slotCountryChange( const QString &textChanged ); | 101 | void slotCountryChange( const QString &textChanged ); |
102 | void slotFullNameChange( const QString &textChanged ); | 102 | void slotFullNameChange( const QString &textChanged ); |
103 | void slotSuffixChange( const QString &textChanged ); | ||
103 | void slotAnniversaryDateChanged( int year, int month, int day); | 104 | void slotAnniversaryDateChanged( int year, int month, int day); |
104 | void slotBirthdayDateChanged( int year, int month, int day); | 105 | void slotBirthdayDateChanged( int year, int month, int day); |
105 | void slotRemoveBirthday(); | 106 | void slotRemoveBirthday(); |
106 | void slotRemoveAnniversary(); | 107 | void slotRemoveAnniversary(); |
107 | void defaultEmailChanged(int); | 108 | void defaultEmailChanged(int); |
108 | 109 | ||
109 | private: | 110 | private: |
110 | enum StackWidgets { TextField = 1, Combo }; | 111 | enum StackWidgets { TextField = 1, Combo }; |
111 | int defaultEmailChooserPosition; | 112 | int defaultEmailChooserPosition; |
112 | void populateDefaultEmailCmb(); | 113 | void populateDefaultEmailCmb(); |
113 | void chooserChange( const QString&, int , QLineEdit*, int ); | 114 | void chooserChange( const QString&, int , QLineEdit*, int ); |
114 | bool cmbChooserChange( int , QWidgetStack*, int ); | 115 | bool cmbChooserChange( int , QWidgetStack*, int ); |
115 | OContactFields contactfields; | 116 | OContactFields contactfields; |
116 | 117 | ||
117 | bool useFullName; | 118 | bool useFullName; |
118 | 119 | ||
119 | OContact ent; | 120 | OContact ent; |
120 | 121 | ||
121 | QDialog *dlgNote; | 122 | QDialog *dlgNote; |
122 | QDialog *dlgName; | 123 | QDialog *dlgName; |
123 | 124 | ||
124 | QList<QLineEdit> listValue; | 125 | QList<QLineEdit> listValue; |
125 | QList<QLabel> listName; | 126 | QList<QLabel> listName; |
126 | 127 | ||
127 | QStringList slDynamicEntries; | 128 | QStringList slDynamicEntries; |
128 | QStringList trlDynamicEntries; | 129 | QStringList trlDynamicEntries; |
129 | 130 | ||
130 | bool m_personalView; | 131 | bool m_personalView; |
131 | 132 | ||
132 | QStringList slHomeAddress; | 133 | QStringList slHomeAddress; |
133 | QStringList slBusinessAddress; | 134 | QStringList slBusinessAddress; |
134 | QStringList slChooserNames; | 135 | QStringList slChooserNames; |
135 | QStringList slChooserValues; | 136 | QStringList slChooserValues; |
136 | QStringList emails; | 137 | QStringList emails; |
137 | QString defaultEmail; | 138 | QString defaultEmail; |
138 | 139 | ||
139 | QMultiLineEdit *txtNote; | 140 | QMultiLineEdit *txtNote; |
140 | QLabel *lblNote; | 141 | QLabel *lblNote; |
141 | 142 | ||
142 | //QLineEdit *txtTitle; | 143 | //QLineEdit *txtTitle; |
143 | QLineEdit *txtFirstName; | 144 | QLineEdit *txtFirstName; |
144 | QLineEdit *txtMiddleName; | 145 | QLineEdit *txtMiddleName; |
145 | QLineEdit *txtLastName; | 146 | QLineEdit *txtLastName; |
146 | QLineEdit *txtSuffix; | 147 | QLineEdit *txtSuffix; |
147 | 148 | ||
148 | QTabWidget *tabMain; | 149 | QTabWidget *tabMain; |
149 | QScrollView *svGeneral; | 150 | QScrollView *svGeneral; |
150 | QPushButton *btnFullName; | 151 | QPushButton *btnFullName; |
151 | QPushButton *btnNote; | 152 | QPushButton *btnNote; |
152 | QLineEdit *txtFullName; | 153 | QLineEdit *txtFullName; |
153 | QLineEdit *txtJobTitle; | 154 | QLineEdit *txtJobTitle; |
154 | QLineEdit *txtOrganization; | 155 | QLineEdit *txtOrganization; |
155 | QLineEdit *txtChooserField1; | 156 | QLineEdit *txtChooserField1; |
156 | QLineEdit *txtChooserField2; | 157 | QLineEdit *txtChooserField2; |
157 | QLineEdit *txtChooserField3; | 158 | QLineEdit *txtChooserField3; |
158 | QLineEdit *txtChooserField4; | 159 | QLineEdit *txtChooserField4; |
159 | QWidgetStack* m_widgetStack1; | 160 | QWidgetStack* m_widgetStack1; |
160 | QWidgetStack* m_widgetStack2; | 161 | QWidgetStack* m_widgetStack2; |
161 | QWidgetStack* m_widgetStack3; | 162 | QWidgetStack* m_widgetStack3; |
162 | QWidgetStack* m_widgetStack4; | 163 | QWidgetStack* m_widgetStack4; |
163 | QComboBox *cmbChooserField1; | 164 | QComboBox *cmbChooserField1; |
164 | QComboBox *cmbChooserField2; | 165 | QComboBox *cmbChooserField2; |
165 | QComboBox *cmbChooserField3; | 166 | QComboBox *cmbChooserField3; |
166 | QComboBox *cmbChooserField4; | 167 | QComboBox *cmbChooserField4; |