summaryrefslogtreecommitdiffabout
authorzautrix <zautrix>2004-08-06 08:39:55 (UTC)
committer zautrix <zautrix>2004-08-06 08:39:55 (UTC)
commit15edf84bf2bdd1cb00cbdc37d0402b9587c40f21 (patch) (unidiff)
treef4da393d531292ff6702aed0936f2405bdf20555
parent3bf62eb85312197352b7c836239d6d239e9a70cf (diff)
downloadkdepimpi-15edf84bf2bdd1cb00cbdc37d0402b9587c40f21.zip
kdepimpi-15edf84bf2bdd1cb00cbdc37d0402b9587c40f21.tar.gz
kdepimpi-15edf84bf2bdd1cb00cbdc37d0402b9587c40f21.tar.bz2
Fixed some beaming problems
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--kaddressbook/kabcore.cpp49
1 files changed, 35 insertions, 14 deletions
diff --git a/kaddressbook/kabcore.cpp b/kaddressbook/kabcore.cpp
index d891b07..25891a0 100644
--- a/kaddressbook/kabcore.cpp
+++ b/kaddressbook/kabcore.cpp
@@ -421,69 +421,69 @@ void KABCore::setContactSelected( const QString &uid )
421 if ( !addr.isEmpty() ) { 421 if ( !addr.isEmpty() ) {
422 emit contactSelected( addr.formattedName() ); 422 emit contactSelected( addr.formattedName() );
423 KABC::Picture pic = addr.photo(); 423 KABC::Picture pic = addr.photo();
424 if ( pic.isIntern() ) { 424 if ( pic.isIntern() ) {
425//US emit contactSelected( pic.data() ); 425//US emit contactSelected( pic.data() );
426//US instead use: 426//US instead use:
427 QPixmap px; 427 QPixmap px;
428 if (pic.data().isNull() != true) 428 if (pic.data().isNull() != true)
429 { 429 {
430 px.convertFromImage(pic.data()); 430 px.convertFromImage(pic.data());
431 } 431 }
432 432
433 emit contactSelected( px ); 433 emit contactSelected( px );
434 } 434 }
435 } 435 }
436 436
437 437
438 mExtensionManager->setSelectionChanged(); 438 mExtensionManager->setSelectionChanged();
439 439
440 // update the actions 440 // update the actions
441 bool selected = !uid.isEmpty(); 441 bool selected = !uid.isEmpty();
442 442
443 if ( mReadWrite ) { 443 if ( mReadWrite ) {
444 mActionCut->setEnabled( selected ); 444 mActionCut->setEnabled( selected );
445 mActionPaste->setEnabled( selected ); 445 mActionPaste->setEnabled( selected );
446 } 446 }
447 447
448 mActionCopy->setEnabled( selected ); 448 mActionCopy->setEnabled( selected );
449 mActionDelete->setEnabled( selected ); 449 mActionDelete->setEnabled( selected );
450 mActionEditAddressee->setEnabled( selected ); 450 mActionEditAddressee->setEnabled( selected );
451 mActionMail->setEnabled( selected ); 451 mActionMail->setEnabled( selected );
452 mActionMailVCard->setEnabled( selected ); 452 mActionMailVCard->setEnabled( selected );
453 if (mActionBeam) 453 //if (mActionBeam)
454 mActionBeam->setEnabled( selected ); 454 //mActionBeam->setEnabled( selected );
455 455
456 if (mActionBeam) 456 if (mActionBeamVCard)
457 mActionBeamVCard->setEnabled( selected ); 457 mActionBeamVCard->setEnabled( selected );
458 458
459 mActionWhoAmI->setEnabled( selected ); 459 mActionWhoAmI->setEnabled( selected );
460 mActionCategories->setEnabled( selected ); 460 mActionCategories->setEnabled( selected );
461} 461}
462 462
463void KABCore::sendMail() 463void KABCore::sendMail()
464{ 464{
465 sendMail( mViewManager->selectedEmails().join( ", " ) ); 465 sendMail( mViewManager->selectedEmails().join( ", " ) );
466} 466}
467 467
468void KABCore::sendMail( const QString& email ) 468void KABCore::sendMail( const QString& email )
469{ 469{
470//US original kde implementation : kapp->invokeMailer( email, "" ); 470//US original kde implementation : kapp->invokeMailer( email, "" );
471 471
472/*US original qtopia implementation 472/*US original qtopia implementation
473 PimContact c = abList->currentEntry(); 473 PimContact c = abList->currentEntry();
474 QString name = c.fileAs(); 474 QString name = c.fileAs();
475 QString email = c.defaultEmail(); 475 QString email = c.defaultEmail();
476#ifndef QT_NO_COP 476#ifndef QT_NO_COP
477 QCopEnvelope e(Service::channel("Email"), "writeMail(QString,QString)"); 477 QCopEnvelope e(Service::channel("Email"), "writeMail(QString,QString)");
478 e << name << email; 478 e << name << email;
479#else 479#else
480*/ 480*/
481 481
482 482
483#ifndef QT_NO_COP 483#ifndef QT_NO_COP
484 QCString channel = KABPrefs::instance()->mEmailChannel.latin1(); 484 QCString channel = KABPrefs::instance()->mEmailChannel.latin1();
485 qDebug("Using QCopEnvelope e(\"" + channel + "\", \"writeMail(QMap(QString,QString))\")"); 485 qDebug("Using QCopEnvelope e(\"" + channel + "\", \"writeMail(QMap(QString,QString))\")");
486 486
487 QCopEnvelope e(channel, "writeMail(QString,QString)"); 487 QCopEnvelope e(channel, "writeMail(QString,QString)");
488 //US we need no names in the To field. The emailadresses are enough 488 //US we need no names in the To field. The emailadresses are enough
489 e << "" << email; 489 e << "" << email;
@@ -556,155 +556,172 @@ void KABCore::mailVCard( const QStringList& uids )
556 QString::null, // body 556 QString::null, // body
557 QString::null, 557 QString::null,
558 urls ); // attachments 558 urls ); // attachments
559*/ 559*/
560#ifndef QT_NO_COP 560#ifndef QT_NO_COP
561 QCString channel = KABPrefs::instance()->mEmailChannel.latin1(); 561 QCString channel = KABPrefs::instance()->mEmailChannel.latin1();
562 qDebug("Using QCopEnvelope e(\"" + channel + "\", \"writeMail(QMap(QString,QString))\")"); 562 qDebug("Using QCopEnvelope e(\"" + channel + "\", \"writeMail(QMap(QString,QString))\")");
563 563
564 QMap<QString, QString> parameterMap; 564 QMap<QString, QString> parameterMap;
565 parameterMap.insert("ATTACHMENT<n>", urls.join(", ")); 565 parameterMap.insert("ATTACHMENT<n>", urls.join(", "));
566 566
567 QCopEnvelope e(channel, "writeMail(QMap(QString,QString))"); 567 QCopEnvelope e(channel, "writeMail(QMap(QString,QString))");
568 e << parameterMap; 568 e << parameterMap;
569#else 569#else
570 KMessageBox::sorry( this, i18n( "This version does not support sending emails." ) ); 570 KMessageBox::sorry( this, i18n( "This version does not support sending emails." ) );
571#endif 571#endif
572 572
573 573
574} 574}
575 575
576/** 576/**
577 Beams the "WhoAmI contact. 577 Beams the "WhoAmI contact.
578*/ 578*/
579void KABCore::beamMySelf() 579void KABCore::beamMySelf()
580{ 580{
581 KABC::Addressee a = KABC::StdAddressBook::self()->whoAmI(); 581 KABC::Addressee a = KABC::StdAddressBook::self()->whoAmI();
582 if (!a.isEmpty()) 582 if (!a.isEmpty())
583 { 583 {
584 QStringList uids; 584 QStringList uids;
585 uids << a.uid(); 585 uids << a.uid();
586 586
587 beamVCard(uids); 587 beamVCard(uids);
588 } else {
589 KMessageBox::information( this, i18n( "Your personal contact is\nnot set! Please select it\nand set it with menu:\nSettings - Set Who Am I\n" ) );
590
591
588 } 592 }
589} 593}
590 594
591void KABCore::beamVCard() 595void KABCore::beamVCard()
592{ 596{
593 QStringList uids = mViewManager->selectedUids(); 597 QStringList uids = mViewManager->selectedUids();
594 if ( !uids.isEmpty() ) 598 if ( !uids.isEmpty() )
595 beamVCard( uids ); 599 beamVCard( uids );
596} 600}
597 601
598 602
599void KABCore::beamVCard(const QStringList& uids) 603void KABCore::beamVCard(const QStringList& uids)
600{ 604{
601/*US 605/*US
602 QString beamFilename; 606 QString beamFilename;
603 Opie::OPimContact c; 607 Opie::OPimContact c;
604 if ( actionPersonal->isOn() ) { 608 if ( actionPersonal->isOn() ) {
605 beamFilename = addressbookPersonalVCardName(); 609 beamFilename = addressbookPersonalVCardName();
606 if ( !QFile::exists( beamFilename ) ) 610 if ( !QFile::exists( beamFilename ) )
607 return; // can't beam a non-existent file 611 return; // can't beam a non-existent file
608 Opie::OPimContactAccessBackend* vcard_backend = new Opie::OPimContactAccessBackend_VCard( QString::null, 612 Opie::OPimContactAccessBackend* vcard_backend = new Opie::OPimContactAccessBackend_VCard( QString::null,
609 beamFilename ); 613 beamFilename );
610 Opie::OPimContactAccess* access = new Opie::OPimContactAccess ( "addressbook", QString::null , vcard_backend, true ); 614 Opie::OPimContactAccess* access = new Opie::OPimContactAccess ( "addressbook", QString::null , vcard_backend, true );
611 Opie::OPimContactAccess::List allList = access->allRecords(); 615 Opie::OPimContactAccess::List allList = access->allRecords();
612 Opie::OPimContactAccess::List::Iterator it = allList.begin(); // Just take first 616 Opie::OPimContactAccess::List::Iterator it = allList.begin(); // Just take first
613 c = *it; 617 c = *it;
614 618
615 delete access; 619 delete access;
616 } else { 620 } else {
617 unlink( beamfile ); // delete if exists 621 unlink( beamfile ); // delete if exists
618 mkdir("/tmp/obex/", 0755); 622 mkdir("/tmp/obex/", 0755);
619 c = m_abView -> currentEntry(); 623 c = m_abView -> currentEntry();
620 Opie::OPimContactAccessBackend* vcard_backend = new Opie::OPimContactAccessBackend_VCard( QString::null, 624 Opie::OPimContactAccessBackend* vcard_backend = new Opie::OPimContactAccessBackend_VCard( QString::null,
621 beamfile ); 625 beamfile );
622 Opie::OPimContactAccess* access = new Opie::OPimContactAccess ( "addressbook", QString::null , vcard_backend, true ); 626 Opie::OPimContactAccess* access = new Opie::OPimContactAccess ( "addressbook", QString::null , vcard_backend, true );
623 access->add( c ); 627 access->add( c );
624 access->save(); 628 access->save();
625 delete access; 629 delete access;
626 630
627 beamFilename = beamfile; 631 beamFilename = beamfile;
628 } 632 }
629 633
630 owarn << "Beaming: " << beamFilename << oendl; 634 owarn << "Beaming: " << beamFilename << oendl;
631*/ 635*/
636
637#if 0
632 QString tmpdir = locateLocal("tmp", KGlobal::getAppName()); 638 QString tmpdir = locateLocal("tmp", KGlobal::getAppName());
633 639
634 QString dirName = tmpdir + "/" + KApplication::randomString( 8 ); 640 QString dirName = tmpdir + "/" + KApplication::randomString( 8 );
635 641
636 QString name = "contact.vcf"; 642 QString name = "contact.vcf";
637 643
638 QString fileName = dirName + "/" + name; 644 QString fileName = dirName + "/" + name;
645#endif
646 // LR: we should use the /tmp dir, because: /tmp = RAM, (HOME)/kdepim = flash memory
647 //
648 QString fileName = "/tmp/kdepimbeamfile";
639 649
640 650
641 QDir().mkdir( dirName, true ); 651 //QDir().mkdir( dirName, true );
642 652
643 QFile outFile(fileName); 653 QFile outFile(fileName);
644 KABC::VCardConverter converter; 654 KABC::VCardConverter converter;
645 QString description; 655 QString description;
646 656
647 if ( outFile.open(IO_WriteOnly) ) { // file opened successfully 657 if ( outFile.open(IO_WriteOnly) ) { // file opened successfully
648 658
649 QTextStream t( &outFile ); // use a text stream 659 QTextStream t( &outFile ); // use a text stream
650 t.setEncoding( QTextStream::UnicodeUTF8 ); 660 t.setEncoding( QTextStream::UnicodeUTF8 );
651 661
652 for( QStringList::ConstIterator it = uids.begin(); it != uids.end(); ++it ) { 662 for( QStringList::ConstIterator it = uids.begin(); it != uids.end(); ++it ) {
653 KABC::Addressee a = mAddressBook->findByUid( *it ); 663 KABC::Addressee a = mAddressBook->findByUid( *it );
654 664
655 if ( a.isEmpty() ) 665 if ( a.isEmpty() )
656 continue; 666 continue;
657 667
658 if (description.isEmpty()) 668 if (description.isEmpty())
659 description = a.formattedName(); 669 description = a.formattedName();
660 670
661 QString vcard; 671 QString vcard;
662 converter.addresseeToVCard( a, vcard ); 672 converter.addresseeToVCard( a, vcard );
663 t << vcard; 673 t << vcard;
664 674
665 } 675 }
676 } else {
677 qDebug("Error open temp beam file ");
678 return;
666 } 679 }
667 680
668 outFile.close(); 681 outFile.close();
669 682
683#ifndef DESKTOP_VERSION
670 Ir *ir = new Ir( this ); 684 Ir *ir = new Ir( this );
671 connect( ir, SIGNAL( done(Ir*) ), this, SLOT( beamDone(Ir*) ) ); 685 connect( ir, SIGNAL( done(Ir*) ), this, SLOT( beamDone(Ir*) ) );
672 ir->send( fileName, description, "text/x-vCard" ); 686 ir->send( fileName, description, "text/x-vCard" );
687#endif
673 688
674} 689}
675 690
676void KABCore::beamDone( Ir *ir ) 691void KABCore::beamDone( Ir *ir )
677{ 692{
693#ifndef DESKTOP_VERSION
678 delete ir; 694 delete ir;
695#endif
679} 696}
680 697
681 698
682void KABCore::browse( const QString& url ) 699void KABCore::browse( const QString& url )
683{ 700{
684#ifndef KAB_EMBEDDED 701#ifndef KAB_EMBEDDED
685 kapp->invokeBrowser( url ); 702 kapp->invokeBrowser( url );
686#else //KAB_EMBEDDED 703#else //KAB_EMBEDDED
687 qDebug("KABCore::browse must be fixed"); 704 qDebug("KABCore::browse must be fixed");
688#endif //KAB_EMBEDDED 705#endif //KAB_EMBEDDED
689} 706}
690 707
691void KABCore::selectAllContacts() 708void KABCore::selectAllContacts()
692{ 709{
693 mViewManager->setSelected( QString::null, true ); 710 mViewManager->setSelected( QString::null, true );
694} 711}
695 712
696void KABCore::deleteContacts() 713void KABCore::deleteContacts()
697{ 714{
698 QStringList uidList = mViewManager->selectedUids(); 715 QStringList uidList = mViewManager->selectedUids();
699 deleteContacts( uidList ); 716 deleteContacts( uidList );
700} 717}
701 718
702void KABCore::deleteContacts( const QStringList &uids ) 719void KABCore::deleteContacts( const QStringList &uids )
703{ 720{
704 if ( uids.count() > 0 ) { 721 if ( uids.count() > 0 ) {
705 PwDeleteCommand *command = new PwDeleteCommand( mAddressBook, uids ); 722 PwDeleteCommand *command = new PwDeleteCommand( mAddressBook, uids );
706 UndoStack::instance()->push( command ); 723 UndoStack::instance()->push( command );
707 RedoStack::instance()->clear(); 724 RedoStack::instance()->clear();
708 725
709 // now if we deleted anything, refresh 726 // now if we deleted anything, refresh
710 setContactSelected( QString::null ); 727 setContactSelected( QString::null );
@@ -1461,70 +1478,77 @@ void KABCore::initActions()
1461//US qDebug("KABCore::initActions(): mIsPart %i", mIsPart); 1478//US qDebug("KABCore::initActions(): mIsPart %i", mIsPart);
1462 1479
1463#ifndef KAB_EMBEDDED 1480#ifndef KAB_EMBEDDED
1464 connect( QApplication::clipboard(), SIGNAL( dataChanged() ), 1481 connect( QApplication::clipboard(), SIGNAL( dataChanged() ),
1465 SLOT( clipboardDataChanged() ) ); 1482 SLOT( clipboardDataChanged() ) );
1466#endif //KAB_EMBEDDED 1483#endif //KAB_EMBEDDED
1467 1484
1468 // file menu 1485 // file menu
1469 if ( mIsPart ) { 1486 if ( mIsPart ) {
1470 mActionMail = new KAction( i18n( "&Mail" ), "mail_generic", 0, this, 1487 mActionMail = new KAction( i18n( "&Mail" ), "mail_generic", 0, this,
1471 SLOT( sendMail() ), actionCollection(), 1488 SLOT( sendMail() ), actionCollection(),
1472 "kaddressbook_mail" ); 1489 "kaddressbook_mail" );
1473 mActionPrint = new KAction( i18n( "&Print" ), "fileprint", CTRL + Key_P, this, 1490 mActionPrint = new KAction( i18n( "&Print" ), "fileprint", CTRL + Key_P, this,
1474 SLOT( print() ), actionCollection(), "kaddressbook_print" ); 1491 SLOT( print() ), actionCollection(), "kaddressbook_print" );
1475 1492
1476 } else { 1493 } else {
1477 mActionMail = KStdAction::mail( this, SLOT( sendMail() ), actionCollection() ); 1494 mActionMail = KStdAction::mail( this, SLOT( sendMail() ), actionCollection() );
1478 mActionPrint = KStdAction::print( this, SLOT( print() ), actionCollection() ); 1495 mActionPrint = KStdAction::print( this, SLOT( print() ), actionCollection() );
1479 } 1496 }
1480 1497
1481 1498
1482 mActionSave = new KAction( i18n( "&Save" ), "filesave", CTRL+Key_S, this, 1499 mActionSave = new KAction( i18n( "&Save" ), "filesave", CTRL+Key_S, this,
1483 SLOT( save() ), actionCollection(), "file_sync" ); 1500 SLOT( save() ), actionCollection(), "file_sync" );
1484 1501
1485 mActionNewContact = new KAction( i18n( "&New Contact..." ), "filenew", CTRL+Key_N, this, 1502 mActionNewContact = new KAction( i18n( "&New Contact..." ), "filenew", CTRL+Key_N, this,
1486 SLOT( newContact() ), actionCollection(), "file_new_contact" ); 1503 SLOT( newContact() ), actionCollection(), "file_new_contact" );
1487 1504
1488 mActionMailVCard = new KAction(i18n("Mail &vCard..."), "mail_post_to", 0, 1505 mActionMailVCard = new KAction(i18n("Mail &vCard..."), "mail_post_to", 0,
1489 this, SLOT( mailVCard() ), 1506 this, SLOT( mailVCard() ),
1490 actionCollection(), "file_mail_vcard"); 1507 actionCollection(), "file_mail_vcard");
1491 1508
1492 mActionBeamVCard = 0; 1509 mActionBeamVCard = 0;
1510 mActionBeam = 0;
1511
1512#ifndef DESKTOP_VERSION
1493 if ( Ir::supported() ) { 1513 if ( Ir::supported() ) {
1494 mActionBeamVCard = new KAction( i18n( "Beam v&Card" ), "beam", 0, this, 1514 mActionBeamVCard = new KAction( i18n( "Beam selected v&Card(s)" ), "beam", 0, this,
1495 SLOT( beamVCard() ), actionCollection(), 1515 SLOT( beamVCard() ), actionCollection(),
1496 "kaddressbook_beam_vcard" ); 1516 "kaddressbook_beam_vcard" );
1517
1518 mActionBeam = new KAction( i18n( "&Beam personal vCard" ), "beam", 0, this,
1519 SLOT( beamMySelf() ), actionCollection(),
1520 "kaddressbook_beam_myself" );
1497 } 1521 }
1498 1522#endif
1499 1523
1500 mActionEditAddressee = new KAction( i18n( "&Edit Contact..." ), "edit", 0, 1524 mActionEditAddressee = new KAction( i18n( "&Edit Contact..." ), "edit", 0,
1501 this, SLOT( editContact2() ), 1525 this, SLOT( editContact2() ),
1502 actionCollection(), "file_properties" ); 1526 actionCollection(), "file_properties" );
1503 1527
1504#ifdef KAB_EMBEDDED 1528#ifdef KAB_EMBEDDED
1505 // mActionQuit = KStdAction::quit( mMainWindow, SLOT( exit() ), actionCollection() ); 1529 // mActionQuit = KStdAction::quit( mMainWindow, SLOT( exit() ), actionCollection() );
1506 mActionQuit = new KAction( i18n( "&Exit" ), "exit", 0, 1530 mActionQuit = new KAction( i18n( "&Exit" ), "exit", 0,
1507 mMainWindow, SLOT( exit() ), 1531 mMainWindow, SLOT( exit() ),
1508 actionCollection(), "quit" ); 1532 actionCollection(), "quit" );
1509#endif //KAB_EMBEDDED 1533#endif //KAB_EMBEDDED
1510 1534
1511 // edit menu 1535 // edit menu
1512 if ( mIsPart ) { 1536 if ( mIsPart ) {
1513 mActionCopy = new KAction( i18n( "&Copy" ), "editcopy", CTRL + Key_C, this, 1537 mActionCopy = new KAction( i18n( "&Copy" ), "editcopy", CTRL + Key_C, this,
1514 SLOT( copyContacts() ), actionCollection(), 1538 SLOT( copyContacts() ), actionCollection(),
1515 "kaddressbook_copy" ); 1539 "kaddressbook_copy" );
1516 mActionCut = new KAction( i18n( "Cu&t" ), "editcut", CTRL + Key_X, this, 1540 mActionCut = new KAction( i18n( "Cu&t" ), "editcut", CTRL + Key_X, this,
1517 SLOT( cutContacts() ), actionCollection(), 1541 SLOT( cutContacts() ), actionCollection(),
1518 "kaddressbook_cut" ); 1542 "kaddressbook_cut" );
1519 mActionPaste = new KAction( i18n( "&Paste" ), "editpaste", CTRL + Key_V, this, 1543 mActionPaste = new KAction( i18n( "&Paste" ), "editpaste", CTRL + Key_V, this,
1520 SLOT( pasteContacts() ), actionCollection(), 1544 SLOT( pasteContacts() ), actionCollection(),
1521 "kaddressbook_paste" ); 1545 "kaddressbook_paste" );
1522 mActionSelectAll = new KAction( i18n( "Select &All" ), CTRL + Key_A, this, 1546 mActionSelectAll = new KAction( i18n( "Select &All" ), CTRL + Key_A, this,
1523 SLOT( selectAllContacts() ), actionCollection(), 1547 SLOT( selectAllContacts() ), actionCollection(),
1524 "kaddressbook_select_all" ); 1548 "kaddressbook_select_all" );
1525 mActionUndo = new KAction( i18n( "&Undo" ), "undo", CTRL + Key_Z, this, 1549 mActionUndo = new KAction( i18n( "&Undo" ), "undo", CTRL + Key_Z, this,
1526 SLOT( undo() ), actionCollection(), 1550 SLOT( undo() ), actionCollection(),
1527 "kaddressbook_undo" ); 1551 "kaddressbook_undo" );
1528 mActionRedo = new KAction( i18n( "Re&do" ), "redo", CTRL + SHIFT + Key_Z, 1552 mActionRedo = new KAction( i18n( "Re&do" ), "redo", CTRL + SHIFT + Key_Z,
1529 this, SLOT( redo() ), actionCollection(), 1553 this, SLOT( redo() ), actionCollection(),
1530 "kaddressbook_redo" ); 1554 "kaddressbook_redo" );
@@ -1568,70 +1592,65 @@ void KABCore::initActions()
1568 1592
1569 } else { 1593 } else {
1570 mActionConfigKAddressbook = KStdAction::preferences( this, SLOT( openConfigDialog() ), actionCollection() ); 1594 mActionConfigKAddressbook = KStdAction::preferences( this, SLOT( openConfigDialog() ), actionCollection() );
1571 1595
1572 mActionKeyBindings = KStdAction::keyBindings( this, SLOT( configureKeyBindings() ), actionCollection() ); 1596 mActionKeyBindings = KStdAction::keyBindings( this, SLOT( configureKeyBindings() ), actionCollection() );
1573 } 1597 }
1574 1598
1575 mActionJumpBar = new KToggleAction( i18n( "Show Jump Bar" ), 0, 0, 1599 mActionJumpBar = new KToggleAction( i18n( "Show Jump Bar" ), 0, 0,
1576 actionCollection(), "options_show_jump_bar" ); 1600 actionCollection(), "options_show_jump_bar" );
1577 connect( mActionJumpBar, SIGNAL( toggled( bool ) ), SLOT( setJumpButtonBarVisible( bool ) ) ); 1601 connect( mActionJumpBar, SIGNAL( toggled( bool ) ), SLOT( setJumpButtonBarVisible( bool ) ) );
1578 1602
1579 mActionDetails = new KToggleAction( i18n( "Show Details" ), 0, 0, 1603 mActionDetails = new KToggleAction( i18n( "Show Details" ), 0, 0,
1580 actionCollection(), "options_show_details" ); 1604 actionCollection(), "options_show_details" );
1581 connect( mActionDetails, SIGNAL( toggled( bool ) ), SLOT( setDetailsVisible( bool ) ) ); 1605 connect( mActionDetails, SIGNAL( toggled( bool ) ), SLOT( setDetailsVisible( bool ) ) );
1582 1606
1583 // misc 1607 // misc
1584 // only enable LDAP lookup if we can handle the protocol 1608 // only enable LDAP lookup if we can handle the protocol
1585#ifndef KAB_EMBEDDED 1609#ifndef KAB_EMBEDDED
1586 if ( KProtocolInfo::isKnownProtocol( KURL( "ldap://localhost" ) ) ) { 1610 if ( KProtocolInfo::isKnownProtocol( KURL( "ldap://localhost" ) ) ) {
1587 new KAction( i18n( "&Lookup Addresses in Directory" ), "find", 0, 1611 new KAction( i18n( "&Lookup Addresses in Directory" ), "find", 0,
1588 this, SLOT( openLDAPDialog() ), actionCollection(), 1612 this, SLOT( openLDAPDialog() ), actionCollection(),
1589 "ldap_lookup" ); 1613 "ldap_lookup" );
1590 } 1614 }
1591#else //KAB_EMBEDDED 1615#else //KAB_EMBEDDED
1592 //qDebug("KABCore::initActions() LDAP has to be implemented"); 1616 //qDebug("KABCore::initActions() LDAP has to be implemented");
1593#endif //KAB_EMBEDDED 1617#endif //KAB_EMBEDDED
1594 1618
1595 1619
1596 mActionWhoAmI = new KAction( i18n( "Set Who Am I" ), "personal", 0, this, 1620 mActionWhoAmI = new KAction( i18n( "Set Who Am I" ), "personal", 0, this,
1597 SLOT( setWhoAmI() ), actionCollection(), 1621 SLOT( setWhoAmI() ), actionCollection(),
1598 "set_personal" ); 1622 "set_personal" );
1599 1623
1600 mActionBeam = 0; 1624
1601 if ( Ir::supported() ) {
1602 mActionBeam = new KAction( i18n( "&Beam Who Am I" ), "beam", 0, this,
1603 SLOT( beamMySelf() ), actionCollection(),
1604 "kaddressbook_beam_myself" );
1605 }
1606 1625
1607 1626
1608 mActionCategories = new KAction( i18n( "Set Categories" ), 0, this, 1627 mActionCategories = new KAction( i18n( "Set Categories" ), 0, this,
1609 SLOT( setCategories() ), actionCollection(), 1628 SLOT( setCategories() ), actionCollection(),
1610 "edit_set_categories" ); 1629 "edit_set_categories" );
1611 1630
1612 mActionRemoveVoice = new KAction( i18n( "Remove \"voice\"..." ), 0, this, 1631 mActionRemoveVoice = new KAction( i18n( "Remove \"voice\"..." ), 0, this,
1613 SLOT( removeVoice() ), actionCollection(), 1632 SLOT( removeVoice() ), actionCollection(),
1614 "remove_voice" ); 1633 "remove_voice" );
1615 mActionImportOL = new KAction( i18n( "Import from OL..." ), 0, this, 1634 mActionImportOL = new KAction( i18n( "Import from OL..." ), 0, this,
1616 SLOT( importFromOL() ), actionCollection(), 1635 SLOT( importFromOL() ), actionCollection(),
1617 "import_OL" ); 1636 "import_OL" );
1618#ifdef KAB_EMBEDDED 1637#ifdef KAB_EMBEDDED
1619 1638
1620 mActionAboutKAddressbook = new KAction( i18n( "&About KAddressBook" ), "kaddressbook2", 0, 1639 mActionAboutKAddressbook = new KAction( i18n( "&About KAddressBook" ), "kaddressbook2", 0,
1621 this, SLOT( createAboutData() ), actionCollection(), 1640 this, SLOT( createAboutData() ), actionCollection(),
1622 "kaddressbook_about_data" ); 1641 "kaddressbook_about_data" );
1623#endif //KAB_EMBEDDED 1642#endif //KAB_EMBEDDED
1624 1643
1625 clipboardDataChanged(); 1644 clipboardDataChanged();
1626 connect( UndoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) ); 1645 connect( UndoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) );
1627 connect( RedoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) ); 1646 connect( RedoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) );
1628} 1647}
1629 1648
1630//US we need this function, to plug all actions into the correct menues. 1649//US we need this function, to plug all actions into the correct menues.
1631// KDE uses a XML format to plug the actions, but we work her without this overhead. 1650// KDE uses a XML format to plug the actions, but we work her without this overhead.
1632void KABCore::addActionsManually() 1651void KABCore::addActionsManually()
1633{ 1652{
1634//US qDebug("KABCore::initActions(): mIsPart %i", mIsPart); 1653//US qDebug("KABCore::initActions(): mIsPart %i", mIsPart);
1635 1654
1636#ifdef KAB_EMBEDDED 1655#ifdef KAB_EMBEDDED
1637 QPopupMenu *fileMenu = new QPopupMenu( this ); 1656 QPopupMenu *fileMenu = new QPopupMenu( this );
@@ -1664,106 +1683,108 @@ void KABCore::addActionsManually()
1664 1683
1665 tb->enableMoving(false); 1684 tb->enableMoving(false);
1666 popupBarTB->insertItem( "&File", fileMenu ); 1685 popupBarTB->insertItem( "&File", fileMenu );
1667 popupBarTB->insertItem( "&Edit", editMenu ); 1686 popupBarTB->insertItem( "&Edit", editMenu );
1668 popupBarTB->insertItem( "&View", viewMenu ); 1687 popupBarTB->insertItem( "&View", viewMenu );
1669 popupBarTB->insertItem( "&Settings", settingsMenu ); 1688 popupBarTB->insertItem( "&Settings", settingsMenu );
1670 mViewManager->getFilterAction()->plug ( popupBarTB); 1689 mViewManager->getFilterAction()->plug ( popupBarTB);
1671 popupBarTB->insertItem( "&Change selected", changeMenu ); 1690 popupBarTB->insertItem( "&Change selected", changeMenu );
1672 popupBarTB->insertItem( "&Help", helpMenu ); 1691 popupBarTB->insertItem( "&Help", helpMenu );
1673 if (QApplication::desktop()->width() > 320 ) { 1692 if (QApplication::desktop()->width() > 320 ) {
1674 // mViewManager->getFilterAction()->plug ( tb); 1693 // mViewManager->getFilterAction()->plug ( tb);
1675 } 1694 }
1676#endif 1695#endif
1677 // mActionQuit->plug ( mMainWindow->toolBar()); 1696 // mActionQuit->plug ( mMainWindow->toolBar());
1678 1697
1679 1698
1680 1699
1681 //US Now connect the actions with the menue entries. 1700 //US Now connect the actions with the menue entries.
1682 mActionPrint->plug( fileMenu ); 1701 mActionPrint->plug( fileMenu );
1683 mActionMail->plug( fileMenu ); 1702 mActionMail->plug( fileMenu );
1684 fileMenu->insertSeparator(); 1703 fileMenu->insertSeparator();
1685 1704
1686 mActionNewContact->plug( fileMenu ); 1705 mActionNewContact->plug( fileMenu );
1687 mActionNewContact->plug( tb ); 1706 mActionNewContact->plug( tb );
1688 1707
1689 mActionEditAddressee->plug( fileMenu ); 1708 mActionEditAddressee->plug( fileMenu );
1690 fileMenu->insertSeparator(); 1709 fileMenu->insertSeparator();
1691 mActionSave->plug( fileMenu ); 1710 mActionSave->plug( fileMenu );
1692 fileMenu->insertItem( "&Import", ImportMenu ); 1711 fileMenu->insertItem( "&Import", ImportMenu );
1693 fileMenu->insertItem( "&Emport", ExportMenu ); 1712 fileMenu->insertItem( "&Emport", ExportMenu );
1694 fileMenu->insertSeparator(); 1713 fileMenu->insertSeparator();
1695 mActionMailVCard->plug( fileMenu ); 1714 mActionMailVCard->plug( fileMenu );
1715#ifndef DESKTOP_VERSION
1696 if ( Ir::supported() ) mActionBeamVCard->plug( fileMenu ); 1716 if ( Ir::supported() ) mActionBeamVCard->plug( fileMenu );
1717 if ( Ir::supported() ) mActionBeam->plug(fileMenu );
1718#endif
1697 fileMenu->insertSeparator(); 1719 fileMenu->insertSeparator();
1698 mActionQuit->plug( fileMenu ); 1720 mActionQuit->plug( fileMenu );
1699#ifdef _WIN32_ 1721#ifdef _WIN32_
1700 mActionImportOL->plug( ImportMenu ); 1722 mActionImportOL->plug( ImportMenu );
1701#endif 1723#endif
1702 // edit menu 1724 // edit menu
1703 mActionUndo->plug( editMenu ); 1725 mActionUndo->plug( editMenu );
1704 mActionRedo->plug( editMenu ); 1726 mActionRedo->plug( editMenu );
1705 editMenu->insertSeparator(); 1727 editMenu->insertSeparator();
1706 mActionCut->plug( editMenu ); 1728 mActionCut->plug( editMenu );
1707 mActionCopy->plug( editMenu ); 1729 mActionCopy->plug( editMenu );
1708 mActionPaste->plug( editMenu ); 1730 mActionPaste->plug( editMenu );
1709 mActionDelete->plug( editMenu ); 1731 mActionDelete->plug( editMenu );
1710 editMenu->insertSeparator(); 1732 editMenu->insertSeparator();
1711 mActionSelectAll->plug( editMenu ); 1733 mActionSelectAll->plug( editMenu );
1712 1734
1713 mActionRemoveVoice->plug( changeMenu ); 1735 mActionRemoveVoice->plug( changeMenu );
1714 // settings menu 1736 // settings menu
1715//US special menuentry to configure the addressbook resources. On KDE 1737//US special menuentry to configure the addressbook resources. On KDE
1716// you do that through the control center !!! 1738// you do that through the control center !!!
1717 mActionConfigResources->plug( settingsMenu ); 1739 mActionConfigResources->plug( settingsMenu );
1718 settingsMenu->insertSeparator(); 1740 settingsMenu->insertSeparator();
1719 1741
1720 mActionConfigKAddressbook->plug( settingsMenu ); 1742 mActionConfigKAddressbook->plug( settingsMenu );
1721 1743
1722 if ( mIsPart ) { 1744 if ( mIsPart ) {
1723 mActionConfigShortcuts->plug( settingsMenu ); 1745 mActionConfigShortcuts->plug( settingsMenu );
1724 mActionConfigureToolbars->plug( settingsMenu ); 1746 mActionConfigureToolbars->plug( settingsMenu );
1725 1747
1726 } else { 1748 } else {
1727 mActionKeyBindings->plug( settingsMenu ); 1749 mActionKeyBindings->plug( settingsMenu );
1728 } 1750 }
1729 1751
1730 settingsMenu->insertSeparator(); 1752 settingsMenu->insertSeparator();
1731 1753
1732 mActionJumpBar->plug( settingsMenu ); 1754 mActionJumpBar->plug( settingsMenu );
1733 mActionDetails->plug( settingsMenu ); 1755 mActionDetails->plug( settingsMenu );
1734 settingsMenu->insertSeparator(); 1756 settingsMenu->insertSeparator();
1735 1757
1736 mActionWhoAmI->plug( settingsMenu ); 1758 mActionWhoAmI->plug( settingsMenu );
1737 if ( Ir::supported() ) mActionBeam->plug( settingsMenu );
1738 mActionCategories->plug( settingsMenu ); 1759 mActionCategories->plug( settingsMenu );
1739 1760
1740 mActionAboutKAddressbook->plug( helpMenu ); 1761 mActionAboutKAddressbook->plug( helpMenu );
1741 1762
1742 1763
1743 if (QApplication::desktop()->width() > 320 ) { 1764 if (QApplication::desktop()->width() > 320 ) {
1744 1765
1745 mActionEditAddressee->plug( tb ); 1766 mActionEditAddressee->plug( tb );
1746 mActionSave->plug( tb ); 1767 mActionSave->plug( tb );
1747 mViewManager->getFilterAction()->plug ( tb); 1768 mViewManager->getFilterAction()->plug ( tb);
1748 if (QApplication::desktop()->width() > 480 ) { 1769 if (QApplication::desktop()->width() > 480 ) {
1749 mActionUndo->plug( tb ); 1770 mActionUndo->plug( tb );
1750 mActionDelete->plug( tb ); 1771 mActionDelete->plug( tb );
1751 mActionRedo->plug( tb ); 1772 mActionRedo->plug( tb );
1752 } 1773 }
1753 } 1774 }
1754 //mActionQuit->plug ( tb ); 1775 //mActionQuit->plug ( tb );
1755 // tb->insertWidget(-1, 0, mIncSearchWidget, 6); 1776 // tb->insertWidget(-1, 0, mIncSearchWidget, 6);
1756 1777
1757 //US link the searchwidget first to this. 1778 //US link the searchwidget first to this.
1758 // The real linkage to the toolbar happens later. 1779 // The real linkage to the toolbar happens later.
1759//US mIncSearchWidget->reparent(tb, 0, QPoint(50,0), TRUE); 1780//US mIncSearchWidget->reparent(tb, 0, QPoint(50,0), TRUE);
1760//US tb->insertItem( mIncSearchWidget ); 1781//US tb->insertItem( mIncSearchWidget );
1761/*US 1782/*US
1762 mIncSearchWidget = new IncSearchWidget( tb ); 1783 mIncSearchWidget = new IncSearchWidget( tb );
1763 connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ), 1784 connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ),
1764 SLOT( incrementalSearch( const QString& ) ) ); 1785 SLOT( incrementalSearch( const QString& ) ) );
1765 1786
1766 mJumpButtonBar = new JumpButtonBar( this, this ); 1787 mJumpButtonBar = new JumpButtonBar( this, this );
1767 1788
1768//US topLayout->addWidget( mJumpButtonBar ); 1789//US topLayout->addWidget( mJumpButtonBar );
1769 this->layout()->add( mJumpButtonBar ); 1790 this->layout()->add( mJumpButtonBar );