summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/pim/addressbook/addressbook.cpp44
1 files changed, 36 insertions, 8 deletions
diff --git a/core/pim/addressbook/addressbook.cpp b/core/pim/addressbook/addressbook.cpp
index a4c2c6e..7c52ef2 100644
--- a/core/pim/addressbook/addressbook.cpp
+++ b/core/pim/addressbook/addressbook.cpp
@@ -327,517 +327,545 @@ void AddressbookWindow::edit( int /*uid*/ )
327{ 327{
328} 328}
329 329
330void AddressbookWindow::add( const Opie::OPimRecord& ) 330void AddressbookWindow::add( const Opie::OPimRecord& )
331{ 331{
332} 332}
333 333
334void AddressbookWindow::slotItemNew() 334void AddressbookWindow::slotItemNew()
335{ 335{
336 Opie::OPimContact cnt; 336 Opie::OPimContact cnt;
337 if( !syncing ) { 337 if( !syncing ) {
338 editEntry( NewEntry ); 338 editEntry( NewEntry );
339 } else { 339 } else {
340 QMessageBox::warning(this, tr("Contacts"), 340 QMessageBox::warning(this, tr("Contacts"),
341 tr("Can not edit data, currently syncing")); 341 tr("Can not edit data, currently syncing"));
342 } 342 }
343} 343}
344 344
345void AddressbookWindow::slotItemEdit() 345void AddressbookWindow::slotItemEdit()
346{ 346{
347 if(!syncing) { 347 if(!syncing) {
348 if (m_actionPersonal->isOn()) { 348 if (m_actionPersonal->isOn()) {
349 editPersonal(); 349 editPersonal();
350 } else { 350 } else {
351 editEntry( EditEntry ); 351 editEntry( EditEntry );
352 } 352 }
353 } else { 353 } else {
354 QMessageBox::warning( this, tr("Contacts"), 354 QMessageBox::warning( this, tr("Contacts"),
355 tr("Can not edit data, currently syncing") ); 355 tr("Can not edit data, currently syncing") );
356 } 356 }
357} 357}
358 358
359void AddressbookWindow::slotItemDuplicate() 359void AddressbookWindow::slotItemDuplicate()
360{ 360{
361} 361}
362 362
363void AddressbookWindow::slotItemDelete() 363void AddressbookWindow::slotItemDelete()
364{ 364{
365 if(!syncing) { 365 if(!syncing) {
366 Opie::OPimContact tmpEntry = m_abView ->currentEntry(); 366 Opie::OPimContact tmpEntry = m_abView ->currentEntry();
367 367
368 // get a name, do the best we can... 368 // get a name, do the best we can...
369 QString strName = tmpEntry.fullName(); 369 QString strName = tmpEntry.fullName();
370 if ( strName.isEmpty() ) { 370 if ( strName.isEmpty() ) {
371 strName = tmpEntry.company(); 371 strName = tmpEntry.company();
372 if ( strName.isEmpty() ) 372 if ( strName.isEmpty() )
373 strName = "No Name"; 373 strName = "No Name";
374 } 374 }
375 375
376 376
377 if ( QPEMessageBox::confirmDelete( this, tr( "Contacts" ), 377 if ( QPEMessageBox::confirmDelete( this, tr( "Contacts" ),
378 strName ) ) { 378 strName ) ) {
379 m_abView->removeEntry( tmpEntry.uid() ); 379 m_abView->removeEntry( tmpEntry.uid() );
380 } 380 }
381 } else { 381 } else {
382 QMessageBox::warning( this, tr("Contacts"), 382 QMessageBox::warning( this, tr("Contacts"),
383 tr("Can not edit data, currently syncing") ); 383 tr("Can not edit data, currently syncing") );
384 } 384 }
385} 385}
386 386
387static const char * beamfile = "/tmp/obex/contact.vcf"; 387static const char * beamfile = "/tmp/obex/contact.vcf";
388 388
389void AddressbookWindow::slotItemBeam() 389void AddressbookWindow::slotItemBeam()
390{ 390{
391 QString beamFilename; 391 QString beamFilename;
392 Opie::OPimContact c; 392 Opie::OPimContact c;
393 if ( m_actionPersonal->isOn() ) { 393 if ( m_actionPersonal->isOn() ) {
394 beamFilename = addressbookPersonalVCardName(); 394 beamFilename = addressbookPersonalVCardName();
395 if ( !QFile::exists( beamFilename ) ) 395 if ( !QFile::exists( beamFilename ) )
396 return; // can't beam a non-existent file 396 return; // can't beam a non-existent file
397 Opie::OPimContactAccessBackend* vcard_backend = new Opie::OPimContactAccessBackend_VCard( QString::null, 397 Opie::OPimContactAccessBackend* vcard_backend = new Opie::OPimContactAccessBackend_VCard( QString::null,
398 beamFilename ); 398 beamFilename );
399 Opie::OPimContactAccess* access = new Opie::OPimContactAccess ( "addressbook", QString::null , vcard_backend, true ); 399 Opie::OPimContactAccess* access = new Opie::OPimContactAccess ( "addressbook", QString::null , vcard_backend, true );
400 Opie::OPimContactAccess::List allList = access->allRecords(); 400 Opie::OPimContactAccess::List allList = access->allRecords();
401 Opie::OPimContactAccess::List::Iterator it = allList.begin(); // Just take first 401 Opie::OPimContactAccess::List::Iterator it = allList.begin(); // Just take first
402 c = *it; 402 c = *it;
403 403
404 delete access; 404 delete access;
405 } else { 405 } else {
406 unlink( beamfile ); // delete if exists 406 unlink( beamfile ); // delete if exists
407 mkdir("/tmp/obex/", 0755); 407 mkdir("/tmp/obex/", 0755);
408 c = m_abView -> currentEntry(); 408 c = m_abView -> currentEntry();
409 Opie::OPimContactAccessBackend* vcard_backend = new Opie::OPimContactAccessBackend_VCard( QString::null, 409 Opie::OPimContactAccessBackend* vcard_backend = new Opie::OPimContactAccessBackend_VCard( QString::null,
410 beamfile ); 410 beamfile );
411 Opie::OPimContactAccess* access = new Opie::OPimContactAccess ( "addressbook", QString::null , vcard_backend, true ); 411 Opie::OPimContactAccess* access = new Opie::OPimContactAccess ( "addressbook", QString::null , vcard_backend, true );
412 access->add( c ); 412 access->add( c );
413 access->save(); 413 access->save();
414 delete access; 414 delete access;
415 415
416 beamFilename = beamfile; 416 beamFilename = beamfile;
417 } 417 }
418 418
419 odebug << "Beaming: " << beamFilename << oendl; 419 odebug << "Beaming: " << beamFilename << oendl;
420 420
421 Ir *ir = new Ir( this ); 421 Ir *ir = new Ir( this );
422 connect( ir, SIGNAL( done(Ir*) ), this, SLOT( beamDone(Ir*) ) ); 422 connect( ir, SIGNAL( done(Ir*) ), this, SLOT( beamDone(Ir*) ) );
423 QString description = c.fullName(); 423 QString description = c.fullName();
424 ir->send( beamFilename, description, "text/x-vCard" ); 424 ir->send( beamFilename, description, "text/x-vCard" );
425} 425}
426 426
427void AddressbookWindow::slotItemFind() 427void AddressbookWindow::slotItemFind()
428{ 428{
429} 429}
430 430
431void AddressbookWindow::slotConfigure() 431void AddressbookWindow::slotConfigure()
432{ 432{
433 ConfigDlg* dlg = new ConfigDlg( this, "Config" ); 433 ConfigDlg* dlg = new ConfigDlg( this, "Config" );
434 dlg -> setConfig( m_config ); 434 dlg -> setConfig( m_config );
435 if ( QPEApplication::execDialog( dlg ) ) { 435 if ( QPEApplication::execDialog( dlg ) ) {
436 odebug << "Config Dialog accepted!" << oendl; 436 odebug << "Config Dialog accepted!" << oendl;
437 m_config = dlg -> getConfig(); 437 m_config = dlg -> getConfig();
438 if ( m_curFontSize != m_config.fontSize() ){ 438 if ( m_curFontSize != m_config.fontSize() ){
439 odebug << "Font was changed!" << oendl; 439 odebug << "Font was changed!" << oendl;
440 m_curFontSize = m_config.fontSize(); 440 m_curFontSize = m_config.fontSize();
441 emit slotSetFont( m_curFontSize ); 441 emit slotSetFont( m_curFontSize );
442 } 442 }
443 m_abView -> setListOrder( m_config.orderList() ); 443 m_abView -> setListOrder( m_config.orderList() );
444 } 444 }
445 445
446 delete dlg; 446 delete dlg;
447} 447}
448 448
449void AddressbookWindow::slotShowFind( bool show ) 449void AddressbookWindow::slotShowFind( bool show )
450{ 450{
451 if ( show ) 451 if ( show )
452 { 452 {
453 // Display search bar 453 // Display search bar
454 m_searchBar->show(); 454 m_searchBar->show();
455 m_abView -> inSearch(); 455 m_abView -> inSearch();
456 m_searchEdit->setFocus(); 456 m_searchEdit->setFocus();
457 } 457 }
458 else 458 else
459 { 459 {
460 // Hide search bar 460 // Hide search bar
461 m_searchBar->hide(); 461 m_searchBar->hide();
462 m_abView -> offSearch(); 462 m_abView -> offSearch();
463 } 463 }
464} 464}
465 465
466void AddressbookWindow::slotFind() 466void AddressbookWindow::slotFind()
467{ 467{
468 m_abView->slotDoFind( m_searchEdit->text(), m_config.beCaseSensitive(), m_config.useRegExp(), false); 468 m_abView->slotDoFind( m_searchEdit->text(), m_config.beCaseSensitive(), m_config.useRegExp(), false);
469 469
470 m_searchEdit->clearFocus(); 470 m_searchEdit->clearFocus();
471 // m_abView->setFocus(); 471 // m_abView->setFocus();
472 472
473} 473}
474 474
475void AddressbookWindow::slotViewBack() 475void AddressbookWindow::slotViewBack()
476{ 476{
477 // :SX showList(); 477 // :SX showList();
478} 478}
479 479
480void AddressbookWindow::writeMail() 480void AddressbookWindow::writeMail()
481{ 481{
482 Opie::OPimContact c = m_abView -> currentEntry(); 482 Opie::OPimContact c = m_abView -> currentEntry();
483 QString name = c.fileAs(); 483 QString name = c.fileAs();
484 QString email = c.defaultEmail(); 484 QString email = c.defaultEmail();
485 485
486 // I prefer the OPIE-Environment variable before the 486 // I prefer the OPIE-Environment variable before the
487 // QPE-one.. 487 // QPE-one..
488 QString basepath = QString::fromLatin1( getenv("OPIEDIR") ); 488 QString basepath = QString::fromLatin1( getenv("OPIEDIR") );
489 if ( basepath.isEmpty() ) 489 if ( basepath.isEmpty() )
490 basepath = QString::fromLatin1( getenv("QPEDIR") ); 490 basepath = QString::fromLatin1( getenv("QPEDIR") );
491 491
492 // Try to access the preferred. If not possible, try to 492 // Try to access the preferred. If not possible, try to
493 // switch to the other one.. 493 // switch to the other one..
494 if ( m_config.useQtMail() ){ 494 if ( m_config.useQtMail() ){
495 odebug << "Accessing: " << (basepath + "/bin/qtmail") << oendl; 495 odebug << "Accessing: " << (basepath + "/bin/qtmail") << oendl;
496 if ( QFile::exists( basepath + "/bin/qtmail" ) ){ 496 if ( QFile::exists( basepath + "/bin/qtmail" ) ){
497 odebug << "QCop" << oendl; 497 odebug << "QCop" << oendl;
498 QCopEnvelope e("QPE/Application/qtmail", "writeMail(QString,QString)"); 498 QCopEnvelope e("QPE/Application/qtmail", "writeMail(QString,QString)");
499 e << name << email; 499 e << name << email;
500 return; 500 return;
501 } else 501 } else
502 m_config.setUseOpieMail( true ); 502 m_config.setUseOpieMail( true );
503 } 503 }
504 if ( m_config.useOpieMail() ){ 504 if ( m_config.useOpieMail() ){
505 odebug << "Accessing: " << (basepath + "/bin/opiemail") << oendl; 505 odebug << "Accessing: " << (basepath + "/bin/opiemail") << oendl;
506 if ( QFile::exists( basepath + "/bin/opiemail" ) ){ 506 if ( QFile::exists( basepath + "/bin/opiemail" ) ){
507 odebug << "QCop" << oendl; 507 odebug << "QCop" << oendl;
508 QCopEnvelope e("QPE/Application/opiemail", "writeMail(QString,QString)"); 508 QCopEnvelope e("QPE/Application/opiemail", "writeMail(QString,QString)");
509 e << name << email; 509 e << name << email;
510 return; 510 return;
511 } else 511 } else
512 m_config.setUseQtMail( true ); 512 m_config.setUseQtMail( true );
513 } 513 }
514 514
515} 515}
516 516
517void AddressbookWindow::beamDone( Ir *ir ) 517void AddressbookWindow::beamDone( Ir *ir )
518{ 518{
519 519
520 delete ir; 520 delete ir;
521 unlink( beamfile ); 521 unlink( beamfile );
522} 522}
523 523
524 524
525static void parseName( const QString& name, QString *first, QString *middle, 525static void parseName( const QString& name, QString *first, QString *middle,
526 QString * last ) 526 QString * last )
527{ 527{
528 528
529 int comma = name.find ( "," ); 529 int comma = name.find ( "," );
530 QString rest; 530 QString rest;
531 if ( comma > 0 ) { 531 if ( comma > 0 ) {
532 *last = name.left( comma ); 532 *last = name.left( comma );
533 comma++; 533 comma++;
534 while ( comma < int(name.length()) && name[comma] == ' ' ) 534 while ( comma < int(name.length()) && name[comma] == ' ' )
535 comma++; 535 comma++;
536 rest = name.mid( comma ); 536 rest = name.mid( comma );
537 } else { 537 } else {
538 int space = name.findRev( ' ' ); 538 int space = name.findRev( ' ' );
539 *last = name.mid( space+1 ); 539 *last = name.mid( space+1 );
540 rest = name.left( space ); 540 rest = name.left( space );
541 } 541 }
542 int space = rest.find( ' ' ); 542 int space = rest.find( ' ' );
543 if ( space <= 0 ) { 543 if ( space <= 0 ) {
544 *first = rest; 544 *first = rest;
545 } else { 545 } else {
546 *first = rest.left( space ); 546 *first = rest.left( space );
547 *middle = rest.mid( space+1 ); 547 *middle = rest.mid( space+1 );
548 } 548 }
549 549
550} 550}
551 551
552 552
553void AddressbookWindow::appMessage(const QCString &msg, const QByteArray &data) 553void AddressbookWindow::appMessage(const QCString &msg, const QByteArray &data)
554{ 554{
555 bool needShow = false; 555 bool needShow = false;
556 odebug << "Receiving QCop-Call with message " << msg << oendl; 556 odebug << "Receiving QCop-Call with message " << msg << oendl;
557 557
558 558
559 if (msg == "editPersonal()") { 559 if (msg == "editPersonal()") {
560 editPersonal(); 560 editPersonal();
561 561
562 // Categories might have changed, so reload 562 // Categories might have changed, so reload
563 reloadCategories(); 563 reloadCategories();
564 } else if (msg == "editPersonalAndClose()") { 564 } else if (msg == "editPersonalAndClose()") {
565 editPersonal(); 565 editPersonal();
566 close(); 566 close();
567 } else if ( msg == "addContact(QString,QString)" ) { 567 } else if ( msg == "addContact(QString,QString)" ) {
568 QDataStream stream(data,IO_ReadOnly); 568 QDataStream stream(data,IO_ReadOnly);
569 QString name, email; 569 QString name, email;
570 stream >> name >> email; 570 stream >> name >> email;
571 571
572 Opie::OPimContact cnt; 572 Opie::OPimContact cnt;
573 QString fn, mn, ln; 573 QString fn, mn, ln;
574 parseName( name, &fn, &mn, &ln ); 574 parseName( name, &fn, &mn, &ln );
575 //odebug << " " << fn << " - " << mn " - " << ln << oendl; 575 //odebug << " " << fn << " - " << mn " - " << ln << oendl;
576 cnt.setFirstName( fn ); 576 cnt.setFirstName( fn );
577 cnt.setMiddleName( mn ); 577 cnt.setMiddleName( mn );
578 cnt.setLastName( ln ); 578 cnt.setLastName( ln );
579 cnt.insertEmails( email ); 579 cnt.insertEmails( email );
580 cnt.setDefaultEmail( email ); 580 cnt.setDefaultEmail( email );
581 cnt.setFileAs(); 581 cnt.setFileAs();
582 582
583 m_abView -> addEntry( cnt ); 583 m_abView -> addEntry( cnt );
584 584
585 // :SXm_abView()->init( cnt ); 585 // :SXm_abView()->init( cnt );
586 editEntry( EditEntry ); 586 editEntry( EditEntry );
587 587
588 // Categories might have changed, so reload 588 // Categories might have changed, so reload
589 reloadCategories(); 589 reloadCategories();
590 } else if ( msg == "beamBusinessCard()" ) { 590 } else if ( msg == "beamBusinessCard()" ) {
591 QString beamFilename = addressbookPersonalVCardName(); 591 QString beamFilename = addressbookPersonalVCardName();
592 if ( !QFile::exists( beamFilename ) ) 592 if ( !QFile::exists( beamFilename ) )
593 return; // can't beam a non-existent file 593 return; // can't beam a non-existent file
594 594
595 Ir *ir = new Ir( this ); 595 Ir *ir = new Ir( this );
596 connect( ir, SIGNAL( done(Ir*) ), this, SLOT( beamDone(Ir*) ) ); 596 connect( ir, SIGNAL( done(Ir*) ), this, SLOT( beamDone(Ir*) ) );
597 QString description = "mycard.vcf"; 597 QString description = "mycard.vcf";
598 ir->send( beamFilename, description, "text/x-vCard" ); 598 ir->send( beamFilename, description, "text/x-vCard" );
599 } else if ( msg == "show(int)" ) { 599 } else if ( msg == "show(int)" ) {
600 raise(); 600 raise();
601 QDataStream stream(data,IO_ReadOnly); 601 QDataStream stream(data,IO_ReadOnly);
602 int uid; 602 int uid;
603 stream >> uid; 603 stream >> uid;
604 604
605 odebug << "Showing uid: " << uid << oendl; 605 odebug << "Showing uid: " << uid << oendl;
606 606
607 // Deactivate Personal View.. 607 // Deactivate Personal View..
608 if ( m_actionPersonal->isOn() ){ 608 if ( m_actionPersonal->isOn() ){
609 m_actionPersonal->setOn( false ); 609 m_actionPersonal->setOn( false );
610 slotPersonalView(); 610 slotPersonalView();
611 } 611 }
612 612
613 // Reset category and show as card.. 613 // Reset category and show as card..
614 m_abView -> setShowByCategory( QString::null ); 614 m_abView -> setShowByCategory( QString::null );
615 m_abView -> setCurrentUid( uid ); 615 m_abView -> setCurrentUid( uid );
616 slotViewSwitched ( AbView::CardView ); 616 slotViewSwitched ( AbView::CardView );
617 617
618 needShow = true; 618 needShow = true;
619 619
620 620
621 } else if ( msg == "edit(int)" ) { 621 } else if ( msg == "edit(int)" ) {
622 QDataStream stream(data,IO_ReadOnly); 622 QDataStream stream(data,IO_ReadOnly);
623 int uid; 623 int uid;
624 stream >> uid; 624 stream >> uid;
625 625
626 // Deactivate Personal View.. 626 // Deactivate Personal View..
627 if ( m_actionPersonal->isOn() ){ 627 if ( m_actionPersonal->isOn() ){
628 m_actionPersonal->setOn( false ); 628 m_actionPersonal->setOn( false );
629 slotPersonalView(); 629 slotPersonalView();
630 } 630 }
631 631
632 // Reset category and edit.. 632 // Reset category and edit..
633 m_abView -> setShowByCategory( QString::null ); 633 m_abView -> setShowByCategory( QString::null );
634 m_abView -> setCurrentUid( uid ); 634 m_abView -> setCurrentUid( uid );
635 slotItemEdit(); 635 slotItemEdit();
636 636
637 // Categories might have changed, so reload 637 // Categories might have changed, so reload
638 reloadCategories(); 638 reloadCategories();
639 } 639 }
640 640
641 if (needShow) 641 if (needShow)
642 QPEApplication::setKeepRunning(); 642 QPEApplication::setKeepRunning();
643} 643}
644 644
645void AddressbookWindow::editEntry( EntryMode entryMode ) 645void AddressbookWindow::editEntry( EntryMode entryMode )
646{ 646{
647 Opie::OPimContact entry; 647 Opie::OPimContact entry;
648 if ( !abEditor ) { 648 if ( !abEditor ) {
649 abEditor = new ContactEditor( entry, this, "editor" ); 649 abEditor = new ContactEditor( entry, this, "editor" );
650 } 650 }
651 if ( entryMode == EditEntry ) 651 if ( entryMode == EditEntry )
652 abEditor->setEntry( m_abView -> currentEntry() ); 652 abEditor->setEntry( m_abView -> currentEntry() );
653 else if ( entryMode == NewEntry ) 653 else if ( entryMode == NewEntry )
654 abEditor->setEntry( entry ); 654 abEditor->setEntry( entry );
655 // other things may change the caption. 655 // other things may change the caption.
656 abEditor->setCaption( tr("Edit Address") ); 656 abEditor->setCaption( tr("Edit Address") );
657 657
658 // fix the focus... 658 // fix the focus...
659 abEditor->setNameFocus(); 659 abEditor->setNameFocus();
660 if ( QPEApplication::execDialog( abEditor ) == QDialog::Accepted ) { 660 if ( QPEApplication::execDialog( abEditor ) == QDialog::Accepted ) {
661 setFocus(); 661 setFocus();
662 if ( entryMode == NewEntry ) { 662 if ( entryMode == NewEntry ) {
663 Opie::OPimContact insertEntry = abEditor->entry(); 663 Opie::OPimContact insertEntry = abEditor->entry();
664 insertEntry.assignUid(); 664 insertEntry.assignUid();
665 m_abView -> addEntry( insertEntry ); 665 m_abView -> addEntry( insertEntry );
666 m_abView -> setCurrentUid( insertEntry.uid() ); 666 m_abView -> setCurrentUid( insertEntry.uid() );
667 } else { 667 } else {
668 Opie::OPimContact replEntry = abEditor->entry(); 668 Opie::OPimContact replEntry = abEditor->entry();
669 669
670 if ( !replEntry.isValidUid() ) 670 if ( !replEntry.isValidUid() )
671 replEntry.assignUid(); 671 replEntry.assignUid();
672 672
673 m_abView -> replaceEntry( replEntry ); 673 m_abView -> replaceEntry( replEntry );
674 } 674 }
675 675
676 // Categories might have changed, so reload 676 // Categories might have changed, so reload
677 reloadCategories(); 677 reloadCategories();
678 } 678 }
679} 679}
680 680
681void AddressbookWindow::editPersonal() 681void AddressbookWindow::editPersonal()
682{ 682{
683 Opie::OPimContact entry; 683 Opie::OPimContact entry;
684 684
685 // Switch to personal view if not selected 685 // Switch to personal view if not selected
686 // but take care of the menu, too 686 // but take care of the menu, too
687 if ( ! m_actionPersonal->isOn() ){ 687 if ( ! m_actionPersonal->isOn() ){
688 odebug << "*** ++++" << oendl; 688 odebug << "*** ++++" << oendl;
689 m_actionPersonal->setOn( true ); 689 m_actionPersonal->setOn( true );
690 slotPersonalView(); 690 slotPersonalView();
691 } 691 }
692 692
693 if ( !abEditor ) { 693 if ( !abEditor ) {
694 abEditor = new ContactEditor( entry, this, "editor" ); 694 abEditor = new ContactEditor( entry, this, "editor" );
695 } 695 }
696 696
697 abEditor->setCaption(tr("Edit My Personal Details")); 697 abEditor->setCaption(tr("Edit My Personal Details"));
698 abEditor->setPersonalView( true ); 698 abEditor->setPersonalView( true );
699 editEntry( EditEntry ); 699 editEntry( EditEntry );
700 abEditor->setPersonalView( false ); 700 abEditor->setPersonalView( false );
701 701
702} 702}
703 703
704 704
705void AddressbookWindow::slotPersonalView() 705void AddressbookWindow::slotPersonalView()
706{ 706{
707 odebug << "slotPersonalView()" << oendl; 707 odebug << "slotPersonalView()" << oendl;
708 708
709 bool personal = m_actionPersonal->isOn(); 709 bool personal = m_actionPersonal->isOn();
710 710
711 // Disable certain menu items when showing personal details 711 // Disable actions when showing personal details
712 setItemNewEnabled( !personal ); 712 setItemNewEnabled( !personal );
713 setItemDuplicateEnabled( !personal ); 713 setItemDuplicateEnabled( !personal );
714 setItemDeleteEnabled( !personal ); 714 setItemDeleteEnabled( !personal );
715 m_actionMail->setEnabled( !personal ); 715 m_actionMail->setEnabled( !personal );
716 setShowCategories( !personal );
716 717
717 // Display appropriate view 718 // Display appropriate view
718 m_abView->showPersonal( personal ); 719 m_abView->showPersonal( personal );
719 720
720 // Set application caption 721 if ( personal )
721 personal ? setCaption( tr( "Contacts - My Personal Details") ) 722 {
722 : setCaption( tr( "Contacts") ); 723 setCaption( tr( "Contacts - My Personal Details") );
724
725 // Set category to 'All' to make sure personal details is visible
726 setViewCategory( "All" );
727 m_abView->setShowByCategory( "All" );
728
729 // Temporarily disable letter picker
730 pLabel->hide();
731 }
732 else
733 {
734 setCaption( tr( "Contacts") );
735
736 // Re-enable letter picker
737 pLabel->show();
738 }
723} 739}
724 740
725void AddressbookWindow::reload() 741void AddressbookWindow::reload()
726{ 742{
727 syncing = false; 743 syncing = false;
728 m_abView->clear(); 744 m_abView->clear();
729 m_abView->reload(); 745 m_abView->reload();
730} 746}
731 747
732void AddressbookWindow::flush() 748void AddressbookWindow::flush()
733{ 749{
734 syncing = true; 750 syncing = true;
735 m_abView->save(); 751 m_abView->save();
736} 752}
737 753
738 754
739void AddressbookWindow::closeEvent( QCloseEvent *e ) 755void AddressbookWindow::closeEvent( QCloseEvent *e )
740{ 756{
741 if(active_view == AbView::CardView){ 757 if ( active_view == AbView::CardView )
742 slotViewSwitched( AbView::TableView ); 758 {
743 e->ignore(); 759 if ( !m_actionPersonal->isOn() )
744 return; 760 {
761 // Switch to table view only if not editing personal details
762 slotViewSwitched( AbView::TableView );
763 }
764 else
765 {
766 // If currently editing personal details, switch off personal view
767 m_actionPersonal->setOn( false );
768 slotPersonalView();
769 }
770
771 e->ignore();
772 return;
745 } 773 }
746 if(syncing) { 774 if(syncing) {
747 /* shouldn't we save, I hear you say? well its already been set 775 /* shouldn't we save, I hear you say? well its already been set
748 so that an edit can not occur during a sync, and we flushed 776 so that an edit can not occur during a sync, and we flushed
749 at the start of the sync, so there is no need to save 777 at the start of the sync, so there is no need to save
750 Saving however itself would cause problems. */ 778 Saving however itself would cause problems. */
751 e->accept(); 779 e->accept();
752 return; 780 return;
753 } 781 }
754 //################## shouldn't always save 782 //################## shouldn't always save
755 // True, but the database handles this automatically ! (se) 783 // True, but the database handles this automatically ! (se)
756 if ( save() ) 784 if ( save() )
757 e->accept(); 785 e->accept();
758 else 786 else
759 e->ignore(); 787 e->ignore();
760} 788}
761 789
762/* 790/*
763 Returns true if it is OK to exit 791 Returns true if it is OK to exit
764*/ 792*/
765 793
766bool AddressbookWindow::save() 794bool AddressbookWindow::save()
767{ 795{
768 if ( !m_abView->save() ) { 796 if ( !m_abView->save() ) {
769 if ( QMessageBox::critical( 0, tr( "Out of space" ), 797 if ( QMessageBox::critical( 0, tr( "Out of space" ),
770 tr("Unable to save information.\n" 798 tr("Unable to save information.\n"
771 "Free up some space\n" 799 "Free up some space\n"
772 "and try again.\n" 800 "and try again.\n"
773 "\nQuit anyway?"), 801 "\nQuit anyway?"),
774 QMessageBox::Yes|QMessageBox::Escape, 802 QMessageBox::Yes|QMessageBox::Escape,
775 QMessageBox::No|QMessageBox::Default ) 803 QMessageBox::No|QMessageBox::Default )
776 != QMessageBox::No ) 804 != QMessageBox::No )
777 return true; 805 return true;
778 else 806 else
779 return false; 807 return false;
780 } 808 }
781 return true; 809 return true;
782} 810}
783 811
784#ifdef __DEBUG_RELEASE 812#ifdef __DEBUG_RELEASE
785void AddressbookWindow::slotSave() 813void AddressbookWindow::slotSave()
786{ 814{
787 save(); 815 save();
788} 816}
789#endif 817#endif
790 818
791 819
792void AddressbookWindow::slotNotFound() 820void AddressbookWindow::slotNotFound()
793{ 821{
794 odebug << "Got not found signal!" << oendl; 822 odebug << "Got not found signal!" << oendl;
795 QMessageBox::information( this, tr( "Not Found" ), 823 QMessageBox::information( this, tr( "Not Found" ),
796 "<qt>" + tr( "Unable to find a contact for this search pattern!" ) + "</qt>" ); 824 "<qt>" + tr( "Unable to find a contact for this search pattern!" ) + "</qt>" );
797 825
798 826
799} 827}
800void AddressbookWindow::slotWrapAround() 828void AddressbookWindow::slotWrapAround()
801{ 829{
802 odebug << "Got wrap signal!" << oendl; 830 odebug << "Got wrap signal!" << oendl;
803 // if ( doNotifyWrapAround ) 831 // if ( doNotifyWrapAround )
804 // QMessageBox::information( this, tr( "End of list" ), 832 // QMessageBox::information( this, tr( "End of list" ),
805 // tr( "End of list. Wrap around now...!" ) + "\n" ); 833 // tr( "End of list. Wrap around now...!" ) + "\n" );
806 834
807} 835}
808 836
809void AddressbookWindow::slotSetCategory( const QString &category ) 837void AddressbookWindow::slotSetCategory( const QString &category )
810{ 838{
811 odebug << "void AddressbookWindow::slotSetCategory( " << category << " )" << oendl; 839 odebug << "void AddressbookWindow::slotSetCategory( " << category << " )" << oendl;
812 840
813 // Tell the view about the selected category 841 // Tell the view about the selected category
814 m_config.setCategory( category ); 842 m_config.setCategory( category );
815 m_abView -> setShowByCategory( category ); 843 m_abView -> setShowByCategory( category );
816} 844}
817 845
818void AddressbookWindow::slotViewSwitched( int view ) 846void AddressbookWindow::slotViewSwitched( int view )
819{ 847{
820 odebug << "void AddressbookWindow::slotViewSwitched( " << view << " )" << oendl; 848 odebug << "void AddressbookWindow::slotViewSwitched( " << view << " )" << oendl;
821 849
822 // Tell the view about the selected view 850 // Tell the view about the selected view
823 m_abView -> setShowToView ( (AbView::Views) view ); 851 m_abView -> setShowToView ( (AbView::Views) view );
824 active_view = view; 852 active_view = view;
825} 853}
826 854
827 855
828void AddressbookWindow::slotListView() 856void AddressbookWindow::slotListView()
829{ 857{
830 slotViewSwitched( AbView::TableView ); 858 slotViewSwitched( AbView::TableView );
831} 859}
832 860
833void AddressbookWindow::slotCardView() 861void AddressbookWindow::slotCardView()
834{ 862{
835 slotViewSwitched( AbView::CardView ); 863 slotViewSwitched( AbView::CardView );
836} 864}
837 865
838void AddressbookWindow::slotSetLetter( char c ) { 866void AddressbookWindow::slotSetLetter( char c ) {
839 867
840 m_abView->setShowByLetter( c, m_config.letterPickerSearch() ); 868 m_abView->setShowByLetter( c, m_config.letterPickerSearch() );
841 869
842} 870}
843 871