author | zautrix <zautrix> | 2004-10-21 22:20:39 (UTC) |
---|---|---|
committer | zautrix <zautrix> | 2004-10-21 22:20:39 (UTC) |
commit | d6f9bd535e8cabe653bdff329500f9153e5e11fb (patch) (unidiff) | |
tree | 6f83c692713c41896a165e399f259a744f125e5c /korganizer | |
parent | bb235c5a639b914574e1e247d2de6e479517585f (diff) | |
download | kdepimpi-d6f9bd535e8cabe653bdff329500f9153e5e11fb.zip kdepimpi-d6f9bd535e8cabe653bdff329500f9153e5e11fb.tar.gz kdepimpi-d6f9bd535e8cabe653bdff329500f9153e5e11fb.tar.bz2 |
small fixes
-rw-r--r-- | korganizer/koeventviewer.cpp | 5 | ||||
-rw-r--r-- | korganizer/kolistview.cpp | 13 | ||||
-rw-r--r-- | korganizer/main.cpp | 2 |
3 files changed, 17 insertions, 3 deletions
diff --git a/korganizer/koeventviewer.cpp b/korganizer/koeventviewer.cpp index e938e4e..1fcc977 100644 --- a/korganizer/koeventviewer.cpp +++ b/korganizer/koeventviewer.cpp | |||
@@ -306,275 +306,276 @@ void KOEventViewer::appendEvent(Event *event, int mode ) | |||
306 | } | 306 | } |
307 | 307 | ||
308 | addTag("b",i18n("Access: ")); | 308 | addTag("b",i18n("Access: ")); |
309 | mText.append(event->secrecyStr()+"<br>"); | 309 | mText.append(event->secrecyStr()+"<br>"); |
310 | if (!event->description().isEmpty()) { | 310 | if (!event->description().isEmpty()) { |
311 | addTag("p",i18n("<b>Details: </b>")); | 311 | addTag("p",i18n("<b>Details: </b>")); |
312 | addTag("p",event->description()); | 312 | addTag("p",event->description()); |
313 | } | 313 | } |
314 | 314 | ||
315 | formatCategories(event); | 315 | formatCategories(event); |
316 | 316 | ||
317 | formatReadOnly(event); | 317 | formatReadOnly(event); |
318 | formatAttendees(event); | 318 | formatAttendees(event); |
319 | 319 | ||
320 | setText(mText); | 320 | setText(mText); |
321 | //QWhatsThis::add(this,mText); | 321 | //QWhatsThis::add(this,mText); |
322 | 322 | ||
323 | } | 323 | } |
324 | 324 | ||
325 | void KOEventViewer::appendTodo(Todo *event, int mode ) | 325 | void KOEventViewer::appendTodo(Todo *event, int mode ) |
326 | { | 326 | { |
327 | mMailSubject = ""; | 327 | mMailSubject = ""; |
328 | mCurrentIncidence = event; | 328 | mCurrentIncidence = event; |
329 | topLevelWidget()->setCaption(i18n("Todo Viewer")); | 329 | topLevelWidget()->setCaption(i18n("Todo Viewer")); |
330 | bool shortDate = KOPrefs::instance()->mShortDateInViewer; | 330 | bool shortDate = KOPrefs::instance()->mShortDateInViewer; |
331 | if (mode == 0 ) | 331 | if (mode == 0 ) |
332 | addTag("h2",event->summary()); | 332 | addTag("h2",event->summary()); |
333 | else { | 333 | else { |
334 | if ( mColorMode == 1 ) { | 334 | if ( mColorMode == 1 ) { |
335 | mText +="<font color=\"#00A000\">"; | 335 | mText +="<font color=\"#00A000\">"; |
336 | } | 336 | } |
337 | if ( mColorMode == 2 ) { | 337 | if ( mColorMode == 2 ) { |
338 | mText +="<font color=\"#B00000\">"; | 338 | mText +="<font color=\"#B00000\">"; |
339 | } | 339 | } |
340 | if ( mode == 1 ) { | 340 | if ( mode == 1 ) { |
341 | addTag("h2",i18n( "Local: " ) +event->summary()); | 341 | addTag("h2",i18n( "Local: " ) +event->summary()); |
342 | } else { | 342 | } else { |
343 | addTag("h2",i18n( "Remote: " ) +event->summary()); | 343 | addTag("h2",i18n( "Remote: " ) +event->summary()); |
344 | } | 344 | } |
345 | addTag("h3",i18n( "Last modified: " ) + KGlobal::locale()->formatDateTime(event->lastModified(),shortDate, true ) ); | 345 | addTag("h3",i18n( "Last modified: " ) + KGlobal::locale()->formatDateTime(event->lastModified(),shortDate, true ) ); |
346 | if ( mColorMode ) | 346 | if ( mColorMode ) |
347 | mText += "</font>"; | 347 | mText += "</font>"; |
348 | } | 348 | } |
349 | mMailSubject += i18n( "Todo " )+ event->summary(); | 349 | mMailSubject += i18n( "Todo " )+ event->summary(); |
350 | if (event->cancelled ()) { | 350 | if (event->cancelled ()) { |
351 | mText +="<font color=\"#B00000\">"; | 351 | mText +="<font color=\"#B00000\">"; |
352 | addTag("i",i18n("This todo has been cancelled!")); | 352 | addTag("i",i18n("This todo has been cancelled!")); |
353 | mText.append("<br>"); | 353 | mText.append("<br>"); |
354 | mText += "</font>"; | 354 | mText += "</font>"; |
355 | mMailSubject += i18n("(cancelled)"); | 355 | mMailSubject += i18n("(cancelled)"); |
356 | } | 356 | } |
357 | 357 | ||
358 | if (!event->location().isEmpty()) { | 358 | if (!event->location().isEmpty()) { |
359 | addTag("b",i18n("Location: ")); | 359 | addTag("b",i18n("Location: ")); |
360 | mText.append(event->location()+"<br>"); | 360 | mText.append(event->location()+"<br>"); |
361 | mMailSubject += i18n(" at ") + event->location(); | 361 | mMailSubject += i18n(" at ") + event->location(); |
362 | } | 362 | } |
363 | if (event->hasDueDate()) { | 363 | if (event->hasDueDate()) { |
364 | mText.append(i18n("<p><b>Due on:</b> %1</p>").arg(event->dtDueStr(KOPrefs::instance()->mShortDateInViewer))); | 364 | mText.append(i18n("<p><b>Due on:</b> %1</p>").arg(event->dtDueStr(KOPrefs::instance()->mShortDateInViewer))); |
365 | mMailSubject += i18n(" - " )+event->dtDueStr( true ); | 365 | mMailSubject += i18n(" - " )+event->dtDueStr( true ); |
366 | } | 366 | } |
367 | addTag("b",i18n("Access: ")); | 367 | addTag("b",i18n("Access: ")); |
368 | mText.append(event->secrecyStr()+"<br>"); | 368 | mText.append(event->secrecyStr()+"<br>"); |
369 | if (!event->description().isEmpty()) { | 369 | if (!event->description().isEmpty()) { |
370 | addTag("p",i18n("<b>Details: </b>")); | 370 | addTag("p",i18n("<b>Details: </b>")); |
371 | addTag("p",event->description()); | 371 | addTag("p",event->description()); |
372 | } | 372 | } |
373 | 373 | ||
374 | formatCategories(event); | 374 | formatCategories(event); |
375 | 375 | ||
376 | mText.append(i18n("<p><b>Priority:</b> %2</p>") | 376 | mText.append(i18n("<p><b>Priority:</b> %2</p>") |
377 | .arg(QString::number(event->priority()))); | 377 | .arg(QString::number(event->priority()))); |
378 | 378 | ||
379 | mText.append(i18n("<p><i>%1 % completed</i></p>") | 379 | mText.append(i18n("<p><i>%1 % completed</i></p>") |
380 | .arg(event->percentComplete())); | 380 | .arg(event->percentComplete())); |
381 | 381 | ||
382 | formatReadOnly(event); | 382 | formatReadOnly(event); |
383 | formatAttendees(event); | 383 | formatAttendees(event); |
384 | 384 | ||
385 | setText(mText); | 385 | setText(mText); |
386 | } | 386 | } |
387 | 387 | ||
388 | void KOEventViewer::formatCategories(Incidence *event) | 388 | void KOEventViewer::formatCategories(Incidence *event) |
389 | { | 389 | { |
390 | if (!event->categoriesStr().isEmpty()) { | 390 | if (!event->categoriesStr().isEmpty()) { |
391 | if (event->categories().count() == 1) { | 391 | if (event->categories().count() == 1) { |
392 | addTag("h3",i18n("Category")); | 392 | addTag("h3",i18n("Category")); |
393 | } else { | 393 | } else { |
394 | addTag("h3",i18n("Categories")); | 394 | addTag("h3",i18n("Categories")); |
395 | } | 395 | } |
396 | addTag("p",event->categoriesStr()); | 396 | addTag("p",event->categoriesStr()); |
397 | } | 397 | } |
398 | } | 398 | } |
399 | void KOEventViewer::formatAttendees(Incidence *event) | 399 | void KOEventViewer::formatAttendees(Incidence *event) |
400 | { | 400 | { |
401 | QPtrList<Attendee> attendees = event->attendees(); | 401 | QPtrList<Attendee> attendees = event->attendees(); |
402 | if (attendees.count()) { | 402 | if (attendees.count()) { |
403 | 403 | ||
404 | 404 | ||
405 | QString iconPath = KGlobal::iconLoader()->iconPath("mailappt",KIcon::Small); | 405 | QString iconPath = KGlobal::iconLoader()->iconPath("mailappt",KIcon::Small); |
406 | addTag("h3",i18n("Organizer")); | 406 | addTag("h3",i18n("Organizer")); |
407 | mText.append("<ul><li>"); | 407 | mText.append("<ul><li>"); |
408 | #ifndef KORG_NOKABC | 408 | #ifndef KORG_NOKABC |
409 | 409 | ||
410 | #ifdef DESKTOP_VERSION | 410 | #ifdef DESKTOP_VERSION |
411 | KABC::AddressBook *add_book = KABC::StdAddressBook::self(); | 411 | KABC::AddressBook *add_book = KABC::StdAddressBook::self(); |
412 | KABC::Addressee::List addressList; | 412 | KABC::Addressee::List addressList; |
413 | addressList = add_book->findByEmail(event->organizer()); | 413 | addressList = add_book->findByEmail(event->organizer()); |
414 | KABC::Addressee o = addressList.first(); | 414 | KABC::Addressee o = addressList.first(); |
415 | if (!o.isEmpty() && addressList.size()<2) { | 415 | if (!o.isEmpty() && addressList.size()<2) { |
416 | mText += "<a href=\"uid:" + o.uid() + "\">"; | 416 | mText += "<a href=\"uid:" + o.uid() + "\">"; |
417 | mText += o.formattedName(); | 417 | mText += o.formattedName(); |
418 | mText += "</a>\n"; | 418 | mText += "</a>\n"; |
419 | } else { | 419 | } else { |
420 | mText.append(event->organizer()); | 420 | mText.append(event->organizer()); |
421 | } | 421 | } |
422 | #else //DESKTOP_VERSION | 422 | #else //DESKTOP_VERSION |
423 | mText += "<a href=\"uid:organizer\">"; | 423 | mText += "<a href=\"uid:organizer\">"; |
424 | mText += event->organizer(); | 424 | mText += event->organizer(); |
425 | mText += "</a>\n"; | 425 | mText += "</a>\n"; |
426 | #endif //DESKTOP_VERSION | 426 | #endif //DESKTOP_VERSION |
427 | 427 | ||
428 | 428 | ||
429 | #else | 429 | #else |
430 | mText.append(event->organizer()); | 430 | mText.append(event->organizer()); |
431 | #endif | 431 | #endif |
432 | 432 | ||
433 | if (iconPath) { | 433 | if (iconPath) { |
434 | mText += " <a href=\"mailto:" + event->organizer() + "\">"; | 434 | mText += " <a href=\"mailto:" + event->organizer() + "\">"; |
435 | mText += "<IMG src=\"" + iconPath + "\">"; | 435 | mText += "<IMG src=\"" + iconPath + "\">"; |
436 | mText += "</a>\n"; | 436 | mText += "</a>\n"; |
437 | } | 437 | } |
438 | mText.append("</li></ul>"); | 438 | mText.append("</li></ul>"); |
439 | 439 | ||
440 | addTag("h3",i18n("Attendees")); | 440 | addTag("h3",i18n("Attendees")); |
441 | Attendee *a; | 441 | Attendee *a; |
442 | mText.append("<ul>"); | 442 | mText.append("<ul>"); |
443 | for(a=attendees.first();a;a=attendees.next()) { | 443 | for(a=attendees.first();a;a=attendees.next()) { |
444 | #ifndef KORG_NOKABC | 444 | #ifndef KORG_NOKABC |
445 | #ifdef DESKTOP_VERSION | 445 | #ifdef DESKTOP_VERSION |
446 | if (a->name().isEmpty()) { | 446 | if (a->name().isEmpty()) { |
447 | addressList = add_book->findByEmail(a->email()); | 447 | addressList = add_book->findByEmail(a->email()); |
448 | KABC::Addressee o = addressList.first(); | 448 | KABC::Addressee o = addressList.first(); |
449 | if (!o.isEmpty() && addressList.size()<2) { | 449 | if (!o.isEmpty() && addressList.size()<2) { |
450 | mText += "<a href=\"uid:" + o.uid() + "\">"; | 450 | mText += "<a href=\"uid:" + o.uid() + "\">"; |
451 | mText += o.formattedName(); | 451 | mText += o.formattedName(); |
452 | mText += "</a>\n"; | 452 | mText += "</a>\n"; |
453 | } else { | 453 | } else { |
454 | mText += "<li>"; | 454 | mText += "<li>"; |
455 | mText.append(a->email()); | 455 | mText.append(a->email()); |
456 | mText += "\n"; | 456 | mText += "\n"; |
457 | } | 457 | } |
458 | } else { | 458 | } else { |
459 | mText += "<li><a href=\"uid:" + a->uid() + "\">"; | 459 | mText += "<li><a href=\"uid:" + a->uid() + "\">"; |
460 | if (!a->name().isEmpty()) mText += a->name(); | 460 | if (!a->name().isEmpty()) mText += a->name(); |
461 | else mText += a->email(); | 461 | else mText += a->email(); |
462 | mText += "</a>\n"; | 462 | mText += "</a>\n"; |
463 | } | 463 | } |
464 | #else //DESKTOP_VERSION | 464 | #else //DESKTOP_VERSION |
465 | mText += "<li><a href=\"uid:" + a->uid() + "\">"; | 465 | mText += "<li><a href=\"uid:" + a->uid() + "\">"; |
466 | if (!a->name().isEmpty()) mText += a->name(); | 466 | if (!a->name().isEmpty()) mText += a->name(); |
467 | else mText += a->email(); | 467 | else mText += a->email(); |
468 | mText += "</a>\n"; | 468 | mText += "</a>\n"; |
469 | #endif //DESKTOP_VERSION | 469 | #endif //DESKTOP_VERSION |
470 | #else | 470 | #else |
471 | //qDebug("nokabc "); | 471 | //qDebug("nokabc "); |
472 | mText += "<li><a href=\"uid:" + a->uid() + "\">"; | 472 | mText += "<li><a href=\"uid:" + a->uid() + "\">"; |
473 | if (!a->name().isEmpty()) mText += a->name(); | 473 | if (!a->name().isEmpty()) mText += a->name(); |
474 | else mText += a->email(); | 474 | else mText += a->email(); |
475 | mText += "</a>\n"; | 475 | mText += "</a>\n"; |
476 | #endif | 476 | #endif |
477 | 477 | ||
478 | 478 | ||
479 | if (!a->email().isEmpty()) { | 479 | if (!a->email().isEmpty()) { |
480 | if (iconPath) { | 480 | if (iconPath) { |
481 | mText += "<a href=\"mailto:" + a->name() +" <" + a->email() + ">:" + mMailSubject + "\">"; | 481 | mText += "<a href=\"mailto:" + a->name() +" <" + a->email() + ">:" + mMailSubject + "\">"; |
482 | mText += "<IMG src=\"" + iconPath + "\">"; | 482 | mText += "<IMG src=\"" + iconPath + "\">"; |
483 | mText += "</a>\n"; | 483 | mText += "</a>\n"; |
484 | } | 484 | } |
485 | } | 485 | } |
486 | if (a->status() != Attendee::NeedsAction ) | 486 | if (a->status() != Attendee::NeedsAction ) |
487 | mText +="[" + a->statusStr() + "] "; | 487 | mText +="[" + a->statusStr() + "] "; |
488 | if (a->role() == Attendee::Chair ) | 488 | if (a->role() == Attendee::Chair ) |
489 | mText +="(" + a->roleStr().left(1) + ".)"; | 489 | mText +="(" + a->roleStr().left(1) + ".)"; |
490 | } | 490 | } |
491 | mText.append("</li></ul>"); | 491 | mText.append("</li></ul>"); |
492 | } | 492 | } |
493 | 493 | ||
494 | } | 494 | } |
495 | void KOEventViewer::appendJournal(Journal *jour, int mode ) | 495 | void KOEventViewer::appendJournal(Journal *jour, int mode ) |
496 | { | 496 | { |
497 | bool shortDate = KOPrefs::instance()->mShortDateInViewer; | 497 | bool shortDate = KOPrefs::instance()->mShortDateInViewer; |
498 | if (mode == 0 ) | 498 | if (mode == 0 ) { |
499 | addTag("h2",i18n("Journal from: ")); | 499 | addTag("h2",i18n("Journal from: ")); |
500 | } | ||
500 | else { | 501 | else { |
501 | if ( mode == 1 ) { | 502 | if ( mode == 1 ) { |
502 | addTag("h2",i18n( "Local: " ) +i18n("Journal from: ")); | 503 | addTag("h2",i18n( "Local: " ) +i18n("Journal from: ")); |
503 | } else { | 504 | } else { |
504 | addTag("h2",i18n( "Remote: " ) +i18n("Journal from: ")); | 505 | addTag("h2",i18n( "Remote: " ) +i18n("Journal from: ")); |
505 | } | 506 | } |
506 | addTag("h3",i18n( "Last modified " ) + KGlobal::locale()->formatDateTime(jour->lastModified(),shortDate ) ); | ||
507 | } | 507 | } |
508 | topLevelWidget()->setCaption("Journal Viewer"); | 508 | topLevelWidget()->setCaption("Journal Viewer"); |
509 | mText.append(i18n("<h3> %1 </h3> ").arg(jour->dtStartDateStr(KOPrefs::instance()->mShortDateInViewer))); | 509 | mText.append(i18n("<h3> %1 </h3> ").arg(jour->dtStartDateStr(KOPrefs::instance()->mShortDateInViewer))); |
510 | addTag("b",i18n( "Last modified: " ) + KGlobal::locale()->formatDateTime(jour->lastModified(),shortDate ) ); | ||
510 | if (!jour->description().isEmpty()) { | 511 | if (!jour->description().isEmpty()) { |
511 | addTag("p",jour->description()); | 512 | addTag("p",jour->description()); |
512 | } | 513 | } |
513 | setText(mText); | 514 | setText(mText); |
514 | } | 515 | } |
515 | 516 | ||
516 | void KOEventViewer::formatReadOnly(Incidence *event) | 517 | void KOEventViewer::formatReadOnly(Incidence *event) |
517 | { | 518 | { |
518 | if (event->isReadOnly()) { | 519 | if (event->isReadOnly()) { |
519 | addTag("p","<em>(" + i18n("read-only") + ")</em>"); | 520 | addTag("p","<em>(" + i18n("read-only") + ")</em>"); |
520 | } | 521 | } |
521 | } | 522 | } |
522 | void KOEventViewer::setSyncMode( bool b ) | 523 | void KOEventViewer::setSyncMode( bool b ) |
523 | { | 524 | { |
524 | mSyncMode = b; | 525 | mSyncMode = b; |
525 | } | 526 | } |
526 | 527 | ||
527 | 528 | ||
528 | void KOEventViewer::setTodo(Todo *event, bool clearV ) | 529 | void KOEventViewer::setTodo(Todo *event, bool clearV ) |
529 | { | 530 | { |
530 | if ( clearV ) | 531 | if ( clearV ) |
531 | clearEvents(); | 532 | clearEvents(); |
532 | if ( mSyncMode ) { | 533 | if ( mSyncMode ) { |
533 | if ( clearV ) | 534 | if ( clearV ) |
534 | appendTodo(event,1 ); | 535 | appendTodo(event,1 ); |
535 | else | 536 | else |
536 | appendTodo(event,2); | 537 | appendTodo(event,2); |
537 | } else | 538 | } else |
538 | appendTodo(event); | 539 | appendTodo(event); |
539 | } | 540 | } |
540 | void KOEventViewer::setJournal(Journal *event, bool clearV ) | 541 | void KOEventViewer::setJournal(Journal *event, bool clearV ) |
541 | { | 542 | { |
542 | if ( clearV ) | 543 | if ( clearV ) |
543 | clearEvents(); | 544 | clearEvents(); |
544 | if ( mSyncMode ) { | 545 | if ( mSyncMode ) { |
545 | if ( clearV ) | 546 | if ( clearV ) |
546 | appendJournal(event, 1); | 547 | appendJournal(event, 1); |
547 | else | 548 | else |
548 | appendJournal(event, 2); | 549 | appendJournal(event, 2); |
549 | } else | 550 | } else |
550 | appendJournal(event); | 551 | appendJournal(event); |
551 | } | 552 | } |
552 | 553 | ||
553 | void KOEventViewer::setEvent(Event *event) | 554 | void KOEventViewer::setEvent(Event *event) |
554 | { | 555 | { |
555 | clearEvents(); | 556 | clearEvents(); |
556 | if ( mSyncMode ) | 557 | if ( mSyncMode ) |
557 | appendEvent(event, 1); | 558 | appendEvent(event, 1); |
558 | else | 559 | else |
559 | appendEvent(event); | 560 | appendEvent(event); |
560 | } | 561 | } |
561 | 562 | ||
562 | void KOEventViewer::addEvent(Event *event) | 563 | void KOEventViewer::addEvent(Event *event) |
563 | { | 564 | { |
564 | if ( mSyncMode ) | 565 | if ( mSyncMode ) |
565 | appendEvent(event, 2); | 566 | appendEvent(event, 2); |
566 | else | 567 | else |
567 | appendEvent(event); | 568 | appendEvent(event); |
568 | } | 569 | } |
569 | 570 | ||
570 | void KOEventViewer::clearEvents(bool now) | 571 | void KOEventViewer::clearEvents(bool now) |
571 | { | 572 | { |
572 | mText = ""; | 573 | mText = ""; |
573 | if (now) setText(mText); | 574 | if (now) setText(mText); |
574 | } | 575 | } |
575 | 576 | ||
576 | void KOEventViewer::addText(QString text) | 577 | void KOEventViewer::addText(QString text) |
577 | { | 578 | { |
578 | mText.append(text); | 579 | mText.append(text); |
579 | setText(mText); | 580 | setText(mText); |
580 | } | 581 | } |
diff --git a/korganizer/kolistview.cpp b/korganizer/kolistview.cpp index 9a3ba73..bafd349 100644 --- a/korganizer/kolistview.cpp +++ b/korganizer/kolistview.cpp | |||
@@ -1,369 +1,375 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of KOrganizer. | 2 | This file is part of KOrganizer. |
3 | Copyright (c) 1999 Preston Brown | 3 | Copyright (c) 1999 Preston Brown |
4 | Copyright (c) 2000,2001 Cornelius Schumacher <schumacher@kde.org> | 4 | Copyright (c) 2000,2001 Cornelius Schumacher <schumacher@kde.org> |
5 | 5 | ||
6 | This program is free software; you can redistribute it and/or modify | 6 | This program is free software; you can redistribute it and/or modify |
7 | it under the terms of the GNU General Public License as published by | 7 | it under the terms of the GNU General Public License as published by |
8 | the Free Software Foundation; either version 2 of the License, or | 8 | the Free Software Foundation; either version 2 of the License, or |
9 | (at your option) any later version. | 9 | (at your option) any later version. |
10 | 10 | ||
11 | This program is distributed in the hope that it will be useful, | 11 | This program is distributed in the hope that it will be useful, |
12 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 12 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
13 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 13 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
14 | GNU General Public License for more details. | 14 | GNU General Public License for more details. |
15 | 15 | ||
16 | You should have received a copy of the GNU General Public License | 16 | You should have received a copy of the GNU General Public License |
17 | along with this program; if not, write to the Free Software | 17 | along with this program; if not, write to the Free Software |
18 | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | 18 | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
19 | 19 | ||
20 | As a special exception, permission is given to link this program | 20 | As a special exception, permission is given to link this program |
21 | with any edition of Qt, and distribute the resulting executable, | 21 | with any edition of Qt, and distribute the resulting executable, |
22 | without including the source code for Qt in the source distribution. | 22 | without including the source code for Qt in the source distribution. |
23 | */ | 23 | */ |
24 | 24 | ||
25 | #include <qlistview.h> | 25 | #include <qlistview.h> |
26 | #include <qlayout.h> | 26 | #include <qlayout.h> |
27 | #include <qlabel.h> | 27 | #include <qlabel.h> |
28 | #include <qpopupmenu.h> | 28 | #include <qpopupmenu.h> |
29 | #include <qprogressbar.h> | 29 | #include <qprogressbar.h> |
30 | #include <qfileinfo.h> | 30 | #include <qfileinfo.h> |
31 | #include <qmessagebox.h> | 31 | #include <qmessagebox.h> |
32 | #include <qdialog.h> | 32 | #include <qdialog.h> |
33 | #include <qtextstream.h> | 33 | #include <qtextstream.h> |
34 | #include <qdir.h> | 34 | #include <qdir.h> |
35 | #include <qregexp.h> | ||
35 | 36 | ||
36 | #include <klocale.h> | 37 | #include <klocale.h> |
37 | #include <kdebug.h> | 38 | #include <kdebug.h> |
38 | #include <kiconloader.h> | 39 | #include <kiconloader.h> |
39 | #include <kglobal.h> | 40 | #include <kglobal.h> |
40 | 41 | ||
41 | #include <libkcal/calendar.h> | 42 | #include <libkcal/calendar.h> |
42 | #include <libkcal/calendarlocal.h> | 43 | #include <libkcal/calendarlocal.h> |
43 | #include <libkcal/icalformat.h> | 44 | #include <libkcal/icalformat.h> |
44 | #include <libkcal/vcalformat.h> | 45 | #include <libkcal/vcalformat.h> |
45 | #include <libkcal/recurrence.h> | 46 | #include <libkcal/recurrence.h> |
46 | #include <libkcal/filestorage.h> | 47 | #include <libkcal/filestorage.h> |
47 | #include <libkdepim/categoryselectdialog.h> | 48 | #include <libkdepim/categoryselectdialog.h> |
48 | #ifndef DESKTOP_VERSION | 49 | #ifndef DESKTOP_VERSION |
49 | #include <qpe/qpeapplication.h> | 50 | #include <qpe/qpeapplication.h> |
50 | #else | 51 | #else |
51 | #include <qapplication.h> | 52 | #include <qapplication.h> |
52 | #endif | 53 | #endif |
53 | 54 | ||
54 | #ifndef KORG_NOPRINTER | 55 | #ifndef KORG_NOPRINTER |
55 | #include "calprinter.h" | 56 | #include "calprinter.h" |
56 | #endif | 57 | #endif |
57 | #include "koglobals.h" | 58 | #include "koglobals.h" |
58 | #include "koprefs.h" | 59 | #include "koprefs.h" |
59 | #include "kfiledialog.h" | 60 | #include "kfiledialog.h" |
60 | 61 | ||
61 | #include "kolistview.h" | 62 | #include "kolistview.h" |
62 | 63 | ||
63 | ListItemVisitor::ListItemVisitor(KOListViewItem *item, QDate date ) | 64 | ListItemVisitor::ListItemVisitor(KOListViewItem *item, QDate date ) |
64 | { | 65 | { |
65 | mItem = item; | 66 | mItem = item; |
66 | mDate = date; | 67 | mDate = date; |
67 | } | 68 | } |
68 | 69 | ||
69 | ListItemVisitor::~ListItemVisitor() | 70 | ListItemVisitor::~ListItemVisitor() |
70 | { | 71 | { |
71 | } | 72 | } |
72 | 73 | ||
73 | bool ListItemVisitor::visit(Event *e) | 74 | bool ListItemVisitor::visit(Event *e) |
74 | { | 75 | { |
75 | 76 | ||
76 | bool ok = false; | 77 | bool ok = false; |
77 | QString start, end; | 78 | QString start, end; |
78 | if ( e->doesRecur() ) { | 79 | if ( e->doesRecur() ) { |
79 | QDate d = e->getNextOccurence( QDateTime( mDate, QTime(0,0,0)), &ok ).date(); | 80 | QDate d = e->getNextOccurence( QDateTime( mDate, QTime(0,0,0)), &ok ).date(); |
80 | if ( ok ) { | 81 | if ( ok ) { |
81 | int days = e->dtStart().date().daysTo(e->dtEnd().date() ); | 82 | int days = e->dtStart().date().daysTo(e->dtEnd().date() ); |
82 | start = KGlobal::locale()->formatDate(d,true); | 83 | start = KGlobal::locale()->formatDate(d,true); |
83 | end = KGlobal::locale()->formatDate(d.addDays( days),true); | 84 | end = KGlobal::locale()->formatDate(d.addDays( days),true); |
84 | } | 85 | } |
85 | 86 | ||
86 | } | 87 | } |
87 | if ( ! ok ) { | 88 | if ( ! ok ) { |
88 | start =e->dtStartDateStr(); | 89 | start =e->dtStartDateStr(); |
89 | end = e->dtEndDateStr(); | 90 | end = e->dtEndDateStr(); |
90 | } | 91 | } |
91 | mItem->setText(0,e->summary()); | 92 | mItem->setText(0,e->summary()); |
92 | mItem->setText(1,start); | 93 | mItem->setText(1,start); |
93 | mItem->setText(2,e->dtStartTimeStr()); | 94 | mItem->setText(2,e->dtStartTimeStr()); |
94 | mItem->setText(3,end); | 95 | mItem->setText(3,end); |
95 | mItem->setText(4,e->dtEndTimeStr()); | 96 | mItem->setText(4,e->dtEndTimeStr()); |
96 | mItem->setText(5,e->isAlarmEnabled() ? i18n("Yes") : i18n("No")); | 97 | mItem->setText(5,e->isAlarmEnabled() ? i18n("Yes") : i18n("No")); |
97 | mItem->setText(6, e->recurrence()->recurrenceText()); | 98 | mItem->setText(6, e->recurrence()->recurrenceText()); |
98 | mItem->setText(7,"---"); | 99 | mItem->setText(7,"---"); |
99 | mItem->setText(8,"---"); | 100 | mItem->setText(8,"---"); |
100 | mItem->setText(9, e->cancelled() ? i18n("Yes") : i18n("No")); | 101 | mItem->setText(9, e->cancelled() ? i18n("Yes") : i18n("No")); |
101 | mItem->setText(10,e->categoriesStr()); | 102 | mItem->setText(10,e->categoriesStr()); |
102 | 103 | ||
103 | QString key; | 104 | QString key; |
104 | QDate d = e->dtStart().date(); | 105 | QDate d = e->dtStart().date(); |
105 | QTime t = e->doesFloat() ? QTime(0,0) : e->dtStart().time(); | 106 | QTime t = e->doesFloat() ? QTime(0,0) : e->dtStart().time(); |
106 | key.sprintf("%04d%02d%02d%02d%02d",d.year(),d.month(),d.day(),t.hour(),t.minute()); | 107 | key.sprintf("%04d%02d%02d%02d%02d",d.year(),d.month(),d.day(),t.hour(),t.minute()); |
107 | mItem->setSortKey(1,key); | 108 | mItem->setSortKey(1,key); |
108 | 109 | ||
109 | d = e->dtEnd().date(); | 110 | d = e->dtEnd().date(); |
110 | t = e->doesFloat() ? QTime(0,0) : e->dtEnd().time(); | 111 | t = e->doesFloat() ? QTime(0,0) : e->dtEnd().time(); |
111 | key.sprintf("%04d%02d%02d%02d%02d",d.year(),d.month(),d.day(),t.hour(),t.minute()); | 112 | key.sprintf("%04d%02d%02d%02d%02d",d.year(),d.month(),d.day(),t.hour(),t.minute()); |
112 | mItem->setSortKey(3,key); | 113 | mItem->setSortKey(3,key); |
113 | 114 | ||
114 | return true; | 115 | return true; |
115 | } | 116 | } |
116 | 117 | ||
117 | bool ListItemVisitor::visit(Todo *t) | 118 | bool ListItemVisitor::visit(Todo *t) |
118 | { | 119 | { |
119 | mItem->setText(0,i18n("To-Do: %1").arg(t->summary())); | 120 | mItem->setText(0,i18n("To-Do: %1").arg(t->summary())); |
120 | if (t->hasStartDate()) { | 121 | if (t->hasStartDate()) { |
121 | mItem->setText(1,t->dtStartDateStr()); | 122 | mItem->setText(1,t->dtStartDateStr()); |
122 | if (t->doesFloat()) { | 123 | if (t->doesFloat()) { |
123 | mItem->setText(2,"---"); | 124 | mItem->setText(2,"---"); |
124 | } else { | 125 | } else { |
125 | mItem->setText(2,t->dtStartTimeStr()); | 126 | mItem->setText(2,t->dtStartTimeStr()); |
126 | } | 127 | } |
127 | } else { | 128 | } else { |
128 | mItem->setText(1,"---"); | 129 | mItem->setText(1,"---"); |
129 | mItem->setText(2,"---"); | 130 | mItem->setText(2,"---"); |
130 | } | 131 | } |
131 | mItem->setText(3,"---"); | 132 | mItem->setText(3,"---"); |
132 | mItem->setText(4,"---"); | 133 | mItem->setText(4,"---"); |
133 | mItem->setText(5,"---"); | 134 | mItem->setText(5,"---"); |
134 | mItem->setText(6,"---"); | 135 | mItem->setText(6,"---"); |
135 | if (t->hasDueDate()) { | 136 | if (t->hasDueDate()) { |
136 | mItem->setText(7,t->dtDueDateStr()); | 137 | mItem->setText(7,t->dtDueDateStr()); |
137 | if (t->doesFloat()) { | 138 | if (t->doesFloat()) { |
138 | mItem->setText(8,"---"); | 139 | mItem->setText(8,"---"); |
139 | } else { | 140 | } else { |
140 | mItem->setText(8,t->dtDueTimeStr()); | 141 | mItem->setText(8,t->dtDueTimeStr()); |
141 | } | 142 | } |
142 | } else { | 143 | } else { |
143 | mItem->setText(7,"---"); | 144 | mItem->setText(7,"---"); |
144 | mItem->setText(8,"---"); | 145 | mItem->setText(8,"---"); |
145 | } | 146 | } |
146 | mItem->setText(9, t->cancelled() ? i18n("Yes") : i18n("No")); | 147 | mItem->setText(9, t->cancelled() ? i18n("Yes") : i18n("No")); |
147 | mItem->setText(10,t->categoriesStr()); | 148 | mItem->setText(10,t->categoriesStr()); |
148 | 149 | ||
149 | QString key; | 150 | QString key; |
150 | QDate d; | 151 | QDate d; |
151 | if (t->hasDueDate()) { | 152 | if (t->hasDueDate()) { |
152 | d = t->dtDue().date(); | 153 | d = t->dtDue().date(); |
153 | QTime tm = t->doesFloat() ? QTime(0,0) : t->dtDue().time(); | 154 | QTime tm = t->doesFloat() ? QTime(0,0) : t->dtDue().time(); |
154 | key.sprintf("%04d%02d%02d%02d%02d",d.year(),d.month(),d.day(),tm.hour(),tm.minute()); | 155 | key.sprintf("%04d%02d%02d%02d%02d",d.year(),d.month(),d.day(),tm.hour(),tm.minute()); |
155 | mItem->setSortKey(7,key); | 156 | mItem->setSortKey(7,key); |
156 | } | 157 | } |
157 | if ( t->hasStartDate() ) { | 158 | if ( t->hasStartDate() ) { |
158 | d = t->dtStart().date(); | 159 | d = t->dtStart().date(); |
159 | QTime tm = t->doesFloat() ? QTime(0,0) : t->dtStart().time(); | 160 | QTime tm = t->doesFloat() ? QTime(0,0) : t->dtStart().time(); |
160 | key.sprintf("%04d%02d%02d%02d%02d",d.year(),d.month(),d.day(),tm.hour(),tm.minute()); | 161 | key.sprintf("%04d%02d%02d%02d%02d",d.year(),d.month(),d.day(),tm.hour(),tm.minute()); |
161 | mItem->setSortKey(1,key); | 162 | mItem->setSortKey(1,key); |
162 | } | 163 | } |
163 | return true; | 164 | return true; |
164 | } | 165 | } |
165 | 166 | ||
166 | bool ListItemVisitor::visit(Journal * j) | 167 | bool ListItemVisitor::visit(Journal * j) |
167 | { | 168 | { |
168 | mItem->setText(0,i18n("Journal")); | 169 | QString des = j->description().left(50); |
170 | des = des.simplifyWhiteSpace (); | ||
171 | des.replace (QRegExp ("\\n"),"" ); | ||
172 | des.replace (QRegExp ("\\r"),"" ); | ||
173 | mItem->setText(0,i18n("Journal")+": "+des.left(25)); | ||
169 | mItem->setText(1,j->dtStartDateStr()); | 174 | mItem->setText(1,j->dtStartDateStr()); |
170 | mItem->setText(2,"---"); | 175 | mItem->setText(2,"---"); |
171 | mItem->setText(3,"---"); | 176 | mItem->setText(3,"---"); |
172 | mItem->setText(4,"---"); | 177 | mItem->setText(4,"---"); |
173 | mItem->setText(5,"---"); | 178 | mItem->setText(5,"---"); |
174 | mItem->setText(6,"---"); | 179 | mItem->setText(6,"---"); |
175 | mItem->setText(7,j->dtStartDateStr()); | 180 | mItem->setText(7,j->dtStartDateStr()); |
176 | mItem->setText(8,"---"); | 181 | mItem->setText(8,"---"); |
177 | mItem->setText(9,"---"); | 182 | mItem->setText(9,"---"); |
183 | mItem->setText(10,i18n("Last Modified: ")+ KGlobal::locale()->formatDateTime( j->lastModified() , true) ); | ||
178 | 184 | ||
179 | QString key; | 185 | QString key; |
180 | QDate d = j->dtStart().date(); | 186 | QDate d = j->dtStart().date(); |
181 | key.sprintf("%04d%02d%02d",d.year(),d.month(),d.day()); | 187 | key.sprintf("%04d%02d%02d",d.year(),d.month(),d.day()); |
182 | mItem->setSortKey(1,key); | 188 | mItem->setSortKey(1,key); |
183 | mItem->setSortKey(7,key); | 189 | mItem->setSortKey(7,key); |
184 | 190 | ||
185 | return true; | 191 | return true; |
186 | } | 192 | } |
187 | 193 | ||
188 | KOListView::KOListView(Calendar *calendar, QWidget *parent, | 194 | KOListView::KOListView(Calendar *calendar, QWidget *parent, |
189 | const char *name) | 195 | const char *name) |
190 | : KOEventView(calendar, parent, name) | 196 | : KOEventView(calendar, parent, name) |
191 | { | 197 | { |
192 | mActiveItem = 0; | 198 | mActiveItem = 0; |
193 | mListView = new KOListViewListView(this); | 199 | mListView = new KOListViewListView(this); |
194 | mListView->addColumn(i18n("Summary")); | 200 | mListView->addColumn(i18n("Summary")); |
195 | mListView->addColumn(i18n("Start Date")); | 201 | mListView->addColumn(i18n("Start Date")); |
196 | mListView->addColumn(i18n("Start Time")); | 202 | mListView->addColumn(i18n("Start Time")); |
197 | mListView->addColumn(i18n("End Date")); | 203 | mListView->addColumn(i18n("End Date")); |
198 | mListView->addColumn(i18n("End Time")); | 204 | mListView->addColumn(i18n("End Time")); |
199 | mListView->addColumn(i18n("Alarm")); // alarm set? | 205 | mListView->addColumn(i18n("Alarm")); // alarm set? |
200 | mListView->addColumn(i18n("Recurs")); // recurs? | 206 | mListView->addColumn(i18n("Recurs")); // recurs? |
201 | mListView->addColumn(i18n("Due Date")); | 207 | mListView->addColumn(i18n("Due Date")); |
202 | mListView->addColumn(i18n("Due Time")); | 208 | mListView->addColumn(i18n("Due Time")); |
203 | mListView->addColumn(i18n("Cancelled")); | 209 | mListView->addColumn(i18n("Cancelled")); |
204 | mListView->addColumn(i18n("Categories")); | 210 | mListView->addColumn(i18n("Categories")); |
205 | 211 | ||
206 | mListView->setColumnAlignment(0,AlignLeft); | 212 | mListView->setColumnAlignment(0,AlignLeft); |
207 | mListView->setColumnAlignment(1,AlignLeft); | 213 | mListView->setColumnAlignment(1,AlignLeft); |
208 | mListView->setColumnAlignment(2,AlignHCenter); | 214 | mListView->setColumnAlignment(2,AlignHCenter); |
209 | mListView->setColumnAlignment(3,AlignLeft); | 215 | mListView->setColumnAlignment(3,AlignLeft); |
210 | mListView->setColumnAlignment(4,AlignHCenter); | 216 | mListView->setColumnAlignment(4,AlignHCenter); |
211 | mListView->setColumnAlignment(5,AlignLeft); | 217 | mListView->setColumnAlignment(5,AlignLeft); |
212 | mListView->setColumnAlignment(6,AlignLeft); | 218 | mListView->setColumnAlignment(6,AlignLeft); |
213 | mListView->setColumnAlignment(7,AlignLeft); | 219 | mListView->setColumnAlignment(7,AlignLeft); |
214 | mListView->setColumnAlignment(8,AlignLeft); | 220 | mListView->setColumnAlignment(8,AlignLeft); |
215 | mListView->setColumnAlignment(9,AlignLeft); | 221 | mListView->setColumnAlignment(9,AlignLeft); |
216 | mListView->setColumnAlignment(10,AlignLeft); | 222 | mListView->setColumnAlignment(10,AlignLeft); |
217 | 223 | ||
218 | int iii = 0; | 224 | int iii = 0; |
219 | for ( iii = 0; iii< 10 ; ++iii ) | 225 | for ( iii = 0; iii< 10 ; ++iii ) |
220 | mListView->setColumnWidthMode( iii, QListView::Manual ); | 226 | mListView->setColumnWidthMode( iii, QListView::Manual ); |
221 | 227 | ||
222 | QBoxLayout *layoutTop = new QVBoxLayout(this); | 228 | QBoxLayout *layoutTop = new QVBoxLayout(this); |
223 | layoutTop->addWidget(mListView); | 229 | layoutTop->addWidget(mListView); |
224 | mListView->setFont ( KOPrefs::instance()->mListViewFont ); | 230 | mListView->setFont ( KOPrefs::instance()->mListViewFont ); |
225 | mPopupMenu = eventPopup(); | 231 | mPopupMenu = eventPopup(); |
226 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), | 232 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), |
227 | i18n("Select all"),this, | 233 | i18n("Select all"),this, |
228 | SLOT(allSelection()),true); | 234 | SLOT(allSelection()),true); |
229 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), | 235 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), |
230 | i18n("Deselect All"),this, | 236 | i18n("Deselect All"),this, |
231 | SLOT(clearSelection()),true); | 237 | SLOT(clearSelection()),true); |
232 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), | 238 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), |
233 | i18n("Delete all selected"),this, | 239 | i18n("Delete all selected"),this, |
234 | SLOT(deleteAll()),true); | 240 | SLOT(deleteAll()),true); |
235 | mPopupMenu->insertSeparator(); | 241 | mPopupMenu->insertSeparator(); |
236 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), | 242 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), |
237 | i18n("Save selected to file..."),this, | 243 | i18n("Save selected to file..."),this, |
238 | SLOT(saveToFile()),true); | 244 | SLOT(saveToFile()),true); |
239 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), | 245 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), |
240 | i18n("Save Journal/Description..."),this, | 246 | i18n("Save Journal/Description..."),this, |
241 | SLOT(saveDescriptionToFile()),true); | 247 | SLOT(saveDescriptionToFile()),true); |
242 | mPopupMenu->insertSeparator(); | 248 | mPopupMenu->insertSeparator(); |
243 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), | 249 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), |
244 | i18n("Add Categ. to selected..."),this, | 250 | i18n("Add Categ. to selected..."),this, |
245 | SLOT(addCat()),true); | 251 | SLOT(addCat()),true); |
246 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), | 252 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), |
247 | i18n("Set Categ. for selected..."),this, | 253 | i18n("Set Categ. for selected..."),this, |
248 | SLOT(setCat()),true); | 254 | SLOT(setCat()),true); |
249 | mPopupMenu->insertSeparator(); | 255 | mPopupMenu->insertSeparator(); |
250 | 256 | ||
251 | 257 | ||
252 | #ifndef DESKTOP_VERSION | 258 | #ifndef DESKTOP_VERSION |
253 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), | 259 | mPopupMenu->addAdditionalItem(QIconSet(QPixmap()), |
254 | i18n("Beam selected via IR"),this, | 260 | i18n("Beam selected via IR"),this, |
255 | SLOT(beamSelected()),true); | 261 | SLOT(beamSelected()),true); |
256 | #endif | 262 | #endif |
257 | /* | 263 | /* |
258 | mPopupMenu = new QPopupMenu; | 264 | mPopupMenu = new QPopupMenu; |
259 | mPopupMenu->insertItem(i18n("Edit Event"), this, | 265 | mPopupMenu->insertItem(i18n("Edit Event"), this, |
260 | SLOT (editEvent())); | 266 | SLOT (editEvent())); |
261 | mPopupMenu->insertItem(SmallIcon("delete"), i18n("Delete Event"), this, | 267 | mPopupMenu->insertItem(SmallIcon("delete"), i18n("Delete Event"), this, |
262 | SLOT (deleteEvent())); | 268 | SLOT (deleteEvent())); |
263 | mPopupMenu->insertSeparator(); | 269 | mPopupMenu->insertSeparator(); |
264 | mPopupMenu->insertItem(i18n("Show Dates"), this, | 270 | mPopupMenu->insertItem(i18n("Show Dates"), this, |
265 | SLOT(showDates())); | 271 | SLOT(showDates())); |
266 | mPopupMenu->insertItem(i18n("Hide Dates"), this, | 272 | mPopupMenu->insertItem(i18n("Hide Dates"), this, |
267 | SLOT(hideDates())); | 273 | SLOT(hideDates())); |
268 | */ | 274 | */ |
269 | QObject::connect(mListView,SIGNAL( newEvent()), | 275 | QObject::connect(mListView,SIGNAL( newEvent()), |
270 | this,SIGNAL(signalNewEvent())); | 276 | this,SIGNAL(signalNewEvent())); |
271 | QObject::connect(mListView,SIGNAL(doubleClicked(QListViewItem *)), | 277 | QObject::connect(mListView,SIGNAL(doubleClicked(QListViewItem *)), |
272 | this,SLOT(defaultItemAction(QListViewItem *))); | 278 | this,SLOT(defaultItemAction(QListViewItem *))); |
273 | QObject::connect(mListView,SIGNAL(rightButtonClicked ( QListViewItem *, | 279 | QObject::connect(mListView,SIGNAL(rightButtonClicked ( QListViewItem *, |
274 | const QPoint &, int )), | 280 | const QPoint &, int )), |
275 | this,SLOT(popupMenu(QListViewItem *,const QPoint &,int))); | 281 | this,SLOT(popupMenu(QListViewItem *,const QPoint &,int))); |
276 | QObject::connect(mListView,SIGNAL(currentChanged(QListViewItem *)), | 282 | QObject::connect(mListView,SIGNAL(currentChanged(QListViewItem *)), |
277 | SLOT(processSelectionChange(QListViewItem *))); | 283 | SLOT(processSelectionChange(QListViewItem *))); |
278 | QObject::connect(mListView,SIGNAL(showIncidence(Incidence *)), | 284 | QObject::connect(mListView,SIGNAL(showIncidence(Incidence *)), |
279 | SIGNAL(showIncidenceSignal(Incidence *)) ); | 285 | SIGNAL(showIncidenceSignal(Incidence *)) ); |
280 | 286 | ||
281 | readSettings(KOGlobals::config(),"KOListView Layout"); | 287 | readSettings(KOGlobals::config(),"KOListView Layout"); |
282 | } | 288 | } |
283 | 289 | ||
284 | KOListView::~KOListView() | 290 | KOListView::~KOListView() |
285 | { | 291 | { |
286 | delete mPopupMenu; | 292 | delete mPopupMenu; |
287 | } | 293 | } |
288 | 294 | ||
289 | void KOListView::updateList() | 295 | void KOListView::updateList() |
290 | { | 296 | { |
291 | // qDebug(" KOListView::updateList() "); | 297 | // qDebug(" KOListView::updateList() "); |
292 | 298 | ||
293 | } | 299 | } |
294 | 300 | ||
295 | void KOListView::addCat( ) | 301 | void KOListView::addCat( ) |
296 | { | 302 | { |
297 | setCategories( false ); | 303 | setCategories( false ); |
298 | } | 304 | } |
299 | void KOListView::setCat() | 305 | void KOListView::setCat() |
300 | { | 306 | { |
301 | setCategories( true ); | 307 | setCategories( true ); |
302 | } | 308 | } |
303 | void KOListView::setCategories( bool removeOld ) | 309 | void KOListView::setCategories( bool removeOld ) |
304 | { | 310 | { |
305 | 311 | ||
306 | KPIM::CategorySelectDialog* csd = new KPIM::CategorySelectDialog( KOPrefs::instance(), 0 ); | 312 | KPIM::CategorySelectDialog* csd = new KPIM::CategorySelectDialog( KOPrefs::instance(), 0 ); |
307 | if (! csd->exec()) { | 313 | if (! csd->exec()) { |
308 | delete csd; | 314 | delete csd; |
309 | return; | 315 | return; |
310 | } | 316 | } |
311 | QStringList catList = csd->selectedCategories(); | 317 | QStringList catList = csd->selectedCategories(); |
312 | delete csd; | 318 | delete csd; |
313 | // if ( catList.count() == 0 ) | 319 | // if ( catList.count() == 0 ) |
314 | // return; | 320 | // return; |
315 | catList.sort(); | 321 | catList.sort(); |
316 | QString categoriesStr = catList.join(","); | 322 | QString categoriesStr = catList.join(","); |
317 | int i; | 323 | int i; |
318 | QStringList itemList; | 324 | QStringList itemList; |
319 | QPtrList<KOListViewItem> sel ; | 325 | QPtrList<KOListViewItem> sel ; |
320 | QListViewItem *qitem = mListView->firstChild (); | 326 | QListViewItem *qitem = mListView->firstChild (); |
321 | while ( qitem ) { | 327 | while ( qitem ) { |
322 | if ( qitem->isSelected() ) { | 328 | if ( qitem->isSelected() ) { |
323 | sel.append(((KOListViewItem *)qitem)); | 329 | sel.append(((KOListViewItem *)qitem)); |
324 | } | 330 | } |
325 | qitem = qitem->nextSibling(); | 331 | qitem = qitem->nextSibling(); |
326 | } | 332 | } |
327 | KOListViewItem * item, *temp; | 333 | KOListViewItem * item, *temp; |
328 | item = sel.first(); | 334 | item = sel.first(); |
329 | Incidence* inc; | 335 | Incidence* inc; |
330 | while ( item ) { | 336 | while ( item ) { |
331 | inc = item->data(); | 337 | inc = item->data(); |
332 | if ( removeOld ) { | 338 | if ( removeOld ) { |
333 | inc->setCategories( categoriesStr ); | 339 | inc->setCategories( categoriesStr ); |
334 | } else { | 340 | } else { |
335 | itemList = QStringList::split (",", inc->categoriesStr() ); | 341 | itemList = QStringList::split (",", inc->categoriesStr() ); |
336 | for( i = 0; i< catList.count(); ++i ) { | 342 | for( i = 0; i< catList.count(); ++i ) { |
337 | if ( !itemList.contains (catList[i])) | 343 | if ( !itemList.contains (catList[i])) |
338 | itemList.append( catList[i] ); | 344 | itemList.append( catList[i] ); |
339 | } | 345 | } |
340 | itemList.sort(); | 346 | itemList.sort(); |
341 | inc->setCategories( itemList.join(",") ); | 347 | inc->setCategories( itemList.join(",") ); |
342 | } | 348 | } |
343 | temp = item; | 349 | temp = item; |
344 | item = sel.next(); | 350 | item = sel.next(); |
345 | mUidDict.remove( inc->uid() ); | 351 | mUidDict.remove( inc->uid() ); |
346 | delete temp;; | 352 | delete temp;; |
347 | addIncidence( inc ); | 353 | addIncidence( inc ); |
348 | } | 354 | } |
349 | } | 355 | } |
350 | 356 | ||
351 | void KOListView::beamSelected() | 357 | void KOListView::beamSelected() |
352 | { | 358 | { |
353 | int icount = 0; | 359 | int icount = 0; |
354 | QPtrList<Incidence> delSel ; | 360 | QPtrList<Incidence> delSel ; |
355 | QListViewItem *item = mListView->firstChild (); | 361 | QListViewItem *item = mListView->firstChild (); |
356 | while ( item ) { | 362 | while ( item ) { |
357 | if ( item->isSelected() ) { | 363 | if ( item->isSelected() ) { |
358 | delSel.append(((KOListViewItem *)item)->data()); | 364 | delSel.append(((KOListViewItem *)item)->data()); |
359 | ++icount; | 365 | ++icount; |
360 | } | 366 | } |
361 | 367 | ||
362 | item = item->nextSibling(); | 368 | item = item->nextSibling(); |
363 | } | 369 | } |
364 | if ( icount ) { | 370 | if ( icount ) { |
365 | emit beamIncidenceList( delSel ); | 371 | emit beamIncidenceList( delSel ); |
366 | return; | 372 | return; |
367 | QString fn ; | 373 | QString fn ; |
368 | fn = QDir::homeDirPath()+"/kopitempbeamfile.vcs"; | 374 | fn = QDir::homeDirPath()+"/kopitempbeamfile.vcs"; |
369 | QString mes; | 375 | QString mes; |
@@ -500,389 +506,394 @@ void KOListView::saveToFile() | |||
500 | } | 506 | } |
501 | 507 | ||
502 | item = item->nextSibling(); | 508 | item = item->nextSibling(); |
503 | } | 509 | } |
504 | if ( icount ) { | 510 | if ( icount ) { |
505 | QString fn = KOPrefs::instance()->mLastSaveFile; | 511 | QString fn = KOPrefs::instance()->mLastSaveFile; |
506 | fn = KFileDialog::getSaveFileName( fn, i18n("Save filename"), this ); | 512 | fn = KFileDialog::getSaveFileName( fn, i18n("Save filename"), this ); |
507 | 513 | ||
508 | if ( fn == "" ) | 514 | if ( fn == "" ) |
509 | return; | 515 | return; |
510 | QFileInfo info; | 516 | QFileInfo info; |
511 | info.setFile( fn ); | 517 | info.setFile( fn ); |
512 | QString mes; | 518 | QString mes; |
513 | bool createbup = true; | 519 | bool createbup = true; |
514 | if ( info. exists() ) { | 520 | if ( info. exists() ) { |
515 | mes = i18n("File already exists!\nOld file from:\n%1\nOverwrite?\n").arg (KGlobal::locale()->formatDateTime(info.lastModified (), true, false ) ); | 521 | mes = i18n("File already exists!\nOld file from:\n%1\nOverwrite?\n").arg (KGlobal::locale()->formatDateTime(info.lastModified (), true, false ) ); |
516 | int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"),mes, | 522 | int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"),mes, |
517 | i18n("Overwrite!"), i18n("Cancel"), 0, | 523 | i18n("Overwrite!"), i18n("Cancel"), 0, |
518 | 0, 1 ); | 524 | 0, 1 ); |
519 | if ( result != 0 ) { | 525 | if ( result != 0 ) { |
520 | createbup = false; | 526 | createbup = false; |
521 | } | 527 | } |
522 | } | 528 | } |
523 | if ( createbup ) { | 529 | if ( createbup ) { |
524 | CalendarLocal cal; | 530 | CalendarLocal cal; |
525 | cal.setTimeZoneId(KOPrefs::instance()->mTimeZoneId); | 531 | cal.setTimeZoneId(KOPrefs::instance()->mTimeZoneId); |
526 | Incidence *incidence = delSel.first(); | 532 | Incidence *incidence = delSel.first(); |
527 | while ( incidence ) { | 533 | while ( incidence ) { |
528 | cal.addIncidence( incidence->clone() ); | 534 | cal.addIncidence( incidence->clone() ); |
529 | incidence = delSel.next(); | 535 | incidence = delSel.next(); |
530 | } | 536 | } |
531 | ICalFormat format; | 537 | ICalFormat format; |
532 | format.save( &cal, fn ); | 538 | format.save( &cal, fn ); |
533 | mes = i18n("KO/Pi:Saved %1").arg(fn ); | 539 | mes = i18n("KO/Pi:Saved %1").arg(fn ); |
534 | KOPrefs::instance()->mLastSaveFile = fn; | 540 | KOPrefs::instance()->mLastSaveFile = fn; |
535 | topLevelWidget()->setCaption(mes); | 541 | topLevelWidget()->setCaption(mes); |
536 | } | 542 | } |
537 | } | 543 | } |
538 | } | 544 | } |
539 | void KOListView::deleteAll() | 545 | void KOListView::deleteAll() |
540 | { | 546 | { |
541 | int icount = 0; | 547 | int icount = 0; |
542 | QPtrList<Incidence> delSel ; | 548 | QPtrList<Incidence> delSel ; |
543 | QListViewItem *item = mListView->firstChild (); | 549 | QListViewItem *item = mListView->firstChild (); |
544 | while ( item ) { | 550 | while ( item ) { |
545 | if ( item->isSelected() ) { | 551 | if ( item->isSelected() ) { |
546 | delSel.append(((KOListViewItem *)item)->data()); | 552 | delSel.append(((KOListViewItem *)item)->data()); |
547 | ++icount; | 553 | ++icount; |
548 | } | 554 | } |
549 | 555 | ||
550 | item = item->nextSibling(); | 556 | item = item->nextSibling(); |
551 | } | 557 | } |
552 | if ( icount ) { | 558 | if ( icount ) { |
553 | Incidence *incidence = delSel.first(); | 559 | Incidence *incidence = delSel.first(); |
554 | Incidence *toDelete; | 560 | Incidence *toDelete; |
555 | KOPrefs *p = KOPrefs::instance(); | 561 | KOPrefs *p = KOPrefs::instance(); |
556 | bool confirm = p->mConfirm; | 562 | bool confirm = p->mConfirm; |
557 | QString mess; | 563 | QString mess; |
558 | mess = mess.sprintf( i18n("You have %d item(s) selected.\n"), icount ); | 564 | mess = mess.sprintf( i18n("You have %d item(s) selected.\n"), icount ); |
559 | if ( KMessageBox::Continue == KMessageBox::warningContinueCancel(this, mess + i18n("All selected items will be\npermanently deleted.\n(Deleting items will take\nsome time on a PDA)\n"), i18n("KO/Pi Confirmation"),i18n("Delete")) ) { | 565 | if ( KMessageBox::Continue == KMessageBox::warningContinueCancel(this, mess + i18n("All selected items will be\npermanently deleted.\n(Deleting items will take\nsome time on a PDA)\n"), i18n("KO/Pi Confirmation"),i18n("Delete")) ) { |
560 | p->mConfirm = false; | 566 | p->mConfirm = false; |
561 | int delCounter = 0; | 567 | int delCounter = 0; |
562 | QDialog dia ( this, "p-dialog", true ); | 568 | QDialog dia ( this, "p-dialog", true ); |
563 | QLabel lab (i18n("Close dialog to abort deletion!"), &dia ); | 569 | QLabel lab (i18n("Close dialog to abort deletion!"), &dia ); |
564 | QVBoxLayout lay( &dia ); | 570 | QVBoxLayout lay( &dia ); |
565 | lay.setMargin(7); | 571 | lay.setMargin(7); |
566 | lay.setSpacing(7); | 572 | lay.setSpacing(7); |
567 | lay.addWidget( &lab); | 573 | lay.addWidget( &lab); |
568 | QProgressBar bar( icount, &dia ); | 574 | QProgressBar bar( icount, &dia ); |
569 | lay.addWidget( &bar); | 575 | lay.addWidget( &bar); |
570 | int w = 220; | 576 | int w = 220; |
571 | int h = 50; | 577 | int h = 50; |
572 | int dw = QApplication::desktop()->width(); | 578 | int dw = QApplication::desktop()->width(); |
573 | int dh = QApplication::desktop()->height(); | 579 | int dh = QApplication::desktop()->height(); |
574 | dia.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); | 580 | dia.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); |
575 | //dia.resize( 240,50 ); | 581 | //dia.resize( 240,50 ); |
576 | dia.show(); | 582 | dia.show(); |
577 | 583 | ||
578 | while ( incidence ) { | 584 | while ( incidence ) { |
579 | bar.setProgress( delCounter ); | 585 | bar.setProgress( delCounter ); |
580 | mess = mess.sprintf( i18n("Deleting item %d ..."), ++delCounter ); | 586 | mess = mess.sprintf( i18n("Deleting item %d ..."), ++delCounter ); |
581 | dia.setCaption( mess ); | 587 | dia.setCaption( mess ); |
582 | qApp->processEvents(); | 588 | qApp->processEvents(); |
583 | toDelete = (incidence); | 589 | toDelete = (incidence); |
584 | incidence = delSel.next(); | 590 | incidence = delSel.next(); |
585 | emit deleteIncidenceSignal(toDelete ); | 591 | emit deleteIncidenceSignal(toDelete ); |
586 | if ( dia.result() != 0 ) | 592 | if ( dia.result() != 0 ) |
587 | break; | 593 | break; |
588 | 594 | ||
589 | } | 595 | } |
590 | mess = mess.sprintf( i18n("%d items remaining in list."), count() ); | 596 | mess = mess.sprintf( i18n("%d items remaining in list."), count() ); |
591 | topLevelWidget ()->setCaption( mess ); | 597 | topLevelWidget ()->setCaption( mess ); |
592 | p->mConfirm = confirm; | 598 | p->mConfirm = confirm; |
593 | } | 599 | } |
594 | } | 600 | } |
595 | 601 | ||
596 | 602 | ||
597 | } | 603 | } |
598 | int KOListView::maxDatesHint() | 604 | int KOListView::maxDatesHint() |
599 | { | 605 | { |
600 | return 0; | 606 | return 0; |
601 | } | 607 | } |
602 | 608 | ||
603 | int KOListView::currentDateCount() | 609 | int KOListView::currentDateCount() |
604 | { | 610 | { |
605 | return 0; | 611 | return 0; |
606 | } | 612 | } |
607 | 613 | ||
608 | QPtrList<Incidence> KOListView::selectedIncidences() | 614 | QPtrList<Incidence> KOListView::selectedIncidences() |
609 | { | 615 | { |
610 | QPtrList<Incidence> eventList; | 616 | QPtrList<Incidence> eventList; |
611 | QListViewItem *item = mListView->firstChild (); | 617 | QListViewItem *item = mListView->firstChild (); |
612 | while ( item ) { | 618 | while ( item ) { |
613 | if ( item->isSelected() ) { | 619 | if ( item->isSelected() ) { |
614 | eventList.append(((KOListViewItem *)item)->data()); | 620 | eventList.append(((KOListViewItem *)item)->data()); |
615 | } | 621 | } |
616 | 622 | ||
617 | item = item->nextSibling(); | 623 | item = item->nextSibling(); |
618 | } | 624 | } |
619 | 625 | ||
620 | // // QListViewItem *item = mListView->selectedItem(); | 626 | // // QListViewItem *item = mListView->selectedItem(); |
621 | //if (item) eventList.append(((KOListViewItem *)item)->data()); | 627 | //if (item) eventList.append(((KOListViewItem *)item)->data()); |
622 | 628 | ||
623 | return eventList; | 629 | return eventList; |
624 | } | 630 | } |
625 | 631 | ||
626 | DateList KOListView::selectedDates() | 632 | DateList KOListView::selectedDates() |
627 | { | 633 | { |
628 | DateList eventList; | 634 | DateList eventList; |
629 | return eventList; | 635 | return eventList; |
630 | } | 636 | } |
631 | 637 | ||
632 | void KOListView::showDates(bool show) | 638 | void KOListView::showDates(bool show) |
633 | { | 639 | { |
634 | // Shouldn't we set it to a value greater 0? When showDates is called with | 640 | // Shouldn't we set it to a value greater 0? When showDates is called with |
635 | // show == true at first, then the columnwidths are set to zero. | 641 | // show == true at first, then the columnwidths are set to zero. |
636 | static int oldColWidth1 = 0; | 642 | static int oldColWidth1 = 0; |
637 | static int oldColWidth3 = 0; | 643 | static int oldColWidth3 = 0; |
638 | 644 | ||
639 | if (!show) { | 645 | if (!show) { |
640 | oldColWidth1 = mListView->columnWidth(1); | 646 | oldColWidth1 = mListView->columnWidth(1); |
641 | oldColWidth3 = mListView->columnWidth(3); | 647 | oldColWidth3 = mListView->columnWidth(3); |
642 | mListView->setColumnWidth(1, 0); | 648 | mListView->setColumnWidth(1, 0); |
643 | mListView->setColumnWidth(3, 0); | 649 | mListView->setColumnWidth(3, 0); |
644 | } else { | 650 | } else { |
645 | mListView->setColumnWidth(1, oldColWidth1); | 651 | mListView->setColumnWidth(1, oldColWidth1); |
646 | mListView->setColumnWidth(3, oldColWidth3); | 652 | mListView->setColumnWidth(3, oldColWidth3); |
647 | } | 653 | } |
648 | mListView->repaint(); | 654 | mListView->repaint(); |
649 | } | 655 | } |
650 | 656 | ||
651 | void KOListView::printPreview(CalPrinter *calPrinter, const QDate &fd, | 657 | void KOListView::printPreview(CalPrinter *calPrinter, const QDate &fd, |
652 | const QDate &td) | 658 | const QDate &td) |
653 | { | 659 | { |
654 | #ifndef KORG_NOPRINTER | 660 | #ifndef KORG_NOPRINTER |
655 | calPrinter->preview(CalPrinter::Day, fd, td); | 661 | calPrinter->preview(CalPrinter::Day, fd, td); |
656 | #endif | 662 | #endif |
657 | } | 663 | } |
658 | 664 | ||
659 | void KOListView::showDates() | 665 | void KOListView::showDates() |
660 | { | 666 | { |
661 | showDates(true); | 667 | showDates(true); |
662 | } | 668 | } |
663 | 669 | ||
664 | void KOListView::hideDates() | 670 | void KOListView::hideDates() |
665 | { | 671 | { |
666 | showDates(false); | 672 | showDates(false); |
667 | } | 673 | } |
668 | 674 | ||
669 | void KOListView::updateView() | 675 | void KOListView::updateView() |
670 | { | 676 | { |
671 | mListView->setFocus(); | 677 | mListView->setFocus(); |
672 | if ( mListView->firstChild () ) | 678 | if ( mListView->firstChild () ) |
673 | mListView->setCurrentItem( mListView->firstChild () ); | 679 | mListView->setCurrentItem( mListView->firstChild () ); |
674 | } | 680 | } |
675 | void KOListView::updateConfig() | 681 | void KOListView::updateConfig() |
676 | { | 682 | { |
677 | 683 | ||
678 | mListView->setFont ( KOPrefs::instance()->mListViewFont ); | 684 | mListView->setFont ( KOPrefs::instance()->mListViewFont ); |
679 | updateView(); | 685 | updateView(); |
680 | 686 | ||
681 | } | 687 | } |
682 | void KOListView::setStartDate(const QDate &start) | 688 | void KOListView::setStartDate(const QDate &start) |
683 | { | 689 | { |
684 | mStartDate = start; | 690 | mStartDate = start; |
685 | } | 691 | } |
686 | 692 | ||
687 | void KOListView::showDates(const QDate &start, const QDate &end) | 693 | void KOListView::showDates(const QDate &start, const QDate &end) |
688 | { | 694 | { |
689 | clear(); | 695 | clear(); |
690 | mStartDate = start; | 696 | mStartDate = start; |
691 | QDate date = start; | 697 | QDate date = start; |
698 | QPtrList<Journal> j_list; | ||
692 | while( date <= end ) { | 699 | while( date <= end ) { |
693 | addEvents(calendar()->events(date)); | 700 | addEvents(calendar()->events(date)); |
694 | addTodos(calendar()->todos(date)); | 701 | addTodos(calendar()->todos(date)); |
702 | Journal* jo = calendar()->journal(date); | ||
703 | if ( jo ) | ||
704 | j_list.append( jo ); | ||
695 | date = date.addDays( 1 ); | 705 | date = date.addDays( 1 ); |
696 | } | 706 | } |
707 | addJournals(j_list); | ||
697 | emit incidenceSelected( 0 ); | 708 | emit incidenceSelected( 0 ); |
698 | updateView(); | 709 | updateView(); |
699 | 710 | ||
700 | } | 711 | } |
701 | 712 | ||
702 | void KOListView::addEvents(QPtrList<Event> eventList) | 713 | void KOListView::addEvents(QPtrList<Event> eventList) |
703 | { | 714 | { |
704 | Event *ev; | 715 | Event *ev; |
705 | for(ev = eventList.first(); ev; ev = eventList.next()) { | 716 | for(ev = eventList.first(); ev; ev = eventList.next()) { |
706 | addIncidence(ev); | 717 | addIncidence(ev); |
707 | } | 718 | } |
708 | if ( !mListView->currentItem() ){ | 719 | if ( !mListView->currentItem() ){ |
709 | updateView(); | 720 | updateView(); |
710 | } | 721 | } |
711 | } | 722 | } |
712 | 723 | ||
713 | void KOListView::addTodos(QPtrList<Todo> eventList) | 724 | void KOListView::addTodos(QPtrList<Todo> eventList) |
714 | { | 725 | { |
715 | Todo *ev; | 726 | Todo *ev; |
716 | for(ev = eventList.first(); ev; ev = eventList.next()) { | 727 | for(ev = eventList.first(); ev; ev = eventList.next()) { |
717 | addIncidence(ev); | 728 | addIncidence(ev); |
718 | } | 729 | } |
719 | if ( !mListView->currentItem() ){ | 730 | if ( !mListView->currentItem() ){ |
720 | updateView(); | 731 | updateView(); |
721 | } | 732 | } |
722 | } | 733 | } |
723 | void KOListView::addJournals(QPtrList<Journal> eventList) | 734 | void KOListView::addJournals(QPtrList<Journal> eventList) |
724 | { | 735 | { |
725 | Journal *ev; | 736 | Journal *ev; |
726 | for(ev = eventList.first(); ev; ev = eventList.next()) { | 737 | for(ev = eventList.first(); ev; ev = eventList.next()) { |
727 | addIncidence(ev); | 738 | addIncidence(ev); |
728 | } | 739 | } |
729 | if ( !mListView->currentItem() ){ | 740 | if ( !mListView->currentItem() ){ |
730 | updateView(); | 741 | updateView(); |
731 | } | 742 | } |
732 | } | 743 | } |
733 | 744 | ||
734 | void KOListView::addIncidence(Incidence *incidence) | 745 | void KOListView::addIncidence(Incidence *incidence) |
735 | { | 746 | { |
736 | if ( mUidDict.find( incidence->uid() ) ) return; | 747 | if ( mUidDict.find( incidence->uid() ) ) return; |
737 | 748 | ||
738 | // mListView->setFont ( KOPrefs::instance()->mListViewFont ); | 749 | // mListView->setFont ( KOPrefs::instance()->mListViewFont ); |
739 | mUidDict.insert( incidence->uid(), incidence ); | 750 | mUidDict.insert( incidence->uid(), incidence ); |
740 | 751 | ||
741 | KOListViewItem *item = new KOListViewItem( incidence, mListView ); | 752 | KOListViewItem *item = new KOListViewItem( incidence, mListView ); |
742 | ListItemVisitor v(item, mStartDate ); | 753 | ListItemVisitor v(item, mStartDate ); |
743 | if (incidence->accept(v)) return; | 754 | if (incidence->accept(v)) return; |
744 | else delete item; | 755 | else delete item; |
745 | //qDebug("delete item "); | 756 | //qDebug("delete item "); |
746 | } | 757 | } |
747 | 758 | ||
748 | void KOListView::showEvents(QPtrList<Event> eventList) | 759 | void KOListView::showEvents(QPtrList<Event> eventList) |
749 | { | 760 | { |
750 | clear(); | 761 | clear(); |
751 | 762 | ||
752 | addEvents(eventList); | 763 | addEvents(eventList); |
753 | 764 | ||
754 | // After new creation of list view no events are selected. | 765 | // After new creation of list view no events are selected. |
755 | emit incidenceSelected( 0 ); | 766 | emit incidenceSelected( 0 ); |
756 | } | 767 | } |
757 | int KOListView::count() | 768 | int KOListView::count() |
758 | { | 769 | { |
759 | return mListView->childCount(); | 770 | return mListView->childCount(); |
760 | } | 771 | } |
761 | 772 | ||
762 | void KOListView::changeEventDisplay(Event *event, int action) | 773 | void KOListView::changeEventDisplay(Event *event, int action) |
763 | { | 774 | { |
764 | KOListViewItem *item; | 775 | KOListViewItem *item; |
765 | 776 | ||
766 | switch(action) { | 777 | switch(action) { |
767 | case KOGlobals::EVENTADDED: | 778 | case KOGlobals::EVENTADDED: |
768 | addIncidence( event ); | 779 | addIncidence( event ); |
769 | break; | 780 | break; |
770 | case KOGlobals::EVENTEDITED: | 781 | case KOGlobals::EVENTEDITED: |
771 | item = getItemForEvent(event); | 782 | item = getItemForEvent(event); |
772 | if (item) { | 783 | if (item) { |
773 | mUidDict.remove( event->uid() ); | 784 | mUidDict.remove( event->uid() ); |
774 | delete item; | 785 | delete item; |
775 | addIncidence( event ); | 786 | addIncidence( event ); |
776 | } | 787 | } |
777 | break; | 788 | break; |
778 | case KOGlobals::EVENTDELETED: | 789 | case KOGlobals::EVENTDELETED: |
779 | item = getItemForEvent(event); | 790 | item = getItemForEvent(event); |
780 | if (item) { | 791 | if (item) { |
781 | mUidDict.remove( event->uid() ); | 792 | mUidDict.remove( event->uid() ); |
782 | delete item; | 793 | delete item; |
783 | } | 794 | } |
784 | break; | 795 | break; |
785 | default: | 796 | default: |
786 | ; | 797 | ; |
787 | } | 798 | } |
788 | } | 799 | } |
789 | 800 | ||
790 | KOListViewItem *KOListView::getItemForEvent(Event *event) | 801 | KOListViewItem *KOListView::getItemForEvent(Event *event) |
791 | { | 802 | { |
792 | KOListViewItem *item = (KOListViewItem *)mListView->firstChild(); | 803 | KOListViewItem *item = (KOListViewItem *)mListView->firstChild(); |
793 | while (item) { | 804 | while (item) { |
794 | if (item->data() == event) return item; | 805 | if (item->data() == event) return item; |
795 | item = (KOListViewItem *)item->nextSibling(); | 806 | item = (KOListViewItem *)item->nextSibling(); |
796 | } | 807 | } |
797 | return 0; | 808 | return 0; |
798 | } | 809 | } |
799 | 810 | ||
800 | void KOListView::defaultItemAction(QListViewItem *i) | 811 | void KOListView::defaultItemAction(QListViewItem *i) |
801 | { | 812 | { |
802 | KOListViewItem *item = static_cast<KOListViewItem *>( i ); | 813 | KOListViewItem *item = static_cast<KOListViewItem *>( i ); |
803 | if ( item ) defaultAction( item->data() ); | 814 | if ( item ) defaultAction( item->data() ); |
804 | 815 | ||
805 | } | 816 | } |
806 | 817 | ||
807 | void KOListView::popupMenu(QListViewItem *item,const QPoint &,int) | 818 | void KOListView::popupMenu(QListViewItem *item,const QPoint &,int) |
808 | { | 819 | { |
809 | mActiveItem = (KOListViewItem *)item; | 820 | mActiveItem = (KOListViewItem *)item; |
810 | if (mActiveItem) { | 821 | if (mActiveItem) { |
811 | Incidence *incidence = mActiveItem->data(); | 822 | Incidence *incidence = mActiveItem->data(); |
812 | mPopupMenu->showIncidencePopup(incidence); | 823 | mPopupMenu->showIncidencePopup(incidence); |
813 | 824 | ||
814 | /* | 825 | /* |
815 | if ( incidence && incidence->type() == "Event" ) { | 826 | if ( incidence && incidence->type() == "Event" ) { |
816 | Event *event = static_cast<Event *>( incidence ); | 827 | Event *event = static_cast<Event *>( incidence ); |
817 | mPopupMenu->showEventPopup(event); | 828 | mPopupMenu->showEventPopup(event); |
818 | } | 829 | } |
819 | */ | 830 | */ |
820 | } | 831 | } |
821 | } | 832 | } |
822 | 833 | ||
823 | void KOListView::readSettings(KConfig *config, QString setting) | 834 | void KOListView::readSettings(KConfig *config, QString setting) |
824 | { | 835 | { |
825 | // qDebug("KOListView::readSettings "); | 836 | // qDebug("KOListView::readSettings "); |
826 | mListView->restoreLayout(config,setting); | 837 | mListView->restoreLayout(config,setting); |
827 | } | 838 | } |
828 | 839 | ||
829 | void KOListView::writeSettings(KConfig *config, QString setting) | 840 | void KOListView::writeSettings(KConfig *config, QString setting) |
830 | { | 841 | { |
831 | // qDebug("KOListView::writeSettings "); | 842 | // qDebug("KOListView::writeSettings "); |
832 | mListView->saveLayout(config, setting); | 843 | mListView->saveLayout(config, setting); |
833 | } | 844 | } |
834 | 845 | ||
835 | void KOListView::processSelectionChange(QListViewItem *) | 846 | void KOListView::processSelectionChange(QListViewItem *) |
836 | { | 847 | { |
837 | 848 | ||
838 | KOListViewItem *item = | 849 | KOListViewItem *item = |
839 | static_cast<KOListViewItem *>( mListView->currentItem() ); | 850 | static_cast<KOListViewItem *>( mListView->currentItem() ); |
840 | 851 | ||
841 | if ( !item ) { | 852 | if ( !item ) { |
842 | emit incidenceSelected( 0 ); | 853 | emit incidenceSelected( 0 ); |
843 | } else { | 854 | } else { |
844 | emit incidenceSelected( item->data() ); | 855 | emit incidenceSelected( item->data() ); |
845 | } | 856 | } |
846 | } | 857 | } |
847 | 858 | ||
848 | void KOListView::clearSelection() | 859 | void KOListView::clearSelection() |
849 | { | 860 | { |
850 | mListView->selectAll( false ); | 861 | mListView->selectAll( false ); |
851 | } | 862 | } |
852 | void KOListView::allSelection() | 863 | void KOListView::allSelection() |
853 | { | 864 | { |
854 | mListView->selectAll( true ); | 865 | mListView->selectAll( true ); |
855 | } | 866 | } |
856 | 867 | ||
857 | void KOListView::clear() | 868 | void KOListView::clear() |
858 | { | 869 | { |
859 | mListView->clear(); | 870 | mListView->clear(); |
860 | mUidDict.clear(); | 871 | mUidDict.clear(); |
861 | } | 872 | } |
862 | 873 | ||
863 | Incidence* KOListView::currentItem() | 874 | Incidence* KOListView::currentItem() |
864 | { | 875 | { |
865 | if ( mListView->currentItem() ) | 876 | if ( mListView->currentItem() ) |
866 | return ((KOListViewItem*) mListView->currentItem())->data(); | 877 | return ((KOListViewItem*) mListView->currentItem())->data(); |
867 | return 0; | 878 | return 0; |
868 | } | 879 | } |
869 | void KOListView::keyPressEvent ( QKeyEvent *e) | 880 | void KOListView::keyPressEvent ( QKeyEvent *e) |
870 | { | 881 | { |
871 | 882 | ||
872 | if ( e->key() == Qt::Key_Delete || e->key() == Qt::Key_Backspace ) { | 883 | if ( e->key() == Qt::Key_Delete || e->key() == Qt::Key_Backspace ) { |
873 | deleteAll(); | 884 | deleteAll(); |
874 | return; | 885 | return; |
875 | } | 886 | } |
876 | 887 | ||
877 | e->ignore(); | 888 | e->ignore(); |
878 | } | 889 | } |
879 | void KOListViewListView::keyPressEvent ( QKeyEvent *e) | 890 | void KOListViewListView::keyPressEvent ( QKeyEvent *e) |
880 | { | 891 | { |
881 | 892 | ||
882 | switch ( e->key() ) { | 893 | switch ( e->key() ) { |
883 | case Qt::Key_Down: | 894 | case Qt::Key_Down: |
884 | if ( e->state() == ShiftButton ) { | 895 | if ( e->state() == ShiftButton ) { |
885 | QListViewItem* cn = currentItem(); | 896 | QListViewItem* cn = currentItem(); |
886 | if ( !cn ) | 897 | if ( !cn ) |
887 | cn = firstChild(); | 898 | cn = firstChild(); |
888 | if ( !cn ) | 899 | if ( !cn ) |
diff --git a/korganizer/main.cpp b/korganizer/main.cpp index c8a55d2..ca53828 100644 --- a/korganizer/main.cpp +++ b/korganizer/main.cpp | |||
@@ -1,104 +1,106 @@ | |||
1 | 1 | ||
2 | 2 | ||
3 | #ifndef DESKTOP_VERSION | 3 | #ifndef DESKTOP_VERSION |
4 | #include <qpe/qpeapplication.h> | 4 | #include <qpe/qpeapplication.h> |
5 | #include <qcopchannel_qws.h> | 5 | #include <qcopchannel_qws.h> |
6 | #include <qpe/global.h> | 6 | #include <qpe/global.h> |
7 | #include <stdlib.h> | 7 | #include <stdlib.h> |
8 | #else | 8 | #else |
9 | #include <qapplication.h> | 9 | #include <qapplication.h> |
10 | #include <qstring.h> | 10 | #include <qstring.h> |
11 | #include <qwindowsstyle.h> | 11 | #include <qwindowsstyle.h> |
12 | #include <qplatinumstyle.h> | 12 | #include <qplatinumstyle.h> |
13 | #include <qsgistyle.h> | 13 | #include <qsgistyle.h> |
14 | #endif | 14 | #endif |
15 | #include <qtextcodec.h> | ||
15 | 16 | ||
16 | #include <qdir.h> | 17 | #include <qdir.h> |
17 | #include <kstandarddirs.h> | 18 | #include <kstandarddirs.h> |
18 | #include <kglobal.h> | 19 | #include <kglobal.h> |
19 | #include <stdio.h> | 20 | #include <stdio.h> |
20 | #include "mainwindow.h" | 21 | #include "mainwindow.h" |
21 | 22 | ||
22 | int main( int argc, char **argv ) | 23 | int main( int argc, char **argv ) |
23 | { | 24 | { |
24 | #ifndef DESKTOP_VERSION | 25 | #ifndef DESKTOP_VERSION |
25 | QPEApplication a( argc, argv ); | 26 | QPEApplication a( argc, argv ); |
26 | a.setKeepRunning (); | 27 | a.setKeepRunning (); |
27 | #else | 28 | #else |
28 | QApplication a( argc, argv ); | 29 | QApplication a( argc, argv ); |
29 | QApplication::setStyle( new QPlatinumStyle ()); | 30 | QApplication::setStyle( new QPlatinumStyle ()); |
30 | QString hdir = QDir::homeDirPath(); | 31 | QString hdir = QDir::homeDirPath(); |
31 | // there is a bug when creating dirs for WIN 98 | 32 | // there is a bug when creating dirs for WIN 98 |
32 | // it is difficult to fix, because we have no WIN 98 runnung | 33 | // it is difficult to fix, because we have no WIN 98 runnung |
33 | // such that we try it to create the dirs at startup here | 34 | // such that we try it to create the dirs at startup here |
34 | if ( hdir == "C:\\" ) { // win 98 or ME | 35 | if ( hdir == "C:\\" ) { // win 98 or ME |
35 | QDir app_dir; | 36 | QDir app_dir; |
36 | if ( !app_dir.exists("C:\\kdepim") ) | 37 | if ( !app_dir.exists("C:\\kdepim") ) |
37 | app_dir.mkdir ("C:\\kdepim"); | 38 | app_dir.mkdir ("C:\\kdepim"); |
38 | if ( !app_dir.exists("C:\\kdepim\\apps") ) | 39 | if ( !app_dir.exists("C:\\kdepim\\apps") ) |
39 | app_dir.mkdir ("C:\\kdepim\\apps"); | 40 | app_dir.mkdir ("C:\\kdepim\\apps"); |
40 | if ( !app_dir.exists("C:\\kdepim\\config") ) | 41 | if ( !app_dir.exists("C:\\kdepim\\config") ) |
41 | app_dir.mkdir ("C:\\kdepim\\config"); | 42 | app_dir.mkdir ("C:\\kdepim\\config"); |
42 | if ( !app_dir.exists("C:\\kdepim\\apps\\korganizer") ) | 43 | if ( !app_dir.exists("C:\\kdepim\\apps\\korganizer") ) |
43 | app_dir.mkdir ("C:\\kdepim\\apps\\korganizer"); | 44 | app_dir.mkdir ("C:\\kdepim\\apps\\korganizer"); |
44 | } | 45 | } |
45 | #endif | 46 | #endif |
46 | bool exitHelp = false; | 47 | bool exitHelp = false; |
47 | if ( argc > 1 ) { | 48 | if ( argc > 1 ) { |
48 | QString command = argv[1]; | 49 | QString command = argv[1]; |
49 | if ( command == "-help" ){ | 50 | if ( command == "-help" ){ |
50 | printf("KO/Pi command line commands:\n"); | 51 | printf("KO/Pi command line commands:\n"); |
51 | printf(" no command: Start KO/Pi in usual way\n"); | 52 | printf(" no command: Start KO/Pi in usual way\n"); |
52 | printf(" -help: This output\n"); | 53 | printf(" -help: This output\n"); |
53 | printf("Next Option: Open or Show after start:\n"); | 54 | printf("Next Option: Open or Show after start:\n"); |
54 | printf(" -newTodo: New Todo dialog\n"); | 55 | printf(" -newTodo: New Todo dialog\n"); |
55 | printf(" -newEvent: New Event dialog\n"); | 56 | printf(" -newEvent: New Event dialog\n"); |
56 | printf(" -showList: List view\n"); | 57 | printf(" -showList: List view\n"); |
57 | printf(" -showDay: Day view\n"); | 58 | printf(" -showDay: Day view\n"); |
58 | printf(" -showWWeek: Work Week view\n"); | 59 | printf(" -showWWeek: Work Week view\n"); |
59 | printf(" -showWeek: Week view\n"); | 60 | printf(" -showWeek: Week view\n"); |
60 | printf(" -showTodo: Todo view\n"); | 61 | printf(" -showTodo: Todo view\n"); |
61 | printf(" -showJournal: Journal view\n"); | 62 | printf(" -showJournal: Journal view\n"); |
62 | printf(" -showKO: Next Days view\n"); | 63 | printf(" -showKO: Next Days view\n"); |
63 | printf(" -showWNext: What's Next view\n"); | 64 | printf(" -showWNext: What's Next view\n"); |
64 | printf(" -showNextXView: Next X View\n"); | 65 | printf(" -showNextXView: Next X View\n"); |
65 | printf(" -new[Y] and -show[X] may be used togehther\n"); | 66 | printf(" -new[Y] and -show[X] may be used togehther\n"); |
66 | printf(" KO/Pi is exiting now. Bye!\n"); | 67 | printf(" KO/Pi is exiting now. Bye!\n"); |
67 | exitHelp = true; | 68 | exitHelp = true; |
68 | } | 69 | } |
69 | } | 70 | } |
70 | if ( ! exitHelp ) { | 71 | if ( ! exitHelp ) { |
71 | KGlobal::setAppName( "korganizer" ); | 72 | KGlobal::setAppName( "korganizer" ); |
72 | QString fileName ; | 73 | QString fileName ; |
73 | #ifndef DESKTOP_VERSION | 74 | #ifndef DESKTOP_VERSION |
74 | fileName = getenv("QPEDIR"); | 75 | fileName = getenv("QPEDIR"); |
75 | KGlobal::iconLoader()->setIconPath( fileName +"/pics/kdepim/korganizer/"); | 76 | KGlobal::iconLoader()->setIconPath( fileName +"/pics/kdepim/korganizer/"); |
76 | #else | 77 | #else |
77 | fileName = qApp->applicationDirPath () + "/kdepim/korganizer/"; | 78 | fileName = qApp->applicationDirPath () + "/kdepim/korganizer/"; |
78 | KGlobal::iconLoader()->setIconPath(QDir::convertSeparators(fileName)); | 79 | KGlobal::iconLoader()->setIconPath(QDir::convertSeparators(fileName)); |
79 | #endif | 80 | #endif |
80 | KStandardDirs::setAppDir( QDir::convertSeparators(locateLocal("data", "korganizer"))); | 81 | KStandardDirs::setAppDir( QDir::convertSeparators(locateLocal("data", "korganizer"))); |
81 | MainWindow m; | 82 | MainWindow m; |
82 | #ifndef DESKTOP_VERSION | 83 | #ifndef DESKTOP_VERSION |
83 | 84 | ||
84 | QObject::connect( &a, SIGNAL (appMessage ( const QCString &, const QByteArray & )),&m, SLOT(recieve( const QCString&, const QByteArray& ))); | 85 | QObject::connect( &a, SIGNAL (appMessage ( const QCString &, const QByteArray & )),&m, SLOT(recieve( const QCString&, const QByteArray& ))); |
85 | a.showMainWidget(&m ); | 86 | a.showMainWidget(&m ); |
86 | #else | 87 | #else |
87 | a.setMainWidget(&m ); | 88 | a.setMainWidget(&m ); |
88 | m.show(); | 89 | m.show(); |
89 | //m.resize( 800, 600 ); | 90 | //m.resize( 800, 600 ); |
90 | QObject::connect(&a, SIGNAL(lastWindowClosed()), &a, SLOT(quit())); | 91 | QObject::connect(&a, SIGNAL(lastWindowClosed()), &a, SLOT(quit())); |
91 | #endif | 92 | #endif |
92 | if ( argc > 1 ) { | 93 | if ( argc > 1 ) { |
93 | QCString command = argv[1]; | 94 | QCString command = argv[1]; |
94 | if ( argc > 2 ) | 95 | if ( argc > 2 ) |
95 | command += argv[2]; | 96 | command += argv[2]; |
96 | qApp->processEvents(); | 97 | qApp->processEvents(); |
97 | m.recieve(command, QByteArray() ); | 98 | m.recieve(command, QByteArray() ); |
98 | 99 | ||
99 | } | 100 | } |
101 | |||
100 | a.exec(); | 102 | a.exec(); |
101 | 103 | ||
102 | } | 104 | } |
103 | qDebug("KO: Bye! "); | 105 | qDebug("KO: Bye! "); |
104 | } | 106 | } |