-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 | |||
@@ -552,192 +552,194 @@ void ContactEditor::init() { | |||
552 | anniversaryButton= new QToolButton( hBox, "buttonStart" ); | 552 | anniversaryButton= new QToolButton( hBox, "buttonStart" ); |
553 | anniversaryButton->setPopup( m1 ); | 553 | anniversaryButton->setPopup( m1 ); |
554 | anniversaryButton->setPopupDelay(0); | 554 | anniversaryButton->setPopupDelay(0); |
555 | 555 | ||
556 | deleteButton = new QPushButton( QIconSet( Resource::loadPixmap( "trash" ) ), | 556 | deleteButton = new QPushButton( QIconSet( Resource::loadPixmap( "trash" ) ), |
557 | tr( "Delete" ), | 557 | tr( "Delete" ), |
558 | hBox, 0 ); | 558 | hBox, 0 ); |
559 | gl->addWidget( hBox, counter , 1 ); | 559 | gl->addWidget( hBox, counter , 1 ); |
560 | 560 | ||
561 | connect( anniversaryPicker, SIGNAL( dateClicked( int, int, int ) ), | 561 | connect( anniversaryPicker, SIGNAL( dateClicked( int, int, int ) ), |
562 | this, SLOT( slotAnniversaryDateChanged( int, int, int ) ) ); | 562 | this, SLOT( slotAnniversaryDateChanged( int, int, int ) ) ); |
563 | connect( deleteButton, SIGNAL( clicked() ), this, SLOT( slotRemoveAnniversary() ) ); | 563 | connect( deleteButton, SIGNAL( clicked() ), this, SLOT( slotRemoveAnniversary() ) ); |
564 | 564 | ||
565 | ++counter; | 565 | ++counter; |
566 | 566 | ||
567 | // Gender | 567 | // Gender |
568 | l = new QLabel( tr("Gender"), container ); | 568 | l = new QLabel( tr("Gender"), container ); |
569 | gl->addWidget( l, counter, 0 ); | 569 | gl->addWidget( l, counter, 0 ); |
570 | cmbGender = new QComboBox( container ); | 570 | cmbGender = new QComboBox( container ); |
571 | cmbGender->insertItem( "", 0 ); | 571 | cmbGender->insertItem( "", 0 ); |
572 | cmbGender->insertItem( tr("Male"), 1); | 572 | cmbGender->insertItem( tr("Male"), 1); |
573 | cmbGender->insertItem( tr("Female"), 2); | 573 | cmbGender->insertItem( tr("Female"), 2); |
574 | gl->addWidget( cmbGender, counter, 1 ); | 574 | gl->addWidget( cmbGender, counter, 1 ); |
575 | 575 | ||
576 | ++counter; | 576 | ++counter; |
577 | 577 | ||
578 | // Create Labels and lineedit fields for every dynamic entry | 578 | // Create Labels and lineedit fields for every dynamic entry |
579 | QStringList::ConstIterator it = slDynamicEntries.begin(); | 579 | QStringList::ConstIterator it = slDynamicEntries.begin(); |
580 | QMap<QString, int> mapStrToID = OContactFields::untrFieldsToId(); | 580 | QMap<QString, int> mapStrToID = OContactFields::untrFieldsToId(); |
581 | QMap<int, QString> mapIdToStr = OContactFields::idToTrFields(); | 581 | QMap<int, QString> mapIdToStr = OContactFields::idToTrFields(); |
582 | for (i = counter; it != slDynamicEntries.end(); i++, ++it ) { | 582 | for (i = counter; it != slDynamicEntries.end(); i++, ++it ) { |
583 | 583 | ||
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; |
712 | for ( int i = 0; i < cmbDefaultEmail->count(); i++){ | 714 | for ( int i = 0; i < cmbDefaultEmail->count(); i++){ |
713 | qDebug(" populateDefaultEmailCmb text >%s< defaultEmail >%s<", | 715 | qDebug(" populateDefaultEmailCmb text >%s< defaultEmail >%s<", |
714 | cmbDefaultEmail->text( i ).latin1(), defaultEmail.latin1()); | 716 | cmbDefaultEmail->text( i ).latin1(), defaultEmail.latin1()); |
715 | 717 | ||
716 | if ( cmbDefaultEmail->text( i ).stripWhiteSpace() == defaultEmail.stripWhiteSpace() ){ | 718 | if ( cmbDefaultEmail->text( i ).stripWhiteSpace() == defaultEmail.stripWhiteSpace() ){ |
717 | cmbDefaultEmail->setCurrentItem( i ); | 719 | cmbDefaultEmail->setCurrentItem( i ); |
718 | qDebug("set"); | 720 | qDebug("set"); |
719 | found = true; | 721 | found = true; |
720 | } | 722 | } |
721 | } | 723 | } |
722 | 724 | ||
723 | // If the current default email is not found in the list, we choose the | 725 | // If the current default email is not found in the list, we choose the |
724 | // first one.. | 726 | // first one.. |
725 | if ( !found ) | 727 | if ( !found ) |
726 | defaultEmail = cmbDefaultEmail->text(0); | 728 | defaultEmail = cmbDefaultEmail->text(0); |
727 | } | 729 | } |
728 | 730 | ||
729 | // Called when any combobox was changed. | 731 | // Called when any combobox was changed. |
730 | // "true" returned if the change was chandled by this function, else it should | 732 | // "true" returned if the change was chandled by this function, else it should |
731 | // be handled by something else.. | 733 | // be handled by something else.. |
732 | bool ContactEditor::cmbChooserChange( int index, QWidgetStack* inputStack, int widgetPos ) { | 734 | bool ContactEditor::cmbChooserChange( int index, QWidgetStack* inputStack, int widgetPos ) { |
733 | QString type = slChooserNames[index]; | 735 | QString type = slChooserNames[index]; |
734 | qWarning("ContactEditor::cmbChooserChange -> Type: %s, WidgetPos: %d", type.latin1(), widgetPos ); | 736 | qWarning("ContactEditor::cmbChooserChange -> Type: %s, WidgetPos: %d", type.latin1(), widgetPos ); |
735 | 737 | ||
736 | if ( !initializing ) | 738 | if ( !initializing ) |
737 | contactfields.setFieldOrder( widgetPos-1, index ); | 739 | contactfields.setFieldOrder( widgetPos-1, index ); |
738 | 740 | ||
739 | // Create and connect combobox for selecting the default email | 741 | // Create and connect combobox for selecting the default email |
740 | if ( type == "Default Email"){ | 742 | if ( type == "Default Email"){ |
741 | qWarning("Choosing default-email (defaultEmailChooserPosition= %d) ", defaultEmailChooserPosition); | 743 | qWarning("Choosing default-email (defaultEmailChooserPosition= %d) ", defaultEmailChooserPosition); |
742 | 744 | ||
743 | // More than one default-email chooser is not allowed ! | 745 | // More than one default-email chooser is not allowed ! |
@@ -944,343 +946,346 @@ void ContactEditor::slotCountryChange( const QString &textChanged ) { | |||
944 | void ContactEditor::slotCmbChooser1Change( int index ) { | 946 | void ContactEditor::slotCmbChooser1Change( int index ) { |
945 | qWarning("ContactEditor::slotCmbChooser1Change( %d )", index); | 947 | qWarning("ContactEditor::slotCmbChooser1Change( %d )", index); |
946 | if ( !cmbChooserChange( cmbChooserField1->currentItem(), m_widgetStack1, 1) ){ | 948 | if ( !cmbChooserChange( cmbChooserField1->currentItem(), m_widgetStack1, 1) ){ |
947 | 949 | ||
948 | txtChooserField1->setText( slChooserValues[index] ); | 950 | txtChooserField1->setText( slChooserValues[index] ); |
949 | txtChooserField1->setFocus(); | 951 | txtChooserField1->setFocus(); |
950 | 952 | ||
951 | } | 953 | } |
952 | 954 | ||
953 | } | 955 | } |
954 | 956 | ||
955 | void ContactEditor::slotCmbChooser2Change( int index ) { | 957 | void ContactEditor::slotCmbChooser2Change( int index ) { |
956 | qWarning("ContactEditor::slotCmbChooser2Change( %d )", index); | 958 | qWarning("ContactEditor::slotCmbChooser2Change( %d )", index); |
957 | 959 | ||
958 | if ( !cmbChooserChange( cmbChooserField2->currentItem(), m_widgetStack2, 2) ){ | 960 | if ( !cmbChooserChange( cmbChooserField2->currentItem(), m_widgetStack2, 2) ){ |
959 | 961 | ||
960 | txtChooserField2->setText( slChooserValues[index] ); | 962 | txtChooserField2->setText( slChooserValues[index] ); |
961 | txtChooserField2->setFocus(); | 963 | txtChooserField2->setFocus(); |
962 | 964 | ||
963 | } | 965 | } |
964 | } | 966 | } |
965 | 967 | ||
966 | void ContactEditor::slotCmbChooser3Change( int index ) { | 968 | void ContactEditor::slotCmbChooser3Change( int index ) { |
967 | qWarning("ContactEditor::slotCmbChooser3Change( %d )", index); | 969 | qWarning("ContactEditor::slotCmbChooser3Change( %d )", index); |
968 | 970 | ||
969 | if ( !cmbChooserChange( cmbChooserField3->currentItem(), m_widgetStack3, 3) ){ | 971 | if ( !cmbChooserChange( cmbChooserField3->currentItem(), m_widgetStack3, 3) ){ |
970 | 972 | ||
971 | txtChooserField3->setText( slChooserValues[index] ); | 973 | txtChooserField3->setText( slChooserValues[index] ); |
972 | txtChooserField3->setFocus(); | 974 | txtChooserField3->setFocus(); |
973 | 975 | ||
974 | } | 976 | } |
975 | } | 977 | } |
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; |
1255 | // *tmpString = ent.firstName() + " " + ent.middleName() + | 1260 | // *tmpString = ent.firstName() + " " + ent.middleName() + |
1256 | // + " " + ent.lastName() + " " + ent.suffix(); | 1261 | // + " " + ent.lastName() + " " + ent.suffix(); |
1257 | //txtFullName->setText( tmpString->simplifyWhiteSpace() ); | 1262 | //txtFullName->setText( tmpString->simplifyWhiteSpace() ); |
1258 | 1263 | ||
1259 | // Lastnames with multiple words need to be protected by a comma ! | 1264 | // Lastnames with multiple words need to be protected by a comma ! |
1260 | if ( ent.lastName().contains( ' ', TRUE ) ) | 1265 | if ( ent.lastName().contains( ' ', TRUE ) ) |
1261 | txtFullName->setText( ent.lastName() + ", " + ent.firstName() + " " + ent.middleName() ); | 1266 | txtFullName->setText( ent.lastName() + ", " + ent.firstName() + " " + ent.middleName() ); |
1262 | else | 1267 | else |
1263 | txtFullName->setText( ent.firstName() + " " + ent.middleName() + " " + ent.lastName() ); | 1268 | txtFullName->setText( ent.firstName() + " " + ent.middleName() + " " + ent.lastName() ); |
1264 | 1269 | ||
1265 | cmbFileAs->setEditText( ent.fileAs() ); | 1270 | cmbFileAs->setEditText( ent.fileAs() ); |
1266 | 1271 | ||
1267 | //if (hasTitle) | 1272 | //if (hasTitle) |
1268 | txtJobTitle->setText( ent.jobTitle() ); | 1273 | txtJobTitle->setText( ent.jobTitle() ); |
1269 | 1274 | ||
1270 | //if (hasCompany) | 1275 | //if (hasCompany) |
1271 | txtOrganization->setText( ent.company() ); | 1276 | txtOrganization->setText( ent.company() ); |
1272 | 1277 | ||
1273 | //if (hasNotes) | 1278 | //if (hasNotes) |
1274 | txtNote->setText( ent.notes() ); | 1279 | txtNote->setText( ent.notes() ); |
1275 | 1280 | ||
1276 | //if (hasStreet) { | 1281 | //if (hasStreet) { |
1277 | slHomeAddress[0] = ent.homeStreet(); | 1282 | slHomeAddress[0] = ent.homeStreet(); |
1278 | slBusinessAddress[0] = ent.businessStreet(); | 1283 | slBusinessAddress[0] = ent.businessStreet(); |
1279 | //} | 1284 | //} |
1280 | 1285 | ||
1281 | //if (hasCity) { | 1286 | //if (hasCity) { |
1282 | slHomeAddress[3] = ent.homeCity(); | 1287 | slHomeAddress[3] = ent.homeCity(); |
1283 | slBusinessAddress[3] = ent.businessCity(); | 1288 | slBusinessAddress[3] = ent.businessCity(); |
1284 | //} | 1289 | //} |
1285 | 1290 | ||
1286 | //if (hasState) { | 1291 | //if (hasState) { |
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 | |||
@@ -7,186 +7,187 @@ | |||
7 | * GNU General Public License version 2 as published by the Free Software | 7 | * GNU General Public License version 2 as published by the Free Software |
8 | * Foundation and appearing in the file LICENSE.GPL included in the pacakaging | 8 | * Foundation and appearing in the file LICENSE.GPL included in the pacakaging |
9 | * of this file. | 9 | * of this file. |
10 | * | 10 | * |
11 | * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | * | 13 | * |
14 | * | 14 | * |
15 | * This is a rewrite of the abeditor.h file, modified to provide a more | 15 | * This is a rewrite of the abeditor.h file, modified to provide a more |
16 | * intuitive interface to TrollTech's original Address Book editor. This | 16 | * intuitive interface to TrollTech's original Address Book editor. This |
17 | * is made to operate exactly in interface with the exception of name. | 17 | * is made to operate exactly in interface with the exception of name. |
18 | * | 18 | * |
19 | */ | 19 | */ |
20 | 20 | ||
21 | #ifndef CONTACTEDITOR_H | 21 | #ifndef CONTACTEDITOR_H |
22 | #define CONTACTEDITOR_H | 22 | #define CONTACTEDITOR_H |
23 | 23 | ||
24 | #include <opie/ocontact.h> | 24 | #include <opie/ocontact.h> |
25 | 25 | ||
26 | #include <qpe/datebookmonth.h> | 26 | #include <qpe/datebookmonth.h> |
27 | 27 | ||
28 | #include <qdialog.h> | 28 | #include <qdialog.h> |
29 | #include <qlist.h> | 29 | #include <qlist.h> |
30 | #include <qmap.h> | 30 | #include <qmap.h> |
31 | #include <qstringlist.h> | 31 | #include <qstringlist.h> |
32 | #include <qwidgetstack.h> | 32 | #include <qwidgetstack.h> |
33 | 33 | ||
34 | #include "ocontactfields.h" | 34 | #include "ocontactfields.h" |
35 | 35 | ||
36 | const int NAME_LF = 0; | 36 | const int NAME_LF = 0; |
37 | const int NAME_LFM = 1; | 37 | const int NAME_LFM = 1; |
38 | const int NAME_FL = 2; | 38 | 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; |
167 | QComboBox *cmbDefaultEmail; | 168 | QComboBox *cmbDefaultEmail; |
168 | QComboBox *cmbFileAs; | 169 | QComboBox *cmbFileAs; |
169 | CategorySelect *cmbCat; | 170 | CategorySelect *cmbCat; |
170 | QLabel *labCat; | 171 | QLabel *labCat; |
171 | 172 | ||
172 | QScrollView *svAddress; | 173 | QScrollView *svAddress; |
173 | QLineEdit *txtAddress; | 174 | QLineEdit *txtAddress; |
174 | //QLineEdit *txtAddress2; | 175 | //QLineEdit *txtAddress2; |
175 | //QLineEdit *txtPOBox; | 176 | //QLineEdit *txtPOBox; |
176 | QLineEdit *txtCity; | 177 | QLineEdit *txtCity; |
177 | QLineEdit *txtState; | 178 | QLineEdit *txtState; |
178 | QLineEdit *txtZip; | 179 | QLineEdit *txtZip; |
179 | QComboBox *cmbAddress; | 180 | QComboBox *cmbAddress; |
180 | QComboBox *cmbCountry; | 181 | QComboBox *cmbCountry; |
181 | 182 | ||
182 | QScrollView *svDetails; | 183 | QScrollView *svDetails; |
183 | QComboBox *cmbGender; | 184 | QComboBox *cmbGender; |
184 | DateBookMonth* birthdayPicker; | 185 | DateBookMonth* birthdayPicker; |
185 | QToolButton* birthdayButton; | 186 | QToolButton* birthdayButton; |
186 | DateBookMonth* anniversaryPicker; | 187 | DateBookMonth* anniversaryPicker; |
187 | QToolButton* anniversaryButton; | 188 | QToolButton* anniversaryButton; |
188 | 189 | ||
189 | bool initializing; | 190 | bool initializing; |
190 | }; | 191 | }; |
191 | 192 | ||
192 | #endif | 193 | #endif |