author | eilers <eilers> | 2003-02-18 11:55:59 (UTC) |
---|---|---|
committer | eilers <eilers> | 2003-02-18 11:55:59 (UTC) |
commit | 00e9f7731c19604a8e79df9e935ec833fc1937f8 (patch) (unidiff) | |
tree | 7bf9b8230832e2138af7e73740b28eafc4c33101 | |
parent | 065f26b161f6df269cfbf9c75751c09453350995 (diff) | |
download | opie-00e9f7731c19604a8e79df9e935ec833fc1937f8.zip opie-00e9f7731c19604a8e79df9e935ec833fc1937f8.tar.gz opie-00e9f7731c19604a8e79df9e935ec833fc1937f8.tar.bz2 |
Fixing categoryNames in opimrecord which was just checking for Todo List
Now we get the categories in addressbook, too !
-rw-r--r-- | libopie/pim/ocontact.cpp | 4 | ||||
-rw-r--r-- | libopie/pim/opimrecord.cpp | 4 | ||||
-rw-r--r-- | libopie/pim/opimrecord.h | 2 | ||||
-rw-r--r-- | libopie/pim/otodo.cpp | 2 | ||||
-rw-r--r-- | libopie2/opiepim/core/opimrecord.cpp | 4 | ||||
-rw-r--r-- | libopie2/opiepim/core/opimrecord.h | 2 | ||||
-rw-r--r-- | libopie2/opiepim/ocontact.cpp | 4 | ||||
-rw-r--r-- | libopie2/opiepim/otodo.cpp | 2 |
8 files changed, 12 insertions, 12 deletions
diff --git a/libopie/pim/ocontact.cpp b/libopie/pim/ocontact.cpp index 178559b..9cccfc8 100644 --- a/libopie/pim/ocontact.cpp +++ b/libopie/pim/ocontact.cpp | |||
@@ -566,131 +566,131 @@ QString OContact::toRichText() const | |||
566 | str = homeFax(); | 566 | str = homeFax(); |
567 | if ( !str.isEmpty() ){ | 567 | if ( !str.isEmpty() ){ |
568 | text += "<b>" + QObject::tr("Home Fax: ") + "</b>" | 568 | text += "<b>" + QObject::tr("Home Fax: ") + "</b>" |
569 | + Qtopia::escapeString(str) + "<br>"; | 569 | + Qtopia::escapeString(str) + "<br>"; |
570 | marker = true; | 570 | marker = true; |
571 | } | 571 | } |
572 | str = homeMobile(); | 572 | str = homeMobile(); |
573 | if ( !str.isEmpty() ){ | 573 | if ( !str.isEmpty() ){ |
574 | text += "<b>" + QObject::tr("Home Mobile: ") + "</b>" | 574 | text += "<b>" + QObject::tr("Home Mobile: ") + "</b>" |
575 | + Qtopia::escapeString(str) + "<br>"; | 575 | + Qtopia::escapeString(str) + "<br>"; |
576 | marker = true; | 576 | marker = true; |
577 | } | 577 | } |
578 | 578 | ||
579 | if ( marker ) | 579 | if ( marker ) |
580 | text += "<br><hr><br>"; | 580 | text += "<br><hr><br>"; |
581 | // the others... | 581 | // the others... |
582 | str = emails(); | 582 | str = emails(); |
583 | if ( !str.isEmpty() && ( str != defEmail ) ) | 583 | if ( !str.isEmpty() && ( str != defEmail ) ) |
584 | text += "<b>" + QObject::tr("All Emails: ") + "</b>" | 584 | text += "<b>" + QObject::tr("All Emails: ") + "</b>" |
585 | + Qtopia::escapeString(str) + "<br>"; | 585 | + Qtopia::escapeString(str) + "<br>"; |
586 | str = profession(); | 586 | str = profession(); |
587 | if ( !str.isEmpty() ) | 587 | if ( !str.isEmpty() ) |
588 | text += "<b>" + QObject::tr("Profession: ") + "</b>" | 588 | text += "<b>" + QObject::tr("Profession: ") + "</b>" |
589 | + Qtopia::escapeString(str) + "<br>"; | 589 | + Qtopia::escapeString(str) + "<br>"; |
590 | str = assistant(); | 590 | str = assistant(); |
591 | if ( !str.isEmpty() ) | 591 | if ( !str.isEmpty() ) |
592 | text += "<b>" + QObject::tr("Assistant: ") + "</b>" | 592 | text += "<b>" + QObject::tr("Assistant: ") + "</b>" |
593 | + Qtopia::escapeString(str) + "<br>"; | 593 | + Qtopia::escapeString(str) + "<br>"; |
594 | str = manager(); | 594 | str = manager(); |
595 | if ( !str.isEmpty() ) | 595 | if ( !str.isEmpty() ) |
596 | text += "<b>" + QObject::tr("Manager: ") + "</b>" | 596 | text += "<b>" + QObject::tr("Manager: ") + "</b>" |
597 | + Qtopia::escapeString(str) + "<br>"; | 597 | + Qtopia::escapeString(str) + "<br>"; |
598 | str = gender(); | 598 | str = gender(); |
599 | if ( !str.isEmpty() && str.toInt() != 0 ) { | 599 | if ( !str.isEmpty() && str.toInt() != 0 ) { |
600 | if ( str.toInt() == 1 ) | 600 | if ( str.toInt() == 1 ) |
601 | str = QObject::tr( "Male" ); | 601 | str = QObject::tr( "Male" ); |
602 | else if ( str.toInt() == 2 ) | 602 | else if ( str.toInt() == 2 ) |
603 | str = QObject::tr( "Female" ); | 603 | str = QObject::tr( "Female" ); |
604 | text += "<b>" + QObject::tr("Gender: ") + "</b>" + str + "<br>"; | 604 | text += "<b>" + QObject::tr("Gender: ") + "</b>" + str + "<br>"; |
605 | } | 605 | } |
606 | str = spouse(); | 606 | str = spouse(); |
607 | if ( !str.isEmpty() ) | 607 | if ( !str.isEmpty() ) |
608 | text += "<b>" + QObject::tr("Spouse: ") + "</b>" | 608 | text += "<b>" + QObject::tr("Spouse: ") + "</b>" |
609 | + Qtopia::escapeString(str) + "<br>"; | 609 | + Qtopia::escapeString(str) + "<br>"; |
610 | if ( birthday().isValid() ){ | 610 | if ( birthday().isValid() ){ |
611 | str = TimeString::numberDateString( birthday() ); | 611 | str = TimeString::numberDateString( birthday() ); |
612 | text += "<b>" + QObject::tr("Birthday: ") + "</b>" | 612 | text += "<b>" + QObject::tr("Birthday: ") + "</b>" |
613 | + Qtopia::escapeString(str) + "<br>"; | 613 | + Qtopia::escapeString(str) + "<br>"; |
614 | } | 614 | } |
615 | if ( anniversary().isValid() ){ | 615 | if ( anniversary().isValid() ){ |
616 | str = TimeString::numberDateString( anniversary() ); | 616 | str = TimeString::numberDateString( anniversary() ); |
617 | text += "<b>" + QObject::tr("Anniversary: ") + "</b>" | 617 | text += "<b>" + QObject::tr("Anniversary: ") + "</b>" |
618 | + Qtopia::escapeString(str) + "<br>"; | 618 | + Qtopia::escapeString(str) + "<br>"; |
619 | } | 619 | } |
620 | str = children(); | 620 | str = children(); |
621 | if ( !str.isEmpty() ) | 621 | if ( !str.isEmpty() ) |
622 | text += "<b>" + QObject::tr("Children: ") + "</b>" | 622 | text += "<b>" + QObject::tr("Children: ") + "</b>" |
623 | + Qtopia::escapeString(str) + "<br>"; | 623 | + Qtopia::escapeString(str) + "<br>"; |
624 | 624 | ||
625 | str = nickname(); | 625 | str = nickname(); |
626 | if ( !str.isEmpty() ) | 626 | if ( !str.isEmpty() ) |
627 | text += "<b>" + QObject::tr("Nickname: ") + "</b>" | 627 | text += "<b>" + QObject::tr("Nickname: ") + "</b>" |
628 | + Qtopia::escapeString(str) + "<br>"; | 628 | + Qtopia::escapeString(str) + "<br>"; |
629 | 629 | ||
630 | if ( categoryNames().count() ){ | 630 | if ( categoryNames("Contacts").count() ){ |
631 | text += "<b>" + QObject::tr( "Category:") + "</b> "; | 631 | text += "<b>" + QObject::tr( "Category:") + "</b> "; |
632 | text += categoryNames().join(", "); | 632 | text += categoryNames("Contacts").join(", "); |
633 | text += "<br>"; | 633 | text += "<br>"; |
634 | } | 634 | } |
635 | 635 | ||
636 | // notes last | 636 | // notes last |
637 | if ( !(value = notes()).isEmpty() ) { | 637 | if ( !(value = notes()).isEmpty() ) { |
638 | text += "<br><hr><b>" + QObject::tr( "Notes:") + "</b> "; | 638 | text += "<br><hr><b>" + QObject::tr( "Notes:") + "</b> "; |
639 | QRegExp reg("\n"); | 639 | QRegExp reg("\n"); |
640 | 640 | ||
641 | //QString tmp = Qtopia::escapeString(value); | 641 | //QString tmp = Qtopia::escapeString(value); |
642 | QString tmp = QStyleSheet::convertFromPlainText(value); | 642 | QString tmp = QStyleSheet::convertFromPlainText(value); |
643 | //tmp.replace( reg, "<br>" ); | 643 | //tmp.replace( reg, "<br>" ); |
644 | text += "<br>" + tmp + "<br>"; | 644 | text += "<br>" + tmp + "<br>"; |
645 | } | 645 | } |
646 | return text; | 646 | return text; |
647 | } | 647 | } |
648 | 648 | ||
649 | /*! | 649 | /*! |
650 | \internal | 650 | \internal |
651 | */ | 651 | */ |
652 | void OContact::insert( int key, const QString &v ) | 652 | void OContact::insert( int key, const QString &v ) |
653 | { | 653 | { |
654 | QString value = v.stripWhiteSpace(); | 654 | QString value = v.stripWhiteSpace(); |
655 | if ( value.isEmpty() ) | 655 | if ( value.isEmpty() ) |
656 | mMap.remove( key ); | 656 | mMap.remove( key ); |
657 | else | 657 | else |
658 | mMap.insert( key, value ); | 658 | mMap.insert( key, value ); |
659 | } | 659 | } |
660 | 660 | ||
661 | /*! | 661 | /*! |
662 | \internal | 662 | \internal |
663 | */ | 663 | */ |
664 | void OContact::replace( int key, const QString & v ) | 664 | void OContact::replace( int key, const QString & v ) |
665 | { | 665 | { |
666 | QString value = v.stripWhiteSpace(); | 666 | QString value = v.stripWhiteSpace(); |
667 | if ( value.isEmpty() ) | 667 | if ( value.isEmpty() ) |
668 | mMap.remove( key ); | 668 | mMap.remove( key ); |
669 | else | 669 | else |
670 | mMap.replace( key, value ); | 670 | mMap.replace( key, value ); |
671 | } | 671 | } |
672 | 672 | ||
673 | /*! | 673 | /*! |
674 | \internal | 674 | \internal |
675 | */ | 675 | */ |
676 | QString OContact::find( int key ) const | 676 | QString OContact::find( int key ) const |
677 | { | 677 | { |
678 | return mMap[key]; | 678 | return mMap[key]; |
679 | } | 679 | } |
680 | 680 | ||
681 | /*! | 681 | /*! |
682 | \internal | 682 | \internal |
683 | */ | 683 | */ |
684 | QString OContact::displayAddress( const QString &street, | 684 | QString OContact::displayAddress( const QString &street, |
685 | const QString &city, | 685 | const QString &city, |
686 | const QString &state, | 686 | const QString &state, |
687 | const QString &zip, | 687 | const QString &zip, |
688 | const QString &country ) const | 688 | const QString &country ) const |
689 | { | 689 | { |
690 | QString s = street; | 690 | QString s = street; |
691 | if ( !street.isEmpty() ) | 691 | if ( !street.isEmpty() ) |
692 | s+= "\n"; | 692 | s+= "\n"; |
693 | s += city; | 693 | s += city; |
694 | if ( !city.isEmpty() && !state.isEmpty() ) | 694 | if ( !city.isEmpty() && !state.isEmpty() ) |
695 | s += ", "; | 695 | s += ", "; |
696 | s += state; | 696 | s += state; |
diff --git a/libopie/pim/opimrecord.cpp b/libopie/pim/opimrecord.cpp index ac0f4a9..d45417a 100644 --- a/libopie/pim/opimrecord.cpp +++ b/libopie/pim/opimrecord.cpp | |||
@@ -1,104 +1,104 @@ | |||
1 | #include <qarray.h> | 1 | #include <qarray.h> |
2 | 2 | ||
3 | #include <qpe/categories.h> | 3 | #include <qpe/categories.h> |
4 | #include <qpe/categoryselect.h> | 4 | #include <qpe/categoryselect.h> |
5 | 5 | ||
6 | #include "opimrecord.h" | 6 | #include "opimrecord.h" |
7 | 7 | ||
8 | Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia ); | 8 | Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia ); |
9 | 9 | ||
10 | 10 | ||
11 | OPimRecord::OPimRecord( int uid ) | 11 | OPimRecord::OPimRecord( int uid ) |
12 | : Qtopia::Record() { | 12 | : Qtopia::Record() { |
13 | 13 | ||
14 | setUid( uid ); | 14 | setUid( uid ); |
15 | } | 15 | } |
16 | OPimRecord::~OPimRecord() { | 16 | OPimRecord::~OPimRecord() { |
17 | } | 17 | } |
18 | OPimRecord::OPimRecord( const OPimRecord& rec ) | 18 | OPimRecord::OPimRecord( const OPimRecord& rec ) |
19 | : Qtopia::Record( rec ) | 19 | : Qtopia::Record( rec ) |
20 | { | 20 | { |
21 | (*this) = rec; | 21 | (*this) = rec; |
22 | } | 22 | } |
23 | 23 | ||
24 | OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { | 24 | OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { |
25 | Qtopia::Record::operator=( rec ); | 25 | Qtopia::Record::operator=( rec ); |
26 | m_xrefman = rec.m_xrefman; | 26 | m_xrefman = rec.m_xrefman; |
27 | 27 | ||
28 | return *this; | 28 | return *this; |
29 | } | 29 | } |
30 | /* | 30 | /* |
31 | * category names | 31 | * category names |
32 | */ | 32 | */ |
33 | QStringList OPimRecord::categoryNames()const { | 33 | QStringList OPimRecord::categoryNames( const QString& appname ) const { |
34 | QStringList list; | 34 | QStringList list; |
35 | QArray<int> cats = categories(); | 35 | QArray<int> cats = categories(); |
36 | Categories catDB; | 36 | Categories catDB; |
37 | catDB.load( categoryFileName() ); | 37 | catDB.load( categoryFileName() ); |
38 | 38 | ||
39 | for (uint i = 0; i < cats.count(); i++ ) { | 39 | for (uint i = 0; i < cats.count(); i++ ) { |
40 | list << catDB.label("Todo List", cats[i] ); | 40 | list << catDB.label( appname, cats[i] ); |
41 | } | 41 | } |
42 | 42 | ||
43 | return list; | 43 | return list; |
44 | } | 44 | } |
45 | void OPimRecord::setCategoryNames( const QStringList& ) { | 45 | void OPimRecord::setCategoryNames( const QStringList& ) { |
46 | 46 | ||
47 | } | 47 | } |
48 | void OPimRecord::addCategoryName( const QString& ) { | 48 | void OPimRecord::addCategoryName( const QString& ) { |
49 | Categories catDB; | 49 | Categories catDB; |
50 | catDB.load( categoryFileName() ); | 50 | catDB.load( categoryFileName() ); |
51 | 51 | ||
52 | 52 | ||
53 | } | 53 | } |
54 | bool OPimRecord::isEmpty()const { | 54 | bool OPimRecord::isEmpty()const { |
55 | return ( uid() == 0 ); | 55 | return ( uid() == 0 ); |
56 | } | 56 | } |
57 | /*QString OPimRecord::crossToString()const { | 57 | /*QString OPimRecord::crossToString()const { |
58 | QString str; | 58 | QString str; |
59 | QMap<QString, QArray<int> >::ConstIterator it; | 59 | QMap<QString, QArray<int> >::ConstIterator it; |
60 | for (it = m_relations.begin(); it != m_relations.end(); ++it ) { | 60 | for (it = m_relations.begin(); it != m_relations.end(); ++it ) { |
61 | QArray<int> id = it.data(); | 61 | QArray<int> id = it.data(); |
62 | for ( uint i = 0; i < id.size(); ++i ) { | 62 | for ( uint i = 0; i < id.size(); ++i ) { |
63 | str += it.key() + "," + QString::number( i ) + ";"; | 63 | str += it.key() + "," + QString::number( i ) + ";"; |
64 | } | 64 | } |
65 | } | 65 | } |
66 | str = str.remove( str.length()-1, 1); // strip the ; | 66 | str = str.remove( str.length()-1, 1); // strip the ; |
67 | //qWarning("IDS " + str ); | 67 | //qWarning("IDS " + str ); |
68 | 68 | ||
69 | return str; | 69 | return str; |
70 | }*/ | 70 | }*/ |
71 | /* if uid = 1 assign a new one */ | 71 | /* if uid = 1 assign a new one */ |
72 | void OPimRecord::setUid( int uid ) { | 72 | void OPimRecord::setUid( int uid ) { |
73 | if ( uid == 1) | 73 | if ( uid == 1) |
74 | uid = uidGen().generate(); | 74 | uid = uidGen().generate(); |
75 | 75 | ||
76 | Qtopia::Record::setUid( uid ); | 76 | Qtopia::Record::setUid( uid ); |
77 | }; | 77 | }; |
78 | Qtopia::UidGen &OPimRecord::uidGen() { | 78 | Qtopia::UidGen &OPimRecord::uidGen() { |
79 | return m_uidGen; | 79 | return m_uidGen; |
80 | } | 80 | } |
81 | OPimXRefManager &OPimRecord::xrefmanager() { | 81 | OPimXRefManager &OPimRecord::xrefmanager() { |
82 | return m_xrefman; | 82 | return m_xrefman; |
83 | } | 83 | } |
84 | int OPimRecord::rtti(){ | 84 | int OPimRecord::rtti(){ |
85 | return 0; | 85 | return 0; |
86 | } | 86 | } |
87 | 87 | ||
88 | /** | 88 | /** |
89 | * now let's put our data into the stream | 89 | * now let's put our data into the stream |
90 | */ | 90 | */ |
91 | /* | 91 | /* |
92 | * First read UID | 92 | * First read UID |
93 | * Categories | 93 | * Categories |
94 | * XRef | 94 | * XRef |
95 | */ | 95 | */ |
96 | bool OPimRecord::loadFromStream( QDataStream& stream ) { | 96 | bool OPimRecord::loadFromStream( QDataStream& stream ) { |
97 | int Int; | 97 | int Int; |
98 | uint UInt; | 98 | uint UInt; |
99 | stream >> Int; | 99 | stream >> Int; |
100 | setUid(Int); | 100 | setUid(Int); |
101 | 101 | ||
102 | /** Categories */ | 102 | /** Categories */ |
103 | stream >> UInt; | 103 | stream >> UInt; |
104 | QArray<int> array(UInt); | 104 | QArray<int> array(UInt); |
diff --git a/libopie/pim/opimrecord.h b/libopie/pim/opimrecord.h index 665530f..c7f9460 100644 --- a/libopie/pim/opimrecord.h +++ b/libopie/pim/opimrecord.h | |||
@@ -1,105 +1,105 @@ | |||
1 | #ifndef OPIE_PIM_RECORD_H | 1 | #ifndef OPIE_PIM_RECORD_H |
2 | #define OPIE_PIM_RECORD_H | 2 | #define OPIE_PIM_RECORD_H |
3 | 3 | ||
4 | #include <qdatastream.h> | 4 | #include <qdatastream.h> |
5 | #include <qmap.h> | 5 | #include <qmap.h> |
6 | #include <qstring.h> | 6 | #include <qstring.h> |
7 | #include <qstringlist.h> | 7 | #include <qstringlist.h> |
8 | 8 | ||
9 | #include <qpe/palmtoprecord.h> | 9 | #include <qpe/palmtoprecord.h> |
10 | 10 | ||
11 | #include <opie/opimxrefmanager.h> | 11 | #include <opie/opimxrefmanager.h> |
12 | 12 | ||
13 | /** | 13 | /** |
14 | * This is the base class for | 14 | * This is the base class for |
15 | * all PIM Records | 15 | * all PIM Records |
16 | * | 16 | * |
17 | */ | 17 | */ |
18 | class OPimRecord : public Qtopia::Record { | 18 | class OPimRecord : public Qtopia::Record { |
19 | public: | 19 | public: |
20 | /** | 20 | /** |
21 | * c'tor | 21 | * c'tor |
22 | * uid of 0 isEmpty | 22 | * uid of 0 isEmpty |
23 | * uid of 1 will be assigned a new one | 23 | * uid of 1 will be assigned a new one |
24 | */ | 24 | */ |
25 | OPimRecord(int uid = 0); | 25 | OPimRecord(int uid = 0); |
26 | ~OPimRecord(); | 26 | ~OPimRecord(); |
27 | 27 | ||
28 | /** | 28 | /** |
29 | * copy c'tor | 29 | * copy c'tor |
30 | */ | 30 | */ |
31 | OPimRecord( const OPimRecord& rec ); | 31 | OPimRecord( const OPimRecord& rec ); |
32 | 32 | ||
33 | /** | 33 | /** |
34 | * copy operator | 34 | * copy operator |
35 | */ | 35 | */ |
36 | OPimRecord &operator=( const OPimRecord& ); | 36 | OPimRecord &operator=( const OPimRecord& ); |
37 | 37 | ||
38 | /** | 38 | /** |
39 | * category names resolved | 39 | * category names resolved |
40 | */ | 40 | */ |
41 | QStringList categoryNames()const; | 41 | QStringList categoryNames( const QString& appname )const; |
42 | 42 | ||
43 | /** | 43 | /** |
44 | * set category names they will be resolved | 44 | * set category names they will be resolved |
45 | */ | 45 | */ |
46 | void setCategoryNames( const QStringList& ); | 46 | void setCategoryNames( const QStringList& ); |
47 | 47 | ||
48 | /** | 48 | /** |
49 | * addCategoryName adds a name | 49 | * addCategoryName adds a name |
50 | * to the internal category list | 50 | * to the internal category list |
51 | */ | 51 | */ |
52 | void addCategoryName( const QString& ); | 52 | void addCategoryName( const QString& ); |
53 | 53 | ||
54 | /** | 54 | /** |
55 | * if a Record isEmpty | 55 | * if a Record isEmpty |
56 | * it's empty if it's 0 | 56 | * it's empty if it's 0 |
57 | */ | 57 | */ |
58 | virtual bool isEmpty()const; | 58 | virtual bool isEmpty()const; |
59 | 59 | ||
60 | /** | 60 | /** |
61 | * toRichText summary | 61 | * toRichText summary |
62 | */ | 62 | */ |
63 | virtual QString toRichText()const = 0; | 63 | virtual QString toRichText()const = 0; |
64 | 64 | ||
65 | /** | 65 | /** |
66 | * a small one line summary | 66 | * a small one line summary |
67 | */ | 67 | */ |
68 | virtual QString toShortText()const = 0; | 68 | virtual QString toShortText()const = 0; |
69 | 69 | ||
70 | /** | 70 | /** |
71 | * the name of the Record | 71 | * the name of the Record |
72 | */ | 72 | */ |
73 | virtual QString type()const = 0; | 73 | virtual QString type()const = 0; |
74 | 74 | ||
75 | /** | 75 | /** |
76 | * converts the internal structure to a map | 76 | * converts the internal structure to a map |
77 | */ | 77 | */ |
78 | virtual QMap<int, QString> toMap()const = 0; | 78 | virtual QMap<int, QString> toMap()const = 0; |
79 | 79 | ||
80 | /** | 80 | /** |
81 | * key value representation of extra items | 81 | * key value representation of extra items |
82 | */ | 82 | */ |
83 | virtual QMap<QString, QString> toExtraMap()const = 0; | 83 | virtual QMap<QString, QString> toExtraMap()const = 0; |
84 | 84 | ||
85 | /** | 85 | /** |
86 | * the name for a recordField | 86 | * the name for a recordField |
87 | */ | 87 | */ |
88 | virtual QString recordField(int)const = 0; | 88 | virtual QString recordField(int)const = 0; |
89 | 89 | ||
90 | /** | 90 | /** |
91 | * returns a reference of the | 91 | * returns a reference of the |
92 | * Cross Reference Manager | 92 | * Cross Reference Manager |
93 | * Partner 'One' is THIS PIM RECORD! | 93 | * Partner 'One' is THIS PIM RECORD! |
94 | * 'Two' is the Partner where we link to | 94 | * 'Two' is the Partner where we link to |
95 | */ | 95 | */ |
96 | OPimXRefManager& xrefmanager(); | 96 | OPimXRefManager& xrefmanager(); |
97 | 97 | ||
98 | /** | 98 | /** |
99 | * set the uid | 99 | * set the uid |
100 | */ | 100 | */ |
101 | virtual void setUid( int uid ); | 101 | virtual void setUid( int uid ); |
102 | 102 | ||
103 | /* | 103 | /* |
104 | * used inside the Templates for casting | 104 | * used inside the Templates for casting |
105 | * REIMPLEMENT in your .... | 105 | * REIMPLEMENT in your .... |
diff --git a/libopie/pim/otodo.cpp b/libopie/pim/otodo.cpp index cde2b3d..b4d4aa9 100644 --- a/libopie/pim/otodo.cpp +++ b/libopie/pim/otodo.cpp | |||
@@ -194,129 +194,129 @@ void OTodo::setDueDate( const QDate& date ) | |||
194 | void OTodo::setStartDate( const QDate& date ) { | 194 | void OTodo::setStartDate( const QDate& date ) { |
195 | changeOrModify(); | 195 | changeOrModify(); |
196 | data->start = date; | 196 | data->start = date; |
197 | } | 197 | } |
198 | void OTodo::setCompletedDate( const QDate& date ) { | 198 | void OTodo::setCompletedDate( const QDate& date ) { |
199 | changeOrModify(); | 199 | changeOrModify(); |
200 | data->completed = date; | 200 | data->completed = date; |
201 | } | 201 | } |
202 | void OTodo::setState( const OPimState& state ) { | 202 | void OTodo::setState( const OPimState& state ) { |
203 | changeOrModify(); | 203 | changeOrModify(); |
204 | data->state = state; | 204 | data->state = state; |
205 | } | 205 | } |
206 | void OTodo::setRecurrence( const ORecur& rec) { | 206 | void OTodo::setRecurrence( const ORecur& rec) { |
207 | changeOrModify(); | 207 | changeOrModify(); |
208 | data->recur = rec; | 208 | data->recur = rec; |
209 | } | 209 | } |
210 | void OTodo::setMaintainer( const OPimMaintainer& pim ) { | 210 | void OTodo::setMaintainer( const OPimMaintainer& pim ) { |
211 | changeOrModify(); | 211 | changeOrModify(); |
212 | data->maintainer = pim; | 212 | data->maintainer = pim; |
213 | } | 213 | } |
214 | bool OTodo::isOverdue( ) | 214 | bool OTodo::isOverdue( ) |
215 | { | 215 | { |
216 | if( data->hasDate && !data->isCompleted) | 216 | if( data->hasDate && !data->isCompleted) |
217 | return QDate::currentDate() > data->date; | 217 | return QDate::currentDate() > data->date; |
218 | return false; | 218 | return false; |
219 | } | 219 | } |
220 | void OTodo::setProgress(ushort progress ) | 220 | void OTodo::setProgress(ushort progress ) |
221 | { | 221 | { |
222 | changeOrModify(); | 222 | changeOrModify(); |
223 | data->prog = progress; | 223 | data->prog = progress; |
224 | } | 224 | } |
225 | QString OTodo::toShortText() const { | 225 | QString OTodo::toShortText() const { |
226 | return summary(); | 226 | return summary(); |
227 | } | 227 | } |
228 | /*! | 228 | /*! |
229 | Returns a richt text string | 229 | Returns a richt text string |
230 | */ | 230 | */ |
231 | QString OTodo::toRichText() const | 231 | QString OTodo::toRichText() const |
232 | { | 232 | { |
233 | QString text; | 233 | QString text; |
234 | QStringList catlist; | 234 | QStringList catlist; |
235 | 235 | ||
236 | // Description of the todo | 236 | // Description of the todo |
237 | if ( !summary().isEmpty() ) { | 237 | if ( !summary().isEmpty() ) { |
238 | text += "<b>" + QObject::tr( "Summary:") + "</b><br>"; | 238 | text += "<b>" + QObject::tr( "Summary:") + "</b><br>"; |
239 | text += Qtopia::escapeString(summary() ).replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; | 239 | text += Qtopia::escapeString(summary() ).replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; |
240 | } | 240 | } |
241 | if( !description().isEmpty() ){ | 241 | if( !description().isEmpty() ){ |
242 | text += "<b>" + QObject::tr( "Description:" ) + "</b><br>"; | 242 | text += "<b>" + QObject::tr( "Description:" ) + "</b><br>"; |
243 | text += Qtopia::escapeString(description() ).replace(QRegExp( "[\n]"), "<br>" ) ; | 243 | text += Qtopia::escapeString(description() ).replace(QRegExp( "[\n]"), "<br>" ) ; |
244 | } | 244 | } |
245 | text += "<br><br><br>"; | 245 | text += "<br><br><br>"; |
246 | 246 | ||
247 | text += "<b>" + QObject::tr( "Priority:") +" </b>" | 247 | text += "<b>" + QObject::tr( "Priority:") +" </b>" |
248 | + QString::number( priority() ) + " <br>"; | 248 | + QString::number( priority() ) + " <br>"; |
249 | text += "<b>" + QObject::tr( "Progress:") + " </b>" | 249 | text += "<b>" + QObject::tr( "Progress:") + " </b>" |
250 | + QString::number( progress() ) + " %<br>"; | 250 | + QString::number( progress() ) + " %<br>"; |
251 | if (hasDueDate() ){ | 251 | if (hasDueDate() ){ |
252 | text += "<b>" + QObject::tr( "Deadline:") + " </b>"; | 252 | text += "<b>" + QObject::tr( "Deadline:") + " </b>"; |
253 | text += dueDate().toString(); | 253 | text += dueDate().toString(); |
254 | text += "<br>"; | 254 | text += "<br>"; |
255 | } | 255 | } |
256 | 256 | ||
257 | text += "<b>" + QObject::tr( "Category:") + "</b> "; | 257 | text += "<b>" + QObject::tr( "Category:") + "</b> "; |
258 | text += categoryNames().join(", "); | 258 | text += categoryNames( "Todo List" ).join(", "); |
259 | text += "<br>"; | 259 | text += "<br>"; |
260 | 260 | ||
261 | return text; | 261 | return text; |
262 | } | 262 | } |
263 | OPimNotifyManager& OTodo::notifiers() { | 263 | OPimNotifyManager& OTodo::notifiers() { |
264 | return data->notifiers; | 264 | return data->notifiers; |
265 | } | 265 | } |
266 | 266 | ||
267 | bool OTodo::operator<( const OTodo &toDoEvent )const{ | 267 | bool OTodo::operator<( const OTodo &toDoEvent )const{ |
268 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; | 268 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; |
269 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; | 269 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; |
270 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 270 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
271 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 271 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
272 | return priority() < toDoEvent.priority(); | 272 | return priority() < toDoEvent.priority(); |
273 | }else{ | 273 | }else{ |
274 | return dueDate() < toDoEvent.dueDate(); | 274 | return dueDate() < toDoEvent.dueDate(); |
275 | } | 275 | } |
276 | } | 276 | } |
277 | return false; | 277 | return false; |
278 | } | 278 | } |
279 | bool OTodo::operator<=(const OTodo &toDoEvent )const | 279 | bool OTodo::operator<=(const OTodo &toDoEvent )const |
280 | { | 280 | { |
281 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; | 281 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; |
282 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return true; | 282 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return true; |
283 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 283 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
284 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 284 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
285 | return priority() <= toDoEvent.priority(); | 285 | return priority() <= toDoEvent.priority(); |
286 | }else{ | 286 | }else{ |
287 | return dueDate() <= toDoEvent.dueDate(); | 287 | return dueDate() <= toDoEvent.dueDate(); |
288 | } | 288 | } |
289 | } | 289 | } |
290 | return true; | 290 | return true; |
291 | } | 291 | } |
292 | bool OTodo::operator>(const OTodo &toDoEvent )const | 292 | bool OTodo::operator>(const OTodo &toDoEvent )const |
293 | { | 293 | { |
294 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return false; | 294 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return false; |
295 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; | 295 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; |
296 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 296 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
297 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 297 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
298 | return priority() > toDoEvent.priority(); | 298 | return priority() > toDoEvent.priority(); |
299 | }else{ | 299 | }else{ |
300 | return dueDate() > toDoEvent.dueDate(); | 300 | return dueDate() > toDoEvent.dueDate(); |
301 | } | 301 | } |
302 | } | 302 | } |
303 | return false; | 303 | return false; |
304 | } | 304 | } |
305 | bool OTodo::operator>=(const OTodo &toDoEvent )const | 305 | bool OTodo::operator>=(const OTodo &toDoEvent )const |
306 | { | 306 | { |
307 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; | 307 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; |
308 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; | 308 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; |
309 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 309 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
310 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 310 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
311 | return priority() > toDoEvent.priority(); | 311 | return priority() > toDoEvent.priority(); |
312 | }else{ | 312 | }else{ |
313 | return dueDate() > toDoEvent.dueDate(); | 313 | return dueDate() > toDoEvent.dueDate(); |
314 | } | 314 | } |
315 | } | 315 | } |
316 | return true; | 316 | return true; |
317 | } | 317 | } |
318 | bool OTodo::operator==(const OTodo &toDoEvent )const | 318 | bool OTodo::operator==(const OTodo &toDoEvent )const |
319 | { | 319 | { |
320 | if ( data->priority != toDoEvent.data->priority ) return false; | 320 | if ( data->priority != toDoEvent.data->priority ) return false; |
321 | if ( data->priority != toDoEvent.data->prog ) return false; | 321 | if ( data->priority != toDoEvent.data->prog ) return false; |
322 | if ( data->isCompleted != toDoEvent.data->isCompleted ) return false; | 322 | if ( data->isCompleted != toDoEvent.data->isCompleted ) return false; |
diff --git a/libopie2/opiepim/core/opimrecord.cpp b/libopie2/opiepim/core/opimrecord.cpp index ac0f4a9..d45417a 100644 --- a/libopie2/opiepim/core/opimrecord.cpp +++ b/libopie2/opiepim/core/opimrecord.cpp | |||
@@ -1,104 +1,104 @@ | |||
1 | #include <qarray.h> | 1 | #include <qarray.h> |
2 | 2 | ||
3 | #include <qpe/categories.h> | 3 | #include <qpe/categories.h> |
4 | #include <qpe/categoryselect.h> | 4 | #include <qpe/categoryselect.h> |
5 | 5 | ||
6 | #include "opimrecord.h" | 6 | #include "opimrecord.h" |
7 | 7 | ||
8 | Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia ); | 8 | Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia ); |
9 | 9 | ||
10 | 10 | ||
11 | OPimRecord::OPimRecord( int uid ) | 11 | OPimRecord::OPimRecord( int uid ) |
12 | : Qtopia::Record() { | 12 | : Qtopia::Record() { |
13 | 13 | ||
14 | setUid( uid ); | 14 | setUid( uid ); |
15 | } | 15 | } |
16 | OPimRecord::~OPimRecord() { | 16 | OPimRecord::~OPimRecord() { |
17 | } | 17 | } |
18 | OPimRecord::OPimRecord( const OPimRecord& rec ) | 18 | OPimRecord::OPimRecord( const OPimRecord& rec ) |
19 | : Qtopia::Record( rec ) | 19 | : Qtopia::Record( rec ) |
20 | { | 20 | { |
21 | (*this) = rec; | 21 | (*this) = rec; |
22 | } | 22 | } |
23 | 23 | ||
24 | OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { | 24 | OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { |
25 | Qtopia::Record::operator=( rec ); | 25 | Qtopia::Record::operator=( rec ); |
26 | m_xrefman = rec.m_xrefman; | 26 | m_xrefman = rec.m_xrefman; |
27 | 27 | ||
28 | return *this; | 28 | return *this; |
29 | } | 29 | } |
30 | /* | 30 | /* |
31 | * category names | 31 | * category names |
32 | */ | 32 | */ |
33 | QStringList OPimRecord::categoryNames()const { | 33 | QStringList OPimRecord::categoryNames( const QString& appname ) const { |
34 | QStringList list; | 34 | QStringList list; |
35 | QArray<int> cats = categories(); | 35 | QArray<int> cats = categories(); |
36 | Categories catDB; | 36 | Categories catDB; |
37 | catDB.load( categoryFileName() ); | 37 | catDB.load( categoryFileName() ); |
38 | 38 | ||
39 | for (uint i = 0; i < cats.count(); i++ ) { | 39 | for (uint i = 0; i < cats.count(); i++ ) { |
40 | list << catDB.label("Todo List", cats[i] ); | 40 | list << catDB.label( appname, cats[i] ); |
41 | } | 41 | } |
42 | 42 | ||
43 | return list; | 43 | return list; |
44 | } | 44 | } |
45 | void OPimRecord::setCategoryNames( const QStringList& ) { | 45 | void OPimRecord::setCategoryNames( const QStringList& ) { |
46 | 46 | ||
47 | } | 47 | } |
48 | void OPimRecord::addCategoryName( const QString& ) { | 48 | void OPimRecord::addCategoryName( const QString& ) { |
49 | Categories catDB; | 49 | Categories catDB; |
50 | catDB.load( categoryFileName() ); | 50 | catDB.load( categoryFileName() ); |
51 | 51 | ||
52 | 52 | ||
53 | } | 53 | } |
54 | bool OPimRecord::isEmpty()const { | 54 | bool OPimRecord::isEmpty()const { |
55 | return ( uid() == 0 ); | 55 | return ( uid() == 0 ); |
56 | } | 56 | } |
57 | /*QString OPimRecord::crossToString()const { | 57 | /*QString OPimRecord::crossToString()const { |
58 | QString str; | 58 | QString str; |
59 | QMap<QString, QArray<int> >::ConstIterator it; | 59 | QMap<QString, QArray<int> >::ConstIterator it; |
60 | for (it = m_relations.begin(); it != m_relations.end(); ++it ) { | 60 | for (it = m_relations.begin(); it != m_relations.end(); ++it ) { |
61 | QArray<int> id = it.data(); | 61 | QArray<int> id = it.data(); |
62 | for ( uint i = 0; i < id.size(); ++i ) { | 62 | for ( uint i = 0; i < id.size(); ++i ) { |
63 | str += it.key() + "," + QString::number( i ) + ";"; | 63 | str += it.key() + "," + QString::number( i ) + ";"; |
64 | } | 64 | } |
65 | } | 65 | } |
66 | str = str.remove( str.length()-1, 1); // strip the ; | 66 | str = str.remove( str.length()-1, 1); // strip the ; |
67 | //qWarning("IDS " + str ); | 67 | //qWarning("IDS " + str ); |
68 | 68 | ||
69 | return str; | 69 | return str; |
70 | }*/ | 70 | }*/ |
71 | /* if uid = 1 assign a new one */ | 71 | /* if uid = 1 assign a new one */ |
72 | void OPimRecord::setUid( int uid ) { | 72 | void OPimRecord::setUid( int uid ) { |
73 | if ( uid == 1) | 73 | if ( uid == 1) |
74 | uid = uidGen().generate(); | 74 | uid = uidGen().generate(); |
75 | 75 | ||
76 | Qtopia::Record::setUid( uid ); | 76 | Qtopia::Record::setUid( uid ); |
77 | }; | 77 | }; |
78 | Qtopia::UidGen &OPimRecord::uidGen() { | 78 | Qtopia::UidGen &OPimRecord::uidGen() { |
79 | return m_uidGen; | 79 | return m_uidGen; |
80 | } | 80 | } |
81 | OPimXRefManager &OPimRecord::xrefmanager() { | 81 | OPimXRefManager &OPimRecord::xrefmanager() { |
82 | return m_xrefman; | 82 | return m_xrefman; |
83 | } | 83 | } |
84 | int OPimRecord::rtti(){ | 84 | int OPimRecord::rtti(){ |
85 | return 0; | 85 | return 0; |
86 | } | 86 | } |
87 | 87 | ||
88 | /** | 88 | /** |
89 | * now let's put our data into the stream | 89 | * now let's put our data into the stream |
90 | */ | 90 | */ |
91 | /* | 91 | /* |
92 | * First read UID | 92 | * First read UID |
93 | * Categories | 93 | * Categories |
94 | * XRef | 94 | * XRef |
95 | */ | 95 | */ |
96 | bool OPimRecord::loadFromStream( QDataStream& stream ) { | 96 | bool OPimRecord::loadFromStream( QDataStream& stream ) { |
97 | int Int; | 97 | int Int; |
98 | uint UInt; | 98 | uint UInt; |
99 | stream >> Int; | 99 | stream >> Int; |
100 | setUid(Int); | 100 | setUid(Int); |
101 | 101 | ||
102 | /** Categories */ | 102 | /** Categories */ |
103 | stream >> UInt; | 103 | stream >> UInt; |
104 | QArray<int> array(UInt); | 104 | QArray<int> array(UInt); |
diff --git a/libopie2/opiepim/core/opimrecord.h b/libopie2/opiepim/core/opimrecord.h index 665530f..c7f9460 100644 --- a/libopie2/opiepim/core/opimrecord.h +++ b/libopie2/opiepim/core/opimrecord.h | |||
@@ -1,105 +1,105 @@ | |||
1 | #ifndef OPIE_PIM_RECORD_H | 1 | #ifndef OPIE_PIM_RECORD_H |
2 | #define OPIE_PIM_RECORD_H | 2 | #define OPIE_PIM_RECORD_H |
3 | 3 | ||
4 | #include <qdatastream.h> | 4 | #include <qdatastream.h> |
5 | #include <qmap.h> | 5 | #include <qmap.h> |
6 | #include <qstring.h> | 6 | #include <qstring.h> |
7 | #include <qstringlist.h> | 7 | #include <qstringlist.h> |
8 | 8 | ||
9 | #include <qpe/palmtoprecord.h> | 9 | #include <qpe/palmtoprecord.h> |
10 | 10 | ||
11 | #include <opie/opimxrefmanager.h> | 11 | #include <opie/opimxrefmanager.h> |
12 | 12 | ||
13 | /** | 13 | /** |
14 | * This is the base class for | 14 | * This is the base class for |
15 | * all PIM Records | 15 | * all PIM Records |
16 | * | 16 | * |
17 | */ | 17 | */ |
18 | class OPimRecord : public Qtopia::Record { | 18 | class OPimRecord : public Qtopia::Record { |
19 | public: | 19 | public: |
20 | /** | 20 | /** |
21 | * c'tor | 21 | * c'tor |
22 | * uid of 0 isEmpty | 22 | * uid of 0 isEmpty |
23 | * uid of 1 will be assigned a new one | 23 | * uid of 1 will be assigned a new one |
24 | */ | 24 | */ |
25 | OPimRecord(int uid = 0); | 25 | OPimRecord(int uid = 0); |
26 | ~OPimRecord(); | 26 | ~OPimRecord(); |
27 | 27 | ||
28 | /** | 28 | /** |
29 | * copy c'tor | 29 | * copy c'tor |
30 | */ | 30 | */ |
31 | OPimRecord( const OPimRecord& rec ); | 31 | OPimRecord( const OPimRecord& rec ); |
32 | 32 | ||
33 | /** | 33 | /** |
34 | * copy operator | 34 | * copy operator |
35 | */ | 35 | */ |
36 | OPimRecord &operator=( const OPimRecord& ); | 36 | OPimRecord &operator=( const OPimRecord& ); |
37 | 37 | ||
38 | /** | 38 | /** |
39 | * category names resolved | 39 | * category names resolved |
40 | */ | 40 | */ |
41 | QStringList categoryNames()const; | 41 | QStringList categoryNames( const QString& appname )const; |
42 | 42 | ||
43 | /** | 43 | /** |
44 | * set category names they will be resolved | 44 | * set category names they will be resolved |
45 | */ | 45 | */ |
46 | void setCategoryNames( const QStringList& ); | 46 | void setCategoryNames( const QStringList& ); |
47 | 47 | ||
48 | /** | 48 | /** |
49 | * addCategoryName adds a name | 49 | * addCategoryName adds a name |
50 | * to the internal category list | 50 | * to the internal category list |
51 | */ | 51 | */ |
52 | void addCategoryName( const QString& ); | 52 | void addCategoryName( const QString& ); |
53 | 53 | ||
54 | /** | 54 | /** |
55 | * if a Record isEmpty | 55 | * if a Record isEmpty |
56 | * it's empty if it's 0 | 56 | * it's empty if it's 0 |
57 | */ | 57 | */ |
58 | virtual bool isEmpty()const; | 58 | virtual bool isEmpty()const; |
59 | 59 | ||
60 | /** | 60 | /** |
61 | * toRichText summary | 61 | * toRichText summary |
62 | */ | 62 | */ |
63 | virtual QString toRichText()const = 0; | 63 | virtual QString toRichText()const = 0; |
64 | 64 | ||
65 | /** | 65 | /** |
66 | * a small one line summary | 66 | * a small one line summary |
67 | */ | 67 | */ |
68 | virtual QString toShortText()const = 0; | 68 | virtual QString toShortText()const = 0; |
69 | 69 | ||
70 | /** | 70 | /** |
71 | * the name of the Record | 71 | * the name of the Record |
72 | */ | 72 | */ |
73 | virtual QString type()const = 0; | 73 | virtual QString type()const = 0; |
74 | 74 | ||
75 | /** | 75 | /** |
76 | * converts the internal structure to a map | 76 | * converts the internal structure to a map |
77 | */ | 77 | */ |
78 | virtual QMap<int, QString> toMap()const = 0; | 78 | virtual QMap<int, QString> toMap()const = 0; |
79 | 79 | ||
80 | /** | 80 | /** |
81 | * key value representation of extra items | 81 | * key value representation of extra items |
82 | */ | 82 | */ |
83 | virtual QMap<QString, QString> toExtraMap()const = 0; | 83 | virtual QMap<QString, QString> toExtraMap()const = 0; |
84 | 84 | ||
85 | /** | 85 | /** |
86 | * the name for a recordField | 86 | * the name for a recordField |
87 | */ | 87 | */ |
88 | virtual QString recordField(int)const = 0; | 88 | virtual QString recordField(int)const = 0; |
89 | 89 | ||
90 | /** | 90 | /** |
91 | * returns a reference of the | 91 | * returns a reference of the |
92 | * Cross Reference Manager | 92 | * Cross Reference Manager |
93 | * Partner 'One' is THIS PIM RECORD! | 93 | * Partner 'One' is THIS PIM RECORD! |
94 | * 'Two' is the Partner where we link to | 94 | * 'Two' is the Partner where we link to |
95 | */ | 95 | */ |
96 | OPimXRefManager& xrefmanager(); | 96 | OPimXRefManager& xrefmanager(); |
97 | 97 | ||
98 | /** | 98 | /** |
99 | * set the uid | 99 | * set the uid |
100 | */ | 100 | */ |
101 | virtual void setUid( int uid ); | 101 | virtual void setUid( int uid ); |
102 | 102 | ||
103 | /* | 103 | /* |
104 | * used inside the Templates for casting | 104 | * used inside the Templates for casting |
105 | * REIMPLEMENT in your .... | 105 | * REIMPLEMENT in your .... |
diff --git a/libopie2/opiepim/ocontact.cpp b/libopie2/opiepim/ocontact.cpp index 178559b..9cccfc8 100644 --- a/libopie2/opiepim/ocontact.cpp +++ b/libopie2/opiepim/ocontact.cpp | |||
@@ -566,131 +566,131 @@ QString OContact::toRichText() const | |||
566 | str = homeFax(); | 566 | str = homeFax(); |
567 | if ( !str.isEmpty() ){ | 567 | if ( !str.isEmpty() ){ |
568 | text += "<b>" + QObject::tr("Home Fax: ") + "</b>" | 568 | text += "<b>" + QObject::tr("Home Fax: ") + "</b>" |
569 | + Qtopia::escapeString(str) + "<br>"; | 569 | + Qtopia::escapeString(str) + "<br>"; |
570 | marker = true; | 570 | marker = true; |
571 | } | 571 | } |
572 | str = homeMobile(); | 572 | str = homeMobile(); |
573 | if ( !str.isEmpty() ){ | 573 | if ( !str.isEmpty() ){ |
574 | text += "<b>" + QObject::tr("Home Mobile: ") + "</b>" | 574 | text += "<b>" + QObject::tr("Home Mobile: ") + "</b>" |
575 | + Qtopia::escapeString(str) + "<br>"; | 575 | + Qtopia::escapeString(str) + "<br>"; |
576 | marker = true; | 576 | marker = true; |
577 | } | 577 | } |
578 | 578 | ||
579 | if ( marker ) | 579 | if ( marker ) |
580 | text += "<br><hr><br>"; | 580 | text += "<br><hr><br>"; |
581 | // the others... | 581 | // the others... |
582 | str = emails(); | 582 | str = emails(); |
583 | if ( !str.isEmpty() && ( str != defEmail ) ) | 583 | if ( !str.isEmpty() && ( str != defEmail ) ) |
584 | text += "<b>" + QObject::tr("All Emails: ") + "</b>" | 584 | text += "<b>" + QObject::tr("All Emails: ") + "</b>" |
585 | + Qtopia::escapeString(str) + "<br>"; | 585 | + Qtopia::escapeString(str) + "<br>"; |
586 | str = profession(); | 586 | str = profession(); |
587 | if ( !str.isEmpty() ) | 587 | if ( !str.isEmpty() ) |
588 | text += "<b>" + QObject::tr("Profession: ") + "</b>" | 588 | text += "<b>" + QObject::tr("Profession: ") + "</b>" |
589 | + Qtopia::escapeString(str) + "<br>"; | 589 | + Qtopia::escapeString(str) + "<br>"; |
590 | str = assistant(); | 590 | str = assistant(); |
591 | if ( !str.isEmpty() ) | 591 | if ( !str.isEmpty() ) |
592 | text += "<b>" + QObject::tr("Assistant: ") + "</b>" | 592 | text += "<b>" + QObject::tr("Assistant: ") + "</b>" |
593 | + Qtopia::escapeString(str) + "<br>"; | 593 | + Qtopia::escapeString(str) + "<br>"; |
594 | str = manager(); | 594 | str = manager(); |
595 | if ( !str.isEmpty() ) | 595 | if ( !str.isEmpty() ) |
596 | text += "<b>" + QObject::tr("Manager: ") + "</b>" | 596 | text += "<b>" + QObject::tr("Manager: ") + "</b>" |
597 | + Qtopia::escapeString(str) + "<br>"; | 597 | + Qtopia::escapeString(str) + "<br>"; |
598 | str = gender(); | 598 | str = gender(); |
599 | if ( !str.isEmpty() && str.toInt() != 0 ) { | 599 | if ( !str.isEmpty() && str.toInt() != 0 ) { |
600 | if ( str.toInt() == 1 ) | 600 | if ( str.toInt() == 1 ) |
601 | str = QObject::tr( "Male" ); | 601 | str = QObject::tr( "Male" ); |
602 | else if ( str.toInt() == 2 ) | 602 | else if ( str.toInt() == 2 ) |
603 | str = QObject::tr( "Female" ); | 603 | str = QObject::tr( "Female" ); |
604 | text += "<b>" + QObject::tr("Gender: ") + "</b>" + str + "<br>"; | 604 | text += "<b>" + QObject::tr("Gender: ") + "</b>" + str + "<br>"; |
605 | } | 605 | } |
606 | str = spouse(); | 606 | str = spouse(); |
607 | if ( !str.isEmpty() ) | 607 | if ( !str.isEmpty() ) |
608 | text += "<b>" + QObject::tr("Spouse: ") + "</b>" | 608 | text += "<b>" + QObject::tr("Spouse: ") + "</b>" |
609 | + Qtopia::escapeString(str) + "<br>"; | 609 | + Qtopia::escapeString(str) + "<br>"; |
610 | if ( birthday().isValid() ){ | 610 | if ( birthday().isValid() ){ |
611 | str = TimeString::numberDateString( birthday() ); | 611 | str = TimeString::numberDateString( birthday() ); |
612 | text += "<b>" + QObject::tr("Birthday: ") + "</b>" | 612 | text += "<b>" + QObject::tr("Birthday: ") + "</b>" |
613 | + Qtopia::escapeString(str) + "<br>"; | 613 | + Qtopia::escapeString(str) + "<br>"; |
614 | } | 614 | } |
615 | if ( anniversary().isValid() ){ | 615 | if ( anniversary().isValid() ){ |
616 | str = TimeString::numberDateString( anniversary() ); | 616 | str = TimeString::numberDateString( anniversary() ); |
617 | text += "<b>" + QObject::tr("Anniversary: ") + "</b>" | 617 | text += "<b>" + QObject::tr("Anniversary: ") + "</b>" |
618 | + Qtopia::escapeString(str) + "<br>"; | 618 | + Qtopia::escapeString(str) + "<br>"; |
619 | } | 619 | } |
620 | str = children(); | 620 | str = children(); |
621 | if ( !str.isEmpty() ) | 621 | if ( !str.isEmpty() ) |
622 | text += "<b>" + QObject::tr("Children: ") + "</b>" | 622 | text += "<b>" + QObject::tr("Children: ") + "</b>" |
623 | + Qtopia::escapeString(str) + "<br>"; | 623 | + Qtopia::escapeString(str) + "<br>"; |
624 | 624 | ||
625 | str = nickname(); | 625 | str = nickname(); |
626 | if ( !str.isEmpty() ) | 626 | if ( !str.isEmpty() ) |
627 | text += "<b>" + QObject::tr("Nickname: ") + "</b>" | 627 | text += "<b>" + QObject::tr("Nickname: ") + "</b>" |
628 | + Qtopia::escapeString(str) + "<br>"; | 628 | + Qtopia::escapeString(str) + "<br>"; |
629 | 629 | ||
630 | if ( categoryNames().count() ){ | 630 | if ( categoryNames("Contacts").count() ){ |
631 | text += "<b>" + QObject::tr( "Category:") + "</b> "; | 631 | text += "<b>" + QObject::tr( "Category:") + "</b> "; |
632 | text += categoryNames().join(", "); | 632 | text += categoryNames("Contacts").join(", "); |
633 | text += "<br>"; | 633 | text += "<br>"; |
634 | } | 634 | } |
635 | 635 | ||
636 | // notes last | 636 | // notes last |
637 | if ( !(value = notes()).isEmpty() ) { | 637 | if ( !(value = notes()).isEmpty() ) { |
638 | text += "<br><hr><b>" + QObject::tr( "Notes:") + "</b> "; | 638 | text += "<br><hr><b>" + QObject::tr( "Notes:") + "</b> "; |
639 | QRegExp reg("\n"); | 639 | QRegExp reg("\n"); |
640 | 640 | ||
641 | //QString tmp = Qtopia::escapeString(value); | 641 | //QString tmp = Qtopia::escapeString(value); |
642 | QString tmp = QStyleSheet::convertFromPlainText(value); | 642 | QString tmp = QStyleSheet::convertFromPlainText(value); |
643 | //tmp.replace( reg, "<br>" ); | 643 | //tmp.replace( reg, "<br>" ); |
644 | text += "<br>" + tmp + "<br>"; | 644 | text += "<br>" + tmp + "<br>"; |
645 | } | 645 | } |
646 | return text; | 646 | return text; |
647 | } | 647 | } |
648 | 648 | ||
649 | /*! | 649 | /*! |
650 | \internal | 650 | \internal |
651 | */ | 651 | */ |
652 | void OContact::insert( int key, const QString &v ) | 652 | void OContact::insert( int key, const QString &v ) |
653 | { | 653 | { |
654 | QString value = v.stripWhiteSpace(); | 654 | QString value = v.stripWhiteSpace(); |
655 | if ( value.isEmpty() ) | 655 | if ( value.isEmpty() ) |
656 | mMap.remove( key ); | 656 | mMap.remove( key ); |
657 | else | 657 | else |
658 | mMap.insert( key, value ); | 658 | mMap.insert( key, value ); |
659 | } | 659 | } |
660 | 660 | ||
661 | /*! | 661 | /*! |
662 | \internal | 662 | \internal |
663 | */ | 663 | */ |
664 | void OContact::replace( int key, const QString & v ) | 664 | void OContact::replace( int key, const QString & v ) |
665 | { | 665 | { |
666 | QString value = v.stripWhiteSpace(); | 666 | QString value = v.stripWhiteSpace(); |
667 | if ( value.isEmpty() ) | 667 | if ( value.isEmpty() ) |
668 | mMap.remove( key ); | 668 | mMap.remove( key ); |
669 | else | 669 | else |
670 | mMap.replace( key, value ); | 670 | mMap.replace( key, value ); |
671 | } | 671 | } |
672 | 672 | ||
673 | /*! | 673 | /*! |
674 | \internal | 674 | \internal |
675 | */ | 675 | */ |
676 | QString OContact::find( int key ) const | 676 | QString OContact::find( int key ) const |
677 | { | 677 | { |
678 | return mMap[key]; | 678 | return mMap[key]; |
679 | } | 679 | } |
680 | 680 | ||
681 | /*! | 681 | /*! |
682 | \internal | 682 | \internal |
683 | */ | 683 | */ |
684 | QString OContact::displayAddress( const QString &street, | 684 | QString OContact::displayAddress( const QString &street, |
685 | const QString &city, | 685 | const QString &city, |
686 | const QString &state, | 686 | const QString &state, |
687 | const QString &zip, | 687 | const QString &zip, |
688 | const QString &country ) const | 688 | const QString &country ) const |
689 | { | 689 | { |
690 | QString s = street; | 690 | QString s = street; |
691 | if ( !street.isEmpty() ) | 691 | if ( !street.isEmpty() ) |
692 | s+= "\n"; | 692 | s+= "\n"; |
693 | s += city; | 693 | s += city; |
694 | if ( !city.isEmpty() && !state.isEmpty() ) | 694 | if ( !city.isEmpty() && !state.isEmpty() ) |
695 | s += ", "; | 695 | s += ", "; |
696 | s += state; | 696 | s += state; |
diff --git a/libopie2/opiepim/otodo.cpp b/libopie2/opiepim/otodo.cpp index cde2b3d..b4d4aa9 100644 --- a/libopie2/opiepim/otodo.cpp +++ b/libopie2/opiepim/otodo.cpp | |||
@@ -194,129 +194,129 @@ void OTodo::setDueDate( const QDate& date ) | |||
194 | void OTodo::setStartDate( const QDate& date ) { | 194 | void OTodo::setStartDate( const QDate& date ) { |
195 | changeOrModify(); | 195 | changeOrModify(); |
196 | data->start = date; | 196 | data->start = date; |
197 | } | 197 | } |
198 | void OTodo::setCompletedDate( const QDate& date ) { | 198 | void OTodo::setCompletedDate( const QDate& date ) { |
199 | changeOrModify(); | 199 | changeOrModify(); |
200 | data->completed = date; | 200 | data->completed = date; |
201 | } | 201 | } |
202 | void OTodo::setState( const OPimState& state ) { | 202 | void OTodo::setState( const OPimState& state ) { |
203 | changeOrModify(); | 203 | changeOrModify(); |
204 | data->state = state; | 204 | data->state = state; |
205 | } | 205 | } |
206 | void OTodo::setRecurrence( const ORecur& rec) { | 206 | void OTodo::setRecurrence( const ORecur& rec) { |
207 | changeOrModify(); | 207 | changeOrModify(); |
208 | data->recur = rec; | 208 | data->recur = rec; |
209 | } | 209 | } |
210 | void OTodo::setMaintainer( const OPimMaintainer& pim ) { | 210 | void OTodo::setMaintainer( const OPimMaintainer& pim ) { |
211 | changeOrModify(); | 211 | changeOrModify(); |
212 | data->maintainer = pim; | 212 | data->maintainer = pim; |
213 | } | 213 | } |
214 | bool OTodo::isOverdue( ) | 214 | bool OTodo::isOverdue( ) |
215 | { | 215 | { |
216 | if( data->hasDate && !data->isCompleted) | 216 | if( data->hasDate && !data->isCompleted) |
217 | return QDate::currentDate() > data->date; | 217 | return QDate::currentDate() > data->date; |
218 | return false; | 218 | return false; |
219 | } | 219 | } |
220 | void OTodo::setProgress(ushort progress ) | 220 | void OTodo::setProgress(ushort progress ) |
221 | { | 221 | { |
222 | changeOrModify(); | 222 | changeOrModify(); |
223 | data->prog = progress; | 223 | data->prog = progress; |
224 | } | 224 | } |
225 | QString OTodo::toShortText() const { | 225 | QString OTodo::toShortText() const { |
226 | return summary(); | 226 | return summary(); |
227 | } | 227 | } |
228 | /*! | 228 | /*! |
229 | Returns a richt text string | 229 | Returns a richt text string |
230 | */ | 230 | */ |
231 | QString OTodo::toRichText() const | 231 | QString OTodo::toRichText() const |
232 | { | 232 | { |
233 | QString text; | 233 | QString text; |
234 | QStringList catlist; | 234 | QStringList catlist; |
235 | 235 | ||
236 | // Description of the todo | 236 | // Description of the todo |
237 | if ( !summary().isEmpty() ) { | 237 | if ( !summary().isEmpty() ) { |
238 | text += "<b>" + QObject::tr( "Summary:") + "</b><br>"; | 238 | text += "<b>" + QObject::tr( "Summary:") + "</b><br>"; |
239 | text += Qtopia::escapeString(summary() ).replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; | 239 | text += Qtopia::escapeString(summary() ).replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; |
240 | } | 240 | } |
241 | if( !description().isEmpty() ){ | 241 | if( !description().isEmpty() ){ |
242 | text += "<b>" + QObject::tr( "Description:" ) + "</b><br>"; | 242 | text += "<b>" + QObject::tr( "Description:" ) + "</b><br>"; |
243 | text += Qtopia::escapeString(description() ).replace(QRegExp( "[\n]"), "<br>" ) ; | 243 | text += Qtopia::escapeString(description() ).replace(QRegExp( "[\n]"), "<br>" ) ; |
244 | } | 244 | } |
245 | text += "<br><br><br>"; | 245 | text += "<br><br><br>"; |
246 | 246 | ||
247 | text += "<b>" + QObject::tr( "Priority:") +" </b>" | 247 | text += "<b>" + QObject::tr( "Priority:") +" </b>" |
248 | + QString::number( priority() ) + " <br>"; | 248 | + QString::number( priority() ) + " <br>"; |
249 | text += "<b>" + QObject::tr( "Progress:") + " </b>" | 249 | text += "<b>" + QObject::tr( "Progress:") + " </b>" |
250 | + QString::number( progress() ) + " %<br>"; | 250 | + QString::number( progress() ) + " %<br>"; |
251 | if (hasDueDate() ){ | 251 | if (hasDueDate() ){ |
252 | text += "<b>" + QObject::tr( "Deadline:") + " </b>"; | 252 | text += "<b>" + QObject::tr( "Deadline:") + " </b>"; |
253 | text += dueDate().toString(); | 253 | text += dueDate().toString(); |
254 | text += "<br>"; | 254 | text += "<br>"; |
255 | } | 255 | } |
256 | 256 | ||
257 | text += "<b>" + QObject::tr( "Category:") + "</b> "; | 257 | text += "<b>" + QObject::tr( "Category:") + "</b> "; |
258 | text += categoryNames().join(", "); | 258 | text += categoryNames( "Todo List" ).join(", "); |
259 | text += "<br>"; | 259 | text += "<br>"; |
260 | 260 | ||
261 | return text; | 261 | return text; |
262 | } | 262 | } |
263 | OPimNotifyManager& OTodo::notifiers() { | 263 | OPimNotifyManager& OTodo::notifiers() { |
264 | return data->notifiers; | 264 | return data->notifiers; |
265 | } | 265 | } |
266 | 266 | ||
267 | bool OTodo::operator<( const OTodo &toDoEvent )const{ | 267 | bool OTodo::operator<( const OTodo &toDoEvent )const{ |
268 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; | 268 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; |
269 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; | 269 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; |
270 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 270 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
271 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 271 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
272 | return priority() < toDoEvent.priority(); | 272 | return priority() < toDoEvent.priority(); |
273 | }else{ | 273 | }else{ |
274 | return dueDate() < toDoEvent.dueDate(); | 274 | return dueDate() < toDoEvent.dueDate(); |
275 | } | 275 | } |
276 | } | 276 | } |
277 | return false; | 277 | return false; |
278 | } | 278 | } |
279 | bool OTodo::operator<=(const OTodo &toDoEvent )const | 279 | bool OTodo::operator<=(const OTodo &toDoEvent )const |
280 | { | 280 | { |
281 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; | 281 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; |
282 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return true; | 282 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return true; |
283 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 283 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
284 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 284 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
285 | return priority() <= toDoEvent.priority(); | 285 | return priority() <= toDoEvent.priority(); |
286 | }else{ | 286 | }else{ |
287 | return dueDate() <= toDoEvent.dueDate(); | 287 | return dueDate() <= toDoEvent.dueDate(); |
288 | } | 288 | } |
289 | } | 289 | } |
290 | return true; | 290 | return true; |
291 | } | 291 | } |
292 | bool OTodo::operator>(const OTodo &toDoEvent )const | 292 | bool OTodo::operator>(const OTodo &toDoEvent )const |
293 | { | 293 | { |
294 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return false; | 294 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return false; |
295 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; | 295 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; |
296 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 296 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
297 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 297 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
298 | return priority() > toDoEvent.priority(); | 298 | return priority() > toDoEvent.priority(); |
299 | }else{ | 299 | }else{ |
300 | return dueDate() > toDoEvent.dueDate(); | 300 | return dueDate() > toDoEvent.dueDate(); |
301 | } | 301 | } |
302 | } | 302 | } |
303 | return false; | 303 | return false; |
304 | } | 304 | } |
305 | bool OTodo::operator>=(const OTodo &toDoEvent )const | 305 | bool OTodo::operator>=(const OTodo &toDoEvent )const |
306 | { | 306 | { |
307 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; | 307 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; |
308 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; | 308 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; |
309 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 309 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
310 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 310 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
311 | return priority() > toDoEvent.priority(); | 311 | return priority() > toDoEvent.priority(); |
312 | }else{ | 312 | }else{ |
313 | return dueDate() > toDoEvent.dueDate(); | 313 | return dueDate() > toDoEvent.dueDate(); |
314 | } | 314 | } |
315 | } | 315 | } |
316 | return true; | 316 | return true; |
317 | } | 317 | } |
318 | bool OTodo::operator==(const OTodo &toDoEvent )const | 318 | bool OTodo::operator==(const OTodo &toDoEvent )const |
319 | { | 319 | { |
320 | if ( data->priority != toDoEvent.data->priority ) return false; | 320 | if ( data->priority != toDoEvent.data->priority ) return false; |
321 | if ( data->priority != toDoEvent.data->prog ) return false; | 321 | if ( data->priority != toDoEvent.data->prog ) return false; |
322 | if ( data->isCompleted != toDoEvent.data->isCompleted ) return false; | 322 | if ( data->isCompleted != toDoEvent.data->isCompleted ) return false; |