author | ulf69 <ulf69> | 2004-06-30 22:07:56 (UTC) |
---|---|---|
committer | ulf69 <ulf69> | 2004-06-30 22:07:56 (UTC) |
commit | 1b7b7755bfbedddc72293b784577ded4e684bd6f (patch) (unidiff) | |
tree | ff4eba9b8bb53401d2000d70e73a40f7c330d577 | |
parent | c6f3a3f49498dca52d10418d845f4a84c0c6d941 (diff) | |
download | kdepimpi-1b7b7755bfbedddc72293b784577ded4e684bd6f.zip kdepimpi-1b7b7755bfbedddc72293b784577ded4e684bd6f.tar.gz kdepimpi-1b7b7755bfbedddc72293b784577ded4e684bd6f.tar.bz2 |
added a new field of type Resource. This allowes us to display in KAddressbook for each
Addressbookentry its location
-rw-r--r-- | kabc/addressee.cpp | 6 | ||||
-rw-r--r-- | kabc/addressee.h | 6 | ||||
-rw-r--r-- | kabc/field.cpp | 24 |
3 files changed, 32 insertions, 4 deletions
diff --git a/kabc/addressee.cpp b/kabc/addressee.cpp index 5cb194a..d484073 100644 --- a/kabc/addressee.cpp +++ b/kabc/addressee.cpp | |||
@@ -1498,24 +1498,30 @@ void Addressee::parseEmailAddress( const QString &rawEmail, QString &fullName, | |||
1498 | 1498 | ||
1499 | void Addressee::setResource( Resource *resource ) | 1499 | void Addressee::setResource( Resource *resource ) |
1500 | { | 1500 | { |
1501 | detach(); | 1501 | detach(); |
1502 | mData->resource = resource; | 1502 | mData->resource = resource; |
1503 | } | 1503 | } |
1504 | 1504 | ||
1505 | Resource *Addressee::resource() const | 1505 | Resource *Addressee::resource() const |
1506 | { | 1506 | { |
1507 | return mData->resource; | 1507 | return mData->resource; |
1508 | } | 1508 | } |
1509 | 1509 | ||
1510 | //US | ||
1511 | QString Addressee::resourceLabel() | ||
1512 | { | ||
1513 | return i18n("Resource"); | ||
1514 | } | ||
1515 | |||
1510 | void Addressee::setChanged( bool value ) | 1516 | void Addressee::setChanged( bool value ) |
1511 | { | 1517 | { |
1512 | detach(); | 1518 | detach(); |
1513 | mData->changed = value; | 1519 | mData->changed = value; |
1514 | } | 1520 | } |
1515 | 1521 | ||
1516 | bool Addressee::changed() const | 1522 | bool Addressee::changed() const |
1517 | { | 1523 | { |
1518 | return mData->changed; | 1524 | return mData->changed; |
1519 | } | 1525 | } |
1520 | 1526 | ||
1521 | QDataStream &KABC::operator<<( QDataStream &s, const Addressee &a ) | 1527 | QDataStream &KABC::operator<<( QDataStream &s, const Addressee &a ) |
diff --git a/kabc/addressee.h b/kabc/addressee.h index ee98e03..393d1cc 100644 --- a/kabc/addressee.h +++ b/kabc/addressee.h | |||
@@ -783,24 +783,30 @@ class Addressee | |||
783 | 783 | ||
784 | /** | 784 | /** |
785 | Set resource where the addressee is from. | 785 | Set resource where the addressee is from. |
786 | */ | 786 | */ |
787 | void setResource( Resource *resource ); | 787 | void setResource( Resource *resource ); |
788 | 788 | ||
789 | /** | 789 | /** |
790 | Return pointer to resource. | 790 | Return pointer to resource. |
791 | */ | 791 | */ |
792 | Resource *resource() const; | 792 | Resource *resource() const; |
793 | 793 | ||
794 | /** | 794 | /** |
795 | Return resourcelabel. | ||
796 | */ | ||
797 | //US | ||
798 | static QString resourceLabel(); | ||
799 | |||
800 | /** | ||
795 | Mark addressee as changed. | 801 | Mark addressee as changed. |
796 | */ | 802 | */ |
797 | void setChanged( bool value ); | 803 | void setChanged( bool value ); |
798 | 804 | ||
799 | /** | 805 | /** |
800 | Return whether the addressee is changed. | 806 | Return whether the addressee is changed. |
801 | */ | 807 | */ |
802 | bool changed() const; | 808 | bool changed() const; |
803 | 809 | ||
804 | private: | 810 | private: |
805 | Addressee copy(); | 811 | Addressee copy(); |
806 | void detach(); | 812 | void detach(); |
diff --git a/kabc/field.cpp b/kabc/field.cpp index 41bbfde..bc2e176 100644 --- a/kabc/field.cpp +++ b/kabc/field.cpp | |||
@@ -23,24 +23,25 @@ | |||
23 | Enhanced Version of the file for platform independent KDE tools. | 23 | Enhanced Version of the file for platform independent KDE tools. |
24 | Copyright (c) 2004 Ulf Schenk | 24 | Copyright (c) 2004 Ulf Schenk |
25 | 25 | ||
26 | $Id$ | 26 | $Id$ |
27 | */ | 27 | */ |
28 | 28 | ||
29 | #include <klocale.h> | 29 | #include <klocale.h> |
30 | #include <kconfig.h> | 30 | #include <kconfig.h> |
31 | #include <kconfigbase.h> | 31 | #include <kconfigbase.h> |
32 | #include <kglobal.h> | 32 | #include <kglobal.h> |
33 | 33 | ||
34 | #include "field.h" | 34 | #include "field.h" |
35 | #include "resource.h" | ||
35 | 36 | ||
36 | using namespace KABC; | 37 | using namespace KABC; |
37 | 38 | ||
38 | class Field::FieldImpl | 39 | class Field::FieldImpl |
39 | { | 40 | { |
40 | public: | 41 | public: |
41 | FieldImpl( int fieldId, int category = 0, | 42 | FieldImpl( int fieldId, int category = 0, |
42 | const QString &label = QString::null, | 43 | const QString &label = QString::null, |
43 | const QString &key = QString::null, | 44 | const QString &key = QString::null, |
44 | const QString &app = QString::null ) | 45 | const QString &app = QString::null ) |
45 | : mFieldId( fieldId ), mCategory( category ), mLabel( label ), | 46 | : mFieldId( fieldId ), mCategory( category ), mLabel( label ), |
46 | mKey( key ), mApp( app ) {} | 47 | mKey( key ), mApp( app ) {} |
@@ -73,25 +74,26 @@ class Field::FieldImpl | |||
73 | MobilePhone, | 74 | MobilePhone, |
74 | HomeFax, | 75 | HomeFax, |
75 | BusinessFax, | 76 | BusinessFax, |
76 | CarPhone, | 77 | CarPhone, |
77 | Isdn, | 78 | Isdn, |
78 | Pager, | 79 | Pager, |
79 | Email, | 80 | Email, |
80 | Mailer, | 81 | Mailer, |
81 | Title, | 82 | Title, |
82 | Role, | 83 | Role, |
83 | Organization, | 84 | Organization, |
84 | Note, | 85 | Note, |
85 | Url | 86 | Url, |
87 | Resource | ||
86 | }; | 88 | }; |
87 | 89 | ||
88 | int fieldId() { return mFieldId; } | 90 | int fieldId() { return mFieldId; } |
89 | int category() { return mCategory; } | 91 | int category() { return mCategory; } |
90 | 92 | ||
91 | QString label() { return mLabel; } | 93 | QString label() { return mLabel; } |
92 | QString key() { return mKey; } | 94 | QString key() { return mKey; } |
93 | QString app() { return mApp; } | 95 | QString app() { return mApp; } |
94 | 96 | ||
95 | private: | 97 | private: |
96 | int mFieldId; | 98 | int mFieldId; |
97 | int mCategory; | 99 | int mCategory; |
@@ -181,24 +183,26 @@ QString Field::label() | |||
181 | case FieldImpl::Mailer: | 183 | case FieldImpl::Mailer: |
182 | return Addressee::mailerLabel(); | 184 | return Addressee::mailerLabel(); |
183 | case FieldImpl::Title: | 185 | case FieldImpl::Title: |
184 | return Addressee::titleLabel(); | 186 | return Addressee::titleLabel(); |
185 | case FieldImpl::Role: | 187 | case FieldImpl::Role: |
186 | return Addressee::roleLabel(); | 188 | return Addressee::roleLabel(); |
187 | case FieldImpl::Organization: | 189 | case FieldImpl::Organization: |
188 | return Addressee::organizationLabel(); | 190 | return Addressee::organizationLabel(); |
189 | case FieldImpl::Note: | 191 | case FieldImpl::Note: |
190 | return Addressee::noteLabel(); | 192 | return Addressee::noteLabel(); |
191 | case FieldImpl::Url: | 193 | case FieldImpl::Url: |
192 | return Addressee::urlLabel(); | 194 | return Addressee::urlLabel(); |
195 | case FieldImpl::Resource: | ||
196 | return Addressee::resourceLabel(); | ||
193 | case FieldImpl::CustomField: | 197 | case FieldImpl::CustomField: |
194 | return mImpl->label(); | 198 | return mImpl->label(); |
195 | default: | 199 | default: |
196 | return i18n("Unknown Field"); | 200 | return i18n("Unknown Field"); |
197 | } | 201 | } |
198 | } | 202 | } |
199 | 203 | ||
200 | int Field::category() | 204 | int Field::category() |
201 | { | 205 | { |
202 | return mImpl->category(); | 206 | return mImpl->category(); |
203 | } | 207 | } |
204 | 208 | ||
@@ -258,24 +262,27 @@ QString Field::value( const KABC::Addressee &a ) | |||
258 | //the generated code had the following format: return a.birthday().date().toString( Qt::ISODate ); | 262 | //the generated code had the following format: return a.birthday().date().toString( Qt::ISODate ); |
259 | // But Qt::IsoDate was not specified. | 263 | // But Qt::IsoDate was not specified. |
260 | QString _oldFormat = KGlobal::locale()->dateFormat(); | 264 | QString _oldFormat = KGlobal::locale()->dateFormat(); |
261 | KGlobal::locale()->setDateFormat("%Y-%m-%d"); // = Qt::ISODate | 265 | KGlobal::locale()->setDateFormat("%Y-%m-%d"); // = Qt::ISODate |
262 | QString dt = KGlobal::locale()->formatDate(a.birthday().date(), false); | 266 | QString dt = KGlobal::locale()->formatDate(a.birthday().date(), false); |
263 | KGlobal::locale()->setDateFormat(_oldFormat); | 267 | KGlobal::locale()->setDateFormat(_oldFormat); |
264 | return dt; | 268 | return dt; |
265 | } | 269 | } |
266 | else | 270 | else |
267 | return QString::null; | 271 | return QString::null; |
268 | case FieldImpl::Url: | 272 | case FieldImpl::Url: |
269 | return a.url().prettyURL(); | 273 | return a.url().prettyURL(); |
274 | //US | ||
275 | case FieldImpl::Resource: | ||
276 | return a.resource()->resourceName(); | ||
270 | case FieldImpl::HomePhone: | 277 | case FieldImpl::HomePhone: |
271 | return a.phoneNumber( PhoneNumber::Home ).number(); | 278 | return a.phoneNumber( PhoneNumber::Home ).number(); |
272 | case FieldImpl::BusinessPhone: | 279 | case FieldImpl::BusinessPhone: |
273 | return a.phoneNumber( PhoneNumber::Work ).number(); | 280 | return a.phoneNumber( PhoneNumber::Work ).number(); |
274 | case FieldImpl::MobilePhone: | 281 | case FieldImpl::MobilePhone: |
275 | return a.phoneNumber( PhoneNumber::Cell ).number(); | 282 | return a.phoneNumber( PhoneNumber::Cell ).number(); |
276 | case FieldImpl::HomeFax: | 283 | case FieldImpl::HomeFax: |
277 | return a.phoneNumber( PhoneNumber::Home | PhoneNumber::Fax ).number(); | 284 | return a.phoneNumber( PhoneNumber::Home | PhoneNumber::Fax ).number(); |
278 | case FieldImpl::BusinessFax: | 285 | case FieldImpl::BusinessFax: |
279 | return a.phoneNumber( PhoneNumber::Work | PhoneNumber::Fax ).number(); | 286 | return a.phoneNumber( PhoneNumber::Work | PhoneNumber::Fax ).number(); |
280 | case FieldImpl::CarPhone: | 287 | case FieldImpl::CarPhone: |
281 | return a.phoneNumber( PhoneNumber::Car ).number(); | 288 | return a.phoneNumber( PhoneNumber::Car ).number(); |
@@ -351,24 +358,26 @@ bool Field::setValue( KABC::Addressee &a, const QString &value ) | |||
351 | return true; | 358 | return true; |
352 | case FieldImpl::Birthday: | 359 | case FieldImpl::Birthday: |
353 | //US | 360 | //US |
354 | //the generated code had the following format: return a.setBirthday( QDate::fromString( value, Qt::ISODate ) ); | 361 | //the generated code had the following format: return a.setBirthday( QDate::fromString( value, Qt::ISODate ) ); |
355 | // But Qt::IsoDate and QDate::fromString was not specified. Do I have the wrong QT version ? | 362 | // But Qt::IsoDate and QDate::fromString was not specified. Do I have the wrong QT version ? |
356 | { | 363 | { |
357 | QDate dt = KGlobal::locale()->readDate( value, "%Y-%m-%d"); // = Qt::ISODate | 364 | QDate dt = KGlobal::locale()->readDate( value, "%Y-%m-%d"); // = Qt::ISODate |
358 | a.setBirthday(dt); | 365 | a.setBirthday(dt); |
359 | } | 366 | } |
360 | return true; | 367 | return true; |
361 | case FieldImpl::CustomField: | 368 | case FieldImpl::CustomField: |
362 | a.insertCustom( mImpl->app(), mImpl->key(), value ); | 369 | a.insertCustom( mImpl->app(), mImpl->key(), value ); |
370 | //US never copy the resourcename back to the adressee. | ||
371 | case FieldImpl::Resource: | ||
363 | default: | 372 | default: |
364 | return false; | 373 | return false; |
365 | } | 374 | } |
366 | } | 375 | } |
367 | 376 | ||
368 | bool Field::isCustom() | 377 | bool Field::isCustom() |
369 | { | 378 | { |
370 | return mImpl->fieldId() == FieldImpl::CustomField; | 379 | return mImpl->fieldId() == FieldImpl::CustomField; |
371 | } | 380 | } |
372 | 381 | ||
373 | Field::List Field::allFields() | 382 | Field::List Field::allFields() |
374 | { | 383 | { |
@@ -399,24 +408,25 @@ Field::List Field::allFields() | |||
399 | createField( FieldImpl::HomeFax ); | 408 | createField( FieldImpl::HomeFax ); |
400 | createField( FieldImpl::BusinessFax ); | 409 | createField( FieldImpl::BusinessFax ); |
401 | createField( FieldImpl::CarPhone ); | 410 | createField( FieldImpl::CarPhone ); |
402 | createField( FieldImpl::Isdn ); | 411 | createField( FieldImpl::Isdn ); |
403 | createField( FieldImpl::Pager ); | 412 | createField( FieldImpl::Pager ); |
404 | createField( FieldImpl::Email, Email|Frequent ); | 413 | createField( FieldImpl::Email, Email|Frequent ); |
405 | createField( FieldImpl::Mailer, Email ); | 414 | createField( FieldImpl::Mailer, Email ); |
406 | createField( FieldImpl::Title, Organization ); | 415 | createField( FieldImpl::Title, Organization ); |
407 | createField( FieldImpl::Role, Organization ); | 416 | createField( FieldImpl::Role, Organization ); |
408 | createField( FieldImpl::Organization, Organization ); | 417 | createField( FieldImpl::Organization, Organization ); |
409 | createField( FieldImpl::Note ); | 418 | createField( FieldImpl::Note ); |
410 | createField( FieldImpl::Url ); | 419 | createField( FieldImpl::Url ); |
420 | createField( FieldImpl::Resource ); | ||
411 | } | 421 | } |
412 | 422 | ||
413 | return mAllFields; | 423 | return mAllFields; |
414 | } | 424 | } |
415 | 425 | ||
416 | Field::List Field::defaultFields() | 426 | Field::List Field::defaultFields() |
417 | { | 427 | { |
418 | if ( mDefaultFields.isEmpty() ) { | 428 | if ( mDefaultFields.isEmpty() ) { |
419 | createDefaultField( FieldImpl::GivenName ); | 429 | createDefaultField( FieldImpl::GivenName ); |
420 | createDefaultField( FieldImpl::FamilyName ); | 430 | createDefaultField( FieldImpl::FamilyName ); |
421 | createDefaultField( FieldImpl::Email ); | 431 | createDefaultField( FieldImpl::Email ); |
422 | } | 432 | } |
@@ -459,61 +469,64 @@ void Field::saveFields( const QString &identifier, | |||
459 | { | 469 | { |
460 | KConfig *cfg = KGlobal::config(); | 470 | KConfig *cfg = KGlobal::config(); |
461 | KConfigGroupSaver( cfg, "KABCFields" ); | 471 | KConfigGroupSaver( cfg, "KABCFields" ); |
462 | saveFields( cfg, identifier, fields ); | 472 | saveFields( cfg, identifier, fields ); |
463 | } | 473 | } |
464 | 474 | ||
465 | void Field::saveFields( KConfig *cfg, const QString &identifier, | 475 | void Field::saveFields( KConfig *cfg, const QString &identifier, |
466 | const Field::List &fields ) | 476 | const Field::List &fields ) |
467 | { | 477 | { |
468 | QValueList<int> fieldIds; | 478 | QValueList<int> fieldIds; |
469 | 479 | ||
470 | //US | 480 | //US |
471 | //US qDebug("Field::saveFields to %s %s", cfg->getFileName().latin1(), identifier.latin1()); | 481 | // qDebug("Field::saveFields to %s %s", cfg->getFileName().latin1(), identifier.latin1()); |
472 | 482 | ||
473 | int custom = 0; | 483 | int custom = 0; |
474 | Field::List::ConstIterator it; | 484 | Field::List::ConstIterator it; |
475 | for( it = fields.begin(); it != fields.end(); ++it ) { | 485 | for( it = fields.begin(); it != fields.end(); ++it ) { |
476 | //US | 486 | //US |
477 | //US qDebug("Field::saveFields field:%i", (*it)->mImpl->fieldId()); | 487 | // qDebug("Field::saveFields field:%i", (*it)->mImpl->fieldId()); |
478 | 488 | ||
479 | fieldIds.append( (*it)->mImpl->fieldId() ); | 489 | fieldIds.append( (*it)->mImpl->fieldId() ); |
480 | if( (*it)->isCustom() ) { | 490 | if( (*it)->isCustom() ) { |
481 | QStringList customEntry; | 491 | QStringList customEntry; |
482 | customEntry << (*it)->mImpl->label(); | 492 | customEntry << (*it)->mImpl->label(); |
483 | customEntry << (*it)->mImpl->key(); | 493 | customEntry << (*it)->mImpl->key(); |
484 | customEntry << (*it)->mImpl->app(); | 494 | customEntry << (*it)->mImpl->app(); |
485 | cfg->writeEntry( "KABC_CustomEntry_" + identifier + "_" + | 495 | cfg->writeEntry( "KABC_CustomEntry_" + identifier + "_" + |
486 | QString::number( custom++ ), customEntry ); | 496 | QString::number( custom++ ), customEntry ); |
487 | } | 497 | } |
488 | } | 498 | } |
489 | cfg->writeEntry( identifier, fieldIds ); | 499 | cfg->writeEntry( identifier, fieldIds ); |
490 | } | 500 | } |
491 | 501 | ||
492 | Field::List Field::restoreFields( const QString &identifier ) | 502 | Field::List Field::restoreFields( const QString &identifier ) |
493 | { | 503 | { |
504 | //US | ||
505 | // qDebug("Field::restoreFields, identifier: %s", identifier.latin1()); | ||
506 | |||
494 | KConfig *cfg = KGlobal::config(); | 507 | KConfig *cfg = KGlobal::config(); |
495 | KConfigGroupSaver( cfg, "KABCFields" ); | 508 | KConfigGroupSaver( cfg, "KABCFields" ); |
496 | cfg->setGroup( "KABCFields" ); | 509 | cfg->setGroup( "KABCFields" ); |
497 | 510 | ||
498 | Field::List l = restoreFields( cfg, identifier ); | 511 | Field::List l = restoreFields( cfg, identifier ); |
499 | 512 | ||
500 | return l; | 513 | return l; |
501 | } | 514 | } |
502 | 515 | ||
503 | Field::List Field::restoreFields( KConfig *cfg, const QString &identifier ) | 516 | Field::List Field::restoreFields( KConfig *cfg, const QString &identifier ) |
504 | { | 517 | { |
505 | QValueList<int> fieldIds = cfg->readIntListEntry( identifier); | 518 | QValueList<int> fieldIds = cfg->readIntListEntry( identifier); |
506 | //US | 519 | //US |
507 | qDebug("Field::restoreFields from %s", cfg->getFileName().latin1()); | 520 | // qDebug("Field::restoreFields from %s, identifier: %s", cfg->getFileName().latin1(), identifier.latin1()); |
508 | 521 | ||
509 | Field::List fields; | 522 | Field::List fields; |
510 | 523 | ||
511 | int custom = 0; | 524 | int custom = 0; |
512 | QValueList<int>::ConstIterator it; | 525 | QValueList<int>::ConstIterator it; |
513 | for( it = fieldIds.begin(); it != fieldIds.end(); ++it ) { | 526 | for( it = fieldIds.begin(); it != fieldIds.end(); ++it ) { |
514 | FieldImpl *f = 0; | 527 | FieldImpl *f = 0; |
515 | if ( (*it) == FieldImpl::CustomField ) { | 528 | if ( (*it) == FieldImpl::CustomField ) { |
516 | QStringList customEntry = cfg->readListEntry( "KABC_CustomEntry_" + | 529 | QStringList customEntry = cfg->readListEntry( "KABC_CustomEntry_" + |
517 | identifier + "_" + | 530 | identifier + "_" + |
518 | QString::number( custom++ ) ); | 531 | QString::number( custom++ ) ); |
519 | f = new FieldImpl( *it, CustomCategory, customEntry[ 0 ], | 532 | f = new FieldImpl( *it, CustomCategory, customEntry[ 0 ], |
@@ -535,16 +548,19 @@ bool Field::equals( Field *field ) | |||
535 | 548 | ||
536 | if ( mImpl->fieldId() != FieldImpl::CustomField ) return true; | 549 | if ( mImpl->fieldId() != FieldImpl::CustomField ) return true; |
537 | 550 | ||
538 | return mImpl->key() == field->mImpl->key(); | 551 | return mImpl->key() == field->mImpl->key(); |
539 | } | 552 | } |
540 | 553 | ||
541 | Field *Field::createCustomField( const QString &label, int category, | 554 | Field *Field::createCustomField( const QString &label, int category, |
542 | const QString &key, const QString &app ) | 555 | const QString &key, const QString &app ) |
543 | { | 556 | { |
544 | Field *field = new Field( new FieldImpl( FieldImpl::CustomField, | 557 | Field *field = new Field( new FieldImpl( FieldImpl::CustomField, |
545 | category | CustomCategory, | 558 | category | CustomCategory, |
546 | label, key, app ) ); | 559 | label, key, app ) ); |
560 | //US | ||
561 | // qDebug("Field::createCustomField label %s", label.latin1() ); | ||
562 | |||
547 | mCustomFields.append( field ); | 563 | mCustomFields.append( field ); |
548 | 564 | ||
549 | return field; | 565 | return field; |
550 | } | 566 | } |