-rw-r--r-- | bin/kdepim/WhatsNew.txt | 4 | ||||
-rw-r--r-- | kabc/addresseeview.cpp | 28 |
2 files changed, 31 insertions, 1 deletions
diff --git a/bin/kdepim/WhatsNew.txt b/bin/kdepim/WhatsNew.txt index d75ff7e..013c3f8 100644 --- a/bin/kdepim/WhatsNew.txt +++ b/bin/kdepim/WhatsNew.txt | |||
@@ -1,34 +1,38 @@ | |||
1 | Info about the changes in new versions of KDE-Pim/Pi | 1 | Info about the changes in new versions of KDE-Pim/Pi |
2 | 2 | ||
3 | ********** VERSION 2.2.1 ************ | 3 | ********** VERSION 2.2.1 ************ |
4 | 4 | ||
5 | KO/Pi: | 5 | KO/Pi: |
6 | Fixed a problem displaying very long allday events in agenda view in single day mode. | 6 | Fixed a problem displaying very long allday events in agenda view in single day mode. |
7 | Fixed a problem with the default settings for new todos. | 7 | Fixed a problem with the default settings for new todos. |
8 | Added an error message dialog if saving of calendar files is not possible. | 8 | Added an error message dialog if saving of calendar files is not possible. |
9 | Made it impossible to close KO/Pi if saving fails. | 9 | Made it impossible to close KO/Pi if saving fails. |
10 | Fixed a problem adding calendars on windows such that these calendars can be used on the memory stick. | 10 | Fixed a problem adding calendars on windows such that these calendars can be used on the memory stick. |
11 | Added config options for conflict detection. | 11 | Added config options for conflict detection. |
12 | 12 | ||
13 | KA/Pi: | 13 | KA/Pi: |
14 | Added a config option to turn on asking before a contact is deleted. | 14 | Added a config option to turn on asking before a contact is deleted. |
15 | Fixed a problem with the default view and view selection at startup. | 15 | Fixed a problem with the default view and view selection at startup. |
16 | Formatted name is now set on import, if formatted name is empty. | 16 | Formatted name is now set on import, if formatted name is empty. |
17 | Fixed a problem of displaying images in the contact details view: | ||
18 | Now the wid/hei ratio is not changed. | ||
19 | I a picture is larger than 128 pixels in wid or hei it is downscaled to | ||
20 | max 128 pixels wid/hei. | ||
17 | 21 | ||
18 | ********** VERSION 2.2.0 ************ | 22 | ********** VERSION 2.2.0 ************ |
19 | 23 | ||
20 | New stable release! | 24 | New stable release! |
21 | Fixed some minor usability problems. | 25 | Fixed some minor usability problems. |
22 | Added writing of next alarm to a file for usage on pdaXrom. | 26 | Added writing of next alarm to a file for usage on pdaXrom. |
23 | 27 | ||
24 | 28 | ||
25 | ************************************* | 29 | ************************************* |
26 | 30 | ||
27 | You can find the complete changelog | 31 | You can find the complete changelog |
28 | from version 1.7.7 to 2.2.0 | 32 | from version 1.7.7 to 2.2.0 |
29 | in the source package or on | 33 | in the source package or on |
30 | 34 | ||
31 | http://www.pi-sync.net/html/changelog.html | 35 | http://www.pi-sync.net/html/changelog.html |
32 | 36 | ||
33 | 37 | ||
34 | 38 | ||
diff --git a/kabc/addresseeview.cpp b/kabc/addresseeview.cpp index f3cfb23..05d604f 100644 --- a/kabc/addresseeview.cpp +++ b/kabc/addresseeview.cpp | |||
@@ -265,269 +265,295 @@ void AddresseeView::setAddressee( const KABC::Addressee& mAddressee ) | |||
265 | if ( !tempX.isEmpty() ) { | 265 | if ( !tempX.isEmpty() ) { |
266 | notes += QString( | 266 | notes += QString( |
267 | "<tr><td align=\"right\"><b>%1</b></td>" | 267 | "<tr><td align=\"right\"><b>%1</b></td>" |
268 | "<td align=\"left\">%2</td></tr>" ) | 268 | "<td align=\"left\">%2</td></tr>" ) |
269 | .arg( i18n( "Profession" ) ) | 269 | .arg( i18n( "Profession" ) ) |
270 | .arg( tempX ); | 270 | .arg( tempX ); |
271 | } | 271 | } |
272 | tempX = mAddressee.custom( "KADDRESSBOOK", "X-Office" ); | 272 | tempX = mAddressee.custom( "KADDRESSBOOK", "X-Office" ); |
273 | if ( !tempX.isEmpty() ) { | 273 | if ( !tempX.isEmpty() ) { |
274 | notes += QString( | 274 | notes += QString( |
275 | "<tr><td align=\"right\"><b>%1</b></td>" | 275 | "<tr><td align=\"right\"><b>%1</b></td>" |
276 | "<td align=\"left\">%2</td></tr>" ) | 276 | "<td align=\"left\">%2</td></tr>" ) |
277 | .arg( i18n( "Office" ) ) | 277 | .arg( i18n( "Office" ) ) |
278 | .arg( tempX ); | 278 | .arg( tempX ); |
279 | } | 279 | } |
280 | tempX = mAddressee.custom( "KADDRESSBOOK", "X-Department" ); | 280 | tempX = mAddressee.custom( "KADDRESSBOOK", "X-Department" ); |
281 | if ( !tempX.isEmpty() ) { | 281 | if ( !tempX.isEmpty() ) { |
282 | notes += QString( | 282 | notes += QString( |
283 | "<tr><td align=\"right\"><b>%1</b></td>" | 283 | "<tr><td align=\"right\"><b>%1</b></td>" |
284 | "<td align=\"left\">%2</td></tr>" ) | 284 | "<td align=\"left\">%2</td></tr>" ) |
285 | .arg( i18n( "Department" ) ) | 285 | .arg( i18n( "Department" ) ) |
286 | .arg( tempX ); | 286 | .arg( tempX ); |
287 | } | 287 | } |
288 | 288 | ||
289 | tempX = mAddressee.custom( "KADDRESSBOOK", "X-ManagersName" ); | 289 | tempX = mAddressee.custom( "KADDRESSBOOK", "X-ManagersName" ); |
290 | if ( !tempX.isEmpty() ) { | 290 | if ( !tempX.isEmpty() ) { |
291 | notes += QString( | 291 | notes += QString( |
292 | "<tr><td align=\"right\"><b>%1</b></td>" | 292 | "<tr><td align=\"right\"><b>%1</b></td>" |
293 | "<td align=\"left\">%2</td></tr>" ) | 293 | "<td align=\"left\">%2</td></tr>" ) |
294 | .arg( i18n( "Manager" ) ) | 294 | .arg( i18n( "Manager" ) ) |
295 | .arg( tempX ); | 295 | .arg( tempX ); |
296 | } | 296 | } |
297 | tempX = mAddressee.custom( "KADDRESSBOOK", "X-AssistantsName" ); | 297 | tempX = mAddressee.custom( "KADDRESSBOOK", "X-AssistantsName" ); |
298 | if ( !tempX.isEmpty() ) { | 298 | if ( !tempX.isEmpty() ) { |
299 | notes += QString( | 299 | notes += QString( |
300 | "<tr><td align=\"right\"><b>%1</b></td>" | 300 | "<tr><td align=\"right\"><b>%1</b></td>" |
301 | "<td align=\"left\">%2</td></tr>" ) | 301 | "<td align=\"left\">%2</td></tr>" ) |
302 | .arg( i18n( "Assistant" ) ) | 302 | .arg( i18n( "Assistant" ) ) |
303 | .arg( tempX ); | 303 | .arg( tempX ); |
304 | } | 304 | } |
305 | if ( !mAddressee.url().url().isEmpty() ) { | 305 | if ( !mAddressee.url().url().isEmpty() ) { |
306 | notes += QString( | 306 | notes += QString( |
307 | "<tr><td align=\"right\"><b>%1</b></td>" | 307 | "<tr><td align=\"right\"><b>%1</b></td>" |
308 | "<td align=\"left\">%2</td></tr>" ) | 308 | "<td align=\"left\">%2</td></tr>" ) |
309 | .arg( i18n( "Homepage" ) ) | 309 | .arg( i18n( "Homepage" ) ) |
310 | .arg( mAddressee.url().url() ); | 310 | .arg( mAddressee.url().url() ); |
311 | } | 311 | } |
312 | tempX = mAddressee.nickName(); | 312 | tempX = mAddressee.nickName(); |
313 | if ( !tempX.isEmpty() ) { | 313 | if ( !tempX.isEmpty() ) { |
314 | notes += QString( | 314 | notes += QString( |
315 | "<tr><td align=\"right\"><b>%1</b></td>" | 315 | "<tr><td align=\"right\"><b>%1</b></td>" |
316 | "<td align=\"left\">%2</td></tr>" ) | 316 | "<td align=\"left\">%2</td></tr>" ) |
317 | .arg( i18n( "Nickname" ) ) | 317 | .arg( i18n( "Nickname" ) ) |
318 | .arg( tempX ); | 318 | .arg( tempX ); |
319 | } | 319 | } |
320 | tempX = mAddressee.custom( "KADDRESSBOOK", "X-IMAddress" ); | 320 | tempX = mAddressee.custom( "KADDRESSBOOK", "X-IMAddress" ); |
321 | if ( !tempX.isEmpty() ) { | 321 | if ( !tempX.isEmpty() ) { |
322 | notes += QString( | 322 | notes += QString( |
323 | "<tr><td align=\"right\"><b>%1</b></td>" | 323 | "<tr><td align=\"right\"><b>%1</b></td>" |
324 | "<td align=\"left\">%2</td></tr>" ) | 324 | "<td align=\"left\">%2</td></tr>" ) |
325 | .arg( i18n( "Messanger" ) ) | 325 | .arg( i18n( "Messanger" ) ) |
326 | .arg( tempX ); | 326 | .arg( tempX ); |
327 | } | 327 | } |
328 | 328 | ||
329 | tempX = mAddressee.custom( "KADDRESSBOOK", "X-Anniversary" ); | 329 | tempX = mAddressee.custom( "KADDRESSBOOK", "X-Anniversary" ); |
330 | if ( !tempX.isEmpty() ) { | 330 | if ( !tempX.isEmpty() ) { |
331 | QDate dt = KGlobal::locale()->readDate( tempX, "%Y-%m-%d"); | 331 | QDate dt = KGlobal::locale()->readDate( tempX, "%Y-%m-%d"); |
332 | if ( dt.isValid () ) { | 332 | if ( dt.isValid () ) { |
333 | tempX = KGlobal::locale()->formatDate(dt, true); | 333 | tempX = KGlobal::locale()->formatDate(dt, true); |
334 | notes += QString( | 334 | notes += QString( |
335 | "<tr><td align=\"right\"><b>%1</b></td>" | 335 | "<tr><td align=\"right\"><b>%1</b></td>" |
336 | "<td align=\"left\">%2</td></tr>" ) | 336 | "<td align=\"left\">%2</td></tr>" ) |
337 | .arg( i18n( "Anniversary" ) ) | 337 | .arg( i18n( "Anniversary" ) ) |
338 | .arg( tempX ); | 338 | .arg( tempX ); |
339 | } | 339 | } |
340 | } | 340 | } |
341 | tempX = mAddressee.custom( "KADDRESSBOOK", "X-SpousesName" ); | 341 | tempX = mAddressee.custom( "KADDRESSBOOK", "X-SpousesName" ); |
342 | if ( !tempX.isEmpty() ) { | 342 | if ( !tempX.isEmpty() ) { |
343 | notes += QString( | 343 | notes += QString( |
344 | "<tr><td align=\"right\"><b>%1</b></td>" | 344 | "<tr><td align=\"right\"><b>%1</b></td>" |
345 | "<td align=\"left\">%2</td></tr>" ) | 345 | "<td align=\"left\">%2</td></tr>" ) |
346 | .arg( i18n( "Spouse" ) ) | 346 | .arg( i18n( "Spouse" ) ) |
347 | .arg( tempX ); | 347 | .arg( tempX ); |
348 | } | 348 | } |
349 | tempX = mAddressee.custom( "KADDRESSBOOK", "X-Children" ); | 349 | tempX = mAddressee.custom( "KADDRESSBOOK", "X-Children" ); |
350 | if ( !tempX.isEmpty() ) { | 350 | if ( !tempX.isEmpty() ) { |
351 | notes += QString( | 351 | notes += QString( |
352 | "<tr><td align=\"right\"><b>%1</b></td>" | 352 | "<tr><td align=\"right\"><b>%1</b></td>" |
353 | "<td align=\"left\">%2</td></tr>" ) | 353 | "<td align=\"left\">%2</td></tr>" ) |
354 | .arg( i18n( "Children" ) ) | 354 | .arg( i18n( "Children" ) ) |
355 | .arg( tempX ); | 355 | .arg( tempX ); |
356 | } | 356 | } |
357 | 357 | ||
358 | if ( !mAddressee.note().isEmpty() ) { | 358 | if ( !mAddressee.note().isEmpty() ) { |
359 | notes += QString( | 359 | notes += QString( |
360 | "<tr>" | 360 | "<tr>" |
361 | "<td align=\"right\" valign=\"top\"><b>%1</b></td>" // note label | 361 | "<td align=\"right\" valign=\"top\"><b>%1</b></td>" // note label |
362 | "<td align=\"left\">%2</td>" // note | 362 | "<td align=\"left\">%2</td>" // note |
363 | "</tr>" ).arg( i18n( "Notes" ) ) | 363 | "</tr>" ).arg( i18n( "Notes" ) ) |
364 | //US .arg( mAddressee.note().replace( '\n', "<br>" ) ); | 364 | //US .arg( mAddressee.note().replace( '\n', "<br>" ) ); |
365 | .arg( mAddressee.note().replace( QRegExp("\n"), "<br>" ) ); | 365 | .arg( mAddressee.note().replace( QRegExp("\n"), "<br>" ) ); |
366 | //qDebug("AddresseeView::setAddressee has to be verified."); | 366 | //qDebug("AddresseeView::setAddressee has to be verified."); |
367 | } | 367 | } |
368 | } else { | 368 | } else { |
369 | notes = QString( | 369 | notes = QString( |
370 | "<tr><td align=\"right\"><b>%1</b></td>" | 370 | "<tr><td align=\"right\"><b>%1</b></td>" |
371 | "<td align=\"left\"><a href=\"allDetails\">%4</a></td></tr>" ) | 371 | "<td align=\"left\"><a href=\"allDetails\">%4</a></td></tr>" ) |
372 | .arg( i18n("Details") ) | 372 | .arg( i18n("Details") ) |
373 | .arg( i18n("Show!") ); | 373 | .arg( i18n("Show!") ); |
374 | 374 | ||
375 | 375 | ||
376 | } | 376 | } |
377 | 377 | ||
378 | QString aRole = ""; | 378 | QString aRole = ""; |
379 | QString aOrga = ""; | 379 | QString aOrga = ""; |
380 | if ( true /*!mAddressee.role().isEmpty()*/ ) { | 380 | if ( true /*!mAddressee.role().isEmpty()*/ ) { |
381 | aRole = "<tr>" | 381 | aRole = "<tr>" |
382 | "<td align=\"left\">" + mAddressee.role() + "</td>" | 382 | "<td align=\"left\">" + mAddressee.role() + "</td>" |
383 | "</tr>"; | 383 | "</tr>"; |
384 | } | 384 | } |
385 | if ( true /*!mAddressee.organization().isEmpty()*/ ) { | 385 | if ( true /*!mAddressee.organization().isEmpty()*/ ) { |
386 | aOrga = "<tr>" | 386 | aOrga = "<tr>" |
387 | "<td align=\"left\">" + mAddressee.organization() + "</td>" | 387 | "<td align=\"left\">" + mAddressee.organization() + "</td>" |
388 | "</tr>"; | 388 | "</tr>"; |
389 | } | 389 | } |
390 | mText = ""; | 390 | mText = ""; |
391 | QString picString = ""; | 391 | QString picString = ""; |
392 | KABC::Picture picture = mAddressee.photo(); | 392 | KABC::Picture picture = mAddressee.photo(); |
393 | if (picture.undefined() ) picture = mAddressee.logo(); | ||
393 | bool picAvailintern = false; | 394 | bool picAvailintern = false; |
394 | bool picAvailUrl = false; | 395 | bool picAvailUrl = false; |
395 | if (! picture.undefined() ) { | 396 | if (! picture.undefined() ) { |
396 | picAvailintern = (picture.isIntern() && !picture.data().isNull()); | 397 | picAvailintern = (picture.isIntern() && !picture.data().isNull()); |
397 | picAvailUrl = !picture.isIntern() && QFile::exists(picture.url() ); | 398 | picAvailUrl = !picture.isIntern() && QFile::exists(picture.url() ); |
398 | } | 399 | } |
399 | if ( picAvailUrl || picAvailintern || QApplication::desktop()->width() > 320 ) { | 400 | if ( picAvailUrl || picAvailintern || QApplication::desktop()->width() > 320 ) { |
400 | picString = "<img src=\"myimage\" width=\"50\" height=\"70\">"; | 401 | picString = "<img src=\"myimage\" width=\"50\" height=\"70\">"; |
401 | if ( picAvailintern ) { | 402 | if ( picAvailintern ) { |
402 | QMimeSourceFactory::defaultFactory()->setImage( "myimage", picture.data() ); | 403 | QMimeSourceFactory::defaultFactory()->setImage( "myimage", picture.data() ); |
404 | int wid = picture.data().width(); | ||
405 | int hei = picture.data().height(); | ||
406 | if ( wid > 128 || hei > 128 ) { | ||
407 | if ( wid > hei ) { | ||
408 | hei = (hei*128)/wid; | ||
409 | wid = 128; | ||
410 | } else { | ||
411 | wid = (wid*128)/hei; | ||
412 | hei = 128; | ||
413 | } | ||
414 | } | ||
415 | picString = QString("<img src=\"myimage\" width=\"%1\" height=\"%2\">").arg(wid).arg(hei); | ||
403 | } else { | 416 | } else { |
404 | if ( picAvailUrl ) { | 417 | if ( picAvailUrl ) { |
405 | QMimeSourceFactory::defaultFactory()->setPixmap( "myimage", QPixmap( picture.url() )); | 418 | QPixmap picPix( picture.url() ); |
419 | QMimeSourceFactory::defaultFactory()->setPixmap( "myimage", picPix ); | ||
420 | int wid = picPix.width(); | ||
421 | int hei = picPix.height(); | ||
422 | if ( wid > 128 || hei > 128 ) { | ||
423 | if ( wid > hei ) { | ||
424 | hei = (hei*128)/wid; | ||
425 | wid = 128; | ||
426 | } else { | ||
427 | wid = (wid*128)/hei; | ||
428 | hei = 128; | ||
429 | } | ||
430 | } | ||
431 | picString = QString("<img src=\"myimage\" width=\"%1\" height=\"%2\">").arg(wid).arg(hei); | ||
406 | } else { | 432 | } else { |
407 | if ( !mAddressee.custom( "KADDRESSBOOK", "X-Children" ).isEmpty() ) { | 433 | if ( !mAddressee.custom( "KADDRESSBOOK", "X-Children" ).isEmpty() ) { |
408 | static bool setDefaultImageChildren = false; | 434 | static bool setDefaultImageChildren = false; |
409 | if ( !setDefaultImageChildren ) { | 435 | if ( !setDefaultImageChildren ) { |
410 | QMimeSourceFactory::defaultFactory()->setPixmap( "familyIcon", KGlobal::iconLoader()->loadIcon( "ic_kids", KIcon::Desktop, 128 ) ); | 436 | QMimeSourceFactory::defaultFactory()->setPixmap( "familyIcon", KGlobal::iconLoader()->loadIcon( "ic_kids", KIcon::Desktop, 128 ) ); |
411 | setDefaultImageChildren = true; | 437 | setDefaultImageChildren = true; |
412 | } | 438 | } |
413 | picString = "<img src=\"familyIcon\" width=\"64\" height=\"64\">"; | 439 | picString = "<img src=\"familyIcon\" width=\"64\" height=\"64\">"; |
414 | 440 | ||
415 | } else if ( !mAddressee.custom( "KADDRESSBOOK", "X-SpousesName" ).isEmpty() ) { | 441 | } else if ( !mAddressee.custom( "KADDRESSBOOK", "X-SpousesName" ).isEmpty() ) { |
416 | static bool setDefaultImagepouses = false; | 442 | static bool setDefaultImagepouses = false; |
417 | if ( !setDefaultImagepouses ) { | 443 | if ( !setDefaultImagepouses ) { |
418 | QMimeSourceFactory::defaultFactory()->setPixmap( "SpousesIcon", KGlobal::iconLoader()->loadIcon( "ic_family", KIcon::Desktop, 128 ) ); | 444 | QMimeSourceFactory::defaultFactory()->setPixmap( "SpousesIcon", KGlobal::iconLoader()->loadIcon( "ic_family", KIcon::Desktop, 128 ) ); |
419 | setDefaultImagepouses = true; | 445 | setDefaultImagepouses = true; |
420 | } | 446 | } |
421 | picString = "<img src=\"SpousesIcon\" width=\"64\" height=\"64\">"; | 447 | picString = "<img src=\"SpousesIcon\" width=\"64\" height=\"64\">"; |
422 | } else { | 448 | } else { |
423 | QString gen = mAddressee.custom( "KADDRESSBOOK", "X-Gender" ); | 449 | QString gen = mAddressee.custom( "KADDRESSBOOK", "X-Gender" ); |
424 | if ( gen == "male" ) { | 450 | if ( gen == "male" ) { |
425 | static bool setDefaultImageMale = false; | 451 | static bool setDefaultImageMale = false; |
426 | if ( !setDefaultImageMale ) { | 452 | if ( !setDefaultImageMale ) { |
427 | QMimeSourceFactory::defaultFactory()->setPixmap( "MaleIcon", KGlobal::iconLoader()->loadIcon( "ic_male", KIcon::Desktop, 128 ) ); | 453 | QMimeSourceFactory::defaultFactory()->setPixmap( "MaleIcon", KGlobal::iconLoader()->loadIcon( "ic_male", KIcon::Desktop, 128 ) ); |
428 | setDefaultImageMale = true; | 454 | setDefaultImageMale = true; |
429 | } | 455 | } |
430 | picString = "<img src=\"MaleIcon\" width=\"64\" height=\"64\">"; | 456 | picString = "<img src=\"MaleIcon\" width=\"64\" height=\"64\">"; |
431 | 457 | ||
432 | } else if ( gen == "female" ) { | 458 | } else if ( gen == "female" ) { |
433 | static bool setDefaultImageFemale = false; | 459 | static bool setDefaultImageFemale = false; |
434 | if ( !setDefaultImageFemale ) { | 460 | if ( !setDefaultImageFemale ) { |
435 | QMimeSourceFactory::defaultFactory()->setPixmap( "FemaleIcon", KGlobal::iconLoader()->loadIcon( "ic_female", KIcon::Desktop, 128 ) ); | 461 | QMimeSourceFactory::defaultFactory()->setPixmap( "FemaleIcon", KGlobal::iconLoader()->loadIcon( "ic_female", KIcon::Desktop, 128 ) ); |
436 | setDefaultImageFemale = true; | 462 | setDefaultImageFemale = true; |
437 | } | 463 | } |
438 | picString = "<img src=\"FemaleIcon\" width=\"64\" height=\"64\">"; | 464 | picString = "<img src=\"FemaleIcon\" width=\"64\" height=\"64\">"; |
439 | 465 | ||
440 | } else { | 466 | } else { |
441 | static bool setDefaultImage = false; | 467 | static bool setDefaultImage = false; |
442 | if ( !setDefaultImage ) { | 468 | if ( !setDefaultImage ) { |
443 | //qDebug("Setting default pixmap "); | 469 | //qDebug("Setting default pixmap "); |
444 | QMimeSourceFactory::defaultFactory()->setPixmap( "defaultIcon", KGlobal::iconLoader()->loadIcon( "ic_penguin", KIcon::Desktop, 128 ) ); | 470 | QMimeSourceFactory::defaultFactory()->setPixmap( "defaultIcon", KGlobal::iconLoader()->loadIcon( "ic_penguin", KIcon::Desktop, 128 ) ); |
445 | setDefaultImage = true; | 471 | setDefaultImage = true; |
446 | } | 472 | } |
447 | picString = "<img src=\"defaultIcon\" width=\"64\" height=\"64\">"; | 473 | picString = "<img src=\"defaultIcon\" width=\"64\" height=\"64\">"; |
448 | } | 474 | } |
449 | } | 475 | } |
450 | } | 476 | } |
451 | } | 477 | } |
452 | mText = QString::fromLatin1( | 478 | mText = QString::fromLatin1( |
453 | "<html>" | 479 | "<html>" |
454 | "<body text=\"%1\" bgcolor=\"%2\">" // text and background color | 480 | "<body text=\"%1\" bgcolor=\"%2\">" // text and background color |
455 | "<table>" | 481 | "<table>" |
456 | "<tr>" | 482 | "<tr>" |
457 | "<td rowspan=\"3\" align=\"right\" valign=\"top\">" | 483 | "<td rowspan=\"3\" align=\"right\" valign=\"top\">" |
458 | "%3" | 484 | "%3" |
459 | "</td>" | 485 | "</td>" |
460 | "<td align=\"left\"><font size=\"+2\"><b>%4</b></font></td>" // name | 486 | "<td align=\"left\"><font size=\"+2\"><b>%4</b></font></td>" // name |
461 | "</tr>" | 487 | "</tr>" |
462 | "%5" // role | 488 | "%5" // role |
463 | "%6" // organization | 489 | "%6" // organization |
464 | "<td colspan=\"2\"> </td>" | 490 | "<td colspan=\"2\"> </td>" |
465 | "%7" // dynamic part | 491 | "%7" // dynamic part |
466 | "%8" // notes | 492 | "%8" // notes |
467 | "</table>" | 493 | "</table>" |
468 | "</body>" | 494 | "</body>" |
469 | "</html>") | 495 | "</html>") |
470 | //US | 496 | //US |
471 | .arg( /*KGlobalSettings::textColor().name()*/ "black" ) | 497 | .arg( /*KGlobalSettings::textColor().name()*/ "black" ) |
472 | //US | 498 | //US |
473 | .arg( /*KGlobalSettings::baseColor().name()*/ "white" ) | 499 | .arg( /*KGlobalSettings::baseColor().name()*/ "white" ) |
474 | .arg( picString ) | 500 | .arg( picString ) |
475 | .arg( name ) | 501 | .arg( name ) |
476 | .arg( aRole ) | 502 | .arg( aRole ) |
477 | .arg( aOrga ) | 503 | .arg( aOrga ) |
478 | .arg( dynamicPart ) | 504 | .arg( dynamicPart ) |
479 | .arg( notes ); | 505 | .arg( notes ); |
480 | 506 | ||
481 | } else { // no picture! | 507 | } else { // no picture! |
482 | 508 | ||
483 | mText = "<table width=\"100%\">\n"; | 509 | mText = "<table width=\"100%\">\n"; |
484 | //mText += "<tr bgcolor=\"#3679AD\"><td><h2>"; | 510 | //mText += "<tr bgcolor=\"#3679AD\"><td><h2>"; |
485 | #ifdef DESKTOP_VERSION | 511 | #ifdef DESKTOP_VERSION |
486 | mText += "<tr bgcolor=\"#5699CD\"><td align=\"left\"><h1>"; | 512 | mText += "<tr bgcolor=\"#5699CD\"><td align=\"left\"><h1>"; |
487 | mText += "<font color=\"#FFFFFF\">" + name +"</font></h1>"; | 513 | mText += "<font color=\"#FFFFFF\">" + name +"</font></h1>"; |
488 | #else | 514 | #else |
489 | mText += "<tr bgcolor=\"#5699CD\"><td align=\"left\"><h3>"; | 515 | mText += "<tr bgcolor=\"#5699CD\"><td align=\"left\"><h3>"; |
490 | mText += "<font color=\"#FFFFFF\"> " + name +"</font></h3>"; | 516 | mText += "<font color=\"#FFFFFF\"> " + name +"</font></h3>"; |
491 | #endif | 517 | #endif |
492 | 518 | ||
493 | mText += "</td></tr>\n<tr bgcolor=\"#EAF8FA\"><td>"; | 519 | mText += "</td></tr>\n<tr bgcolor=\"#EAF8FA\"><td>"; |
494 | 520 | ||
495 | mText += "<table><td colspan=\"2\"> </td>"; | 521 | mText += "<table><td colspan=\"2\"> </td>"; |
496 | /* | 522 | /* |
497 | mText += QString("<tr><td align=\"right\"><b2>%1</b2></td>" | 523 | mText += QString("<tr><td align=\"right\"><b2>%1</b2></td>" |
498 | "<td align=\"left\"><b>%2</b></td></tr>" ) | 524 | "<td align=\"left\"><b>%2</b></td></tr>" ) |
499 | .arg( i18n(" ") ) | 525 | .arg( i18n(" ") ) |
500 | .arg( name ); | 526 | .arg( name ); |
501 | */ | 527 | */ |
502 | if ( ! mAddressee.role().isEmpty() ) | 528 | if ( ! mAddressee.role().isEmpty() ) |
503 | mText += QString("<tr><td align=\"right\"><b>%1</b></td>" | 529 | mText += QString("<tr><td align=\"right\"><b>%1</b></td>" |
504 | "<td align=\"left\">%2</td></tr>" ) | 530 | "<td align=\"left\">%2</td></tr>" ) |
505 | .arg( i18n(" ") ) | 531 | .arg( i18n(" ") ) |
506 | .arg( mAddressee.role()); | 532 | .arg( mAddressee.role()); |
507 | if ( ! mAddressee.organization().isEmpty() ) | 533 | if ( ! mAddressee.organization().isEmpty() ) |
508 | mText += QString("<tr><td align=\"right\"><b>%1</b></td>" | 534 | mText += QString("<tr><td align=\"right\"><b>%1</b></td>" |
509 | "<td align=\"left\">%2</td></tr>" ) | 535 | "<td align=\"left\">%2</td></tr>" ) |
510 | .arg( i18n(" ") ) | 536 | .arg( i18n(" ") ) |
511 | .arg( mAddressee.organization()); | 537 | .arg( mAddressee.organization()); |
512 | mText += dynamicPart; | 538 | mText += dynamicPart; |
513 | mText += notes; | 539 | mText += notes; |
514 | mText += "</table>"; | 540 | mText += "</table>"; |
515 | 541 | ||
516 | } | 542 | } |
517 | 543 | ||
518 | // at last display it... | 544 | // at last display it... |
519 | setText( mText ); | 545 | setText( mText ); |
520 | 546 | ||
521 | } | 547 | } |
522 | 548 | ||
523 | QString AddresseeView::getPhoneNumbers( KABC::PhoneNumber::List phones ,bool preferred ) | 549 | QString AddresseeView::getPhoneNumbers( KABC::PhoneNumber::List phones ,bool preferred ) |
524 | { | 550 | { |
525 | ExternalAppHandler* eah = ExternalAppHandler::instance(); | 551 | ExternalAppHandler* eah = ExternalAppHandler::instance(); |
526 | bool kphoneAvail = eah->isPhoneAppAvailable(); | 552 | bool kphoneAvail = eah->isPhoneAppAvailable(); |
527 | bool kfaxAvail = eah->isFaxAppAvailable(); | 553 | bool kfaxAvail = eah->isFaxAppAvailable(); |
528 | bool ksmsAvail = eah->isSMSAppAvailable(); | 554 | bool ksmsAvail = eah->isSMSAppAvailable(); |
529 | bool kpagerAvail = eah->isPagerAppAvailable(); | 555 | bool kpagerAvail = eah->isPagerAppAvailable(); |
530 | bool ksipAvail = eah->isSIPAppAvailable(); | 556 | bool ksipAvail = eah->isSIPAppAvailable(); |
531 | QString dynamicPart; | 557 | QString dynamicPart; |
532 | KABC::PhoneNumber::List::ConstIterator phoneIt; | 558 | KABC::PhoneNumber::List::ConstIterator phoneIt; |
533 | QString extension; | 559 | QString extension; |