author | zautrix <zautrix> | 2004-10-22 02:21:29 (UTC) |
---|---|---|
committer | zautrix <zautrix> | 2004-10-22 02:21:29 (UTC) |
commit | c17118a0b2da49ec633e21cdcd51798c0c38644a (patch) (unidiff) | |
tree | 581fbcaa64a5566991ffe0bd3b1b2d428589d87f /kabc/addresseeview.cpp | |
parent | d6f9bd535e8cabe653bdff329500f9153e5e11fb (diff) | |
download | kdepimpi-c17118a0b2da49ec633e21cdcd51798c0c38644a.zip kdepimpi-c17118a0b2da49ec633e21cdcd51798c0c38644a.tar.gz kdepimpi-c17118a0b2da49ec633e21cdcd51798c0c38644a.tar.bz2 |
made addressbook much faster
-rw-r--r-- | kabc/addresseeview.cpp | 28 |
1 files changed, 13 insertions, 15 deletions
diff --git a/kabc/addresseeview.cpp b/kabc/addresseeview.cpp index 90be928..7a4336b 100644 --- a/kabc/addresseeview.cpp +++ b/kabc/addresseeview.cpp | |||
@@ -73,83 +73,80 @@ void AddresseeView::setSource(const QString& n) | |||
73 | //qDebug("********AddresseeView::setSource %s", n.latin1()); | 73 | //qDebug("********AddresseeView::setSource %s", n.latin1()); |
74 | 74 | ||
75 | if ( n.left( 6 ) == "mailto" ) | 75 | if ( n.left( 6 ) == "mailto" ) |
76 | ExternalAppHandler::instance()->mailToOneContact( n.mid(7) ); | 76 | ExternalAppHandler::instance()->mailToOneContact( n.mid(7) ); |
77 | else if ( n.left( 7 ) == "phoneto" ) | 77 | else if ( n.left( 7 ) == "phoneto" ) |
78 | ExternalAppHandler::instance()->callByPhone( n.mid(8) ); | 78 | ExternalAppHandler::instance()->callByPhone( n.mid(8) ); |
79 | else if ( n.left( 5 ) == "faxto" ) | 79 | else if ( n.left( 5 ) == "faxto" ) |
80 | ExternalAppHandler::instance()->callByFax( n.mid(6) ); | 80 | ExternalAppHandler::instance()->callByFax( n.mid(6) ); |
81 | else if ( n.left( 5 ) == "smsto" ) | 81 | else if ( n.left( 5 ) == "smsto" ) |
82 | ExternalAppHandler::instance()->callBySMS( n.mid(6) ); | 82 | ExternalAppHandler::instance()->callBySMS( n.mid(6) ); |
83 | else if ( n.left( 7 ) == "pagerto" ) | 83 | else if ( n.left( 7 ) == "pagerto" ) |
84 | ExternalAppHandler::instance()->callByPager( n.mid(8) ); | 84 | ExternalAppHandler::instance()->callByPager( n.mid(8) ); |
85 | else if ( n.left( 5 ) == "sipto" ) | 85 | else if ( n.left( 5 ) == "sipto" ) |
86 | ExternalAppHandler::instance()->callBySIP( n.mid(6) ); | 86 | ExternalAppHandler::instance()->callBySIP( n.mid(6) ); |
87 | 87 | ||
88 | } | 88 | } |
89 | void AddresseeView::setAddressee( const KABC::Addressee& addr ) | 89 | void AddresseeView::setAddressee( const KABC::Addressee& mAddressee ) |
90 | { | 90 | { |
91 | ExternalAppHandler* eah = ExternalAppHandler::instance(); | 91 | bool kemailAvail = ExternalAppHandler::instance()->isEmailAppAvailable(); |
92 | bool kemailAvail = eah->isEmailAppAvailable(); | 92 | // mAddressee = addr; |
93 | |||
94 | |||
95 | |||
96 | mAddressee = addr; | ||
97 | // clear view | 93 | // clear view |
98 | setText( QString::null ); | 94 | //setText( QString::null ); |
99 | |||
100 | if ( mAddressee.isEmpty() ) | ||
101 | return; | ||
102 | 95 | ||
96 | if ( mAddressee.isEmpty() ) { | ||
97 | setText( QString::null); | ||
98 | return; | ||
99 | } | ||
103 | QString name = ( mAddressee.assembledName().isEmpty() ? | 100 | QString name = ( mAddressee.assembledName().isEmpty() ? |
104 | mAddressee.formattedName() : mAddressee.assembledName() ); | 101 | mAddressee.formattedName() : mAddressee.assembledName() ); |
105 | 102 | ||
106 | QString dynamicPart; | 103 | QString dynamicPart; |
107 | 104 | ||
108 | dynamicPart += getPhoneNumbers( true ); | 105 | dynamicPart += getPhoneNumbers( mAddressee.phoneNumbers(),true ); |
109 | QStringList emails = mAddressee.emails(); | 106 | QStringList emails = mAddressee.emails(); |
110 | QStringList::ConstIterator emailIt; | 107 | QStringList::ConstIterator emailIt; |
111 | QString type = i18n( "Email" ); | 108 | QString type = i18n( "Email" ); |
112 | emailIt = emails.begin(); | 109 | emailIt = emails.begin(); |
113 | if ( emailIt != emails.end() ) { | 110 | if ( emailIt != emails.end() ) { |
114 | if ( kemailAvail ) { | 111 | if ( kemailAvail ) { |
115 | dynamicPart += QString( | 112 | dynamicPart += QString( |
116 | "<tr><td align=\"right\"><b>%1</b></td>" | 113 | "<tr><td align=\"right\"><b>%1</b></td>" |
117 | "<td align=\"left\"><a href=\"mailto:%2 <%3> \">%4</a></td></tr>" ) | 114 | "<td align=\"left\"><a href=\"mailto:%2 <%3> \">%4</a></td></tr>" ) |
118 | .arg( type ) | 115 | .arg( type ) |
119 | .arg( name ) | 116 | .arg( name ) |
120 | .arg( *emailIt ) | 117 | .arg( *emailIt ) |
121 | .arg( *emailIt ); | 118 | .arg( *emailIt ); |
122 | ++emailIt; | 119 | ++emailIt; |
123 | } else { | 120 | } else { |
124 | dynamicPart += QString( | 121 | dynamicPart += QString( |
125 | "<tr><td align=\"right\"><b>%1</b></td>" | 122 | "<tr><td align=\"right\"><b>%1</b></td>" |
126 | "<td align=\"left\">%2</td></tr>" ) | 123 | "<td align=\"left\">%2</td></tr>" ) |
127 | .arg( type ) | 124 | .arg( type ) |
128 | .arg( *emailIt ); | 125 | .arg( *emailIt ); |
129 | ++emailIt; | 126 | ++emailIt; |
130 | } | 127 | } |
131 | } | 128 | } |
132 | if ( mAddressee.birthday().date().isValid() ) { | 129 | if ( mAddressee.birthday().date().isValid() ) { |
133 | dynamicPart += QString( | 130 | dynamicPart += QString( |
134 | "<tr><td align=\"right\"><b>%1</b></td>" | 131 | "<tr><td align=\"right\"><b>%1</b></td>" |
135 | "<td align=\"left\">%2</td></tr>" ) | 132 | "<td align=\"left\">%2</td></tr>" ) |
136 | .arg( i18n ("Birthday") ) | 133 | .arg( i18n ("Birthday") ) |
137 | .arg( KGlobal::locale()->formatDate( mAddressee.birthday().date() ,true) ); | 134 | .arg( KGlobal::locale()->formatDate( mAddressee.birthday().date() ,true) ); |
138 | } | 135 | } |
139 | dynamicPart += getPhoneNumbers( false ); | 136 | dynamicPart += getPhoneNumbers( mAddressee.phoneNumbers(), false ); |
140 | 137 | ||
141 | for ( ; emailIt != emails.end(); ++emailIt ) { | 138 | for ( ; emailIt != emails.end(); ++emailIt ) { |
142 | if ( kemailAvail ) { | 139 | if ( kemailAvail ) { |
143 | dynamicPart += QString( | 140 | dynamicPart += QString( |
144 | "<tr><td align=\"right\"><b>%1</b></td>" | 141 | "<tr><td align=\"right\"><b>%1</b></td>" |
145 | "<td align=\"left\"><a href=\"mailto:%2 <%3> \">%4</a></td></tr>" ) | 142 | "<td align=\"left\"><a href=\"mailto:%2 <%3> \">%4</a></td></tr>" ) |
146 | .arg( type ) | 143 | .arg( type ) |
147 | .arg( name ) | 144 | .arg( name ) |
148 | .arg( *emailIt ) | 145 | .arg( *emailIt ) |
149 | .arg( *emailIt ); | 146 | .arg( *emailIt ); |
150 | } else { | 147 | } else { |
151 | dynamicPart += QString( | 148 | dynamicPart += QString( |
152 | "<tr><td align=\"right\"><b>%1</b></td>" | 149 | "<tr><td align=\"right\"><b>%1</b></td>" |
153 | "<td align=\"left\">%2</td></tr>" ) | 150 | "<td align=\"left\">%2</td></tr>" ) |
154 | .arg( type ) | 151 | .arg( type ) |
155 | .arg( *emailIt ); | 152 | .arg( *emailIt ); |
@@ -295,42 +292,41 @@ mText = "<table width=\"100%\">\n"; | |||
295 | if ( ! mAddressee.organization().isEmpty() ) | 292 | if ( ! mAddressee.organization().isEmpty() ) |
296 | mText += QString("<tr><td align=\"right\"><b>%1</b></td>" | 293 | mText += QString("<tr><td align=\"right\"><b>%1</b></td>" |
297 | "<td align=\"left\">%2</td></tr>" ) | 294 | "<td align=\"left\">%2</td></tr>" ) |
298 | .arg( i18n(" ") ) | 295 | .arg( i18n(" ") ) |
299 | .arg( mAddressee.organization()); | 296 | .arg( mAddressee.organization()); |
300 | mText += dynamicPart; | 297 | mText += dynamicPart; |
301 | mText += notes; | 298 | mText += notes; |
302 | mText += "</table>"; | 299 | mText += "</table>"; |
303 | 300 | ||
304 | } | 301 | } |
305 | 302 | ||
306 | // at last display it... | 303 | // at last display it... |
307 | setText( mText ); | 304 | setText( mText ); |
308 | 305 | ||
309 | } | 306 | } |
310 | 307 | ||
311 | QString AddresseeView::getPhoneNumbers( bool preferred ) | 308 | QString AddresseeView::getPhoneNumbers( KABC::PhoneNumber::List phones ,bool preferred ) |
312 | { | 309 | { |
313 | ExternalAppHandler* eah = ExternalAppHandler::instance(); | 310 | ExternalAppHandler* eah = ExternalAppHandler::instance(); |
314 | bool kphoneAvail = eah->isPhoneAppAvailable(); | 311 | bool kphoneAvail = eah->isPhoneAppAvailable(); |
315 | bool kfaxAvail = eah->isFaxAppAvailable(); | 312 | bool kfaxAvail = eah->isFaxAppAvailable(); |
316 | bool ksmsAvail = eah->isSMSAppAvailable(); | 313 | bool ksmsAvail = eah->isSMSAppAvailable(); |
317 | bool kpagerAvail = eah->isPagerAppAvailable(); | 314 | bool kpagerAvail = eah->isPagerAppAvailable(); |
318 | bool ksipAvail = eah->isSIPAppAvailable(); | 315 | bool ksipAvail = eah->isSIPAppAvailable(); |
319 | QString dynamicPart; | 316 | QString dynamicPart; |
320 | KABC::PhoneNumber::List phones = mAddressee.phoneNumbers(); | ||
321 | KABC::PhoneNumber::List::ConstIterator phoneIt; | 317 | KABC::PhoneNumber::List::ConstIterator phoneIt; |
322 | QString extension; | 318 | QString extension; |
323 | int phonetype; | 319 | int phonetype; |
324 | QString sms; | 320 | QString sms; |
325 | for ( phoneIt = phones.begin(); phoneIt != phones.end(); ++phoneIt ) { | 321 | for ( phoneIt = phones.begin(); phoneIt != phones.end(); ++phoneIt ) { |
326 | phonetype = (*phoneIt).type(); | 322 | phonetype = (*phoneIt).type(); |
327 | if ( ((phonetype & KABC::PhoneNumber::Pref) == 0 ) == preferred ) | 323 | if ( ((phonetype & KABC::PhoneNumber::Pref) == 0 ) == preferred ) |
328 | continue; | 324 | continue; |
329 | if (ksmsAvail && | 325 | if (ksmsAvail && |
330 | ( | 326 | ( |
331 | ((phonetype & KABC::PhoneNumber::Car) == KABC::PhoneNumber::Car) || | 327 | ((phonetype & KABC::PhoneNumber::Car) == KABC::PhoneNumber::Car) || |
332 | ((phonetype & KABC::PhoneNumber::Cell) == KABC::PhoneNumber::Cell) | 328 | ((phonetype & KABC::PhoneNumber::Cell) == KABC::PhoneNumber::Cell) |
333 | ) | 329 | ) |
334 | ) | 330 | ) |
335 | { | 331 | { |
336 | sms = QString("<a href=\"smsto:%1 \">(sms)</a>" ) | 332 | sms = QString("<a href=\"smsto:%1 \">(sms)</a>" ) |
@@ -364,36 +360,38 @@ QString AddresseeView::getPhoneNumbers( bool preferred ) | |||
364 | .arg( extension ) | 360 | .arg( extension ) |
365 | .arg( (*phoneIt).number() ) | 361 | .arg( (*phoneIt).number() ) |
366 | .arg( (*phoneIt).number() ) | 362 | .arg( (*phoneIt).number() ) |
367 | .arg( sms ); | 363 | .arg( sms ); |
368 | 364 | ||
369 | } else { | 365 | } else { |
370 | dynamicPart += QString( | 366 | dynamicPart += QString( |
371 | "<tr><td align=\"right\"><b>%1</b></td>" | 367 | "<tr><td align=\"right\"><b>%1</b></td>" |
372 | "<td align=\"left\">%2 %3</td></tr>" ) | 368 | "<td align=\"left\">%2 %3</td></tr>" ) |
373 | .arg( KABC::PhoneNumber::typeLabel( phonetype ) ) | 369 | .arg( KABC::PhoneNumber::typeLabel( phonetype ) ) |
374 | .arg( (*phoneIt).number() ) | 370 | .arg( (*phoneIt).number() ) |
375 | .arg( sms ); | 371 | .arg( sms ); |
376 | } | 372 | } |
377 | } | 373 | } |
378 | return dynamicPart; | 374 | return dynamicPart; |
379 | } | 375 | } |
376 | /* | ||
380 | KABC::Addressee AddresseeView::addressee() const | 377 | KABC::Addressee AddresseeView::addressee() const |
381 | { | 378 | { |
382 | return mAddressee; | 379 | return mAddressee; |
383 | } | 380 | } |
381 | */ | ||
384 | void AddresseeView::addTag(const QString & tag,const QString & text) | 382 | void AddresseeView::addTag(const QString & tag,const QString & text) |
385 | { | 383 | { |
386 | if ( text.isEmpty() ) | 384 | if ( text.isEmpty() ) |
387 | return; | 385 | return; |
388 | int number=text.contains("\n"); | 386 | int number=text.contains("\n"); |
389 | QString str = "<" + tag + ">"; | 387 | QString str = "<" + tag + ">"; |
390 | QString tmpText=text; | 388 | QString tmpText=text; |
391 | QString tmpStr=str; | 389 | QString tmpStr=str; |
392 | if(number !=-1) | 390 | if(number !=-1) |
393 | { | 391 | { |
394 | if (number > 0) { | 392 | if (number > 0) { |
395 | int pos=0; | 393 | int pos=0; |
396 | QString tmp; | 394 | QString tmp; |
397 | for(int i=0;i<=number;i++) { | 395 | for(int i=0;i<=number;i++) { |
398 | pos=tmpText.find("\n"); | 396 | pos=tmpText.find("\n"); |
399 | tmp=tmpText.left(pos); | 397 | tmp=tmpText.left(pos); |