summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/pim/addressbook/addressbook.cpp13
-rw-r--r--core/pim/addressbook/addressbook.h4
2 files changed, 12 insertions, 5 deletions
diff --git a/core/pim/addressbook/addressbook.cpp b/core/pim/addressbook/addressbook.cpp
index c2cce92..12dc24e 100644
--- a/core/pim/addressbook/addressbook.cpp
+++ b/core/pim/addressbook/addressbook.cpp
@@ -460,526 +460,537 @@ void AddressbookWindow::slotFindOpen()
460 searchBar->show(); 460 searchBar->show();
461 m_abView -> inSearch(); 461 m_abView -> inSearch();
462 searchEdit->setFocus(); 462 searchEdit->setFocus();
463} 463}
464void AddressbookWindow::slotFindClose() 464void AddressbookWindow::slotFindClose()
465{ 465{
466 searchBar->hide(); 466 searchBar->hide();
467 m_abView -> offSearch(); 467 m_abView -> offSearch();
468 // m_abView->setFocus(); 468 // m_abView->setFocus();
469} 469}
470 470
471 471
472void AddressbookWindow::slotFind() 472void AddressbookWindow::slotFind()
473{ 473{
474 m_abView->slotDoFind( searchEdit->text(), m_config.beCaseSensitive(), m_config.useRegExp(), false); 474 m_abView->slotDoFind( searchEdit->text(), m_config.beCaseSensitive(), m_config.useRegExp(), false);
475 475
476 searchEdit->clearFocus(); 476 searchEdit->clearFocus();
477 // m_abView->setFocus(); 477 // m_abView->setFocus();
478 478
479} 479}
480 480
481void AddressbookWindow::slotViewBack() 481void AddressbookWindow::slotViewBack()
482{ 482{
483 // :SX showList(); 483 // :SX showList();
484} 484}
485 485
486void AddressbookWindow::slotViewEdit() 486void AddressbookWindow::slotViewEdit()
487{ 487{
488 if(!syncing) { 488 if(!syncing) {
489 if (actionPersonal->isOn()) { 489 if (actionPersonal->isOn()) {
490 editPersonal(); 490 editPersonal();
491 } else { 491 } else {
492 editEntry( EditEntry ); 492 editEntry( EditEntry );
493 } 493 }
494 } else { 494 } else {
495 QMessageBox::warning( this, tr("Contacts"), 495 QMessageBox::warning( this, tr("Contacts"),
496 tr("Can not edit data, currently syncing") ); 496 tr("Can not edit data, currently syncing") );
497 } 497 }
498} 498}
499 499
500 500
501 501
502void AddressbookWindow::writeMail() 502void AddressbookWindow::writeMail()
503{ 503{
504 OContact c = m_abView -> currentEntry(); 504 OContact c = m_abView -> currentEntry();
505 QString name = c.fileAs(); 505 QString name = c.fileAs();
506 QString email = c.defaultEmail(); 506 QString email = c.defaultEmail();
507 507
508 // I prefer the OPIE-Environment variable before the 508 // I prefer the OPIE-Environment variable before the
509 // QPE-one.. 509 // QPE-one..
510 QString basepath = QString::fromLatin1( getenv("OPIEDIR") ); 510 QString basepath = QString::fromLatin1( getenv("OPIEDIR") );
511 if ( basepath.isEmpty() ) 511 if ( basepath.isEmpty() )
512 basepath = QString::fromLatin1( getenv("QPEDIR") ); 512 basepath = QString::fromLatin1( getenv("QPEDIR") );
513 513
514 // Try to access the preferred. If not possible, try to 514 // Try to access the preferred. If not possible, try to
515 // switch to the other one.. 515 // switch to the other one..
516 if ( m_config.useQtMail() ){ 516 if ( m_config.useQtMail() ){
517 qWarning ("Accessing: %s", (basepath + "/bin/qtmail").latin1()); 517 qWarning ("Accessing: %s", (basepath + "/bin/qtmail").latin1());
518 if ( QFile::exists( basepath + "/bin/qtmail" ) ){ 518 if ( QFile::exists( basepath + "/bin/qtmail" ) ){
519 qWarning ("QCop"); 519 qWarning ("QCop");
520 QCopEnvelope e("QPE/Application/qtmail", "writeMail(QString,QString)"); 520 QCopEnvelope e("QPE/Application/qtmail", "writeMail(QString,QString)");
521 e << name << email; 521 e << name << email;
522 return; 522 return;
523 } else 523 } else
524 m_config.setUseOpieMail( true ); 524 m_config.setUseOpieMail( true );
525 } 525 }
526 if ( m_config.useOpieMail() ){ 526 if ( m_config.useOpieMail() ){
527 qWarning ("Accessing: %s", (basepath + "/bin/mail").latin1()); 527 qWarning ("Accessing: %s", (basepath + "/bin/mail").latin1());
528 if ( QFile::exists( basepath + "/bin/mail" ) ){ 528 if ( QFile::exists( basepath + "/bin/mail" ) ){
529 qWarning ("QCop"); 529 qWarning ("QCop");
530 QCopEnvelope e("QPE/Application/mail", "writeMail(QString,QString)"); 530 QCopEnvelope e("QPE/Application/mail", "writeMail(QString,QString)");
531 e << name << email; 531 e << name << email;
532 return; 532 return;
533 } else 533 } else
534 m_config.setUseQtMail( true ); 534 m_config.setUseQtMail( true );
535 } 535 }
536 536
537} 537}
538 538
539static const char * beamfile = "/tmp/obex/contact.vcf"; 539static const char * beamfile = "/tmp/obex/contact.vcf";
540 540
541void AddressbookWindow::slotBeam() 541void AddressbookWindow::slotBeam()
542{ 542{
543 QString filename; 543 QString filename;
544 OContact c; 544 OContact c;
545 if ( actionPersonal->isOn() ) { 545 if ( actionPersonal->isOn() ) {
546 filename = addressbookPersonalVCardName(); 546 filename = addressbookPersonalVCardName();
547 if (!QFile::exists(filename)) 547 if (!QFile::exists(filename))
548 return; // can't beam a non-existent file 548 return; // can't beam a non-existent file
549 OContactAccessBackend* vcard_backend = new OContactAccessBackend_VCard( QString::null, 549 OContactAccessBackend* vcard_backend = new OContactAccessBackend_VCard( QString::null,
550 filename ); 550 filename );
551 OContactAccess* access = new OContactAccess ( "addressbook", QString::null , vcard_backend, true ); 551 OContactAccess* access = new OContactAccess ( "addressbook", QString::null , vcard_backend, true );
552 OContactAccess::List allList = access->allRecords(); 552 OContactAccess::List allList = access->allRecords();
553 OContactAccess::List::Iterator it = allList.begin(); // Just take first 553 OContactAccess::List::Iterator it = allList.begin(); // Just take first
554 c = *it; 554 c = *it;
555 555
556 delete access; 556 delete access;
557 } else { 557 } else {
558 unlink( beamfile ); // delete if exists 558 unlink( beamfile ); // delete if exists
559 mkdir("/tmp/obex/", 0755); 559 mkdir("/tmp/obex/", 0755);
560 c = m_abView -> currentEntry(); 560 c = m_abView -> currentEntry();
561 OContactAccessBackend* vcard_backend = new OContactAccessBackend_VCard( QString::null, 561 OContactAccessBackend* vcard_backend = new OContactAccessBackend_VCard( QString::null,
562 beamfile ); 562 beamfile );
563 OContactAccess* access = new OContactAccess ( "addressbook", QString::null , vcard_backend, true ); 563 OContactAccess* access = new OContactAccess ( "addressbook", QString::null , vcard_backend, true );
564 access->add( c ); 564 access->add( c );
565 access->save(); 565 access->save();
566 delete access; 566 delete access;
567 567
568 filename = beamfile; 568 filename = beamfile;
569 } 569 }
570 570
571 571
572 Ir *ir = new Ir( this ); 572 Ir *ir = new Ir( this );
573 connect( ir, SIGNAL( done( Ir * ) ), this, SLOT( beamDone( Ir * ) ) ); 573 connect( ir, SIGNAL( done( Ir * ) ), this, SLOT( beamDone( Ir * ) ) );
574 QString description = c.fullName(); 574 QString description = c.fullName();
575 ir->send( filename, description, "text/x-vCard" ); 575 ir->send( filename, description, "text/x-vCard" );
576} 576}
577 577
578void AddressbookWindow::beamDone( Ir *ir ) 578void AddressbookWindow::beamDone( Ir *ir )
579{ 579{
580 delete ir; 580 delete ir;
581 unlink( beamfile ); 581 unlink( beamfile );
582} 582}
583 583
584 584
585static void parseName( const QString& name, QString *first, QString *middle, 585static void parseName( const QString& name, QString *first, QString *middle,
586 QString * last ) 586 QString * last )
587{ 587{
588 588
589 int comma = name.find ( "," ); 589 int comma = name.find ( "," );
590 QString rest; 590 QString rest;
591 if ( comma > 0 ) { 591 if ( comma > 0 ) {
592 *last = name.left( comma ); 592 *last = name.left( comma );
593 comma++; 593 comma++;
594 while ( comma < int(name.length()) && name[comma] == ' ' ) 594 while ( comma < int(name.length()) && name[comma] == ' ' )
595 comma++; 595 comma++;
596 rest = name.mid( comma ); 596 rest = name.mid( comma );
597 } else { 597 } else {
598 int space = name.findRev( ' ' ); 598 int space = name.findRev( ' ' );
599 *last = name.mid( space+1 ); 599 *last = name.mid( space+1 );
600 rest = name.left( space ); 600 rest = name.left( space );
601 } 601 }
602 int space = rest.find( ' ' ); 602 int space = rest.find( ' ' );
603 if ( space <= 0 ) { 603 if ( space <= 0 ) {
604 *first = rest; 604 *first = rest;
605 } else { 605 } else {
606 *first = rest.left( space ); 606 *first = rest.left( space );
607 *middle = rest.mid( space+1 ); 607 *middle = rest.mid( space+1 );
608 } 608 }
609 609
610} 610}
611 611
612 612
613void AddressbookWindow::appMessage(const QCString &msg, const QByteArray &data) 613void AddressbookWindow::appMessage(const QCString &msg, const QByteArray &data)
614{ 614{
615 if (msg == "editPersonal()") { 615 if (msg == "editPersonal()") {
616 editPersonal(); 616 editPersonal();
617 } else if (msg == "editPersonalAndClose()") { 617 } else if (msg == "editPersonalAndClose()") {
618 editPersonal(); 618 editPersonal();
619 close(); 619 close();
620 } else if ( msg == "addContact(QString,QString)" ) { 620 } else if ( msg == "addContact(QString,QString)" ) {
621 QDataStream stream(data,IO_ReadOnly); 621 QDataStream stream(data,IO_ReadOnly);
622 QString name, email; 622 QString name, email;
623 stream >> name >> email; 623 stream >> name >> email;
624 624
625 OContact cnt; 625 OContact cnt;
626 QString fn, mn, ln; 626 QString fn, mn, ln;
627 parseName( name, &fn, &mn, &ln ); 627 parseName( name, &fn, &mn, &ln );
628 // qDebug( " %s - %s - %s", fn.latin1(), mn.latin1(), ln.latin1() ); 628 // qDebug( " %s - %s - %s", fn.latin1(), mn.latin1(), ln.latin1() );
629 cnt.setFirstName( fn ); 629 cnt.setFirstName( fn );
630 cnt.setMiddleName( mn ); 630 cnt.setMiddleName( mn );
631 cnt.setLastName( ln ); 631 cnt.setLastName( ln );
632 cnt.insertEmails( email ); 632 cnt.insertEmails( email );
633 cnt.setDefaultEmail( email ); 633 cnt.setDefaultEmail( email );
634 cnt.setFileAs(); 634 cnt.setFileAs();
635 635
636 m_abView -> addEntry( cnt ); 636 m_abView -> addEntry( cnt );
637 637
638 // :SXm_abView()->init( cnt ); 638 // :SXm_abView()->init( cnt );
639 editEntry( EditEntry ); 639 editEntry( EditEntry );
640 640
641 641
642 642
643 } 643 }
644#if 0 644#if 0
645 else if (msg == "pickAddresses(QCString,QCString,QStringList,...)" ) { 645 else if (msg == "pickAddresses(QCString,QCString,QStringList,...)" ) {
646 QDataStream stream(data,IO_ReadOnly); 646 QDataStream stream(data,IO_ReadOnly);
647 QCString ch,m; 647 QCString ch,m;
648 QStringList types; 648 QStringList types;
649 stream >> ch >> m >> types; 649 stream >> ch >> m >> types;
650 AddressPicker picker(abList,this,0,TRUE); 650 AddressPicker picker(abList,this,0,TRUE);
651 picker.showMaximized(); 651 picker.showMaximized();
652 picker.setChoiceNames(types); 652 picker.setChoiceNames(types);
653 int i=0; 653 int i=0;
654 for (QStringList::ConstIterator it = types.begin(); it!=types.end(); ++it) { 654 for (QStringList::ConstIterator it = types.begin(); it!=types.end(); ++it) {
655 QStringList sel; 655 QStringList sel;
656 stream >> sel; 656 stream >> sel;
657 picker.setSelection(i++,sel); 657 picker.setSelection(i++,sel);
658 } 658 }
659 picker.showMaximized(); 659 picker.showMaximized();
660 picker.exec(); 660 picker.exec();
661 661
662 // ###### note: contacts may have been added - save here! 662 // ###### note: contacts may have been added - save here!
663 663
664 setCentralWidget(abList); 664 setCentralWidget(abList);
665 QCopEnvelope e(ch,m); 665 QCopEnvelope e(ch,m);
666 i=0; 666 i=0;
667 for (QStringList::ConstIterator it = types.begin(); it!=types.end(); ++it) { 667 for (QStringList::ConstIterator it = types.begin(); it!=types.end(); ++it) {
668 QStringList sel = picker.selection(i++); 668 QStringList sel = picker.selection(i++);
669 e << sel; 669 e << sel;
670 } 670 }
671 } 671 }
672#endif 672#endif
673 673
674} 674}
675 675
676void AddressbookWindow::editEntry( EntryMode entryMode ) 676void AddressbookWindow::editEntry( EntryMode entryMode )
677{ 677{
678 OContact entry; 678 OContact entry;
679 if ( !abEditor ) { 679 if ( !abEditor ) {
680 abEditor = new ContactEditor( entry, this, "editor" ); 680 abEditor = new ContactEditor( entry, this, "editor" );
681 } 681 }
682 if ( entryMode == EditEntry ) 682 if ( entryMode == EditEntry )
683 abEditor->setEntry( m_abView -> currentEntry() ); 683 abEditor->setEntry( m_abView -> currentEntry() );
684 else if ( entryMode == NewEntry ) 684 else if ( entryMode == NewEntry )
685 abEditor->setEntry( entry ); 685 abEditor->setEntry( entry );
686 // other things may change the caption. 686 // other things may change the caption.
687 abEditor->setCaption( tr("Edit Address") ); 687 abEditor->setCaption( tr("Edit Address") );
688 688
689#if defined(Q_WS_QWS) || defined(_WS_QWS_) 689#if defined(Q_WS_QWS) || defined(_WS_QWS_)
690 abEditor->showMaximized(); 690 abEditor->showMaximized();
691#endif 691#endif
692 // fix the foxus... 692 // fix the foxus...
693 abEditor->setNameFocus(); 693 abEditor->setNameFocus();
694 if ( abEditor->exec() ) { 694 if ( abEditor->exec() ) {
695 setFocus(); 695 setFocus();
696 if ( entryMode == NewEntry ) { 696 if ( entryMode == NewEntry ) {
697 OContact insertEntry = abEditor->entry(); 697 OContact insertEntry = abEditor->entry();
698 insertEntry.assignUid(); 698 insertEntry.assignUid();
699 m_abView -> addEntry( insertEntry ); 699 m_abView -> addEntry( insertEntry );
700 } else { 700 } else {
701 OContact replEntry = abEditor->entry(); 701 OContact replEntry = abEditor->entry();
702 702
703 if ( !replEntry.isValidUid() ) 703 if ( !replEntry.isValidUid() )
704 replEntry.assignUid(); 704 replEntry.assignUid();
705 705
706 m_abView -> replaceEntry( replEntry ); 706 m_abView -> replaceEntry( replEntry );
707 } 707 }
708 } 708 }
709 // populateCategories(); 709 // populateCategories();
710 710
711} 711}
712 712
713void AddressbookWindow::editPersonal() 713void AddressbookWindow::editPersonal()
714{ 714{
715 OContact entry; 715 OContact entry;
716
717 // Switch to personal view if not selected
718 // but take care of the menu, too
719 if ( ! actionPersonal->isOn() ){
720 qWarning("*** ++++");
721 actionPersonal->setOn( true );
722 slotPersonalView();
723 }
724
716 if ( !abEditor ) { 725 if ( !abEditor ) {
717 abEditor = new ContactEditor( entry, this, "editor" ); 726 abEditor = new ContactEditor( entry, this, "editor" );
718 } 727 }
719 728
720 m_abView->showPersonal( true );
721 abEditor->setCaption(tr("Edit My Personal Details")); 729 abEditor->setCaption(tr("Edit My Personal Details"));
722 abEditor->setPersonalView( true ); 730 abEditor->setPersonalView( true );
723 editEntry( EditEntry ); 731 editEntry( EditEntry );
724 abEditor->setPersonalView( false ); 732 abEditor->setPersonalView( false );
725 733
726} 734}
727 735
728 736
729void AddressbookWindow::slotPersonalView() 737void AddressbookWindow::slotPersonalView()
730{ 738{
739 qWarning("slotPersonalView()");
731 if (!actionPersonal->isOn()) { 740 if (!actionPersonal->isOn()) {
732 // we just turned it off 741 // we just turned it off
742 qWarning("slotPersonalView()-> OFF");
733 setCaption( tr("Contacts") ); 743 setCaption( tr("Contacts") );
734 actionNew->setEnabled(TRUE); 744 actionNew->setEnabled(TRUE);
735 actionTrash->setEnabled(TRUE); 745 actionTrash->setEnabled(TRUE);
736 actionFind->setEnabled(TRUE); 746 actionFind->setEnabled(TRUE);
737 actionMail->setEnabled(TRUE); 747 actionMail->setEnabled(TRUE);
738 // slotUpdateToolbar(); 748 // slotUpdateToolbar();
739 749
740 m_abView->showPersonal( false ); 750 m_abView->showPersonal( false );
741 751
742 return; 752 return;
743 } 753 }
744 754
755 qWarning("slotPersonalView()-> ON");
745 // XXX need to disable some QActions. 756 // XXX need to disable some QActions.
746 actionNew->setEnabled(FALSE); 757 actionNew->setEnabled(FALSE);
747 actionTrash->setEnabled(FALSE); 758 actionTrash->setEnabled(FALSE);
748 actionFind->setEnabled(FALSE); 759 actionFind->setEnabled(FALSE);
749 actionMail->setEnabled(FALSE); 760 actionMail->setEnabled(FALSE);
750 761
751 setCaption( tr("Contacts - My Personal Details") ); 762 setCaption( tr("Contacts - My Personal Details") );
752 763
753 m_abView->showPersonal( true ); 764 m_abView->showPersonal( true );
754 765
755} 766}
756 767
757 768
758void AddressbookWindow::listIsEmpty( bool empty ) 769void AddressbookWindow::listIsEmpty( bool empty )
759{ 770{
760 if ( !empty ) { 771 if ( !empty ) {
761 deleteButton->setEnabled( TRUE ); 772 deleteButton->setEnabled( TRUE );
762 } 773 }
763} 774}
764 775
765void AddressbookWindow::reload() 776void AddressbookWindow::reload()
766{ 777{
767 syncing = FALSE; 778 syncing = FALSE;
768 m_abView->clear(); 779 m_abView->clear();
769 m_abView->reload(); 780 m_abView->reload();
770} 781}
771 782
772void AddressbookWindow::flush() 783void AddressbookWindow::flush()
773{ 784{
774 syncing = TRUE; 785 syncing = TRUE;
775 m_abView->save(); 786 m_abView->save();
776} 787}
777 788
778 789
779void AddressbookWindow::closeEvent( QCloseEvent *e ) 790void AddressbookWindow::closeEvent( QCloseEvent *e )
780{ 791{
781 if(active_view == AbView::CardView){ 792 if(active_view == AbView::CardView){
782 slotViewSwitched( AbView::TableView ); 793 slotViewSwitched( AbView::TableView );
783 e->ignore(); 794 e->ignore();
784 return; 795 return;
785 } 796 }
786 if(syncing) { 797 if(syncing) {
787 /* shouldn't we save, I hear you say? well its already been set 798 /* shouldn't we save, I hear you say? well its already been set
788 so that an edit can not occur during a sync, and we flushed 799 so that an edit can not occur during a sync, and we flushed
789 at the start of the sync, so there is no need to save 800 at the start of the sync, so there is no need to save
790 Saving however itself would cause problems. */ 801 Saving however itself would cause problems. */
791 e->accept(); 802 e->accept();
792 return; 803 return;
793 } 804 }
794 //################## shouldn't always save 805 //################## shouldn't always save
795 // True, but the database handles this automatically ! (se) 806 // True, but the database handles this automatically ! (se)
796 if ( save() ) 807 if ( save() )
797 e->accept(); 808 e->accept();
798 else 809 else
799 e->ignore(); 810 e->ignore();
800} 811}
801 812
802/* 813/*
803 Returns TRUE if it is OK to exit 814 Returns TRUE if it is OK to exit
804*/ 815*/
805 816
806bool AddressbookWindow::save() 817bool AddressbookWindow::save()
807{ 818{
808 if ( !m_abView->save() ) { 819 if ( !m_abView->save() ) {
809 if ( QMessageBox::critical( 0, tr( "Out of space" ), 820 if ( QMessageBox::critical( 0, tr( "Out of space" ),
810 tr("Unable to save information.\n" 821 tr("Unable to save information.\n"
811 "Free up some space\n" 822 "Free up some space\n"
812 "and try again.\n" 823 "and try again.\n"
813 "\nQuit anyway?"), 824 "\nQuit anyway?"),
814 QMessageBox::Yes|QMessageBox::Escape, 825 QMessageBox::Yes|QMessageBox::Escape,
815 QMessageBox::No|QMessageBox::Default ) 826 QMessageBox::No|QMessageBox::Default )
816 != QMessageBox::No ) 827 != QMessageBox::No )
817 return TRUE; 828 return TRUE;
818 else 829 else
819 return FALSE; 830 return FALSE;
820 } 831 }
821 return TRUE; 832 return TRUE;
822} 833}
823 834
824#ifdef __DEBUG_RELEASE 835#ifdef __DEBUG_RELEASE
825void AddressbookWindow::slotSave() 836void AddressbookWindow::slotSave()
826{ 837{
827 save(); 838 save();
828} 839}
829#endif 840#endif
830 841
831 842
832void AddressbookWindow::slotNotFound() 843void AddressbookWindow::slotNotFound()
833{ 844{
834 qWarning("Got notfound signal!"); 845 qWarning("Got notfound signal!");
835 QMessageBox::information( this, tr( "Not Found" ), 846 QMessageBox::information( this, tr( "Not Found" ),
836 tr( "Unable to find a contact for this \n search pattern!" ) ); 847 tr( "Unable to find a contact for this \n search pattern!" ) );
837 848
838 849
839} 850}
840void AddressbookWindow::slotWrapAround() 851void AddressbookWindow::slotWrapAround()
841{ 852{
842 qWarning("Got wrap signal!"); 853 qWarning("Got wrap signal!");
843 // if ( doNotifyWrapAround ) 854 // if ( doNotifyWrapAround )
844 // QMessageBox::information( this, tr( "End of list" ), 855 // QMessageBox::information( this, tr( "End of list" ),
845 // tr( "End of list. Wrap around now...!" ) + "\n" ); 856 // tr( "End of list. Wrap around now...!" ) + "\n" );
846 857
847} 858}
848 859
849void AddressbookWindow::slotSetCategory( int c ) 860void AddressbookWindow::slotSetCategory( int c )
850{ 861{
851 qWarning( "void AddressbookWindow::slotSetCategory( %d ) from %d", c, catMenu->count() ); 862 qWarning( "void AddressbookWindow::slotSetCategory( %d ) from %d", c, catMenu->count() );
852 863
853 QString cat, book; 864 QString cat, book;
854 AbView::Views view = AbView::TableView; 865 AbView::Views view = AbView::TableView;
855 866
856 if ( c <= 0 ) 867 if ( c <= 0 )
857 return; 868 return;
858 869
859 // Switch view 870 // Switch view
860 if ( c < 3 ) 871 if ( c < 3 )
861 for ( unsigned int i = 1; i < 3; i++ ){ 872 for ( unsigned int i = 1; i < 3; i++ ){
862 if ( catMenu ) 873 if ( catMenu )
863 catMenu->setItemChecked( i, c == (int)i ); 874 catMenu->setItemChecked( i, c == (int)i );
864 } 875 }
865 else 876 else
866 // Checkmark Category Menu Item Selected 877 // Checkmark Category Menu Item Selected
867 for ( unsigned int i = 3; i < catMenu->count(); i++ ) 878 for ( unsigned int i = 3; i < catMenu->count(); i++ )
868 catMenu->setItemChecked( i, c == (int)i ); 879 catMenu->setItemChecked( i, c == (int)i );
869 880
870 // Now switch to the selected category 881 // Now switch to the selected category
871 for ( unsigned int i = 1; i < catMenu->count(); i++ ) { 882 for ( unsigned int i = 1; i < catMenu->count(); i++ ) {
872 if (catMenu->isItemChecked( i )) { 883 if (catMenu->isItemChecked( i )) {
873 if ( i == 1 ){ // default List view 884 if ( i == 1 ){ // default List view
874 book = QString::null; 885 book = QString::null;
875 view = AbView::TableView; 886 view = AbView::TableView;
876 }else if ( i == 2 ){ 887 }else if ( i == 2 ){
877 book = tr( "Cards" ); 888 book = tr( "Cards" );
878 view = AbView::CardView; 889 view = AbView::CardView;
879 // }else if ( i == 3 ){ 890 // }else if ( i == 3 ){
880 // book = tr( "Personal" ); 891 // book = tr( "Personal" );
881 // view = AbView:: PersonalView; 892 // view = AbView:: PersonalView;
882 }else if ( i == 3 ){ // default All Categories 893 }else if ( i == 3 ){ // default All Categories
883 cat = QString::null; 894 cat = QString::null;
884 }else if ( i == (unsigned int)catMenu->count() - 1 ){ // last menu option (seperator is counted, too) will be Unfiled 895 }else if ( i == (unsigned int)catMenu->count() - 1 ){ // last menu option (seperator is counted, too) will be Unfiled
885 cat = "Unfiled"; 896 cat = "Unfiled";
886 qWarning ("Unfiled selected!!!"); 897 qWarning ("Unfiled selected!!!");
887 }else{ 898 }else{
888 cat = m_abView->categories()[i - 4]; 899 cat = m_abView->categories()[i - 4];
889 } 900 }
890 } 901 }
891 } 902 }
892 903
893 // Switch to the selected View 904 // Switch to the selected View
894 slotViewSwitched( view ); 905 slotViewSwitched( view );
895 906
896 // Tell the view about the selected category 907 // Tell the view about the selected category
897 m_abView -> setShowByCategory( cat ); 908 m_abView -> setShowByCategory( cat );
898 909
899 if ( book.isEmpty() ) 910 if ( book.isEmpty() )
900 book = "List"; 911 book = "List";
901 if ( cat.isEmpty() ) 912 if ( cat.isEmpty() )
902 cat = "All"; 913 cat = "All";
903 914
904 setCaption( tr( "Contacts" ) + " - " + book + " - " + tr( cat ) ); 915 setCaption( tr( "Contacts" ) + " - " + book + " - " + tr( cat ) );
905} 916}
906 917
907void AddressbookWindow::slotViewSwitched( int view ) 918void AddressbookWindow::slotViewSwitched( int view )
908{ 919{
909 qWarning( "void AddressbookWindow::slotViewSwitched( %d )", view ); 920 qWarning( "void AddressbookWindow::slotViewSwitched( %d )", view );
910 int menu = 0; 921 int menu = 0;
911 922
912 // Switch to selected view 923 // Switch to selected view
913 switch ( view ){ 924 switch ( view ){
914 case AbView::TableView: 925 case AbView::TableView:
915 menu = 1; 926 menu = 1;
916 m_tableViewButton->setOn(true); 927 m_tableViewButton->setOn(true);
917 m_cardViewButton->setOn(false); 928 m_cardViewButton->setOn(false);
918 break; 929 break;
919 case AbView::CardView: 930 case AbView::CardView:
920 menu = 2; 931 menu = 2;
921 m_tableViewButton->setOn(false); 932 m_tableViewButton->setOn(false);
922 m_cardViewButton->setOn(true); 933 m_cardViewButton->setOn(true);
923 break; 934 break;
924 } 935 }
925 for ( unsigned int i = 1; i < 3; i++ ){ 936 for ( unsigned int i = 1; i < 3; i++ ){
926 if ( catMenu ) 937 if ( catMenu )
927 catMenu->setItemChecked( i, menu == (int)i ); 938 catMenu->setItemChecked( i, menu == (int)i );
928 } 939 }
929 940
930 // Tell the view about the selected view 941 // Tell the view about the selected view
931 m_abView -> setShowToView ( (AbView::Views) view ); 942 m_abView -> setShowToView ( (AbView::Views) view );
932 active_view = view; 943 active_view = view;
933} 944}
934 945
935 946
936void AddressbookWindow::slotListView() 947void AddressbookWindow::slotListView()
937{ 948{
938 slotViewSwitched( AbView::TableView ); 949 slotViewSwitched( AbView::TableView );
939} 950}
940 951
941void AddressbookWindow::slotCardView() 952void AddressbookWindow::slotCardView()
942{ 953{
943 slotViewSwitched( AbView::CardView ); 954 slotViewSwitched( AbView::CardView );
944} 955}
945 956
946void AddressbookWindow::slotSetLetter( char c ) { 957void AddressbookWindow::slotSetLetter( char c ) {
947 958
948 m_abView->setShowByLetter( c ); 959 m_abView->setShowByLetter( c );
949 960
950} 961}
951 962
952 963
953void AddressbookWindow::populateCategories() 964void AddressbookWindow::populateCategories()
954{ 965{
955 catMenu->clear(); 966 catMenu->clear();
956 967
957 int id, rememberId; 968 int id, rememberId;
958 id = 1; 969 id = 1;
959 rememberId = 0; 970 rememberId = 0;
960 971
961 catMenu->insertItem( Resource::loadPixmap( "datebook/weeklst" ), tr( "List" ), id++ ); 972 catMenu->insertItem( Resource::loadPixmap( "datebook/weeklst" ), tr( "List" ), id++ );
962 catMenu->insertItem( Resource::loadPixmap( "day" ), tr( "Cards" ), id++ ); 973 catMenu->insertItem( Resource::loadPixmap( "day" ), tr( "Cards" ), id++ );
963 // catMenu->insertItem( tr( "Personal" ), id++ ); 974 // catMenu->insertItem( tr( "Personal" ), id++ );
964 catMenu->insertSeparator(); 975 catMenu->insertSeparator();
965 976
966 catMenu->insertItem( tr( "All" ), id++ ); 977 catMenu->insertItem( tr( "All" ), id++ );
967 QStringList categories = m_abView->categories(); 978 QStringList categories = m_abView->categories();
968 categories.append( tr( "Unfiled" ) ); 979 categories.append( tr( "Unfiled" ) );
969 for ( QStringList::Iterator it = categories.begin(); 980 for ( QStringList::Iterator it = categories.begin();
970 it != categories.end(); ++it ) { 981 it != categories.end(); ++it ) {
971 catMenu->insertItem( *it, id ); 982 catMenu->insertItem( *it, id );
972 if ( *it == m_abView -> showCategory() ) 983 if ( *it == m_abView -> showCategory() )
973 rememberId = id; 984 rememberId = id;
974 ++id; 985 ++id;
975 } 986 }
976 987
977 988
978 if ( m_abView -> showCategory().isEmpty() ) { 989 if ( m_abView -> showCategory().isEmpty() ) {
979 slotSetCategory( 3 ); 990 slotSetCategory( 3 );
980 } 991 }
981 else { 992 else {
982 slotSetCategory( rememberId ); 993 slotSetCategory( rememberId );
983 } 994 }
984} 995}
985 996
diff --git a/core/pim/addressbook/addressbook.h b/core/pim/addressbook/addressbook.h
index 2bedc0b..69fe2f8 100644
--- a/core/pim/addressbook/addressbook.h
+++ b/core/pim/addressbook/addressbook.h
@@ -1,139 +1,135 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000 Trolltech AS. All rights reserved. 2** Copyright (C) 2000 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qt Palmtop Environment. 4** This file is part of Qt Palmtop Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#ifndef Addressbook_H 20#ifndef Addressbook_H
21#define Addressbook_H 21#define Addressbook_H
22 22
23// Remove this for OPIE releae 1.0 ! 23// Remove this for OPIE releae 1.0 !
24#define __DEBUG_RELEASE 24#define __DEBUG_RELEASE
25 25
26#include <qmainwindow.h> 26#include <qmainwindow.h>
27#include <qvaluelist.h> 27#include <qvaluelist.h>
28#include <qstringlist.h> 28#include <qstringlist.h>
29#include <qlineedit.h> 29#include <qlineedit.h>
30#include "ofloatbar.h" 30#include "ofloatbar.h"
31#include "abview.h" 31#include "abview.h"
32#include "abconfig.h" 32#include "abconfig.h"
33 33
34class ContactEditor; 34class ContactEditor;
35class AbLabel; 35class AbLabel;
36class AbTable; 36class AbTable;
37class QPEToolBar; 37class QPEToolBar;
38class QPopupMenu; 38class QPopupMenu;
39class QToolButton; 39class QToolButton;
40class QDialog; 40class QDialog;
41class Ir; 41class Ir;
42class QAction; 42class QAction;
43class LetterPicker; 43class LetterPicker;
44 44
45class AddressbookWindow: public QMainWindow 45class AddressbookWindow: public QMainWindow
46{ 46{
47 Q_OBJECT 47 Q_OBJECT
48public: 48public:
49 enum EntryMode { NewEntry=0, EditEntry }; 49 enum EntryMode { NewEntry=0, EditEntry };
50 50
51 AddressbookWindow( QWidget *parent = 0, const char *name = 0, WFlags f = 0 ); 51 AddressbookWindow( QWidget *parent = 0, const char *name = 0, WFlags f = 0 );
52 ~AddressbookWindow(); 52 ~AddressbookWindow();
53 53
54protected: 54protected:
55 void resizeEvent( QResizeEvent * e ); 55 void resizeEvent( QResizeEvent * e );
56 56
57 void editPersonal(); 57 void editPersonal();
58 void editEntry( EntryMode ); 58 void editEntry( EntryMode );
59 void closeEvent( QCloseEvent *e ); 59 void closeEvent( QCloseEvent *e );
60 bool save(); 60 bool save();
61 61
62public slots: 62public slots:
63 void flush(); 63 void flush();
64 void reload(); 64 void reload();
65 void appMessage(const QCString &, const QByteArray &); 65 void appMessage(const QCString &, const QByteArray &);
66 void setDocument( const QString & ); 66 void setDocument( const QString & );
67#ifdef __DEBUG_RELEASE 67#ifdef __DEBUG_RELEASE
68 void slotSave(); 68 void slotSave();
69#endif 69#endif
70 70
71private slots: 71private slots:
72 void importvCard(); 72 void importvCard();
73 void slotListNew(); 73 void slotListNew();
74 /* void slotListView(); */ 74 /* void slotListView(); */
75 void slotListDelete(); 75 void slotListDelete();
76 void slotViewBack(); 76 void slotViewBack();
77 void slotViewEdit(); 77 void slotViewEdit();
78 void slotPersonalView(); 78 void slotPersonalView();
79 void listIsEmpty( bool ); 79 void listIsEmpty( bool );
80 /* void slotSettings(); */ 80 /* void slotSettings(); */
81 void writeMail(); 81 void writeMail();
82 void slotBeam(); 82 void slotBeam();
83 void beamDone( Ir * ); 83 void beamDone( Ir * );
84 void slotSetCategory( int ); 84 void slotSetCategory( int );
85 void slotSetLetter( char ); 85 void slotSetLetter( char );
86 void slotUpdateToolbar(); 86 void slotUpdateToolbar();
87 void slotSetFont(int); 87 void slotSetFont(int);
88 88
89 void slotFindOpen(); 89 void slotFindOpen();
90 void slotFindClose(); 90 void slotFindClose();
91 void slotFind(); 91 void slotFind();
92 void slotNotFound(); 92 void slotNotFound();
93 void slotWrapAround(); 93 void slotWrapAround();
94 94
95 void slotViewSwitched( int ); 95 void slotViewSwitched( int );
96 void slotListView(); 96 void slotListView();
97 void slotCardView(); 97 void slotCardView();
98 98
99 void slotConfig(); 99 void slotConfig();
100 100
101private: 101private:
102 //void initFields(); // inititialize our fields...
103 // AbLabel *abView();
104 void populateCategories(); 102 void populateCategories();
105 103
106 QPopupMenu *catMenu; 104 QPopupMenu *catMenu;
107 QPEToolBar *listTools; 105 QPEToolBar *listTools;
108 QToolButton *deleteButton; 106 QToolButton *deleteButton;
109 //QValueList<int> allFields, orderedFields;
110 //QStringList slOrderedFields;
111 enum Panes { paneList=0, paneView, paneEdit }; 107 enum Panes { paneList=0, paneView, paneEdit };
112 ContactEditor *abEditor; 108 ContactEditor *abEditor;
113 LetterPicker *pLabel; 109 LetterPicker *pLabel;
114 AbView* m_abView; 110 AbView* m_abView;
115 QWidget *listContainer; 111 QWidget *listContainer;
116 112
117 // Searching stuff 113 // Searching stuff
118 OFloatBar* searchBar; 114 OFloatBar* searchBar;
119 QLineEdit* searchEdit; 115 QLineEdit* searchEdit;
120 116
121 QAction *actionNew, *actionEdit, *actionTrash, *actionFind, *actionBeam, *actionPersonal, *actionMail; 117 QAction *actionNew, *actionEdit, *actionTrash, *actionFind, *actionBeam, *actionPersonal, *actionMail;
122 118
123 int viewMargin; 119 int viewMargin;
124 120
125 bool syncing; 121 bool syncing;
126 QFont *defaultFont; 122 QFont *defaultFont;
127 int m_curFontSize; 123 int m_curFontSize;
128 124
129 bool isLoading; 125 bool isLoading;
130 126
131 AbConfig m_config; 127 AbConfig m_config;
132 128
133 QAction* m_tableViewButton; 129 QAction* m_tableViewButton;
134 QAction* m_cardViewButton; 130 QAction* m_cardViewButton;
135 131
136 int active_view; 132 int active_view;
137}; 133};
138 134
139#endif 135#endif