-rw-r--r-- | noncore/apps/zsafe/zsafe.cpp | 132 | ||||
-rw-r--r-- | noncore/apps/zsafe/zsafe.h | 8 |
2 files changed, 122 insertions, 18 deletions
diff --git a/noncore/apps/zsafe/zsafe.cpp b/noncore/apps/zsafe/zsafe.cpp index 189453e..5cad7cb 100644 --- a/noncore/apps/zsafe/zsafe.cpp +++ b/noncore/apps/zsafe/zsafe.cpp | |||
@@ -41,32 +41,33 @@ using namespace Opie::Ui; | |||
41 | 41 | ||
42 | #include <sys/types.h> | 42 | #include <sys/types.h> |
43 | #include <sys/stat.h> | 43 | #include <sys/stat.h> |
44 | #include <fcntl.h> | 44 | #include <fcntl.h> |
45 | #include <stdlib.h> | 45 | #include <stdlib.h> |
46 | #ifndef WIN32 | 46 | #ifndef WIN32 |
47 | #include <unistd.h> | 47 | #include <unistd.h> |
48 | #endif | 48 | #endif |
49 | #include <string.h> | 49 | #include <string.h> |
50 | #include <errno.h> | 50 | #include <errno.h> |
51 | 51 | ||
52 | #include <qmenubar.h> | 52 | #include <qmenubar.h> |
53 | #include <qpopupmenu.h> | 53 | #include <qpopupmenu.h> |
54 | 54 | ||
55 | #ifdef DESKTOP | 55 | #ifdef DESKTOP |
56 | #include <qfiledialog.h> | 56 | #include <qfiledialog.h> |
57 | #include <qdragobject.h> | ||
57 | #ifndef WIN32 | 58 | #ifndef WIN32 |
58 | #include <qsettings.h> | 59 | #include <qsettings.h> |
59 | #else | 60 | #else |
60 | #include "qsettings.h" | 61 | #include "qsettings.h" |
61 | #endif | 62 | #endif |
62 | #include <qapplication.h> | 63 | #include <qapplication.h> |
63 | #else | 64 | #else |
64 | #include <qfile.h> | 65 | #include <qfile.h> |
65 | #include <qpe/fileselector.h> | 66 | #include <qpe/fileselector.h> |
66 | #include <qpe/global.h> | 67 | #include <qpe/global.h> |
67 | #include <qpe/qpeapplication.h> | 68 | #include <qpe/qpeapplication.h> |
68 | #include <qpe/resource.h> | 69 | #include <qpe/resource.h> |
69 | #include <qpe/config.h> | 70 | #include <qpe/config.h> |
70 | #endif | 71 | #endif |
71 | 72 | ||
72 | #include <qtimer.h> | 73 | #include <qtimer.h> |
@@ -380,32 +381,33 @@ static const char* const general_data[] = { | |||
380 | 381 | ||
381 | 382 | ||
382 | /* | 383 | /* |
383 | * Constructs a ZSafe which is a child of 'parent', with the | 384 | * Constructs a ZSafe which is a child of 'parent', with the |
384 | * name 'name' and widget flags set to 'f' | 385 | * name 'name' and widget flags set to 'f' |
385 | * | 386 | * |
386 | * The dialog will by default be modeless, unless you set 'modal' to | 387 | * The dialog will by default be modeless, unless you set 'modal' to |
387 | * TRUE to construct a modal dialog. | 388 | * TRUE to construct a modal dialog. |
388 | */ | 389 | */ |
389 | ZSafe::ZSafe( QWidget* parent, const char* name, bool modal, WFlags fl ) | 390 | ZSafe::ZSafe( QWidget* parent, const char* name, bool modal, WFlags fl ) |
390 | : QDialog( parent, name, modal, fl ), | 391 | : QDialog( parent, name, modal, fl ), |
391 | Edit(0l), Delete(0l), Find(0l), New(0l), ListView(0l) | 392 | Edit(0l), Delete(0l), Find(0l), New(0l), ListView(0l) |
392 | { | 393 | { |
393 | IsCut = false; | 394 | IsCut = false; |
394 | IsCopy = false; | 395 | IsCopy = false; |
395 | modified = false; | 396 | modified = false; |
397 | showpwd = false; | ||
396 | 398 | ||
397 | // set the config file | 399 | // set the config file |
398 | cfgFile=QDir::homeDirPath(); | 400 | cfgFile=QDir::homeDirPath(); |
399 | cfgFile += "/.zsafe.cfg"; | 401 | cfgFile += "/.zsafe.cfg"; |
400 | // set the icon path | 402 | // set the icon path |
401 | #ifdef NO_OPIE | 403 | #ifdef NO_OPIE |
402 | QString qpedir ((const char *)getenv("QPEDIR")); | 404 | QString qpedir ((const char *)getenv("QPEDIR")); |
403 | #else | 405 | #else |
404 | QString qpedir ((const char *)getenv("OPIEDIR")); | 406 | QString qpedir ((const char *)getenv("OPIEDIR")); |
405 | #endif | 407 | #endif |
406 | 408 | ||
407 | #ifdef DESKTOP | 409 | #ifdef DESKTOP |
408 | iconPath = QDir::homeDirPath() + "/pics/"; | 410 | iconPath = QDir::homeDirPath() + "/pics/"; |
409 | #else | 411 | #else |
410 | if (qpedir.isEmpty()) | 412 | if (qpedir.isEmpty()) |
411 | iconPath = "/home/QtPalmtop/pics/"; | 413 | iconPath = "/home/QtPalmtop/pics/"; |
@@ -444,33 +446,34 @@ ZSafe::ZSafe( QWidget* parent, const char* name, bool modal, WFlags fl ) | |||
444 | QPixmap find_img((const char**) find_xpm); | 446 | QPixmap find_img((const char**) find_xpm); |
445 | QPixmap folder_open_img((const char**) folder_open_xpm); | 447 | QPixmap folder_open_img((const char**) folder_open_xpm); |
446 | QPixmap help_icon_img((const char**) help_icon_xpm); | 448 | QPixmap help_icon_img((const char**) help_icon_xpm); |
447 | QPixmap new_img((const char**) new_xpm); | 449 | QPixmap new_img((const char**) new_xpm); |
448 | QPixmap paste_img((const char**) paste_xpm); | 450 | QPixmap paste_img((const char**) paste_xpm); |
449 | QPixmap quit_icon_img((const char**) quit_icon_xpm); | 451 | QPixmap quit_icon_img((const char**) quit_icon_xpm); |
450 | QPixmap save_img((const char**) save_xpm); | 452 | QPixmap save_img((const char**) save_xpm); |
451 | QPixmap trash_img((const char**) trash_xpm); | 453 | QPixmap trash_img((const char**) trash_xpm); |
452 | QPixmap expand_img((const char**) expand_xpm); | 454 | QPixmap expand_img((const char**) expand_xpm); |
453 | QPixmap export_img((const char**) export_xpm); | 455 | QPixmap export_img((const char**) export_xpm); |
454 | QPixmap import_img((const char**) import_xpm); | 456 | QPixmap import_img((const char**) import_xpm); |
455 | 457 | ||
456 | QPixmap bank_cards( ( const char** ) bank_cards_data ); | 458 | QPixmap bank_cards( ( const char** ) bank_cards_data ); |
457 | QPixmap passwords( ( const char** ) passwords_data ); | 459 | QPixmap passwords( ( const char** ) passwords_data ); |
458 | QPixmap software( ( const char** ) software_data ); | 460 | QPixmap software( ( const char** ) software_data ); |
459 | QPixmap general( ( const char** ) general_data ); | 461 | QPixmap general( ( const char** ) general_data ); |
460 | if ( !name ) | 462 | QPixmap image0( ( const char** ) zsafe_xpm ); |
463 | if ( !name ) | ||
461 | setName( "ZSafe" ); | 464 | setName( "ZSafe" ); |
462 | 465 | ||
463 | #ifdef DESKTOP | 466 | #ifdef DESKTOP |
464 | #ifdef WIN32 | 467 | #ifdef WIN32 |
465 | setGeometry(100, 150, DeskW, DeskH-30 ); | 468 | setGeometry(100, 150, DeskW, DeskH-30 ); |
466 | #else | 469 | #else |
467 | resize( DeskW, DeskH-30 ); | 470 | resize( DeskW, DeskH-30 ); |
468 | #endif | 471 | #endif |
469 | 472 | ||
470 | #else | 473 | #else |
471 | 474 | ||
472 | #ifdef JPATCH_HDE | 475 | #ifdef JPATCH_HDE |
473 | int DeskS; | 476 | int DeskS; |
474 | if(DeskW > DeskH) | 477 | if(DeskW > DeskH) |
475 | { | 478 | { |
476 | DeskS = DeskW; | 479 | DeskS = DeskW; |
@@ -479,71 +482,109 @@ ZSafe::ZSafe( QWidget* parent, const char* name, bool modal, WFlags fl ) | |||
479 | { | 482 | { |
480 | DeskS = DeskH; | 483 | DeskS = DeskH; |
481 | } | 484 | } |
482 | resize( DeskW, DeskH ); | 485 | resize( DeskW, DeskH ); |
483 | setMinimumSize( QSize( DeskS, DeskS ) ); | 486 | setMinimumSize( QSize( DeskS, DeskS ) ); |
484 | setMaximumSize( QSize( DeskS, DeskS ) ); | 487 | setMaximumSize( QSize( DeskS, DeskS ) ); |
485 | #else | 488 | #else |
486 | resize( DeskW, DeskH-30 ); | 489 | resize( DeskW, DeskH-30 ); |
487 | #endif | 490 | #endif |
488 | 491 | ||
489 | #endif | 492 | #endif |
490 | setCaption( tr( "ZSafe" ) ); | 493 | setCaption( tr( "ZSafe" ) ); |
491 | QString zsafeAppDirPath = QDir::homeDirPath() + "/Documents/application/zsafe"; | 494 | QString zsafeAppDirPath = QDir::homeDirPath() + "/Documents/application/zsafe"; |
492 | QString filename = conf->readEntry(APP_KEY+"document"); | 495 | QString filename = conf->readEntry(APP_KEY+"document"); |
493 | if (filename.isEmpty() || filename.isNull()) | 496 | if (filename.isEmpty() || filename.isNull()) |
494 | { | 497 | { |
495 | if ( !QDir( zsafeAppDirPath ).exists() ) | 498 | |
499 | // check if the directory application exists, if not | ||
500 | // create it | ||
501 | // #ifndef WIN32 | ||
502 | // QString d1("Documents/application"); | ||
503 | // #else | ||
504 | QString d1(QDir::homeDirPath() + "/Documents/application"); | ||
505 | // #endif | ||
506 | QDir pd1(d1); | ||
507 | if (!pd1.exists()) | ||
508 | { | ||
509 | |||
510 | QDir pd2(QDir::homeDirPath() + "/Documents"); | ||
511 | if (!pd2.exists()) { | ||
512 | QDir pd3(QDir::homeDirPath()); | ||
513 | if (!pd3.mkdir("Documents", FALSE)) { | ||
514 | } | ||
515 | } | ||
516 | |||
517 | if (!pd2.mkdir("application", FALSE)) | ||
496 | { | 518 | { |
497 | //FIXME: Pending someone to look into why QDir.mkdir does not work as expected | 519 | QMessageBox::critical( 0, tr("ZSafe"), |
498 | QString cmdline = QString().sprintf( "mkdir -p %s", (const char*) zsafeAppDirPath ); | 520 | #ifdef JPATCH_HDE |
499 | ::system( cmdline ); | 521 | tr("<P>Can't create directory ..."+d1+"</P><P>ZSafe will now exit.</P>")); |
522 | #else | ||
523 | tr("<P>Can't create directory %1</P><P>ZSafe will now exit.</P>").arg(d1)); | ||
524 | #endif | ||
525 | exitZs (1); | ||
500 | } | 526 | } |
501 | if ( !QDir( zsafeAppDirPath ).exists() ) | 527 | } |
528 | // #ifndef WIN32 | ||
529 | // QString d2("Documents/application/zsafe"); | ||
530 | // #else | ||
531 | QString d2(QDir::homeDirPath() + "/Documents/application/zsafe"); | ||
532 | // #endif | ||
533 | QDir pd2(d2); | ||
534 | if (!pd2.exists()) | ||
535 | { | ||
536 | if (!pd1.mkdir("zsafe", FALSE)) | ||
502 | { | 537 | { |
503 | QMessageBox::critical( 0, "ZSafe", tr("Can't create application data directory.\nZSafe will now exit.")); | 538 | QMessageBox::critical( 0, tr("ZSafe"), |
504 | exitZs (1); | 539 | #ifdef JPATCH_HDE |
540 | tr("<P>Can't create directory ...//Documents/application/zsafe</P><P>ZSafe will now exit.</P")); | ||
541 | #else | ||
542 | tr("<P>Can't create directory %1</P><P>ZSafe will now exit.</P>").arg(d2)); | ||
543 | #endif | ||
544 | exitZs (1); | ||
505 | } | 545 | } |
506 | } | 546 | } |
507 | 547 | ||
508 | // set the default filename | 548 | // set the default filename |
509 | filename = zsafeAppDirPath + "/passwords.zsf"; | 549 | filename = zsafeAppDirPath + "/passwords.zsf"; |
510 | 550 | ||
511 | // save the current filename to the config file | 551 | // save the current filename to the config file |
512 | conf->writeEntry(APP_KEY+"document", filename); | 552 | conf->writeEntry(APP_KEY+"document", filename); |
513 | saveConf(); | 553 | saveConf(); |
514 | 554 | } | |
515 | //if (filename == "INVALIDPWD") | 555 | //if (filename == "INVALIDPWD") |
516 | //filename = ""; | 556 | //filename = ""; |
517 | 557 | ||
518 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); | 558 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); |
519 | #ifdef WIN32 | 559 | #ifdef WIN32 |
520 | this->setCaption("Qt ZSafe: " + ti); | 560 | this->setCaption("Qt ZSafe: " + ti); |
521 | #else | 561 | #else |
522 | this->setCaption("ZSafe: " + ti); | 562 | this->setCaption("ZSafe: " + ti); |
523 | #endif | 563 | #endif |
524 | 564 | ||
525 | selectedItem = NULL; | 565 | selectedItem = NULL; |
526 | lastSearchedCategory = NULL; | 566 | lastSearchedCategory = NULL; |
527 | lastSearchedItem = NULL; | 567 | lastSearchedItem = NULL; |
528 | lastSearchedName = ""; | 568 | lastSearchedName = ""; |
529 | lastSearchedUsername = ""; | 569 | lastSearchedUsername = ""; |
530 | lastSearchedComment = ""; | 570 | lastSearchedComment = ""; |
531 | 571 | ||
532 | infoForm = new InfoForm(); | 572 | infoForm = new InfoForm(); |
533 | categoryDialog = NULL; | 573 | categoryDialog = NULL; |
574 | infoForm->setIcon( image0); | ||
534 | 575 | ||
535 | // add a menu bar | 576 | // add a menu bar |
536 | QMenuBar *menu = new QMenuBar( this ); | 577 | QMenuBar *menu = new QMenuBar( this ); |
537 | 578 | ||
538 | // add file menu | 579 | // add file menu |
539 | // QPopupMenu *file = new QPopupMenu( this ); | 580 | // QPopupMenu *file = new QPopupMenu( this ); |
540 | file = new QPopupMenu( this ); | 581 | file = new QPopupMenu( this ); |
541 | 582 | ||
542 | // #ifdef DESKTOP | 583 | // #ifdef DESKTOP |
543 | file->insertItem( new_img, tr("&New document"), this, SLOT(newDocument()) ); | 584 | file->insertItem( new_img, tr("&New document"), this, SLOT(newDocument()) ); |
544 | file->insertItem( folder_open_img, tr("&Open document"), this, SLOT(loadDocument()) ); | 585 | file->insertItem( folder_open_img, tr("&Open document"), this, SLOT(loadDocument()) ); |
545 | file->insertItem( save_img, tr("&Save document as .."), this, SLOT(saveDocumentAs()) ); | 586 | file->insertItem( save_img, tr("&Save document as .."), this, SLOT(saveDocumentAs()) ); |
546 | file->insertSeparator(); | 587 | file->insertSeparator(); |
547 | // #endif | 588 | // #endif |
548 | 589 | ||
549 | file->insertItem( save_img, tr("&Save document"), this, SLOT(saveDocumentWithoutPwd()) ); | 590 | file->insertItem( save_img, tr("&Save document"), this, SLOT(saveDocumentWithoutPwd()) ); |
@@ -653,32 +694,39 @@ ZSafe::ZSafe( QWidget* parent, const char* name, bool modal, WFlags fl ) | |||
653 | openDocument(filename); | 694 | openDocument(filename); |
654 | #endif | 695 | #endif |
655 | 696 | ||
656 | // signals and slots connections for QTollButton | 697 | // signals and slots connections for QTollButton |
657 | connect( New, SIGNAL( clicked() ), this, SLOT( newPwd() ) ); | 698 | connect( New, SIGNAL( clicked() ), this, SLOT( newPwd() ) ); |
658 | connect( Edit, SIGNAL( clicked() ), this, SLOT( editPwd() ) ); | 699 | connect( Edit, SIGNAL( clicked() ), this, SLOT( editPwd() ) ); |
659 | connect( Delete, SIGNAL( clicked() ), this, SLOT( deletePwd() ) ); | 700 | connect( Delete, SIGNAL( clicked() ), this, SLOT( deletePwd() ) ); |
660 | connect( Find, SIGNAL( clicked() ), this, SLOT( findPwd() ) ); | 701 | connect( Find, SIGNAL( clicked() ), this, SLOT( findPwd() ) ); |
661 | // signals and slots connections for QListView | 702 | // signals and slots connections for QListView |
662 | connect( ListView, SIGNAL( selectionChanged(QListViewItem*) ), | 703 | connect( ListView, SIGNAL( selectionChanged(QListViewItem*) ), |
663 | this, SLOT( listViewSelected(QListViewItem*) ) ); | 704 | this, SLOT( listViewSelected(QListViewItem*) ) ); |
664 | connect( ListView, SIGNAL( doubleClicked(QListViewItem*) ), | 705 | connect( ListView, SIGNAL( doubleClicked(QListViewItem*) ), |
665 | this, SLOT( showInfo(QListViewItem*) ) ); | 706 | this, SLOT( showInfo(QListViewItem*) ) ); |
666 | connect( ListView, SIGNAL( returnPressed(QListViewItem*) ), | 707 | connect( ListView, SIGNAL( returnPressed(QListViewItem*) ), |
667 | this, SLOT( showInfo(QListViewItem*) ) ); | 708 | this, SLOT( showInfo(QListViewItem*) ) ); |
668 | 709 | ||
710 | #ifndef DESKTOP | ||
711 | QPEApplication::setStylusOperation( ListView->viewport(),QPEApplication::RightOnHold); | ||
712 | #endif | ||
713 | connect( ListView, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)), | ||
714 | this,SLOT( ListPressed(int, QListViewItem *, const QPoint&, int)) ); | ||
715 | |||
716 | this->setIcon( image0); | ||
669 | } | 717 | } |
670 | 718 | ||
671 | const QColor *ZSafe::evenRowColor = &Qt::white; | 719 | const QColor *ZSafe::evenRowColor = &Qt::white; |
672 | // const QColor *ZSafe::oddRowColor = &Qt::lightGray; | 720 | // const QColor *ZSafe::oddRowColor = &Qt::lightGray; |
673 | const QColor *ZSafe::oddRowColor = new QColor(216,240,255); | 721 | const QColor *ZSafe::oddRowColor = new QColor(216,240,255); |
674 | 722 | ||
675 | /* | 723 | /* |
676 | * Destroys the object and frees any allocated resources | 724 | * Destroys the object and frees any allocated resources |
677 | */ | 725 | */ |
678 | ZSafe::~ZSafe() | 726 | ZSafe::~ZSafe() |
679 | { | 727 | { |
680 | // no need to delete child widgets, Qt does it all for us | 728 | // no need to delete child widgets, Qt does it all for us |
681 | quitMe(); | 729 | quitMe(); |
682 | } | 730 | } |
683 | 731 | ||
684 | // load the default document | 732 | // load the default document |
@@ -1503,33 +1551,33 @@ void ZSafe::readAllEntries() | |||
1503 | 1551 | ||
1504 | Category *c1 = new Category(); | 1552 | Category *c1 = new Category(); |
1505 | c1->setCategoryName(category); | 1553 | c1->setCategoryName(category); |
1506 | 1554 | ||
1507 | QString icon; | 1555 | QString icon; |
1508 | QString fullIconPath; | 1556 | QString fullIconPath; |
1509 | QPixmap *pix; | 1557 | QPixmap *pix; |
1510 | // #ifndef WIN32 | 1558 | // #ifndef WIN32 |
1511 | icon = conf->readEntry(APP_KEY+category); | 1559 | icon = conf->readEntry(APP_KEY+category); |
1512 | // #endif | 1560 | // #endif |
1513 | bool isIconAv = false; | 1561 | bool isIconAv = false; |
1514 | if (!icon.isEmpty() && !icon.isNull()) | 1562 | if (!icon.isEmpty() && !icon.isNull()) |
1515 | { | 1563 | { |
1516 | // build the full path | 1564 | // build the full path |
1517 | fullIconPath = iconPath + icon; | 1565 | fullIconPath = iconPath + icon; |
1518 | pix = new QPixmap (fullIconPath); | 1566 | pix = new QPixmap (fullIconPath); |
1519 | if (pix) | 1567 | if (!pix->isNull()) |
1520 | { | 1568 | { |
1521 | QImage img = pix->convertToImage(); | 1569 | QImage img = pix->convertToImage(); |
1522 | pix->convertFromImage(img.smoothScale(14,14)); | 1570 | pix->convertFromImage(img.smoothScale(14,14)); |
1523 | c1->setIconName (icon); | 1571 | c1->setIconName (icon); |
1524 | c1->setIcon (*pix); | 1572 | c1->setIcon (*pix); |
1525 | isIconAv = true; | 1573 | isIconAv = true; |
1526 | } | 1574 | } |
1527 | } | 1575 | } |
1528 | if (!isIconAv) | 1576 | if (!isIconAv) |
1529 | { | 1577 | { |
1530 | c1->setIcon (*getPredefinedIcon(category)); | 1578 | c1->setIcon (*getPredefinedIcon(category)); |
1531 | } | 1579 | } |
1532 | c1->setListItem (catI); | 1580 | c1->setListItem (catI); |
1533 | c1->initListItem(); | 1581 | c1->initListItem(); |
1534 | categories.insert (c1->getCategoryName(), c1); | 1582 | categories.insert (c1->getCategoryName(), c1); |
1535 | } | 1583 | } |
@@ -1718,87 +1766,90 @@ void ZSafe::readAllEntries() | |||
1718 | 1766 | ||
1719 | Category *c1 = new Category(); | 1767 | Category *c1 = new Category(); |
1720 | c1->setCategoryName(category); | 1768 | c1->setCategoryName(category); |
1721 | 1769 | ||
1722 | QString icon; | 1770 | QString icon; |
1723 | QString fullIconPath; | 1771 | QString fullIconPath; |
1724 | QPixmap *pix; | 1772 | QPixmap *pix; |
1725 | // #ifndef WIN32 | 1773 | // #ifndef WIN32 |
1726 | icon = conf->readEntry(APP_KEY+category); | 1774 | icon = conf->readEntry(APP_KEY+category); |
1727 | // #endif | 1775 | // #endif |
1728 | bool isIconAv = false; | 1776 | bool isIconAv = false; |
1729 | if (!icon.isEmpty() && !icon.isNull()) | 1777 | if (!icon.isEmpty() && !icon.isNull()) |
1730 | { | 1778 | { |
1731 | // build the full path | 1779 | // build the full path |
1732 | fullIconPath = iconPath + icon; | 1780 | fullIconPath = iconPath + icon; |
1733 | pix = new QPixmap (fullIconPath); | 1781 | pix = new QPixmap (fullIconPath); |
1734 | if (pix) | 1782 | if (!pix->isNull()) |
1735 | { | 1783 | { |
1736 | QImage img = pix->convertToImage(); | 1784 | QImage img = pix->convertToImage(); |
1737 | pix->convertFromImage(img.smoothScale(14,14)); | 1785 | pix->convertFromImage(img.smoothScale(14,14)); |
1738 | c1->setIconName (icon); | 1786 | c1->setIconName (icon); |
1739 | c1->setIcon (*pix); | 1787 | c1->setIcon (*pix); |
1740 | isIconAv = true; | 1788 | isIconAv = true; |
1741 | } | 1789 | } |
1742 | } | 1790 | } |
1743 | if (!isIconAv) | 1791 | if (!isIconAv) |
1744 | { | 1792 | { |
1745 | c1->setIcon (*getPredefinedIcon(category)); | 1793 | c1->setIcon (*getPredefinedIcon(category)); |
1746 | } | 1794 | } |
1747 | c1->setListItem (catI); | 1795 | c1->setListItem (catI); |
1748 | c1->initListItem(); | 1796 | c1->initListItem(); |
1749 | categories.insert (c1->getCategoryName(), c1); | 1797 | categories.insert (c1->getCategoryName(), c1); |
1750 | } | 1798 | } |
1751 | 1799 | ||
1752 | } | 1800 | } |
1753 | f.close(); | 1801 | f.close(); |
1754 | 1802 | ||
1755 | } | 1803 | } |
1756 | #endif // UNUSED | 1804 | #endif // UNUSED |
1757 | 1805 | ||
1758 | void ZSafe::resume(int) | 1806 | void ZSafe::resume(int) |
1759 | { | 1807 | { |
1760 | owarn << "Resume" << oendl; | 1808 | owarn << "Resume" << oendl; |
1761 | // hide the main window | 1809 | // hide the main window |
1762 | 1810 | ||
1811 | if ( !showpwd ) | ||
1812 | { | ||
1763 | infoForm->hide(); | 1813 | infoForm->hide(); |
1764 | // open zsafe again | 1814 | // open zsafe again |
1765 | m_password = ""; | 1815 | m_password = ""; |
1766 | selectedItem = NULL; | 1816 | selectedItem = NULL; |
1767 | 1817 | ||
1768 | // clear the password list | 1818 | // clear the password list |
1769 | QListViewItem *i; | 1819 | QListViewItem *i; |
1770 | // step through all categories | 1820 | // step through all categories |
1771 | for (i = ListView->firstChild(); | 1821 | for (i = ListView->firstChild(); |
1772 | i != NULL; | 1822 | i != NULL; |
1773 | i = i->nextSibling()) | 1823 | i = i->nextSibling()) |
1774 | { | 1824 | { |
1775 | // step through all subitems | 1825 | // step through all subitems |
1776 | QListViewItem *si; | 1826 | QListViewItem *si; |
1777 | for (si = i->firstChild(); | 1827 | for (si = i->firstChild(); |
1778 | si != NULL; ) | 1828 | si != NULL; ) |
1779 | { | 1829 | { |
1780 | QListViewItem *_si = si; | 1830 | QListViewItem *_si = si; |
1781 | si = si->nextSibling(); | 1831 | si = si->nextSibling(); |
1782 | i->takeItem(_si); // remove from view list | 1832 | i->takeItem(_si); // remove from view list |
1783 | if (_si) delete _si; | 1833 | if (_si) delete _si; |
1784 | } | 1834 | } |
1785 | } | 1835 | } |
1786 | 1836 | ||
1787 | // ask for password and read again | 1837 | // ask for password and read again |
1788 | openDocument(filename); | 1838 | openDocument(filename); |
1839 | } | ||
1789 | } | 1840 | } |
1790 | 1841 | ||
1791 | //--------------------------------------------- | 1842 | //--------------------------------------------- |
1792 | 1843 | ||
1793 | 1844 | ||
1794 | bool ZSafe::openDocument(const char* _filename, const char* ) | 1845 | bool ZSafe::openDocument(const char* _filename, const char* ) |
1795 | { | 1846 | { |
1796 | int retval; | 1847 | int retval; |
1797 | char* entry[FIELD_SIZE]; | 1848 | char* entry[FIELD_SIZE]; |
1798 | // #ifndef WIN32 | 1849 | // #ifndef WIN32 |
1799 | int validationFlag = conf->readNumEntry(APP_KEY+"valzsafe", 1); | 1850 | int validationFlag = conf->readNumEntry(APP_KEY+"valzsafe", 1); |
1800 | // #else | 1851 | // #else |
1801 | // int validationFlag = 1; | 1852 | // int validationFlag = 1; |
1802 | // #endif | 1853 | // #endif |
1803 | 1854 | ||
1804 | int pwdOk = 0; | 1855 | int pwdOk = 0; |
@@ -1941,33 +1992,33 @@ bool ZSafe::openDocument(const char* _filename, const char* ) | |||
1941 | 1992 | ||
1942 | Category *c1 = new Category(); | 1993 | Category *c1 = new Category(); |
1943 | c1->setCategoryName(category); | 1994 | c1->setCategoryName(category); |
1944 | 1995 | ||
1945 | QString icon; | 1996 | QString icon; |
1946 | QString fullIconPath; | 1997 | QString fullIconPath; |
1947 | QPixmap *pix; | 1998 | QPixmap *pix; |
1948 | // #ifndef WIN32 | 1999 | // #ifndef WIN32 |
1949 | icon = conf->readEntry(APP_KEY+category); | 2000 | icon = conf->readEntry(APP_KEY+category); |
1950 | // #endif | 2001 | // #endif |
1951 | bool isIconAv = false; | 2002 | bool isIconAv = false; |
1952 | if (!icon.isEmpty() && !icon.isNull()) | 2003 | if (!icon.isEmpty() && !icon.isNull()) |
1953 | { | 2004 | { |
1954 | // build the full path | 2005 | // build the full path |
1955 | fullIconPath = iconPath + icon; | 2006 | fullIconPath = iconPath + icon; |
1956 | pix = new QPixmap (fullIconPath); | 2007 | pix = new QPixmap (fullIconPath); |
1957 | if (pix) | 2008 | if (!pix->isNull()) |
1958 | { | 2009 | { |
1959 | QImage img = pix->convertToImage(); | 2010 | QImage img = pix->convertToImage(); |
1960 | pix->convertFromImage(img.smoothScale(14,14)); | 2011 | pix->convertFromImage(img.smoothScale(14,14)); |
1961 | c1->setIconName (icon); | 2012 | c1->setIconName (icon); |
1962 | c1->setIcon (*pix); | 2013 | c1->setIcon (*pix); |
1963 | isIconAv = true; | 2014 | isIconAv = true; |
1964 | } | 2015 | } |
1965 | } | 2016 | } |
1966 | if (!isIconAv) | 2017 | if (!isIconAv) |
1967 | { | 2018 | { |
1968 | c1->setIcon (*getPredefinedIcon(category)); | 2019 | c1->setIcon (*getPredefinedIcon(category)); |
1969 | } | 2020 | } |
1970 | 2021 | ||
1971 | c1->setListItem (catI); | 2022 | c1->setListItem (catI); |
1972 | c1->initListItem(); | 2023 | c1->initListItem(); |
1973 | categories.insert (c1->getCategoryName(), c1); | 2024 | categories.insert (c1->getCategoryName(), c1); |
@@ -2289,32 +2340,35 @@ bool ZSafe::saveDocument(const char* _filename, | |||
2289 | PasswordForm *newPwdDialog; | 2340 | PasswordForm *newPwdDialog; |
2290 | bool newPwdDialogResult = false; | 2341 | bool newPwdDialogResult = false; |
2291 | void ZSafe::setPasswordDialogDone() | 2342 | void ZSafe::setPasswordDialogDone() |
2292 | { | 2343 | { |
2293 | newPwdDialogResult = true; | 2344 | newPwdDialogResult = true; |
2294 | newPwdDialog->close(); | 2345 | newPwdDialog->close(); |
2295 | } | 2346 | } |
2296 | 2347 | ||
2297 | void ZSafe::getDocPassword(QString title) | 2348 | void ZSafe::getDocPassword(QString title) |
2298 | { | 2349 | { |
2299 | owarn << "getDocPassword" << oendl; | 2350 | owarn << "getDocPassword" << oendl; |
2300 | // open the 'Password' dialog | 2351 | // open the 'Password' dialog |
2301 | PasswordForm *dialog = new PasswordForm(this, title, TRUE); | 2352 | PasswordForm *dialog = new PasswordForm(this, title, TRUE); |
2302 | newPwdDialog = dialog; | 2353 | newPwdDialog = dialog; |
2303 | newPwdDialogResult = false; | 2354 | newPwdDialogResult = false; |
2304 | 2355 | ||
2356 | QPixmap image0( ( const char** ) zsafe_xpm ); | ||
2357 | dialog->setIcon( image0); | ||
2358 | |||
2305 | connect( dialog->PasswordField, SIGNAL( returnPressed() ), | 2359 | connect( dialog->PasswordField, SIGNAL( returnPressed() ), |
2306 | this, SLOT( setPasswordDialogDone() ) ); | 2360 | this, SLOT( setPasswordDialogDone() ) ); |
2307 | 2361 | ||
2308 | // CS: !!! | 2362 | // CS: !!! |
2309 | // int pos = filename.findRev ('/'); | 2363 | // int pos = filename.findRev ('/'); |
2310 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); | 2364 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); |
2311 | #ifdef WIN32 | 2365 | #ifdef WIN32 |
2312 | dialog->setCaption("Qt " + ti); | 2366 | dialog->setCaption("Qt " + ti); |
2313 | #else | 2367 | #else |
2314 | dialog->setCaption(ti); | 2368 | dialog->setCaption(ti); |
2315 | #endif | 2369 | #endif |
2316 | // dialog->setCaption(title); | 2370 | // dialog->setCaption(title); |
2317 | 2371 | ||
2318 | dialog->PasswordField->setFocus(); | 2372 | dialog->PasswordField->setFocus(); |
2319 | DialogCode result = (DialogCode) dialog->exec(); | 2373 | DialogCode result = (DialogCode) dialog->exec(); |
2320 | #ifdef DESKTOP | 2374 | #ifdef DESKTOP |
@@ -2679,33 +2733,33 @@ void ZSafe::addCategory() | |||
2679 | category = dialog->CategoryField->currentText(); | 2733 | category = dialog->CategoryField->currentText(); |
2680 | icon = dialog->IconField->currentText()+".png"; | 2734 | icon = dialog->IconField->currentText()+".png"; |
2681 | 2735 | ||
2682 | owarn << category << oendl; | 2736 | owarn << category << oendl; |
2683 | 2737 | ||
2684 | QListViewItem *li = new ShadedListItem( 1, ListView ); | 2738 | QListViewItem *li = new ShadedListItem( 1, ListView ); |
2685 | Category *c1 = new Category(); | 2739 | Category *c1 = new Category(); |
2686 | c1->setCategoryName(category); | 2740 | c1->setCategoryName(category); |
2687 | 2741 | ||
2688 | // if (!icon.isEmpty() && !icon.isNull()) | 2742 | // if (!icon.isEmpty() && !icon.isNull()) |
2689 | if (icon != "predefined.png") | 2743 | if (icon != "predefined.png") |
2690 | { | 2744 | { |
2691 | // build the full path | 2745 | // build the full path |
2692 | fullIconPath = iconPath + icon; | 2746 | fullIconPath = iconPath + icon; |
2693 | pix = new QPixmap (fullIconPath); | 2747 | pix = new QPixmap (fullIconPath); |
2694 | // pix->resize(14, 14); | 2748 | // pix->resize(14, 14); |
2695 | if (pix) | 2749 | if (!pix->isNull()) |
2696 | { | 2750 | { |
2697 | // save the full pixmap name into the config file | 2751 | // save the full pixmap name into the config file |
2698 | // #ifndef WIN32 | 2752 | // #ifndef WIN32 |
2699 | conf->writeEntry(APP_KEY+category, icon); | 2753 | conf->writeEntry(APP_KEY+category, icon); |
2700 | // #endif | 2754 | // #endif |
2701 | saveConf(); | 2755 | saveConf(); |
2702 | QImage img = pix->convertToImage(); | 2756 | QImage img = pix->convertToImage(); |
2703 | pix->convertFromImage(img.smoothScale(14,14)); | 2757 | pix->convertFromImage(img.smoothScale(14,14)); |
2704 | c1->setIcon (*pix); | 2758 | c1->setIcon (*pix); |
2705 | c1->setIconName(icon); | 2759 | c1->setIconName(icon); |
2706 | } | 2760 | } |
2707 | else | 2761 | else |
2708 | { | 2762 | { |
2709 | QPixmap folder( ( const char** ) general_data ); | 2763 | QPixmap folder( ( const char** ) general_data ); |
2710 | c1->setIcon (folder); | 2764 | c1->setIcon (folder); |
2711 | } | 2765 | } |
@@ -3148,33 +3202,33 @@ void ZSafe::editCategory() | |||
3148 | saveConf(); | 3202 | saveConf(); |
3149 | } | 3203 | } |
3150 | 3204 | ||
3151 | category = dialog->CategoryField->currentText(); | 3205 | category = dialog->CategoryField->currentText(); |
3152 | icon = dialog->IconField->currentText()+".png"; | 3206 | icon = dialog->IconField->currentText()+".png"; |
3153 | 3207 | ||
3154 | if (cat) | 3208 | if (cat) |
3155 | { | 3209 | { |
3156 | owarn << "Category found" << oendl; | 3210 | owarn << "Category found" << oendl; |
3157 | 3211 | ||
3158 | // if (!icon.isEmpty() && !icon.isNull()) | 3212 | // if (!icon.isEmpty() && !icon.isNull()) |
3159 | if (icon != "predefined.png") | 3213 | if (icon != "predefined.png") |
3160 | { | 3214 | { |
3161 | // build the full path | 3215 | // build the full path |
3162 | fullIconPath = iconPath + icon; | 3216 | fullIconPath = iconPath + icon; |
3163 | pix = new QPixmap (fullIconPath); | 3217 | pix = new QPixmap (fullIconPath); |
3164 | if (pix) | 3218 | if (!pix->isNull()) |
3165 | { | 3219 | { |
3166 | // save the full pixmap name into the config file | 3220 | // save the full pixmap name into the config file |
3167 | // #ifndef WIN32 | 3221 | // #ifndef WIN32 |
3168 | conf->writeEntry(APP_KEY+category, icon); | 3222 | conf->writeEntry(APP_KEY+category, icon); |
3169 | // #endif | 3223 | // #endif |
3170 | saveConf(); | 3224 | saveConf(); |
3171 | QImage img = pix->convertToImage(); | 3225 | QImage img = pix->convertToImage(); |
3172 | pix->convertFromImage(img.smoothScale(14,14)); | 3226 | pix->convertFromImage(img.smoothScale(14,14)); |
3173 | cat->setIconName (icon); | 3227 | cat->setIconName (icon); |
3174 | cat->setIcon (*pix); | 3228 | cat->setIcon (*pix); |
3175 | } | 3229 | } |
3176 | } | 3230 | } |
3177 | else | 3231 | else |
3178 | { | 3232 | { |
3179 | // #ifndef WIN32 | 3233 | // #ifndef WIN32 |
3180 | conf->removeEntry (category); | 3234 | conf->removeEntry (category); |
@@ -3679,17 +3733,63 @@ void ZSafe::setDocument(const QString& fileref) | |||
3679 | si = si->nextSibling(); | 3733 | si = si->nextSibling(); |
3680 | i->takeItem(_si); // remove from view list | 3734 | i->takeItem(_si); // remove from view list |
3681 | if (_si) delete _si; | 3735 | if (_si) delete _si; |
3682 | } | 3736 | } |
3683 | } | 3737 | } |
3684 | if (c) delete c; // delete the previous category | 3738 | if (c) delete c; // delete the previous category |
3685 | categories.clear(); | 3739 | categories.clear(); |
3686 | 3740 | ||
3687 | m_password = ""; | 3741 | m_password = ""; |
3688 | selectedItem = NULL; | 3742 | selectedItem = NULL; |
3689 | 3743 | ||
3690 | openDocument(filename); | 3744 | openDocument(filename); |
3691 | #endif | 3745 | #endif |
3692 | } | 3746 | } |
3693 | 3747 | ||
3694 | 3748 | ||
3749 | void ZSafe::ListPressed(int mouse, QListViewItem *item, const QPoint&, int column) { | ||
3750 | if(item ==0) return; | ||
3751 | switch (mouse) { | ||
3752 | case 1: | ||
3753 | { | ||
3754 | #ifdef DESKTOP | ||
3755 | QDragObject *d = new QTextDrag( item->text(column) , this ); | ||
3756 | d->dragCopy(); | ||
3757 | #endif | ||
3758 | } | ||
3759 | break; | ||
3760 | case 2: | ||
3761 | { | ||
3762 | QClipboard *cb = QApplication::clipboard(); | ||
3763 | |||
3764 | QIconSet copy_img((const char**) copy_xpm); | ||
3765 | QIconSet edit_img((const char**) edit_xpm); | ||
3766 | QPixmap folder_open_img((const char**) folder_open_xpm); | ||
3767 | QPixmap editdelete_img((const char**) editdelete_xpm); | ||
3768 | |||
3769 | QPopupMenu *m = new QPopupMenu(this); | ||
3770 | int copyItem = m->insertItem( copy_img, tr( "Copy to Clipboard" )); | ||
3771 | int editItem = m->insertItem(edit_img, tr( "Edit" )); | ||
3772 | int showItem = m->insertItem(folder_open_img, tr( "Show Info" )); | ||
3773 | int cancelItem = m->insertItem( editdelete_img, tr( "Cancel" )); | ||
3774 | m->setFocus(); | ||
3775 | int me=m->exec( QPoint( QCursor::pos().x(), QCursor::pos().y() ) ) ; | ||
3776 | if(me == copyItem) { | ||
3777 | copyClip( item->text(column) ) ; | ||
3778 | } else if (me == cancelItem) { | ||
3779 | cb->clear(); | ||
3780 | } else if (me == editItem) { | ||
3781 | editPwd(); | ||
3782 | } else if (me == showItem) { | ||
3783 | showInfo(item); | ||
3784 | } | ||
3785 | } | ||
3786 | break; | ||
3787 | }; | ||
3788 | } | ||
3789 | |||
3790 | void ZSafe::copyClip( const QString &text) { | ||
3791 | QClipboard *cb = QApplication::clipboard(); | ||
3792 | cb->setText( text); | ||
3793 | } | ||
3794 | |||
3695 | 3795 | ||
diff --git a/noncore/apps/zsafe/zsafe.h b/noncore/apps/zsafe/zsafe.h index eef5cdc..ca041ff 100644 --- a/noncore/apps/zsafe/zsafe.h +++ b/noncore/apps/zsafe/zsafe.h | |||
@@ -48,52 +48,53 @@ class QPixmap; | |||
48 | 48 | ||
49 | class ZSafe : public QDialog | 49 | class ZSafe : public QDialog |
50 | { | 50 | { |
51 | Q_OBJECT | 51 | Q_OBJECT |
52 | 52 | ||
53 | protected: | 53 | protected: |
54 | void paintEvent( QPaintEvent * e ); | 54 | void paintEvent( QPaintEvent * e ); |
55 | void resizeEvent ( QResizeEvent * ); | 55 | void resizeEvent ( QResizeEvent * ); |
56 | 56 | ||
57 | bool raiseFlag; | 57 | bool raiseFlag; |
58 | QTimer raiseTimer; | 58 | QTimer raiseTimer; |
59 | 59 | ||
60 | public: | 60 | public: |
61 | ZSafe( QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags fl = WDestructiveClose ); | 61 | ZSafe( QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags fl = WDestructiveClose ); |
62 | ~ZSafe(); | 62 | ~ZSafe(); |
63 | 63 | ||
64 | static const QColor *evenRowColor; | 64 | static const QColor *evenRowColor; |
65 | static const QColor *oddRowColor; | 65 | static const QColor *oddRowColor; |
66 | 66 | ||
67 | QToolButton* Edit; | 67 | QToolButton* Edit; |
68 | QToolButton* Delete; | 68 | QToolButton* Delete; |
69 | QToolButton* Find; | 69 | QToolButton* Find; |
70 | QToolButton* New; | 70 | QToolButton* New; |
71 | ZListView* ListView; | 71 | ZListView* ListView; |
72 | 72 | ||
73 | QString cfgFile; | 73 | QString cfgFile; |
74 | QString iconPath; | 74 | QString iconPath; |
75 | 75 | ||
76 | InfoForm *infoForm; | 76 | InfoForm *infoForm; |
77 | CategoryDialog *categoryDialog; | 77 | CategoryDialog *categoryDialog; |
78 | 78 | ||
79 | QListViewItem *selectedItem; // current selected item | 79 | QListViewItem *selectedItem; // current selected item |
80 | QListViewItem *copiedItem; // copied item | 80 | QListViewItem *copiedItem; // copied item |
81 | bool IsCopy; | 81 | bool IsCopy; |
82 | bool IsCut; | 82 | bool IsCut; |
83 | bool modified; // true if database is modified | 83 | bool modified; // true if database is modified |
84 | bool showpwd; // show PWD Dialog | ||
84 | 85 | ||
85 | QListViewItem *lastSearchedCategory; | 86 | QListViewItem *lastSearchedCategory; |
86 | QListViewItem *lastSearchedItem; | 87 | QListViewItem *lastSearchedItem; |
87 | QString lastSearchedName; | 88 | QString lastSearchedName; |
88 | QString lastSearchedUsername; | 89 | QString lastSearchedUsername; |
89 | QString lastSearchedComment; | 90 | QString lastSearchedComment; |
90 | 91 | ||
91 | 92 | ||
92 | CategoryList categories; // list of categories | 93 | CategoryList categories; // list of categories |
93 | 94 | ||
94 | bool isCategory(QListViewItem *_item); | 95 | bool isCategory(QListViewItem *_item); |
95 | void getDocPassword(QString title); | 96 | void getDocPassword(QString title); |
96 | QString filename; | 97 | QString filename; |
97 | 98 | ||
98 | enum { | 99 | enum { |
99 | PWERR_GOOD, // success | 100 | PWERR_GOOD, // success |
@@ -170,24 +171,27 @@ public slots: | |||
170 | virtual void delCategory(); | 171 | virtual void delCategory(); |
171 | virtual void editCategory(); | 172 | virtual void editCategory(); |
172 | virtual void cutItem(); | 173 | virtual void cutItem(); |
173 | virtual void copyItem(); | 174 | virtual void copyItem(); |
174 | virtual void pasteItem(); | 175 | virtual void pasteItem(); |
175 | 176 | ||
176 | virtual void newDocument(); | 177 | virtual void newDocument(); |
177 | virtual void loadDocument(); | 178 | virtual void loadDocument(); |
178 | virtual void saveDocumentAs(); | 179 | virtual void saveDocumentAs(); |
179 | virtual void saveDocumentWithoutPwd(); | 180 | virtual void saveDocumentWithoutPwd(); |
180 | virtual void saveDocumentWithPwd(); | 181 | virtual void saveDocumentWithPwd(); |
181 | virtual void about(); | 182 | virtual void about(); |
182 | virtual void setExpandFlag(); | 183 | virtual void setExpandFlag(); |
183 | 184 | ||
184 | virtual void categoryFieldActivated( const QString& str); | 185 | virtual void categoryFieldActivated( const QString& str); |
185 | 186 | ||
187 | virtual void ListPressed(int, QListViewItem *, const QPoint&, int); | ||
188 | virtual void copyClip( const QString &text); | ||
189 | |||
186 | private slots: | 190 | private slots: |
187 | void setDocument(const QString& fileref); | 191 | void setDocument(const QString& fileref); |
188 | void slotLoadDocu(); | 192 | void slotLoadDocu(); |
189 | void slotRaiseTimer(); | 193 | void slotRaiseTimer(); |
190 | 194 | ||
191 | }; | 195 | }; |
192 | 196 | ||
193 | #endif // ZSAFE_H | 197 | #endif // ZSAFE_H |