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 | |||
@@ -1382,235 +1382,241 @@ void Addressee::insertCustom( const QString &app, const QString &name, | |||
1382 | if ( value.isNull() || name.isEmpty() || app.isEmpty() ) return; | 1382 | if ( value.isNull() || name.isEmpty() || app.isEmpty() ) return; |
1383 | 1383 | ||
1384 | detach(); | 1384 | detach(); |
1385 | mData->empty = false; | 1385 | mData->empty = false; |
1386 | 1386 | ||
1387 | QString qualifiedName = app + "-" + name + ":"; | 1387 | QString qualifiedName = app + "-" + name + ":"; |
1388 | 1388 | ||
1389 | QStringList::Iterator it; | 1389 | QStringList::Iterator it; |
1390 | for( it = mData->custom.begin(); it != mData->custom.end(); ++it ) { | 1390 | for( it = mData->custom.begin(); it != mData->custom.end(); ++it ) { |
1391 | if ( (*it).startsWith( qualifiedName ) ) { | 1391 | if ( (*it).startsWith( qualifiedName ) ) { |
1392 | (*it) = qualifiedName + value; | 1392 | (*it) = qualifiedName + value; |
1393 | return; | 1393 | return; |
1394 | } | 1394 | } |
1395 | } | 1395 | } |
1396 | 1396 | ||
1397 | mData->custom.append( qualifiedName + value ); | 1397 | mData->custom.append( qualifiedName + value ); |
1398 | } | 1398 | } |
1399 | 1399 | ||
1400 | void Addressee::removeCustom( const QString &app, const QString &name) | 1400 | void Addressee::removeCustom( const QString &app, const QString &name) |
1401 | { | 1401 | { |
1402 | detach(); | 1402 | detach(); |
1403 | 1403 | ||
1404 | QString qualifiedName = app + "-" + name + ":"; | 1404 | QString qualifiedName = app + "-" + name + ":"; |
1405 | 1405 | ||
1406 | QStringList::Iterator it; | 1406 | QStringList::Iterator it; |
1407 | for( it = mData->custom.begin(); it != mData->custom.end(); ++it ) { | 1407 | for( it = mData->custom.begin(); it != mData->custom.end(); ++it ) { |
1408 | if ( (*it).startsWith( qualifiedName ) ) { | 1408 | if ( (*it).startsWith( qualifiedName ) ) { |
1409 | mData->custom.remove( it ); | 1409 | mData->custom.remove( it ); |
1410 | return; | 1410 | return; |
1411 | } | 1411 | } |
1412 | } | 1412 | } |
1413 | } | 1413 | } |
1414 | 1414 | ||
1415 | QString Addressee::custom( const QString &app, const QString &name ) const | 1415 | QString Addressee::custom( const QString &app, const QString &name ) const |
1416 | { | 1416 | { |
1417 | QString qualifiedName = app + "-" + name + ":"; | 1417 | QString qualifiedName = app + "-" + name + ":"; |
1418 | QString value; | 1418 | QString value; |
1419 | 1419 | ||
1420 | QStringList::ConstIterator it; | 1420 | QStringList::ConstIterator it; |
1421 | for( it = mData->custom.begin(); it != mData->custom.end(); ++it ) { | 1421 | for( it = mData->custom.begin(); it != mData->custom.end(); ++it ) { |
1422 | if ( (*it).startsWith( qualifiedName ) ) { | 1422 | if ( (*it).startsWith( qualifiedName ) ) { |
1423 | value = (*it).mid( (*it).find( ":" ) + 1 ); | 1423 | value = (*it).mid( (*it).find( ":" ) + 1 ); |
1424 | break; | 1424 | break; |
1425 | } | 1425 | } |
1426 | } | 1426 | } |
1427 | 1427 | ||
1428 | return value; | 1428 | return value; |
1429 | } | 1429 | } |
1430 | 1430 | ||
1431 | void Addressee::setCustoms( const QStringList &l ) | 1431 | void Addressee::setCustoms( const QStringList &l ) |
1432 | { | 1432 | { |
1433 | detach(); | 1433 | detach(); |
1434 | mData->empty = false; | 1434 | mData->empty = false; |
1435 | 1435 | ||
1436 | mData->custom = l; | 1436 | mData->custom = l; |
1437 | } | 1437 | } |
1438 | 1438 | ||
1439 | QStringList Addressee::customs() const | 1439 | QStringList Addressee::customs() const |
1440 | { | 1440 | { |
1441 | return mData->custom; | 1441 | return mData->custom; |
1442 | } | 1442 | } |
1443 | 1443 | ||
1444 | void Addressee::parseEmailAddress( const QString &rawEmail, QString &fullName, | 1444 | void Addressee::parseEmailAddress( const QString &rawEmail, QString &fullName, |
1445 | QString &email) | 1445 | QString &email) |
1446 | { | 1446 | { |
1447 | int startPos, endPos, len; | 1447 | int startPos, endPos, len; |
1448 | QString partA, partB, result; | 1448 | QString partA, partB, result; |
1449 | char endCh = '>'; | 1449 | char endCh = '>'; |
1450 | 1450 | ||
1451 | startPos = rawEmail.find('<'); | 1451 | startPos = rawEmail.find('<'); |
1452 | if (startPos < 0) | 1452 | if (startPos < 0) |
1453 | { | 1453 | { |
1454 | startPos = rawEmail.find('('); | 1454 | startPos = rawEmail.find('('); |
1455 | endCh = ')'; | 1455 | endCh = ')'; |
1456 | } | 1456 | } |
1457 | if (startPos < 0) | 1457 | if (startPos < 0) |
1458 | { | 1458 | { |
1459 | // We couldn't find any separators, so we assume the whole string | 1459 | // We couldn't find any separators, so we assume the whole string |
1460 | // is the email address | 1460 | // is the email address |
1461 | email = rawEmail; | 1461 | email = rawEmail; |
1462 | fullName = ""; | 1462 | fullName = ""; |
1463 | } | 1463 | } |
1464 | else | 1464 | else |
1465 | { | 1465 | { |
1466 | // We have a start position, try to find an end | 1466 | // We have a start position, try to find an end |
1467 | endPos = rawEmail.find(endCh, startPos+1); | 1467 | endPos = rawEmail.find(endCh, startPos+1); |
1468 | 1468 | ||
1469 | if (endPos < 0) | 1469 | if (endPos < 0) |
1470 | { | 1470 | { |
1471 | // We couldn't find the end of the email address. We can only | 1471 | // We couldn't find the end of the email address. We can only |
1472 | // assume the entire string is the email address. | 1472 | // assume the entire string is the email address. |
1473 | email = rawEmail; | 1473 | email = rawEmail; |
1474 | fullName = ""; | 1474 | fullName = ""; |
1475 | } | 1475 | } |
1476 | else | 1476 | else |
1477 | { | 1477 | { |
1478 | // We have a start and end to the email address | 1478 | // We have a start and end to the email address |
1479 | 1479 | ||
1480 | // Grab the name part | 1480 | // Grab the name part |
1481 | fullName = rawEmail.left(startPos).stripWhiteSpace(); | 1481 | fullName = rawEmail.left(startPos).stripWhiteSpace(); |
1482 | 1482 | ||
1483 | // grab the email part | 1483 | // grab the email part |
1484 | email = rawEmail.mid(startPos+1, endPos-startPos-1).stripWhiteSpace(); | 1484 | email = rawEmail.mid(startPos+1, endPos-startPos-1).stripWhiteSpace(); |
1485 | 1485 | ||
1486 | // Check that we do not have any extra characters on the end of the | 1486 | // Check that we do not have any extra characters on the end of the |
1487 | // strings | 1487 | // strings |
1488 | len = fullName.length(); | 1488 | len = fullName.length(); |
1489 | if (fullName[0]=='"' && fullName[len-1]=='"') | 1489 | if (fullName[0]=='"' && fullName[len-1]=='"') |
1490 | fullName = fullName.mid(1, len-2); | 1490 | fullName = fullName.mid(1, len-2); |
1491 | else if (fullName[0]=='<' && fullName[len-1]=='>') | 1491 | else if (fullName[0]=='<' && fullName[len-1]=='>') |
1492 | fullName = fullName.mid(1, len-2); | 1492 | fullName = fullName.mid(1, len-2); |
1493 | else if (fullName[0]=='(' && fullName[len-1]==')') | 1493 | else if (fullName[0]=='(' && fullName[len-1]==')') |
1494 | fullName = fullName.mid(1, len-2); | 1494 | fullName = fullName.mid(1, len-2); |
1495 | } | 1495 | } |
1496 | } | 1496 | } |
1497 | } | 1497 | } |
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 ) |
1522 | { | 1528 | { |
1523 | if (!a.mData) return s; | 1529 | if (!a.mData) return s; |
1524 | 1530 | ||
1525 | s << a.uid(); | 1531 | s << a.uid(); |
1526 | 1532 | ||
1527 | s << a.mData->name; | 1533 | s << a.mData->name; |
1528 | s << a.mData->formattedName; | 1534 | s << a.mData->formattedName; |
1529 | s << a.mData->familyName; | 1535 | s << a.mData->familyName; |
1530 | s << a.mData->givenName; | 1536 | s << a.mData->givenName; |
1531 | s << a.mData->additionalName; | 1537 | s << a.mData->additionalName; |
1532 | s << a.mData->prefix; | 1538 | s << a.mData->prefix; |
1533 | s << a.mData->suffix; | 1539 | s << a.mData->suffix; |
1534 | s << a.mData->nickName; | 1540 | s << a.mData->nickName; |
1535 | s << a.mData->birthday; | 1541 | s << a.mData->birthday; |
1536 | s << a.mData->mailer; | 1542 | s << a.mData->mailer; |
1537 | s << a.mData->timeZone; | 1543 | s << a.mData->timeZone; |
1538 | s << a.mData->geo; | 1544 | s << a.mData->geo; |
1539 | s << a.mData->title; | 1545 | s << a.mData->title; |
1540 | s << a.mData->role; | 1546 | s << a.mData->role; |
1541 | s << a.mData->organization; | 1547 | s << a.mData->organization; |
1542 | s << a.mData->note; | 1548 | s << a.mData->note; |
1543 | s << a.mData->productId; | 1549 | s << a.mData->productId; |
1544 | s << a.mData->revision; | 1550 | s << a.mData->revision; |
1545 | s << a.mData->sortString; | 1551 | s << a.mData->sortString; |
1546 | s << a.mData->url; | 1552 | s << a.mData->url; |
1547 | s << a.mData->secrecy; | 1553 | s << a.mData->secrecy; |
1548 | s << a.mData->logo; | 1554 | s << a.mData->logo; |
1549 | s << a.mData->photo; | 1555 | s << a.mData->photo; |
1550 | s << a.mData->sound; | 1556 | s << a.mData->sound; |
1551 | s << a.mData->agent; | 1557 | s << a.mData->agent; |
1552 | s << a.mData->phoneNumbers; | 1558 | s << a.mData->phoneNumbers; |
1553 | s << a.mData->addresses; | 1559 | s << a.mData->addresses; |
1554 | s << a.mData->emails; | 1560 | s << a.mData->emails; |
1555 | s << a.mData->categories; | 1561 | s << a.mData->categories; |
1556 | s << a.mData->custom; | 1562 | s << a.mData->custom; |
1557 | s << a.mData->keys; | 1563 | s << a.mData->keys; |
1558 | return s; | 1564 | return s; |
1559 | } | 1565 | } |
1560 | 1566 | ||
1561 | QDataStream &KABC::operator>>( QDataStream &s, Addressee &a ) | 1567 | QDataStream &KABC::operator>>( QDataStream &s, Addressee &a ) |
1562 | { | 1568 | { |
1563 | if (!a.mData) return s; | 1569 | if (!a.mData) return s; |
1564 | 1570 | ||
1565 | s >> a.mData->uid; | 1571 | s >> a.mData->uid; |
1566 | 1572 | ||
1567 | s >> a.mData->name; | 1573 | s >> a.mData->name; |
1568 | s >> a.mData->formattedName; | 1574 | s >> a.mData->formattedName; |
1569 | s >> a.mData->familyName; | 1575 | s >> a.mData->familyName; |
1570 | s >> a.mData->givenName; | 1576 | s >> a.mData->givenName; |
1571 | s >> a.mData->additionalName; | 1577 | s >> a.mData->additionalName; |
1572 | s >> a.mData->prefix; | 1578 | s >> a.mData->prefix; |
1573 | s >> a.mData->suffix; | 1579 | s >> a.mData->suffix; |
1574 | s >> a.mData->nickName; | 1580 | s >> a.mData->nickName; |
1575 | s >> a.mData->birthday; | 1581 | s >> a.mData->birthday; |
1576 | s >> a.mData->mailer; | 1582 | s >> a.mData->mailer; |
1577 | s >> a.mData->timeZone; | 1583 | s >> a.mData->timeZone; |
1578 | s >> a.mData->geo; | 1584 | s >> a.mData->geo; |
1579 | s >> a.mData->title; | 1585 | s >> a.mData->title; |
1580 | s >> a.mData->role; | 1586 | s >> a.mData->role; |
1581 | s >> a.mData->organization; | 1587 | s >> a.mData->organization; |
1582 | s >> a.mData->note; | 1588 | s >> a.mData->note; |
1583 | s >> a.mData->productId; | 1589 | s >> a.mData->productId; |
1584 | s >> a.mData->revision; | 1590 | s >> a.mData->revision; |
1585 | s >> a.mData->sortString; | 1591 | s >> a.mData->sortString; |
1586 | s >> a.mData->url; | 1592 | s >> a.mData->url; |
1587 | s >> a.mData->secrecy; | 1593 | s >> a.mData->secrecy; |
1588 | s >> a.mData->logo; | 1594 | s >> a.mData->logo; |
1589 | s >> a.mData->photo; | 1595 | s >> a.mData->photo; |
1590 | s >> a.mData->sound; | 1596 | s >> a.mData->sound; |
1591 | s >> a.mData->agent; | 1597 | s >> a.mData->agent; |
1592 | s >> a.mData->phoneNumbers; | 1598 | s >> a.mData->phoneNumbers; |
1593 | s >> a.mData->addresses; | 1599 | s >> a.mData->addresses; |
1594 | s >> a.mData->emails; | 1600 | s >> a.mData->emails; |
1595 | s >> a.mData->categories; | 1601 | s >> a.mData->categories; |
1596 | s >> a.mData->custom; | 1602 | s >> a.mData->custom; |
1597 | s >> a.mData->keys; | 1603 | s >> a.mData->keys; |
1598 | 1604 | ||
1599 | a.mData->empty = false; | 1605 | a.mData->empty = false; |
1600 | 1606 | ||
1601 | return s; | 1607 | return s; |
1602 | } | 1608 | } |
1603 | 1609 | ||
1604 | bool matchBinaryPattern( int value, int pattern ) | 1610 | bool matchBinaryPattern( int value, int pattern ) |
1605 | { | 1611 | { |
1606 | /** | 1612 | /** |
1607 | We want to match all telephonnumbers/addresses which have the bits in the | 1613 | We want to match all telephonnumbers/addresses which have the bits in the |
1608 | pattern set. More are allowed. | 1614 | pattern set. More are allowed. |
1609 | if pattern == 0 we have a special handling, then we want only those with | 1615 | if pattern == 0 we have a special handling, then we want only those with |
1610 | exactly no bit set. | 1616 | exactly no bit set. |
1611 | */ | 1617 | */ |
1612 | if ( pattern == 0 ) | 1618 | if ( pattern == 0 ) |
1613 | return ( value == 0 ); | 1619 | return ( value == 0 ); |
1614 | else | 1620 | else |
1615 | return ( pattern == ( pattern & value ) ); | 1621 | return ( pattern == ( pattern & value ) ); |
1616 | } | 1622 | } |
diff --git a/kabc/addressee.h b/kabc/addressee.h index ee98e03..393d1cc 100644 --- a/kabc/addressee.h +++ b/kabc/addressee.h | |||
@@ -667,151 +667,157 @@ class Addressee | |||
667 | */ | 667 | */ |
668 | void setKeys( const Key::List& keys); | 668 | void setKeys( const Key::List& keys); |
669 | 669 | ||
670 | /** | 670 | /** |
671 | Return list of keys with a special type. | 671 | Return list of keys with a special type. |
672 | If @p type == Key::Custom you can specify a string | 672 | If @p type == Key::Custom you can specify a string |
673 | that should match. If you leave the string empty, all custom | 673 | that should match. If you leave the string empty, all custom |
674 | keys will be returned. | 674 | keys will be returned. |
675 | */ | 675 | */ |
676 | Key::List keys( int type, QString customTypeString = QString::null ) const; | 676 | Key::List keys( int type, QString customTypeString = QString::null ) const; |
677 | 677 | ||
678 | /** | 678 | /** |
679 | Return key with the given id. | 679 | Return key with the given id. |
680 | */ | 680 | */ |
681 | Key findKey( const QString &id ) const; | 681 | Key findKey( const QString &id ) const; |
682 | 682 | ||
683 | /** | 683 | /** |
684 | Insert an address. If an address with the same id already exists | 684 | Insert an address. If an address with the same id already exists |
685 | in this addressee it is not duplicated. | 685 | in this addressee it is not duplicated. |
686 | */ | 686 | */ |
687 | void insertAddress( const Address &address ); | 687 | void insertAddress( const Address &address ); |
688 | 688 | ||
689 | /** | 689 | /** |
690 | Remove address. If no address with the given id exists for this | 690 | Remove address. If no address with the given id exists for this |
691 | addresse nothing happens. | 691 | addresse nothing happens. |
692 | */ | 692 | */ |
693 | void removeAddress( const Address &address ); | 693 | void removeAddress( const Address &address ); |
694 | 694 | ||
695 | /** | 695 | /** |
696 | Return address, which matches the given type. | 696 | Return address, which matches the given type. |
697 | */ | 697 | */ |
698 | Address address( int type ) const; | 698 | Address address( int type ) const; |
699 | 699 | ||
700 | /** | 700 | /** |
701 | Return list of all addresses. | 701 | Return list of all addresses. |
702 | */ | 702 | */ |
703 | Address::List addresses() const; | 703 | Address::List addresses() const; |
704 | 704 | ||
705 | /** | 705 | /** |
706 | Return list of addresses with a special type. | 706 | Return list of addresses with a special type. |
707 | */ | 707 | */ |
708 | Address::List addresses( int type ) const; | 708 | Address::List addresses( int type ) const; |
709 | 709 | ||
710 | /** | 710 | /** |
711 | Return address with the given id. | 711 | Return address with the given id. |
712 | */ | 712 | */ |
713 | Address findAddress( const QString &id ) const; | 713 | Address findAddress( const QString &id ) const; |
714 | 714 | ||
715 | /** | 715 | /** |
716 | Insert category. If the category already exists it is not duplicated. | 716 | Insert category. If the category already exists it is not duplicated. |
717 | */ | 717 | */ |
718 | void insertCategory( const QString & ); | 718 | void insertCategory( const QString & ); |
719 | 719 | ||
720 | /** | 720 | /** |
721 | Remove category. | 721 | Remove category. |
722 | */ | 722 | */ |
723 | void removeCategory( const QString & ); | 723 | void removeCategory( const QString & ); |
724 | 724 | ||
725 | /** | 725 | /** |
726 | Return, if addressee has the given category. | 726 | Return, if addressee has the given category. |
727 | */ | 727 | */ |
728 | bool hasCategory( const QString & ) const; | 728 | bool hasCategory( const QString & ) const; |
729 | 729 | ||
730 | /** | 730 | /** |
731 | Set categories to given value. | 731 | Set categories to given value. |
732 | */ | 732 | */ |
733 | void setCategories( const QStringList & ); | 733 | void setCategories( const QStringList & ); |
734 | 734 | ||
735 | /** | 735 | /** |
736 | Return list of all set categories. | 736 | Return list of all set categories. |
737 | */ | 737 | */ |
738 | QStringList categories() const; | 738 | QStringList categories() const; |
739 | 739 | ||
740 | /** | 740 | /** |
741 | Insert custom entry. The entry is identified by the name of the inserting | 741 | Insert custom entry. The entry is identified by the name of the inserting |
742 | application and a unique name. If an entry with the given app and name | 742 | application and a unique name. If an entry with the given app and name |
743 | already exists its value is replaced with the new given value. | 743 | already exists its value is replaced with the new given value. |
744 | */ | 744 | */ |
745 | void insertCustom( const QString &app, const QString &name, | 745 | void insertCustom( const QString &app, const QString &name, |
746 | const QString &value ); | 746 | const QString &value ); |
747 | 747 | ||
748 | /** | 748 | /** |
749 | Remove custom entry. | 749 | Remove custom entry. |
750 | */ | 750 | */ |
751 | void removeCustom( const QString &app, const QString &name ); | 751 | void removeCustom( const QString &app, const QString &name ); |
752 | 752 | ||
753 | /** | 753 | /** |
754 | Return value of custom entry, identified by app and entry name. | 754 | Return value of custom entry, identified by app and entry name. |
755 | */ | 755 | */ |
756 | QString custom( const QString &app, const QString &name ) const; | 756 | QString custom( const QString &app, const QString &name ) const; |
757 | 757 | ||
758 | /** | 758 | /** |
759 | Set all custom entries. | 759 | Set all custom entries. |
760 | */ | 760 | */ |
761 | void setCustoms( const QStringList & ); | 761 | void setCustoms( const QStringList & ); |
762 | 762 | ||
763 | /** | 763 | /** |
764 | Return list of all custom entries. | 764 | Return list of all custom entries. |
765 | */ | 765 | */ |
766 | QStringList customs() const; | 766 | QStringList customs() const; |
767 | 767 | ||
768 | /** | 768 | /** |
769 | Parse full email address. The result is given back in fullName and email. | 769 | Parse full email address. The result is given back in fullName and email. |
770 | */ | 770 | */ |
771 | static void parseEmailAddress( const QString &rawEmail, QString &fullName, | 771 | static void parseEmailAddress( const QString &rawEmail, QString &fullName, |
772 | QString &email ); | 772 | QString &email ); |
773 | 773 | ||
774 | /** | 774 | /** |
775 | Debug output. | 775 | Debug output. |
776 | */ | 776 | */ |
777 | void dump() const; | 777 | void dump() const; |
778 | 778 | ||
779 | /** | 779 | /** |
780 | Returns string representation of the addressee. | 780 | Returns string representation of the addressee. |
781 | */ | 781 | */ |
782 | QString asString() const; | 782 | QString asString() const; |
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(); |
807 | 813 | ||
808 | struct AddresseeData; | 814 | struct AddresseeData; |
809 | mutable KSharedPtr<AddresseeData> mData; | 815 | mutable KSharedPtr<AddresseeData> mData; |
810 | }; | 816 | }; |
811 | 817 | ||
812 | QDataStream &operator<<( QDataStream &, const Addressee & ); | 818 | QDataStream &operator<<( QDataStream &, const Addressee & ); |
813 | QDataStream &operator>>( QDataStream &, Addressee & ); | 819 | QDataStream &operator>>( QDataStream &, Addressee & ); |
814 | 820 | ||
815 | } | 821 | } |
816 | 822 | ||
817 | #endif | 823 | #endif |
diff --git a/kabc/field.cpp b/kabc/field.cpp index 41bbfde..bc2e176 100644 --- a/kabc/field.cpp +++ b/kabc/field.cpp | |||
@@ -1,550 +1,566 @@ | |||
1 | /*** Warning! This file has been generated by the script makeaddressee ***/ | 1 | /*** Warning! This file has been generated by the script makeaddressee ***/ |
2 | /* | 2 | /* |
3 | This file is part of libkabc. | 3 | This file is part of libkabc. |
4 | Copyright (c) 2002 Cornelius Schumacher <schumacher@kde.org> | 4 | Copyright (c) 2002 Cornelius Schumacher <schumacher@kde.org> |
5 | 5 | ||
6 | This library is free software; you can redistribute it and/or | 6 | This library is free software; you can redistribute it and/or |
7 | modify it under the terms of the GNU Library General Public | 7 | modify it under the terms of the GNU Library General Public |
8 | License as published by the Free Software Foundation; either | 8 | License as published by the Free Software Foundation; either |
9 | version 2 of the License, or (at your option) any later version. | 9 | version 2 of the License, or (at your option) any later version. |
10 | 10 | ||
11 | This library is distributed in the hope that it will be useful, | 11 | This library is distributed in the hope that it will be useful, |
12 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 12 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
13 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 13 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
14 | Library General Public License for more details. | 14 | Library General Public License for more details. |
15 | 15 | ||
16 | You should have received a copy of the GNU Library General Public License | 16 | You should have received a copy of the GNU Library General Public License |
17 | along with this library; see the file COPYING.LIB. If not, write to | 17 | along with this library; see the file COPYING.LIB. If not, write to |
18 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | 18 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
19 | Boston, MA 02111-1307, USA. | 19 | Boston, MA 02111-1307, USA. |
20 | */ | 20 | */ |
21 | 21 | ||
22 | /* | 22 | /* |
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 ) {} |
47 | 48 | ||
48 | enum FieldId | 49 | enum FieldId |
49 | { | 50 | { |
50 | CustomField, | 51 | CustomField, |
51 | FormattedName, | 52 | FormattedName, |
52 | FamilyName, | 53 | FamilyName, |
53 | GivenName, | 54 | GivenName, |
54 | AdditionalName, | 55 | AdditionalName, |
55 | Prefix, | 56 | Prefix, |
56 | Suffix, | 57 | Suffix, |
57 | NickName, | 58 | NickName, |
58 | Birthday, | 59 | Birthday, |
59 | HomeAddressStreet, | 60 | HomeAddressStreet, |
60 | HomeAddressLocality, | 61 | HomeAddressLocality, |
61 | HomeAddressRegion, | 62 | HomeAddressRegion, |
62 | HomeAddressPostalCode, | 63 | HomeAddressPostalCode, |
63 | HomeAddressCountry, | 64 | HomeAddressCountry, |
64 | HomeAddressLabel, | 65 | HomeAddressLabel, |
65 | BusinessAddressStreet, | 66 | BusinessAddressStreet, |
66 | BusinessAddressLocality, | 67 | BusinessAddressLocality, |
67 | BusinessAddressRegion, | 68 | BusinessAddressRegion, |
68 | BusinessAddressPostalCode, | 69 | BusinessAddressPostalCode, |
69 | BusinessAddressCountry, | 70 | BusinessAddressCountry, |
70 | BusinessAddressLabel, | 71 | BusinessAddressLabel, |
71 | HomePhone, | 72 | HomePhone, |
72 | BusinessPhone, | 73 | BusinessPhone, |
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; |
98 | 100 | ||
99 | QString mLabel; | 101 | QString mLabel; |
100 | QString mKey; | 102 | QString mKey; |
101 | QString mApp; | 103 | QString mApp; |
102 | }; | 104 | }; |
103 | 105 | ||
104 | 106 | ||
105 | Field::List Field::mAllFields; | 107 | Field::List Field::mAllFields; |
106 | Field::List Field::mDefaultFields; | 108 | Field::List Field::mDefaultFields; |
107 | Field::List Field::mCustomFields; | 109 | Field::List Field::mCustomFields; |
108 | 110 | ||
109 | 111 | ||
110 | Field::Field( FieldImpl *impl ) | 112 | Field::Field( FieldImpl *impl ) |
111 | { | 113 | { |
112 | mImpl = impl; | 114 | mImpl = impl; |
113 | } | 115 | } |
114 | 116 | ||
115 | Field::~Field() | 117 | Field::~Field() |
116 | { | 118 | { |
117 | delete mImpl; | 119 | delete mImpl; |
118 | } | 120 | } |
119 | 121 | ||
120 | QString Field::label() | 122 | QString Field::label() |
121 | { | 123 | { |
122 | switch ( mImpl->fieldId() ) { | 124 | switch ( mImpl->fieldId() ) { |
123 | case FieldImpl::FormattedName: | 125 | case FieldImpl::FormattedName: |
124 | return Addressee::formattedNameLabel(); | 126 | return Addressee::formattedNameLabel(); |
125 | case FieldImpl::FamilyName: | 127 | case FieldImpl::FamilyName: |
126 | return Addressee::familyNameLabel(); | 128 | return Addressee::familyNameLabel(); |
127 | case FieldImpl::GivenName: | 129 | case FieldImpl::GivenName: |
128 | return Addressee::givenNameLabel(); | 130 | return Addressee::givenNameLabel(); |
129 | case FieldImpl::AdditionalName: | 131 | case FieldImpl::AdditionalName: |
130 | return Addressee::additionalNameLabel(); | 132 | return Addressee::additionalNameLabel(); |
131 | case FieldImpl::Prefix: | 133 | case FieldImpl::Prefix: |
132 | return Addressee::prefixLabel(); | 134 | return Addressee::prefixLabel(); |
133 | case FieldImpl::Suffix: | 135 | case FieldImpl::Suffix: |
134 | return Addressee::suffixLabel(); | 136 | return Addressee::suffixLabel(); |
135 | case FieldImpl::NickName: | 137 | case FieldImpl::NickName: |
136 | return Addressee::nickNameLabel(); | 138 | return Addressee::nickNameLabel(); |
137 | case FieldImpl::Birthday: | 139 | case FieldImpl::Birthday: |
138 | return Addressee::birthdayLabel(); | 140 | return Addressee::birthdayLabel(); |
139 | case FieldImpl::HomeAddressStreet: | 141 | case FieldImpl::HomeAddressStreet: |
140 | return Addressee::homeAddressStreetLabel(); | 142 | return Addressee::homeAddressStreetLabel(); |
141 | case FieldImpl::HomeAddressLocality: | 143 | case FieldImpl::HomeAddressLocality: |
142 | return Addressee::homeAddressLocalityLabel(); | 144 | return Addressee::homeAddressLocalityLabel(); |
143 | case FieldImpl::HomeAddressRegion: | 145 | case FieldImpl::HomeAddressRegion: |
144 | return Addressee::homeAddressRegionLabel(); | 146 | return Addressee::homeAddressRegionLabel(); |
145 | case FieldImpl::HomeAddressPostalCode: | 147 | case FieldImpl::HomeAddressPostalCode: |
146 | return Addressee::homeAddressPostalCodeLabel(); | 148 | return Addressee::homeAddressPostalCodeLabel(); |
147 | case FieldImpl::HomeAddressCountry: | 149 | case FieldImpl::HomeAddressCountry: |
148 | return Addressee::homeAddressCountryLabel(); | 150 | return Addressee::homeAddressCountryLabel(); |
149 | case FieldImpl::HomeAddressLabel: | 151 | case FieldImpl::HomeAddressLabel: |
150 | return Addressee::homeAddressLabelLabel(); | 152 | return Addressee::homeAddressLabelLabel(); |
151 | case FieldImpl::BusinessAddressStreet: | 153 | case FieldImpl::BusinessAddressStreet: |
152 | return Addressee::businessAddressStreetLabel(); | 154 | return Addressee::businessAddressStreetLabel(); |
153 | case FieldImpl::BusinessAddressLocality: | 155 | case FieldImpl::BusinessAddressLocality: |
154 | return Addressee::businessAddressLocalityLabel(); | 156 | return Addressee::businessAddressLocalityLabel(); |
155 | case FieldImpl::BusinessAddressRegion: | 157 | case FieldImpl::BusinessAddressRegion: |
156 | return Addressee::businessAddressRegionLabel(); | 158 | return Addressee::businessAddressRegionLabel(); |
157 | case FieldImpl::BusinessAddressPostalCode: | 159 | case FieldImpl::BusinessAddressPostalCode: |
158 | return Addressee::businessAddressPostalCodeLabel(); | 160 | return Addressee::businessAddressPostalCodeLabel(); |
159 | case FieldImpl::BusinessAddressCountry: | 161 | case FieldImpl::BusinessAddressCountry: |
160 | return Addressee::businessAddressCountryLabel(); | 162 | return Addressee::businessAddressCountryLabel(); |
161 | case FieldImpl::BusinessAddressLabel: | 163 | case FieldImpl::BusinessAddressLabel: |
162 | return Addressee::businessAddressLabelLabel(); | 164 | return Addressee::businessAddressLabelLabel(); |
163 | case FieldImpl::HomePhone: | 165 | case FieldImpl::HomePhone: |
164 | return Addressee::homePhoneLabel(); | 166 | return Addressee::homePhoneLabel(); |
165 | case FieldImpl::BusinessPhone: | 167 | case FieldImpl::BusinessPhone: |
166 | return Addressee::businessPhoneLabel(); | 168 | return Addressee::businessPhoneLabel(); |
167 | case FieldImpl::MobilePhone: | 169 | case FieldImpl::MobilePhone: |
168 | return Addressee::mobilePhoneLabel(); | 170 | return Addressee::mobilePhoneLabel(); |
169 | case FieldImpl::HomeFax: | 171 | case FieldImpl::HomeFax: |
170 | return Addressee::homeFaxLabel(); | 172 | return Addressee::homeFaxLabel(); |
171 | case FieldImpl::BusinessFax: | 173 | case FieldImpl::BusinessFax: |
172 | return Addressee::businessFaxLabel(); | 174 | return Addressee::businessFaxLabel(); |
173 | case FieldImpl::CarPhone: | 175 | case FieldImpl::CarPhone: |
174 | return Addressee::carPhoneLabel(); | 176 | return Addressee::carPhoneLabel(); |
175 | case FieldImpl::Isdn: | 177 | case FieldImpl::Isdn: |
176 | return Addressee::isdnLabel(); | 178 | return Addressee::isdnLabel(); |
177 | case FieldImpl::Pager: | 179 | case FieldImpl::Pager: |
178 | return Addressee::pagerLabel(); | 180 | return Addressee::pagerLabel(); |
179 | case FieldImpl::Email: | 181 | case FieldImpl::Email: |
180 | return Addressee::emailLabel(); | 182 | return Addressee::emailLabel(); |
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 | ||
205 | QString Field::categoryLabel( int category ) | 209 | QString Field::categoryLabel( int category ) |
206 | { | 210 | { |
207 | switch ( category ) { | 211 | switch ( category ) { |
208 | case All: | 212 | case All: |
209 | return i18n("All"); | 213 | return i18n("All"); |
210 | case Frequent: | 214 | case Frequent: |
211 | return i18n("Frequent"); | 215 | return i18n("Frequent"); |
212 | case Address: | 216 | case Address: |
213 | return i18n("Address"); | 217 | return i18n("Address"); |
214 | case Email: | 218 | case Email: |
215 | return i18n("Email"); | 219 | return i18n("Email"); |
216 | case Personal: | 220 | case Personal: |
217 | return i18n("Personal"); | 221 | return i18n("Personal"); |
218 | case Organization: | 222 | case Organization: |
219 | return i18n("Organization"); | 223 | return i18n("Organization"); |
220 | case CustomCategory: | 224 | case CustomCategory: |
221 | return i18n("Custom"); | 225 | return i18n("Custom"); |
222 | default: | 226 | default: |
223 | return i18n("Undefined"); | 227 | return i18n("Undefined"); |
224 | } | 228 | } |
225 | } | 229 | } |
226 | 230 | ||
227 | QString Field::value( const KABC::Addressee &a ) | 231 | QString Field::value( const KABC::Addressee &a ) |
228 | { | 232 | { |
229 | switch ( mImpl->fieldId() ) { | 233 | switch ( mImpl->fieldId() ) { |
230 | case FieldImpl::FormattedName: | 234 | case FieldImpl::FormattedName: |
231 | return a.formattedName(); | 235 | return a.formattedName(); |
232 | case FieldImpl::FamilyName: | 236 | case FieldImpl::FamilyName: |
233 | return a.familyName(); | 237 | return a.familyName(); |
234 | case FieldImpl::GivenName: | 238 | case FieldImpl::GivenName: |
235 | return a.givenName(); | 239 | return a.givenName(); |
236 | case FieldImpl::AdditionalName: | 240 | case FieldImpl::AdditionalName: |
237 | return a.additionalName(); | 241 | return a.additionalName(); |
238 | case FieldImpl::Prefix: | 242 | case FieldImpl::Prefix: |
239 | return a.prefix(); | 243 | return a.prefix(); |
240 | case FieldImpl::Suffix: | 244 | case FieldImpl::Suffix: |
241 | return a.suffix(); | 245 | return a.suffix(); |
242 | case FieldImpl::NickName: | 246 | case FieldImpl::NickName: |
243 | return a.nickName(); | 247 | return a.nickName(); |
244 | case FieldImpl::Mailer: | 248 | case FieldImpl::Mailer: |
245 | return a.mailer(); | 249 | return a.mailer(); |
246 | case FieldImpl::Title: | 250 | case FieldImpl::Title: |
247 | return a.title(); | 251 | return a.title(); |
248 | case FieldImpl::Role: | 252 | case FieldImpl::Role: |
249 | return a.role(); | 253 | return a.role(); |
250 | case FieldImpl::Organization: | 254 | case FieldImpl::Organization: |
251 | return a.organization(); | 255 | return a.organization(); |
252 | case FieldImpl::Note: | 256 | case FieldImpl::Note: |
253 | return a.note(); | 257 | return a.note(); |
254 | case FieldImpl::Email: | 258 | case FieldImpl::Email: |
255 | return a.preferredEmail(); | 259 | return a.preferredEmail(); |
256 | case FieldImpl::Birthday: | 260 | case FieldImpl::Birthday: |
257 | if ( a.birthday().isValid() ) { | 261 | if ( a.birthday().isValid() ) { |
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(); |
282 | case FieldImpl::Isdn: | 289 | case FieldImpl::Isdn: |
283 | return a.phoneNumber( PhoneNumber::Isdn ).number(); | 290 | return a.phoneNumber( PhoneNumber::Isdn ).number(); |
284 | case FieldImpl::Pager: | 291 | case FieldImpl::Pager: |
285 | return a.phoneNumber( PhoneNumber::Pager ).number(); | 292 | return a.phoneNumber( PhoneNumber::Pager ).number(); |
286 | case FieldImpl::HomeAddressStreet: | 293 | case FieldImpl::HomeAddressStreet: |
287 | return a.address( Address::Home ).street(); | 294 | return a.address( Address::Home ).street(); |
288 | case FieldImpl::HomeAddressLocality: | 295 | case FieldImpl::HomeAddressLocality: |
289 | return a.address( Address::Home ).locality(); | 296 | return a.address( Address::Home ).locality(); |
290 | case FieldImpl::HomeAddressRegion: | 297 | case FieldImpl::HomeAddressRegion: |
291 | return a.address( Address::Home ).region(); | 298 | return a.address( Address::Home ).region(); |
292 | case FieldImpl::HomeAddressPostalCode: | 299 | case FieldImpl::HomeAddressPostalCode: |
293 | return a.address( Address::Home ).postalCode(); | 300 | return a.address( Address::Home ).postalCode(); |
294 | case FieldImpl::HomeAddressCountry: | 301 | case FieldImpl::HomeAddressCountry: |
295 | return a.address( Address::Home ).country(); | 302 | return a.address( Address::Home ).country(); |
296 | case FieldImpl::BusinessAddressStreet: | 303 | case FieldImpl::BusinessAddressStreet: |
297 | return a.address( Address::Work ).street(); | 304 | return a.address( Address::Work ).street(); |
298 | case FieldImpl::BusinessAddressLocality: | 305 | case FieldImpl::BusinessAddressLocality: |
299 | return a.address( Address::Work ).locality(); | 306 | return a.address( Address::Work ).locality(); |
300 | case FieldImpl::BusinessAddressRegion: | 307 | case FieldImpl::BusinessAddressRegion: |
301 | return a.address( Address::Work ).region(); | 308 | return a.address( Address::Work ).region(); |
302 | case FieldImpl::BusinessAddressPostalCode: | 309 | case FieldImpl::BusinessAddressPostalCode: |
303 | return a.address( Address::Work ).postalCode(); | 310 | return a.address( Address::Work ).postalCode(); |
304 | case FieldImpl::BusinessAddressCountry: | 311 | case FieldImpl::BusinessAddressCountry: |
305 | return a.address( Address::Work ).country(); | 312 | return a.address( Address::Work ).country(); |
306 | case FieldImpl::CustomField: | 313 | case FieldImpl::CustomField: |
307 | return a.custom( mImpl->app(), mImpl->key() ); | 314 | return a.custom( mImpl->app(), mImpl->key() ); |
308 | default: | 315 | default: |
309 | return QString::null; | 316 | return QString::null; |
310 | } | 317 | } |
311 | } | 318 | } |
312 | 319 | ||
313 | bool Field::setValue( KABC::Addressee &a, const QString &value ) | 320 | bool Field::setValue( KABC::Addressee &a, const QString &value ) |
314 | { | 321 | { |
315 | switch ( mImpl->fieldId() ) { | 322 | switch ( mImpl->fieldId() ) { |
316 | case FieldImpl::FormattedName: | 323 | case FieldImpl::FormattedName: |
317 | a.setFormattedName( value ); | 324 | a.setFormattedName( value ); |
318 | return true; | 325 | return true; |
319 | case FieldImpl::FamilyName: | 326 | case FieldImpl::FamilyName: |
320 | a.setFamilyName( value ); | 327 | a.setFamilyName( value ); |
321 | return true; | 328 | return true; |
322 | case FieldImpl::GivenName: | 329 | case FieldImpl::GivenName: |
323 | a.setGivenName( value ); | 330 | a.setGivenName( value ); |
324 | return true; | 331 | return true; |
325 | case FieldImpl::AdditionalName: | 332 | case FieldImpl::AdditionalName: |
326 | a.setAdditionalName( value ); | 333 | a.setAdditionalName( value ); |
327 | return true; | 334 | return true; |
328 | case FieldImpl::Prefix: | 335 | case FieldImpl::Prefix: |
329 | a.setPrefix( value ); | 336 | a.setPrefix( value ); |
330 | return true; | 337 | return true; |
331 | case FieldImpl::Suffix: | 338 | case FieldImpl::Suffix: |
332 | a.setSuffix( value ); | 339 | a.setSuffix( value ); |
333 | return true; | 340 | return true; |
334 | case FieldImpl::NickName: | 341 | case FieldImpl::NickName: |
335 | a.setNickName( value ); | 342 | a.setNickName( value ); |
336 | return true; | 343 | return true; |
337 | case FieldImpl::Mailer: | 344 | case FieldImpl::Mailer: |
338 | a.setMailer( value ); | 345 | a.setMailer( value ); |
339 | return true; | 346 | return true; |
340 | case FieldImpl::Title: | 347 | case FieldImpl::Title: |
341 | a.setTitle( value ); | 348 | a.setTitle( value ); |
342 | return true; | 349 | return true; |
343 | case FieldImpl::Role: | 350 | case FieldImpl::Role: |
344 | a.setRole( value ); | 351 | a.setRole( value ); |
345 | return true; | 352 | return true; |
346 | case FieldImpl::Organization: | 353 | case FieldImpl::Organization: |
347 | a.setOrganization( value ); | 354 | a.setOrganization( value ); |
348 | return true; | 355 | return true; |
349 | case FieldImpl::Note: | 356 | case FieldImpl::Note: |
350 | a.setNote( value ); | 357 | a.setNote( 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 | { |
375 | if ( mAllFields.isEmpty() ) { | 384 | if ( mAllFields.isEmpty() ) { |
376 | createField( FieldImpl::FormattedName, Frequent ); | 385 | createField( FieldImpl::FormattedName, Frequent ); |
377 | createField( FieldImpl::FamilyName, Frequent ); | 386 | createField( FieldImpl::FamilyName, Frequent ); |
378 | createField( FieldImpl::GivenName, Frequent ); | 387 | createField( FieldImpl::GivenName, Frequent ); |
379 | createField( FieldImpl::AdditionalName ); | 388 | createField( FieldImpl::AdditionalName ); |
380 | createField( FieldImpl::Prefix ); | 389 | createField( FieldImpl::Prefix ); |
381 | createField( FieldImpl::Suffix ); | 390 | createField( FieldImpl::Suffix ); |
382 | createField( FieldImpl::NickName, Personal ); | 391 | createField( FieldImpl::NickName, Personal ); |
383 | createField( FieldImpl::Birthday, Personal ); | 392 | createField( FieldImpl::Birthday, Personal ); |
384 | createField( FieldImpl::HomeAddressStreet, Address|Personal ); | 393 | createField( FieldImpl::HomeAddressStreet, Address|Personal ); |
385 | createField( FieldImpl::HomeAddressLocality, Address|Personal ); | 394 | createField( FieldImpl::HomeAddressLocality, Address|Personal ); |
386 | createField( FieldImpl::HomeAddressRegion, Address|Personal ); | 395 | createField( FieldImpl::HomeAddressRegion, Address|Personal ); |
387 | createField( FieldImpl::HomeAddressPostalCode, Address|Personal ); | 396 | createField( FieldImpl::HomeAddressPostalCode, Address|Personal ); |
388 | createField( FieldImpl::HomeAddressCountry, Address|Personal ); | 397 | createField( FieldImpl::HomeAddressCountry, Address|Personal ); |
389 | createField( FieldImpl::HomeAddressLabel, Address|Personal ); | 398 | createField( FieldImpl::HomeAddressLabel, Address|Personal ); |
390 | createField( FieldImpl::BusinessAddressStreet, Address|Organization ); | 399 | createField( FieldImpl::BusinessAddressStreet, Address|Organization ); |
391 | createField( FieldImpl::BusinessAddressLocality, Address|Organization ); | 400 | createField( FieldImpl::BusinessAddressLocality, Address|Organization ); |
392 | createField( FieldImpl::BusinessAddressRegion, Address|Organization ); | 401 | createField( FieldImpl::BusinessAddressRegion, Address|Organization ); |
393 | createField( FieldImpl::BusinessAddressPostalCode, Address|Organization ); | 402 | createField( FieldImpl::BusinessAddressPostalCode, Address|Organization ); |
394 | createField( FieldImpl::BusinessAddressCountry, Address|Organization ); | 403 | createField( FieldImpl::BusinessAddressCountry, Address|Organization ); |
395 | createField( FieldImpl::BusinessAddressLabel, Address|Organization ); | 404 | createField( FieldImpl::BusinessAddressLabel, Address|Organization ); |
396 | createField( FieldImpl::HomePhone, Personal|Frequent ); | 405 | createField( FieldImpl::HomePhone, Personal|Frequent ); |
397 | createField( FieldImpl::BusinessPhone, Organization|Frequent ); | 406 | createField( FieldImpl::BusinessPhone, Organization|Frequent ); |
398 | createField( FieldImpl::MobilePhone, Frequent ); | 407 | createField( FieldImpl::MobilePhone, Frequent ); |
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 | } |
423 | 433 | ||
424 | return mDefaultFields; | 434 | return mDefaultFields; |
425 | } | 435 | } |
426 | 436 | ||
427 | void Field::createField( int id, int category ) | 437 | void Field::createField( int id, int category ) |
428 | { | 438 | { |
429 | mAllFields.append( new Field( new FieldImpl( id, category ) ) ); | 439 | mAllFields.append( new Field( new FieldImpl( id, category ) ) ); |
430 | } | 440 | } |
431 | 441 | ||
432 | void Field::createDefaultField( int id, int category ) | 442 | void Field::createDefaultField( int id, int category ) |
433 | { | 443 | { |
434 | mDefaultFields.append( new Field( new FieldImpl( id, category ) ) ); | 444 | mDefaultFields.append( new Field( new FieldImpl( id, category ) ) ); |
435 | } | 445 | } |
436 | 446 | ||
437 | void Field::deleteFields() | 447 | void Field::deleteFields() |
438 | { | 448 | { |
439 | Field::List::ConstIterator it; | 449 | Field::List::ConstIterator it; |
440 | 450 | ||
441 | for( it = mAllFields.begin(); it != mAllFields.end(); ++it ) { | 451 | for( it = mAllFields.begin(); it != mAllFields.end(); ++it ) { |
442 | delete (*it); | 452 | delete (*it); |
443 | } | 453 | } |
444 | mAllFields.clear(); | 454 | mAllFields.clear(); |
445 | 455 | ||
446 | for( it = mDefaultFields.begin(); it != mDefaultFields.end(); ++it ) { | 456 | for( it = mDefaultFields.begin(); it != mDefaultFields.end(); ++it ) { |
447 | delete (*it); | 457 | delete (*it); |
448 | } | 458 | } |
449 | mDefaultFields.clear(); | 459 | mDefaultFields.clear(); |
450 | 460 | ||
451 | for( it = mCustomFields.begin(); it != mCustomFields.end(); ++it ) { | 461 | for( it = mCustomFields.begin(); it != mCustomFields.end(); ++it ) { |
452 | delete (*it); | 462 | delete (*it); |
453 | } | 463 | } |
454 | mCustomFields.clear(); | 464 | mCustomFields.clear(); |
455 | } | 465 | } |
456 | 466 | ||
457 | void Field::saveFields( const QString &identifier, | 467 | void Field::saveFields( const QString &identifier, |
458 | const Field::List &fields ) | 468 | const Field::List &fields ) |
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 ], |
520 | customEntry[ 1 ], customEntry[ 2 ] ); | 533 | customEntry[ 1 ], customEntry[ 2 ] ); |
521 | } else { | 534 | } else { |
522 | f = new FieldImpl( *it ); | 535 | f = new FieldImpl( *it ); |
523 | } | 536 | } |
524 | fields.append( new Field( f ) ); | 537 | fields.append( new Field( f ) ); |
525 | } | 538 | } |
526 | 539 | ||
527 | return fields; | 540 | return fields; |
528 | } | 541 | } |
529 | 542 | ||
530 | bool Field::equals( Field *field ) | 543 | bool Field::equals( Field *field ) |
531 | { | 544 | { |
532 | bool sameId = ( mImpl->fieldId() == field->mImpl->fieldId() ); | 545 | bool sameId = ( mImpl->fieldId() == field->mImpl->fieldId() ); |
533 | 546 | ||
534 | if ( !sameId ) return false; | 547 | if ( !sameId ) return false; |
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 | } |