author | ulf69 <ulf69> | 2004-07-13 15:07:00 (UTC) |
---|---|---|
committer | ulf69 <ulf69> | 2004-07-13 15:07:00 (UTC) |
commit | 02380b50374340283fe9dd0f804254ee17374347 (patch) (side-by-side diff) | |
tree | 83928927651c22dd0231195f84b0614ba6442254 /kabc | |
parent | f88d48384d2c012fbaa3ffaa613d6eaa3694fab7 (diff) | |
download | kdepimpi-02380b50374340283fe9dd0f804254ee17374347.zip kdepimpi-02380b50374340283fe9dd0f804254ee17374347.tar.gz kdepimpi-02380b50374340283fe9dd0f804254ee17374347.tar.bz2 |
more changes to resolve the "other" problematic.
e.g. home+pref was shown as "other".
-rw-r--r-- | kabc/phonenumber.cpp | 107 |
1 files changed, 47 insertions, 60 deletions
diff --git a/kabc/phonenumber.cpp b/kabc/phonenumber.cpp index 04b1168..3f641d1 100644 --- a/kabc/phonenumber.cpp +++ b/kabc/phonenumber.cpp @@ -134,73 +134,60 @@ QString PhoneNumber::label( int type ) { return typeLabel( type ); } QString PhoneNumber::typeLabel( int type ) { - switch ( type ) { - case Home: - return i18n("Home phone", "Home"); - break; - case Work: - return i18n("Work phone", "Work"); - break; - case Msg: - return i18n("Messenger"); - break; - case Pref: - return i18n("Preferred Number"); - break; - case Voice: - return i18n("Voice"); - break; - case Fax: - return i18n("Fax"); - break; - case Cell: - return i18n("Mobile Phone" ); - break; - case Cell | Home: - return i18n("Home Mobile" ); - break; - case Cell | Work: - return i18n("Home Mobile" ); - break; - case Video: - return i18n("Video"); - break; - case Bbs: - return i18n("Mailbox"); - break; - case Modem: - return i18n("Modem"); - break; - case Car: - return i18n("Car Phone", "Car" ); - break; - case Isdn: - return i18n("ISDN"); - break; - case Pcs: - return i18n("PCS"); - break; - case Pager: - return i18n("Pager"); - break; - case Work | Pager: - return i18n("Work Pager"); - break; - case Home | Fax: - return i18n("Home Fax"); - break; - case Work | Fax: - return i18n("Work Fax"); - break; - default: - return i18n("Other"); + QString typeString; + + if ((type & Home) == Home) + typeString += i18n("Home"); + else if ((type & Work) == Work) + typeString += i18n("Work"); + + if (!typeString.isEmpty()) + typeString += " "; + + if ((type & Cell) == Cell) + typeString += i18n("Mobile"); + else if ((type & Fax) == Fax) + typeString += i18n("Fax"); + else if ((type & Msg) == Msg) + typeString += i18n("Messenger"); + else if ((type & Voice) == Voice) { +// add nothing in case of the Voice flag +// typeString += i18n("Voice"); } + else if ((type & Video) == Video) + typeString += i18n("Video"); + else if ((type & Bbs) == Bbs) + typeString += i18n("Mailbox"); + else if ((type & Modem) == Modem) + typeString += i18n("Modem"); + else if ((type & Car) == Car) + typeString += i18n("Car"); + else if ((type & Isdn) == Isdn) + typeString += i18n("ISDN"); + else if ((type & Pcs) == Pcs) + typeString += i18n("PCS"); + else if ((type & Pager) == Pager) + typeString += i18n("Pager"); + + // add the prefered flag + if (!typeString.isEmpty()) + typeString += " "; + + if ((type & Pref) == Pref) + typeString += i18n("(Preferred)"); + + //if we still have no match, return "other" + if (typeString.isEmpty()) + return i18n("Other"); + + + return typeString; } QDataStream &KABC::operator<<( QDataStream &s, const PhoneNumber &phone ) { return s << phone.mId << phone.mType << phone.mNumber; } |