summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/pim/addressbook/contacteditor.cpp56
1 files changed, 39 insertions, 17 deletions
diff --git a/core/pim/addressbook/contacteditor.cpp b/core/pim/addressbook/contacteditor.cpp
index 66e94ef..6d92ac3 100644
--- a/core/pim/addressbook/contacteditor.cpp
+++ b/core/pim/addressbook/contacteditor.cpp
@@ -444,19 +444,19 @@ void ContactEditor::init() {
444 gl->addWidget( l, 3, 0 ); 444 gl->addWidget( l, 3, 0 );
445 txtSuffix = new QLineEdit( dlgName ); 445 txtSuffix = new QLineEdit( dlgName );
446 gl->addWidget( txtSuffix, 3, 1 ); 446 gl->addWidget( txtSuffix, 3, 1 );
447 447
448 cmbChooserField1->insertStringList( *slChooserNames ); 448 cmbChooserField1->insertStringList( *slChooserNames );
449 cmbChooserField2->insertStringList( *slChooserNames ); 449 cmbChooserField2->insertStringList( *slChooserNames );
450 cmbChooserField3->insertStringList( *slChooserNames ); 450 cmbChooserField3->insertStringList( *slChooserNames );
451 451
452 cmbChooserField1->setCurrentItem( 1 ); 452 cmbChooserField1->setCurrentItem( 0 );
453 cmbChooserField2->setCurrentItem( 2 ); 453 cmbChooserField2->setCurrentItem( 1 );
454 cmbChooserField3->setCurrentItem( 3 ); 454 cmbChooserField3->setCurrentItem( 2 );
455 455
456 connect( btnFullName, SIGNAL(clicked()), this, SLOT(slotName()) ); 456 connect( btnFullName, SIGNAL(clicked()), this, SLOT(slotName()) );
457 457
458 connect( txtFullName, SIGNAL(textChanged(const QString &)), this, SLOT(slotFullNameChange(const QString &)) ); 458 connect( txtFullName, SIGNAL(textChanged(const QString &)), this, SLOT(slotFullNameChange(const QString &)) );
459 459
460 connect( txtChooserField1, SIGNAL(textChanged(const QString &)), this, SLOT(slotChooser1Change(const QString &)) ); 460 connect( txtChooserField1, SIGNAL(textChanged(const QString &)), this, SLOT(slotChooser1Change(const QString &)) );
461 connect( txtChooserField2, SIGNAL(textChanged(const QString &)), this, SLOT(slotChooser2Change(const QString &)) ); 461 connect( txtChooserField2, SIGNAL(textChanged(const QString &)), this, SLOT(slotChooser2Change(const QString &)) );
462 connect( txtChooserField3, SIGNAL(textChanged(const QString &)), this, SLOT(slotChooser3Change(const QString &)) ); 462 connect( txtChooserField3, SIGNAL(textChanged(const QString &)), this, SLOT(slotChooser3Change(const QString &)) );
@@ -954,16 +954,17 @@ void ContactEditor::cleanupFields() {
954 txtTmp->setText(""); 954 txtTmp->setText("");
955 955
956} 956}
957 957
958void ContactEditor::setEntry( const Contact &entry ) { 958void ContactEditor::setEntry( const Contact &entry ) {
959 959
960 cleanupFields(); 960 cleanupFields();
961 961
962
962 ent = entry; 963 ent = entry;
963 964
964 useFullName = FALSE; 965 useFullName = FALSE;
965 txtFirstName->setText( ent.firstName() ); 966 txtFirstName->setText( ent.firstName() );
966 txtMiddleName->setText( ent.middleName() ); 967 txtMiddleName->setText( ent.middleName() );
967 txtLastName->setText( ent.lastName() ); 968 txtLastName->setText( ent.lastName() );
968 txtSuffix->setText( ent.suffix() ); 969 txtSuffix->setText( ent.suffix() );
969 970
@@ -1009,16 +1010,21 @@ void ContactEditor::setEntry( const Contact &entry ) {
1009 (*slBusinessAddress)[4] = ent.businessState(); 1010 (*slBusinessAddress)[4] = ent.businessState();
1010 } 1011 }
1011 1012
1012 if (hasZip) { 1013 if (hasZip) {
1013 (*slHomeAddress)[5] = ent.homeZip(); 1014 (*slHomeAddress)[5] = ent.homeZip();
1014 (*slBusinessAddress)[5] = ent.businessZip(); 1015 (*slBusinessAddress)[5] = ent.businessZip();
1015 } 1016 }
1016 1017
1018 if (hasCountry) {
1019 (*slHomeAddress)[6] = ent.homeCountry();
1020 (*slBusinessAddress)[6] = ent.businessCountry();
1021 }
1022
1017 QStringList::ConstIterator it; 1023 QStringList::ConstIterator it;
1018 QListIterator<QLineEdit> itLE( listValue ); 1024 QListIterator<QLineEdit> itLE( listValue );
1019 for ( it = slDynamicEntries->begin(); it != slDynamicEntries->end(); ++it, ++itLE) { 1025 for ( it = slDynamicEntries->begin(); it != slDynamicEntries->end(); ++it, ++itLE) {
1020 if ( *it == "Department" ) 1026 if ( *it == "Department" )
1021 (*itLE)->setText( ent.department() ); 1027 (*itLE)->setText( ent.department() );
1022 1028
1023 if ( *it == "Company" ) 1029 if ( *it == "Company" )
1024 (*itLE)->setText( ent.company() ); 1030 (*itLE)->setText( ent.company() );
@@ -1050,26 +1056,26 @@ void ContactEditor::setEntry( const Contact &entry ) {
1050 if ( *it == "Children" ) 1056 if ( *it == "Children" )
1051 (*itLE)->setText( ent.children() ); 1057 (*itLE)->setText( ent.children() );
1052 1058
1053 } 1059 }
1054 1060
1055 QStringList::Iterator itV; 1061 QStringList::Iterator itV;
1056 for ( it = slChooserNames->begin(), itV = slChooserValues->begin(); it != slChooserNames->end(); ++it, ++itV ) { 1062 for ( it = slChooserNames->begin(), itV = slChooserValues->begin(); it != slChooserNames->end(); ++it, ++itV ) {
1057 1063
1058 if ( *it == "Business Phone" ) 1064 if ( *it == "Business Phone" || *it == "Work Phone" )
1059 *itV = ent.businessPhone(); 1065 *itV = ent.businessPhone();
1060/* 1066/*
1061 if ( *it == "Business 2 Phone" ) 1067 if ( *it == "Business 2 Phone" )
1062 *itV = ent.business2Phone(); 1068 *itV = ent.business2Phone();
1063*/ 1069*/
1064 if ( *it == "Business Fax" ) 1070 if ( *it == "Business Fax" || *it == "Work Fax" )
1065 *itV = ent.businessFax(); 1071 *itV = ent.businessFax();
1066 1072
1067 if ( *it == "Business Mobile" ) 1073 if ( *it == "Business Mobile" || *it == "work Mobile" )
1068 *itV = ent.businessMobile(); 1074 *itV = ent.businessMobile();
1069/* 1075/*
1070 if ( *it == "Company Phone" ) 1076 if ( *it == "Company Phone" )
1071 *itV = ent.companyPhone(); 1077 *itV = ent.companyPhone();
1072*/ 1078*/
1073 if ( *it == "Default Email" ) 1079 if ( *it == "Default Email" )
1074 *itV = ent.defaultEmail(); 1080 *itV = ent.defaultEmail();
1075 1081
@@ -1092,17 +1098,17 @@ void ContactEditor::setEntry( const Contact &entry ) {
1092 *itV = ent.carPhone(); 1098 *itV = ent.carPhone();
1093 1099
1094 if ( *it == "ISDN Phone" ) 1100 if ( *it == "ISDN Phone" )
1095 *itV = ent.ISDNPhone(); 1101 *itV = ent.ISDNPhone();
1096 1102
1097 if ( *it == "Other Phone" ) 1103 if ( *it == "Other Phone" )
1098 *itV = ent.otherPhone(); 1104 *itV = ent.otherPhone();
1099*/ 1105*/
1100 if ( *it == "Business Pager" ) 1106 if ( *it == "Business Pager" || *it == "Work Pager" )
1101 *itV = ent.businessPager(); 1107 *itV = ent.businessPager();
1102/* 1108/*
1103 if ( *it == "Home Pager") 1109 if ( *it == "Home Pager")
1104 *itV = ent.homePager(); 1110 *itV = ent.homePager();
1105 1111
1106 if ( *it == "AIM IM" ) 1112 if ( *it == "AIM IM" )
1107 *itV = ent.AIMIM(); 1113 *itV = ent.AIMIM();
1108 1114
@@ -1115,29 +1121,35 @@ void ContactEditor::setEntry( const Contact &entry ) {
1115 if ( *it == "MSN IM" ) 1121 if ( *it == "MSN IM" )
1116 *itV = ent.MSNIM(); 1122 *itV = ent.MSNIM();
1117 1123
1118 if ( *it == "Yahoo IM" ) 1124 if ( *it == "Yahoo IM" )
1119 *itV = ent.yahooIM(); 1125 *itV = ent.yahooIM();
1120*/ 1126*/
1121 if ( *it == "Home Web Page" ) 1127 if ( *it == "Home Web Page" )
1122 *itV = ent.homeWebpage(); 1128 *itV = ent.homeWebpage();
1123 if ( *it == "Business Web Page" ) 1129 if ( *it == "Business Web Page" || *it == "Work Web Page" )
1124 *itV = ent.businessWebpage(); 1130 *itV = ent.businessWebpage();
1125 1131
1126 1132
1127 } 1133 }
1128 1134
1129 cmbCat->setCategories( ent.categories(), "Contacts", tr("Contacts") ); 1135 cmbCat->setCategories( ent.categories(), "Contacts", tr("Contacts") );
1130 1136
1131 QString gender = ent.gender(); 1137 QString gender = ent.gender();
1132 cmbGender->setCurrentItem( gender.toInt() ); 1138 cmbGender->setCurrentItem( gender.toInt() );
1133 1139
1134 txtNote->setText( ent.notes() ); 1140 txtNote->setText( ent.notes() );
1135 1141
1142 slotCmbChooser1Change( cmbChooserField1->currentItem() );
1143 slotCmbChooser2Change( cmbChooserField2->currentItem() );
1144 slotCmbChooser3Change( cmbChooserField3->currentItem() );
1145
1146 slotAddressTypeChange( cmbAddress->currentItem() );
1147
1136} 1148}
1137 1149
1138void ContactEditor::saveEntry() { 1150void ContactEditor::saveEntry() {
1139 1151
1140 if ( useFullName == TRUE ) { 1152 if ( useFullName == TRUE ) {
1141 txtFirstName->setText( parseName( txtFullName->text(), NAME_F ) ); 1153 txtFirstName->setText( parseName( txtFullName->text(), NAME_F ) );
1142 txtMiddleName->setText( parseName( txtFullName->text(), NAME_M ) ); 1154 txtMiddleName->setText( parseName( txtFullName->text(), NAME_M ) );
1143 txtLastName->setText( parseName( txtFullName->text(), NAME_L ) ); 1155 txtLastName->setText( parseName( txtFullName->text(), NAME_L ) );
@@ -1193,16 +1205,21 @@ void ContactEditor::saveEntry() {
1193 ent.setHomeState( (*slHomeAddress)[4] ); 1205 ent.setHomeState( (*slHomeAddress)[4] );
1194 ent.setBusinessState( (*slBusinessAddress)[4] ); 1206 ent.setBusinessState( (*slBusinessAddress)[4] );
1195 } 1207 }
1196 1208
1197 if (hasZip) { 1209 if (hasZip) {
1198 ent.setHomeZip( (*slHomeAddress)[5] ); 1210 ent.setHomeZip( (*slHomeAddress)[5] );
1199 ent.setBusinessZip( (*slBusinessAddress)[5] ); 1211 ent.setBusinessZip( (*slBusinessAddress)[5] );
1200 } 1212 }
1213
1214 if (hasCountry) {
1215 ent.setHomeCountry( (*slHomeAddress)[6] );
1216 ent.setBusinessCountry( (*slBusinessAddress)[6] );
1217 }
1201 1218
1202 QStringList::ConstIterator it; 1219 QStringList::ConstIterator it;
1203 QListIterator<QLineEdit> itLE( listValue ); 1220 QListIterator<QLineEdit> itLE( listValue );
1204 for ( it = slDynamicEntries->begin(); it != slDynamicEntries->end(); ++it, ++itLE) { 1221 for ( it = slDynamicEntries->begin(); it != slDynamicEntries->end(); ++it, ++itLE) {
1205 if ( *it == "Department" ) 1222 if ( *it == "Department" )
1206 ent.setDepartment( (*itLE)->text() ); 1223 ent.setDepartment( (*itLE)->text() );
1207 1224
1208 if ( *it == "Company" ) 1225 if ( *it == "Company" )
@@ -1235,36 +1252,41 @@ void ContactEditor::saveEntry() {
1235 if ( *it == "Children" ) 1252 if ( *it == "Children" )
1236 ent.setChildren( (*itLE)->text() ); 1253 ent.setChildren( (*itLE)->text() );
1237 1254
1238 } 1255 }
1239 1256
1240 QStringList::ConstIterator itV; 1257 QStringList::ConstIterator itV;
1241 for ( it = slChooserNames->begin(), itV = slChooserValues->begin(); it != slChooserNames->end(); ++it, ++itV ) { 1258 for ( it = slChooserNames->begin(), itV = slChooserValues->begin(); it != slChooserNames->end(); ++it, ++itV ) {
1242 1259
1243 if ( *it == "Business Phone" ) 1260 if ( *it == "Business Phone" || *it == "Work Phone" )
1244 ent.setBusinessPhone( *itV ); 1261 ent.setBusinessPhone( *itV );
1245/* 1262/*
1246 if ( *it == "Business 2 Phone" ) 1263 if ( *it == "Business 2 Phone" )
1247 ent.setBusiness2Phone( *itV ); 1264 ent.setBusiness2Phone( *itV );
1248*/ 1265*/
1249 if ( *it == "Business Fax" ) 1266 if ( *it == "Business Fax" || *it == "Work Fax" )
1250 ent.setBusinessFax( *itV ); 1267 ent.setBusinessFax( *itV );
1251 1268
1252 if ( *it == "Business Mobile" ) 1269 if ( *it == "Business Mobile" || *it == "Work Mobile" )
1253 ent.setBusinessMobile( *itV ); 1270 ent.setBusinessMobile( *itV );
1254/* 1271/*
1255 if ( *it == "Company Phone" ) 1272 if ( *it == "Company Phone" )
1256 ent.setCompanyPhone( *itV ); 1273 ent.setCompanyPhone( *itV );
1257*/ 1274*/
1258 if ( *it == "Default Email" ) 1275 //if ( *it == "Default Email" )
1259 ent.setDefaultEmail( *itV ); 1276 //ent.setDefaultEmail( *itV );
1260 1277
1261 if ( *it == "Emails" ) 1278 if ( *it == "Emails" ) {
1279 QString allemail;
1280 QString defaultmail;
1281 parseEmailFrom( *itV, defaultmail, allemail );
1282 ent.setDefaultEmail( defaultmail );
1262 ent.setEmails( *itV ); 1283 ent.setEmails( *itV );
1284 }
1263 1285
1264 if ( *it == "Home Phone" ) 1286 if ( *it == "Home Phone" )
1265 ent.setHomePhone( *itV ); 1287 ent.setHomePhone( *itV );
1266/* 1288/*
1267 if ( *it == "Home 2 Phone" ) 1289 if ( *it == "Home 2 Phone" )
1268 ent.setHome2Phone( *itV ); 1290 ent.setHome2Phone( *itV );
1269*/ 1291*/
1270 if ( *it == "Home Fax" ) 1292 if ( *it == "Home Fax" )
@@ -1277,17 +1299,17 @@ void ContactEditor::saveEntry() {
1277 ent.setCarPhone( *itV ); 1299 ent.setCarPhone( *itV );
1278 1300
1279 if ( *it == "ISDN Phone" ) 1301 if ( *it == "ISDN Phone" )
1280 ent.setISDNPhone( *itV ); 1302 ent.setISDNPhone( *itV );
1281 1303
1282 if ( *it == "Other Phone" ) 1304 if ( *it == "Other Phone" )
1283 ent.setOtherPhone( *itV ); 1305 ent.setOtherPhone( *itV );
1284*/ 1306*/
1285 if ( *it == "Business Pager" ) 1307 if ( *it == "Business Pager" || *it == "Work Pager" )
1286 ent.setBusinessPager( *itV ); 1308 ent.setBusinessPager( *itV );
1287/* 1309/*
1288 if ( *it == "Home Pager" ) 1310 if ( *it == "Home Pager" )
1289 ent.setHomePager( *itV ); 1311 ent.setHomePager( *itV );
1290 1312
1291 if ( *it == "AIM IM" ) 1313 if ( *it == "AIM IM" )
1292 ent.setAIMIM( *itV ); 1314 ent.setAIMIM( *itV );
1293 1315
@@ -1300,17 +1322,17 @@ void ContactEditor::saveEntry() {
1300 if ( *it == "MSN IM" ) 1322 if ( *it == "MSN IM" )
1301 ent.setMSNIM( *itV ); 1323 ent.setMSNIM( *itV );
1302 1324
1303 if ( *it == "Yahoo IM" ) 1325 if ( *it == "Yahoo IM" )
1304 ent.setYahooIM( *itV ); 1326 ent.setYahooIM( *itV );
1305*/ 1327*/
1306 if ( *it == "Home Web Page" ) 1328 if ( *it == "Home Web Page" )
1307 ent.setHomeWebpage( *itV ); 1329 ent.setHomeWebpage( *itV );
1308 if ( *it == "Business Web Page" ) 1330 if ( *it == "Business Web Page" || *it == "Work Web Page" )
1309 ent.setBusinessWebpage( *itV ); 1331 ent.setBusinessWebpage( *itV );
1310 1332
1311 1333
1312 } 1334 }
1313 1335
1314 int gender = cmbGender->currentItem(); 1336 int gender = cmbGender->currentItem();
1315 ent.setGender( QString::number( gender ) ); 1337 ent.setGender( QString::number( gender ) );
1316 1338