-rw-r--r-- | noncore/apps/zsafe/zsafe.cpp | 691 | ||||
-rw-r--r-- | noncore/apps/zsafe/zsafe.h | 10 |
2 files changed, 72 insertions, 629 deletions
diff --git a/noncore/apps/zsafe/zsafe.cpp b/noncore/apps/zsafe/zsafe.cpp index 1ae3b15..2b182f9 100644 --- a/noncore/apps/zsafe/zsafe.cpp +++ b/noncore/apps/zsafe/zsafe.cpp | |||
@@ -1,150 +1,108 @@ | |||
1 | /**************************************************************************** | 1 | /**************************************************************************** |
2 | ** | 2 | ** |
3 | ** Created: Sat Apr 6 17:57:45 2002 | 3 | ** Created: Sat Apr 6 17:57:45 2002 |
4 | ** | 4 | ** |
5 | ** Author: Carsten Schneider <CarstenSchneider@t-online.de> | 5 | ** Author: Carsten Schneider <CarstenSchneider@t-online.de> |
6 | ** | 6 | ** |
7 | ** $Id$ | 7 | ** $Id$ |
8 | ** | 8 | ** |
9 | ** Homepage: http://home.t-online.de/home/CarstenSchneider/zsafe/index.html | 9 | ** Homepage: http://home.t-online.de/home/CarstenSchneider/zsafe/index.html |
10 | ** | 10 | ** |
11 | ** Compile Flags: | ||
12 | ** Zaurus arm : -DNO_OPIE | ||
13 | ** Zaurus Opie arm: none | ||
14 | ** Linux Desktop : -DDESKTOP -DNO_OPIE | ||
15 | ** Windows Desktop: -DDESKTOP -DNO_OPIE | ||
16 | ** use qmake | ||
17 | ** for japanese version additional use: -DJPATCH_HDE | ||
18 | ** | 11 | ** |
19 | ****************************************************************************/ | 12 | ****************************************************************************/ |
20 | #include "zsafe.h" | 13 | #include "zsafe.h" |
21 | #include "newdialog.h" | 14 | #include "newdialog.h" |
22 | #include "searchdialog.h" | 15 | #include "searchdialog.h" |
23 | #include "categorydialog.h" | 16 | #include "categorydialog.h" |
24 | #include "passworddialog.h" | 17 | #include "passworddialog.h" |
25 | #include "infoform.h" | 18 | #include "infoform.h" |
26 | #include "zlistview.h" | 19 | #include "zlistview.h" |
27 | #include "shadedlistitem.h" | 20 | #include "shadedlistitem.h" |
28 | 21 | ||
29 | #ifndef DESKTOP | ||
30 | #ifndef NO_OPIE | ||
31 | #include <opie2/ofiledialog.h> | 22 | #include <opie2/ofiledialog.h> |
32 | #include <opie2/odebug.h> | 23 | #include <opie2/odebug.h> |
33 | using namespace Opie::Core; | 24 | using namespace Opie::Core; |
34 | using namespace Opie::Ui; | 25 | using namespace Opie::Ui; |
35 | #else | ||
36 | #include "scqtfileedit.h" | ||
37 | #endif | ||
38 | #endif | ||
39 | 26 | ||
40 | #include <qclipboard.h> | 27 | #include <qclipboard.h> |
41 | 28 | ||
42 | #include <sys/types.h> | 29 | #include <sys/types.h> |
43 | #include <sys/stat.h> | 30 | #include <sys/stat.h> |
44 | #include <fcntl.h> | 31 | #include <fcntl.h> |
45 | #include <stdlib.h> | 32 | #include <stdlib.h> |
46 | #ifndef Q_WS_WIN | ||
47 | #include <unistd.h> | 33 | #include <unistd.h> |
48 | #endif | ||
49 | #include <string.h> | 34 | #include <string.h> |
50 | #include <errno.h> | 35 | #include <errno.h> |
51 | 36 | ||
52 | #include <qmenubar.h> | 37 | #include <qmenubar.h> |
53 | #include <qpopupmenu.h> | 38 | #include <qpopupmenu.h> |
54 | 39 | ||
55 | #ifdef DESKTOP | ||
56 | #include <qfiledialog.h> | ||
57 | #include <qdragobject.h> | ||
58 | #ifndef Q_WS_WIN | ||
59 | #include <qsettings.h> | ||
60 | #else | ||
61 | #include "qsettings.h" | ||
62 | #endif | ||
63 | #include <qapplication.h> | ||
64 | #else | ||
65 | #include <qfile.h> | 40 | #include <qfile.h> |
66 | #include <qpe/fileselector.h> | 41 | #include <qpe/fileselector.h> |
67 | #include <qpe/global.h> | 42 | #include <qpe/global.h> |
68 | #include <qpe/qpeapplication.h> | 43 | #include <qpe/qpeapplication.h> |
69 | #include <qpe/resource.h> | 44 | #include <qpe/resource.h> |
70 | #include <qpe/config.h> | 45 | #include <qpe/config.h> |
71 | #endif | ||
72 | 46 | ||
73 | #include <qtimer.h> | 47 | #include <qtimer.h> |
74 | #include <qlayout.h> | 48 | #include <qlayout.h> |
75 | #include <qmessagebox.h> | 49 | #include <qmessagebox.h> |
76 | #include <qfile.h> | 50 | #include <qfile.h> |
77 | #include <qtextstream.h> | 51 | #include <qtextstream.h> |
78 | #include <qheader.h> | 52 | #include <qheader.h> |
79 | #include <qlistview.h> | 53 | #include <qlistview.h> |
80 | #include <qtoolbutton.h> | 54 | #include <qtoolbutton.h> |
81 | #include <qvariant.h> | 55 | #include <qvariant.h> |
82 | #include <qtooltip.h> | 56 | #include <qtooltip.h> |
83 | #include <qwhatsthis.h> | 57 | #include <qwhatsthis.h> |
84 | #include <qimage.h> | 58 | #include <qimage.h> |
85 | #include <qpixmap.h> | 59 | #include <qpixmap.h> |
86 | #include <qlineedit.h> | 60 | #include <qlineedit.h> |
87 | #include <qmultilineedit.h> | 61 | #include <qmultilineedit.h> |
88 | #include <qregexp.h> | 62 | #include <qregexp.h> |
89 | #include <qdir.h> | 63 | #include <qdir.h> |
90 | #include <qtextbrowser.h> | 64 | #include <qtextbrowser.h> |
91 | #include <qlabel.h> | 65 | #include <qlabel.h> |
92 | #include <qcombobox.h> | 66 | #include <qcombobox.h> |
93 | 67 | ||
94 | #include "krc2.h" | 68 | #include "krc2.h" |
95 | 69 | ||
96 | #include "wait.h" | 70 | #include "wait.h" |
97 | 71 | ||
98 | extern int DeskW, DeskH; | 72 | int DeskW, DeskH; |
99 | #ifdef DESKTOP | 73 | QApplication *appl; |
100 | extern QApplication *appl; | 74 | ZSafe *zs; |
101 | #else | ||
102 | extern QPEApplication *appl; | ||
103 | #endif | ||
104 | |||
105 | #ifdef JPATCH_HDE | ||
106 | #define tr(arg) arg | ||
107 | #endif | ||
108 | |||
109 | 75 | ||
110 | #ifdef DESKTOP | 76 | const QString APP_KEY = ""; |
111 | #ifndef Q_WS_WIN | ||
112 | const QString APP_KEY="/.zsafe/"; | ||
113 | #else | ||
114 | const QString APP_KEY=""; | ||
115 | #endif | ||
116 | #else | ||
117 | const QString APP_KEY=""; | ||
118 | #endif | ||
119 | 77 | ||
120 | // include xmp images | 78 | // include xmp images |
121 | #include "pics/zsafe/copy.xpm" | 79 | #include "pics/zsafe/copy.xpm" |
122 | #include "pics/zsafe/cut.xpm" | 80 | #include "pics/zsafe/cut.xpm" |
123 | #include "pics/zsafe/edit.xpm" | 81 | #include "pics/zsafe/edit.xpm" |
124 | #include "pics/zsafe/editdelete.xpm" | 82 | #include "pics/zsafe/editdelete.xpm" |
125 | #include "pics/zsafe/find.xpm" | 83 | #include "pics/zsafe/find.xpm" |
126 | #include "pics/zsafe/folder_open.xpm" | 84 | #include "pics/zsafe/folder_open.xpm" |
127 | #include "pics/zsafe/help_icon.xpm" | 85 | #include "pics/zsafe/help_icon.xpm" |
128 | #include "pics/zsafe/new.xpm" | 86 | #include "pics/zsafe/new.xpm" |
129 | #include "pics/zsafe/paste.xpm" | 87 | #include "pics/zsafe/paste.xpm" |
130 | #include "pics/zsafe/quit_icon.xpm" | 88 | #include "pics/zsafe/quit_icon.xpm" |
131 | #include "pics/zsafe/save.xpm" | 89 | #include "pics/zsafe/save.xpm" |
132 | #include "pics/zsafe/trash.xpm" | 90 | #include "pics/zsafe/trash.xpm" |
133 | #include "pics/zsafe/expand.xpm" | 91 | #include "pics/zsafe/expand.xpm" |
134 | #include "pics/zsafe/export.xpm" | 92 | #include "pics/zsafe/export.xpm" |
135 | #include "pics/zsafe/import.xpm" | 93 | #include "pics/zsafe/import.xpm" |
136 | #include "pics/zsafe/zsafe.xpm" | 94 | #include "pics/zsafe/zsafe.xpm" |
137 | 95 | ||
138 | static const char* const bank_cards_data[] = { | 96 | static const char* const bank_cards_data[] = { |
139 | "14 14 16 1", | 97 | "14 14 16 1", |
140 | ". c None", | 98 | ". c None", |
141 | "# c #000000", | 99 | "# c #000000", |
142 | "b c #0000de", | 100 | "b c #0000de", |
143 | "a c #0000e6", | 101 | "a c #0000e6", |
144 | "j c #41de83", | 102 | "j c #41de83", |
145 | "k c #4acecd", | 103 | "k c #4acecd", |
146 | "h c #4aced5", | 104 | "h c #4aced5", |
147 | "g c #5a40cd", | 105 | "g c #5a40cd", |
148 | "d c #5a44d5", | 106 | "d c #5a44d5", |
149 | "l c #9440d5", | 107 | "l c #9440d5", |
150 | "m c #b4ce4a", | 108 | "m c #b4ce4a", |
@@ -335,283 +293,201 @@ static const char* const general_data[] = { | |||
335 | "QtQtQtQtQtQtQtQtQtQtQtQtQtQt", | 293 | "QtQtQtQtQtQtQtQtQtQtQtQtQtQt", |
336 | "QtQtQt.#.a.b.cQtQtQtQtQtQtQt", | 294 | "QtQtQt.#.a.b.cQtQtQtQtQtQtQt", |
337 | "QtQt.d.e.f.g.h.i.c.j.dQt.kQt", | 295 | "QtQt.d.e.f.g.h.i.c.j.dQt.kQt", |
338 | ".a.l.m.n.o.p.q.r.s.t.u.v.wQt", | 296 | ".a.l.m.n.o.p.q.r.s.t.u.v.wQt", |
339 | ".x.y.z.A.B.C.D.p.q.E.F.G.H.I", | 297 | ".x.y.z.A.B.C.D.p.q.E.F.G.H.I", |
340 | ".I.J.K.L.M.N.O.P.o.p.Q.R.S.T", | 298 | ".I.J.K.L.M.N.O.P.o.p.Q.R.S.T", |
341 | "Qt.U.V.L.W.X.Y.Z.0.P.1.s.2.3", | 299 | "Qt.U.V.L.W.X.Y.Z.0.P.1.s.2.3", |
342 | "Qt.3.X.W.4.X.5.6.7.8.9.s#.##", | 300 | "Qt.3.X.W.4.X.5.6.7.8.9.s#.##", |
343 | "QtQt#a.X#b#c.5.6#d#e#f#g#h#i", | 301 | "QtQt#a.X#b#c.5.6#d#e#f#g#h#i", |
344 | "QtQtQt#j.7#k.6#d#l#m#n#o#p#q", | 302 | "QtQtQt#j.7#k.6#d#l#m#n#o#p#q", |
345 | "QtQtQtQt.k#r#s#m#t.H#u#v#w#x", | 303 | "QtQtQtQt.k#r#s#m#t.H#u#v#w#x", |
346 | "QtQtQtQtQtQt.k#y#z.v#A#B#C#x", | 304 | "QtQtQtQtQtQt.k#y#z.v#A#B#C#x", |
347 | "QtQtQtQtQtQtQtQt.k#D.w#s#E.k", | 305 | "QtQtQtQtQtQtQtQt.k#D.w#s#E.k", |
348 | "QtQtQtQtQtQtQtQtQtQtQt#x#FQt"}; | 306 | "QtQtQtQtQtQtQtQtQtQtQt#x#FQt"}; |
349 | 307 | ||
350 | // exit ZSafe and clear the clipboard for security reasons | 308 | // exit ZSafe and clear the clipboard for security reasons |
351 | void ZSafe::exitZs (int ec) | 309 | void ZSafe::exitZs (int ec) |
352 | { | 310 | { |
353 | QClipboard *cb = QApplication::clipboard(); | 311 | QClipboard *cb = QApplication::clipboard(); |
354 | cb->clear(); | 312 | cb->clear(); |
355 | 313 | ||
356 | exit (ec); | 314 | exit (ec); |
357 | } | 315 | } |
358 | 316 | ||
359 | 317 | ||
360 | // save the configuration into the file | 318 | // save the configuration into the file |
361 | void ZSafe::saveConf () | 319 | void ZSafe::saveConf () |
362 | { | 320 | { |
363 | if (conf) | 321 | if (conf) |
364 | { | 322 | { |
365 | delete conf; | 323 | delete conf; |
366 | 324 | ||
367 | #ifdef DESKTOP | 325 | conf = new Config ("zsafe"); |
368 | #ifndef Q_WS_WIN | 326 | conf->setGroup ("zsafe"); |
369 | conf = new QSettings(); | ||
370 | conf->insertSearchPath (QSettings::Unix, QDir::homeDirPath()); | ||
371 | #else | ||
372 | conf = new QSettings (cfgFile); | ||
373 | conf->insertSearchPath (QSettings::Unix, cfgFile); | ||
374 | #endif | ||
375 | #else | ||
376 | conf = new Config (cfgFile, Config::File); | ||
377 | conf->setGroup ("zsafePrefs"); | ||
378 | #endif | ||
379 | } | 327 | } |
380 | } | 328 | } |
381 | 329 | ||
382 | 330 | ||
383 | /* | 331 | /* |
384 | * Constructs a ZSafe which is a child of 'parent', with the | 332 | * Constructs a ZSafe which is a child of 'parent', with the |
385 | * name 'name' and widget flags set to 'f' | 333 | * name 'name' and widget flags set to 'f' |
386 | * | 334 | * |
387 | * The dialog will by default be modeless, unless you set 'modal' to | 335 | * The dialog will by default be modeless, unless you set 'modal' to |
388 | * TRUE to construct a modal dialog. | 336 | * TRUE to construct a modal dialog. |
389 | */ | 337 | */ |
390 | ZSafe::ZSafe( QWidget* parent, const char* name, bool modal, WFlags fl ) | 338 | ZSafe::ZSafe( QWidget* parent, const char* name, WFlags fl ) |
391 | : QDialog( parent, name, modal, fl ), | 339 | : QWidget( parent, name, fl), |
392 | Edit(0l), Delete(0l), Find(0l), New(0l), ListView(0l) | 340 | Edit(0l), Delete(0l), Find(0l), New(0l), ListView(0l) |
393 | { | 341 | { |
342 | zs = this; | ||
343 | appl = qApp; | ||
344 | DeskW = qApp->desktop()->width(); | ||
345 | DeskH = qApp->desktop()->height(); | ||
346 | |||
394 | IsCut = false; | 347 | IsCut = false; |
395 | IsCopy = false; | 348 | IsCopy = false; |
396 | modified = false; | 349 | modified = false; |
397 | showpwd = false; | 350 | showpwd = false; |
398 | 351 | ||
399 | // set the config file | 352 | // set the config file |
400 | cfgFile=QDir::homeDirPath(); | 353 | cfgFile=QDir::homeDirPath(); |
401 | cfgFile += "/.zsafe.cfg"; | 354 | cfgFile += "/.zsafe.cfg"; |
402 | // set the icon path | 355 | // set the icon path |
403 | #ifdef NO_OPIE | ||
404 | QString qpedir ((const char *)getenv("QPEDIR")); | ||
405 | #else | ||
406 | QString qpedir ((const char *)getenv("OPIEDIR")); | ||
407 | #endif | ||
408 | 356 | ||
409 | #ifdef DESKTOP | 357 | QString qpeDir = QPEApplication::qpeDir(); |
410 | iconPath = QDir::homeDirPath() + "/pics/"; | ||
411 | #else | ||
412 | if (qpedir.isEmpty()) | ||
413 | iconPath = "/home/QtPalmtop/pics/"; | ||
414 | else | ||
415 | iconPath = qpedir + "/pics/"; | ||
416 | #endif | ||
417 | 358 | ||
418 | // create a zsafe configuration object | 359 | conf = new Config ("zsafe"); |
419 | #ifdef DESKTOP | ||
420 | #ifndef Q_WS_WIN | ||
421 | conf = new QSettings (); | ||
422 | conf->insertSearchPath (QSettings::Unix, QDir::homeDirPath()); | ||
423 | #else | ||
424 | conf = new QSettings (cfgFile); | ||
425 | conf->insertSearchPath (QSettings::Unix, cfgFile); | ||
426 | #endif | ||
427 | #else | ||
428 | conf = new Config (cfgFile, Config::File); | ||
429 | conf->setGroup ("zsafePrefs"); | 360 | conf->setGroup ("zsafePrefs"); |
430 | #endif | 361 | |
431 | #ifdef DESKTOP | ||
432 | // #ifndef Q_WS_WIN | ||
433 | expandTree = conf->readBoolEntry(APP_KEY+"expandTree", false); | ||
434 | // #endif | ||
435 | #else | ||
436 | expandTree = conf->readNumEntry(APP_KEY+"expandTree", 0); | 362 | expandTree = conf->readNumEntry(APP_KEY+"expandTree", 0); |
437 | #endif | ||
438 | #ifndef DESKTOP | ||
439 | conf->setGroup ("zsafe"); | 363 | conf->setGroup ("zsafe"); |
440 | #endif | ||
441 | 364 | ||
442 | QPixmap copy_img((const char**) copy_xpm); | 365 | QPixmap copy_img((const char**) copy_xpm); |
443 | QPixmap cut_img((const char**) cut_xpm); | 366 | QPixmap cut_img((const char**) cut_xpm); |
444 | QPixmap edit_img((const char**) edit_xpm); | 367 | QPixmap edit_img((const char**) edit_xpm); |
445 | QPixmap editdelete_img((const char**) editdelete_xpm); | 368 | QPixmap editdelete_img((const char**) editdelete_xpm); |
446 | QPixmap find_img((const char**) find_xpm); | 369 | QPixmap find_img((const char**) find_xpm); |
447 | QPixmap folder_open_img((const char**) folder_open_xpm); | 370 | QPixmap folder_open_img((const char**) folder_open_xpm); |
448 | QPixmap help_icon_img((const char**) help_icon_xpm); | 371 | QPixmap help_icon_img((const char**) help_icon_xpm); |
449 | QPixmap new_img((const char**) new_xpm); | 372 | QPixmap new_img((const char**) new_xpm); |
450 | QPixmap paste_img((const char**) paste_xpm); | 373 | QPixmap paste_img((const char**) paste_xpm); |
451 | QPixmap quit_icon_img((const char**) quit_icon_xpm); | 374 | QPixmap quit_icon_img((const char**) quit_icon_xpm); |
452 | QPixmap save_img((const char**) save_xpm); | 375 | QPixmap save_img((const char**) save_xpm); |
453 | QPixmap trash_img((const char**) trash_xpm); | 376 | QPixmap trash_img((const char**) trash_xpm); |
454 | QPixmap expand_img((const char**) expand_xpm); | 377 | QPixmap expand_img((const char**) expand_xpm); |
455 | QPixmap export_img((const char**) export_xpm); | 378 | QPixmap export_img((const char**) export_xpm); |
456 | QPixmap import_img((const char**) import_xpm); | 379 | QPixmap import_img((const char**) import_xpm); |
457 | 380 | ||
458 | QPixmap bank_cards( ( const char** ) bank_cards_data ); | 381 | QPixmap bank_cards( ( const char** ) bank_cards_data ); |
459 | QPixmap passwords( ( const char** ) passwords_data ); | 382 | QPixmap passwords( ( const char** ) passwords_data ); |
460 | QPixmap software( ( const char** ) software_data ); | 383 | QPixmap software( ( const char** ) software_data ); |
461 | QPixmap general( ( const char** ) general_data ); | 384 | QPixmap general( ( const char** ) general_data ); |
462 | QPixmap image0( ( const char** ) zsafe_xpm ); | 385 | QPixmap image0( ( const char** ) zsafe_xpm ); |
463 | if ( !name ) | ||
464 | setName( "ZSafe" ); | ||
465 | |||
466 | #ifdef DESKTOP | ||
467 | #ifdef Q_WS_WIN | ||
468 | setGeometry(100, 150, DeskW, DeskH-30 ); | ||
469 | #else | ||
470 | resize( DeskW, DeskH-30 ); | ||
471 | #endif | ||
472 | |||
473 | #else | ||
474 | 386 | ||
475 | #ifdef JPATCH_HDE | 387 | if ( !name ) |
476 | int DeskS; | 388 | setName( "ZSafe" ); |
477 | if(DeskW > DeskH) | ||
478 | { | ||
479 | DeskS = DeskW; | ||
480 | } | ||
481 | else | ||
482 | { | ||
483 | DeskS = DeskH; | ||
484 | } | ||
485 | resize( DeskW, DeskH ); | ||
486 | setMinimumSize( QSize( DeskS, DeskS ) ); | ||
487 | setMaximumSize( QSize( DeskS, DeskS ) ); | ||
488 | #else | ||
489 | resize( DeskW, DeskH-30 ); | ||
490 | #endif | ||
491 | 389 | ||
492 | #endif | ||
493 | setCaption( tr( "ZSafe" ) ); | 390 | setCaption( tr( "ZSafe" ) ); |
494 | QString zsafeAppDirPath = QDir::homeDirPath() + "/Documents/application/zsafe"; | 391 | QString zsafeAppDirPath = QDir::homeDirPath() + "/Documents/application/zsafe"; |
392 | |||
495 | filename = conf->readEntry(APP_KEY+"document"); | 393 | filename = conf->readEntry(APP_KEY+"document"); |
496 | if ( !QFileInfo(filename).exists() || !QDir(zsafeAppDirPath).exists() ) | 394 | if ( !QFileInfo(filename).exists() || !QDir(zsafeAppDirPath).exists() ) |
497 | { | 395 | { |
498 | // check if the directory application exists, if not | 396 | // check if the directory application exists, if not |
499 | // create it | 397 | // create it |
500 | // #ifndef Q_WS_WIN | ||
501 | // QString d1("Documents/application"); | ||
502 | // #else | ||
503 | QString d1(QDir::homeDirPath() + "/Documents/application"); | 398 | QString d1(QDir::homeDirPath() + "/Documents/application"); |
504 | // #endif | ||
505 | QDir pd1(d1); | 399 | QDir pd1(d1); |
506 | if (!pd1.exists()) | 400 | if (!pd1.exists()) |
507 | { | 401 | { |
508 | QDir pd2(QDir::homeDirPath() + "/Documents"); | 402 | QDir pd2(QDir::homeDirPath() + "/Documents"); |
509 | if (!pd2.exists()) { | 403 | if (!pd2.exists()) { |
510 | QDir pd3(QDir::homeDirPath()); | 404 | QDir pd3(QDir::homeDirPath()); |
511 | if (!pd3.mkdir("Documents", FALSE)) { | 405 | if (!pd3.mkdir("Documents", FALSE)) { |
512 | } | 406 | } |
513 | } | 407 | } |
514 | 408 | ||
515 | if (!pd2.mkdir("application", FALSE)) | 409 | if (!pd2.mkdir("application", FALSE)) |
516 | { | 410 | { |
517 | QMessageBox::critical( 0, tr("ZSafe"), | 411 | QMessageBox::critical( 0, tr("ZSafe"), |
518 | #ifdef JPATCH_HDE | ||
519 | tr("<P>Can't create directory ..."+d1+"</P><P>ZSafe will now exit.</P>")); | ||
520 | #else | ||
521 | tr("<P>Can't create directory %1</P><P>ZSafe will now exit.</P>").arg(d1)); | 412 | tr("<P>Can't create directory %1</P><P>ZSafe will now exit.</P>").arg(d1)); |
522 | #endif | ||
523 | exitZs (1); | 413 | exitZs (1); |
524 | } | 414 | } |
525 | } | 415 | } |
526 | // #ifndef Q_WS_WIN | ||
527 | // QString d2("Documents/application/zsafe"); | ||
528 | // #else | ||
529 | QString d2(QDir::homeDirPath() + "/Documents/application/zsafe"); | 416 | QString d2(QDir::homeDirPath() + "/Documents/application/zsafe"); |
530 | // #endif | ||
531 | QDir pd2(d2); | 417 | QDir pd2(d2); |
532 | if (!pd2.exists()) | 418 | if (!pd2.exists()) |
533 | { | 419 | { |
534 | if (!pd1.mkdir("zsafe", FALSE)) | 420 | if (!pd1.mkdir("zsafe", FALSE)) |
535 | { | 421 | { |
536 | QMessageBox::critical( 0, tr("ZSafe"), | 422 | QMessageBox::critical( 0, tr("ZSafe"), |
537 | #ifdef JPATCH_HDE | ||
538 | tr("<P>Can't create directory ...//Documents/application/zsafe</P><P>ZSafe will now exit.</P")); | ||
539 | #else | ||
540 | tr("<P>Can't create directory %1</P><P>ZSafe will now exit.</P>").arg(d2)); | 423 | tr("<P>Can't create directory %1</P><P>ZSafe will now exit.</P>").arg(d2)); |
541 | #endif | ||
542 | exitZs (1); | 424 | exitZs (1); |
543 | } | 425 | } |
544 | } | 426 | } |
545 | 427 | ||
546 | filename = zsafeAppDirPath + "/passwords.zsf"; | 428 | filename = zsafeAppDirPath + "/passwords.zsf"; |
547 | 429 | ||
548 | // save the current filename to the config file | 430 | // save the current filename to the config file |
549 | conf->writeEntry(APP_KEY+"document", filename); | 431 | conf->writeEntry(APP_KEY+"document", filename); |
550 | saveConf(); | 432 | saveConf(); |
551 | } | 433 | } |
552 | //if (filename == "INVALIDPWD") | 434 | //if (filename == "INVALIDPWD") |
553 | //filename = ""; | 435 | //filename = ""; |
554 | 436 | ||
555 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); | 437 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); |
556 | #ifdef Q_WS_WIN | 438 | this->setCaption(tr("ZSafe: ") + ti); |
557 | this->setCaption("Qt ZSafe: " + ti); | ||
558 | #else | ||
559 | this->setCaption("ZSafe: " + ti); | ||
560 | #endif | ||
561 | 439 | ||
562 | selectedItem = NULL; | 440 | selectedItem = NULL; |
563 | lastSearchedCategory = NULL; | 441 | lastSearchedCategory = NULL; |
564 | lastSearchedItem = NULL; | 442 | lastSearchedItem = NULL; |
565 | lastSearchedName = ""; | 443 | lastSearchedName = ""; |
566 | lastSearchedUsername = ""; | 444 | lastSearchedUsername = ""; |
567 | lastSearchedComment = ""; | 445 | lastSearchedComment = ""; |
568 | 446 | ||
569 | infoForm = new InfoForm(this, "show_info", TRUE); | 447 | infoForm = new InfoForm(this, "show_info", TRUE); |
570 | categoryDialog = NULL; | 448 | categoryDialog = NULL; |
571 | infoForm->setIcon( image0); | 449 | infoForm->setIcon( image0); |
572 | 450 | ||
573 | // add a menu bar | 451 | // add a menu bar |
574 | QMenuBar *menu = new QMenuBar( this ); | 452 | QMenuBar *menu = new QMenuBar( this ); |
575 | 453 | ||
576 | // add file menu | 454 | // add file menu |
577 | // QPopupMenu *file = new QPopupMenu( this ); | 455 | // QPopupMenu *file = new QPopupMenu( this ); |
578 | file = new QPopupMenu( this ); | 456 | file = new QPopupMenu( this ); |
579 | 457 | ||
580 | // #ifdef DESKTOP | ||
581 | file->insertItem( new_img, tr("&New document"), this, SLOT(newDocument()) ); | 458 | file->insertItem( new_img, tr("&New document"), this, SLOT(newDocument()) ); |
582 | file->insertItem( folder_open_img, tr("&Open document"), this, SLOT(loadDocument()) ); | 459 | file->insertItem( folder_open_img, tr("&Open document"), this, SLOT(loadDocument()) ); |
583 | file->insertItem( save_img, tr("&Save document as .."), this, SLOT(saveDocumentAs()) ); | 460 | file->insertItem( save_img, tr("&Save document as .."), this, SLOT(saveDocumentAs()) ); |
584 | file->insertSeparator(); | 461 | file->insertSeparator(); |
585 | // #endif | ||
586 | 462 | ||
587 | file->insertItem( save_img, tr("&Save document"), this, SLOT(saveDocumentWithoutPwd()) ); | 463 | file->insertItem( save_img, tr("&Save document"), this, SLOT(saveDocumentWithoutPwd()) ); |
588 | file->insertItem( save_img, tr("S&ave document with new Password"), this, | 464 | file->insertItem( save_img, tr("S&ave document with new Password"), this, |
589 | SLOT(saveDocumentWithPwd()) ); | 465 | SLOT(saveDocumentWithPwd()) ); |
590 | file->insertSeparator(); | 466 | file->insertSeparator(); |
591 | file->insertItem( export_img, tr("&Export text file"), this, SLOT(writeAllEntries()) ); | 467 | file->insertItem( export_img, tr("&Export text file"), this, SLOT(writeAllEntries()) ); |
592 | file->insertItem( import_img, tr("&Import text file"), this, SLOT(readAllEntries()) ); | 468 | file->insertItem( import_img, tr("&Import text file"), this, SLOT(readAllEntries()) ); |
593 | file->insertItem( trash_img, tr("&Remove text file"), this, SLOT(removeAsciiFile()) ); | 469 | file->insertItem( trash_img, tr("&Remove text file"), this, SLOT(removeAsciiFile()) ); |
594 | file->insertSeparator(); | 470 | file->insertSeparator(); |
595 | file->insertItem( expand_img, tr("&Open entries expanded"), this, | 471 | file->insertItem( expand_img, tr("&Open entries expanded"), this, |
596 | SLOT(setExpandFlag()), 0, 'o'); | 472 | SLOT(setExpandFlag()), 0, 'o'); |
597 | file->setItemChecked('o', expandTree); | 473 | file->setItemChecked('o', expandTree); |
598 | file->insertSeparator(); | 474 | file->insertSeparator(); |
599 | file->insertItem( quit_icon_img, tr("E&xit"), this, SLOT(quitMe()) ); | 475 | file->insertItem( quit_icon_img, tr("E&xit"), this, SLOT(quitMe()) ); |
600 | menu->insertItem( tr("&File"), file ); | 476 | menu->insertItem( tr("&File"), file ); |
601 | 477 | ||
602 | QPopupMenu *cat = new QPopupMenu( this ); | 478 | QPopupMenu *cat = new QPopupMenu( this ); |
603 | cat->insertItem( new_img, tr("&New"), this, SLOT(addCategory()) ); | 479 | cat->insertItem( new_img, tr("&New"), this, SLOT(addCategory()) ); |
604 | cat->insertItem( edit_img, tr("&Edit"), this, SLOT(editCategory()) ); | 480 | cat->insertItem( edit_img, tr("&Edit"), this, SLOT(editCategory()) ); |
605 | cat->insertItem( trash_img, tr("&Delete"), this, SLOT(delCategory()) ); | 481 | cat->insertItem( trash_img, tr("&Delete"), this, SLOT(delCategory()) ); |
606 | menu->insertItem( tr("&Category"), cat ); | 482 | menu->insertItem( tr("&Category"), cat ); |
607 | 483 | ||
608 | QPopupMenu *it = new QPopupMenu( this ); | 484 | QPopupMenu *it = new QPopupMenu( this ); |
609 | it->insertItem( cut_img, tr("&Cut"), this, SLOT(cutItem()) ); | 485 | it->insertItem( cut_img, tr("&Cut"), this, SLOT(cutItem()) ); |
610 | it->insertItem( copy_img, tr("C&opy"), this, SLOT(copyItem()) ); | 486 | it->insertItem( copy_img, tr("C&opy"), this, SLOT(copyItem()) ); |
611 | it->insertItem( paste_img, tr("&Paste"), this, SLOT(pasteItem()) ); | 487 | it->insertItem( paste_img, tr("&Paste"), this, SLOT(pasteItem()) ); |
612 | it->insertSeparator(); | 488 | it->insertSeparator(); |
613 | it->insertItem( new_img, tr("&New"), this, SLOT(newPwd()) ); | 489 | it->insertItem( new_img, tr("&New"), this, SLOT(newPwd()) ); |
614 | it->insertItem( edit_img, tr("&Edit"), this, SLOT(editPwd()) ); | 490 | it->insertItem( edit_img, tr("&Edit"), this, SLOT(editPwd()) ); |
615 | it->insertItem( trash_img, tr("&Delete"), this, SLOT(deletePwd()) ); | 491 | it->insertItem( trash_img, tr("&Delete"), this, SLOT(deletePwd()) ); |
616 | it->insertItem( find_img, tr("&Search"), this, SLOT(findPwd()) ); | 492 | it->insertItem( find_img, tr("&Search"), this, SLOT(findPwd()) ); |
617 | menu->insertItem( tr("&Entry"), it ); | 493 | menu->insertItem( tr("&Entry"), it ); |
@@ -636,538 +512,439 @@ ZSafe::ZSafe( QWidget* parent, const char* name, bool modal, WFlags fl ) | |||
636 | QToolTip::add( Edit, tr( "Edit category or entry" ) ); | 512 | QToolTip::add( Edit, tr( "Edit category or entry" ) ); |
637 | 513 | ||
638 | Delete = new QToolButton( menu, "Delete" ); | 514 | Delete = new QToolButton( menu, "Delete" ); |
639 | Delete->setGeometry( QRect( DeskW-44, 2, 20, 20 ) ); | 515 | Delete->setGeometry( QRect( DeskW-44, 2, 20, 20 ) ); |
640 | Delete->setText( "" ); | 516 | Delete->setText( "" ); |
641 | Delete->setPixmap( trash_img ); | 517 | Delete->setPixmap( trash_img ); |
642 | QToolTip::add( Delete, tr( "Delete category or entry" ) ); | 518 | QToolTip::add( Delete, tr( "Delete category or entry" ) ); |
643 | 519 | ||
644 | Find = new QToolButton( menu, "Find" ); | 520 | Find = new QToolButton( menu, "Find" ); |
645 | Find->setGeometry( QRect( DeskW-24, 2, 20, 20 ) ); | 521 | Find->setGeometry( QRect( DeskW-24, 2, 20, 20 ) ); |
646 | Find->setText( "" ); | 522 | Find->setText( "" ); |
647 | Find->setPixmap( find_img ); | 523 | Find->setPixmap( find_img ); |
648 | QToolTip::add( Find, tr( "Find entry" ) ); | 524 | QToolTip::add( Find, tr( "Find entry" ) ); |
649 | 525 | ||
650 | /* | 526 | /* |
651 | QBoxLayout * h = new QHBoxLayout( this ); | 527 | QBoxLayout * h = new QHBoxLayout( this ); |
652 | h->addWidget (menu); | 528 | h->addWidget (menu); |
653 | h->addWidget (New); | 529 | h->addWidget (New); |
654 | h->addWidget (Edit); | 530 | h->addWidget (Edit); |
655 | h->addWidget (Delete); | 531 | h->addWidget (Delete); |
656 | h->addWidget (Find); | 532 | h->addWidget (Find); |
657 | */ | 533 | */ |
658 | 534 | ||
659 | ListView = new ZListView( this, "ListView" ); | 535 | ListView = new ZListView( this, "ListView" ); |
660 | ListView->addColumn( tr( "Name" ) ); | 536 | ListView->addColumn( tr( "Name" ) ); |
661 | ListView->addColumn( tr( "Field 2" ) ); | 537 | ListView->addColumn( tr( "Field 2" ) ); |
662 | ListView->addColumn( tr( "Field 3" ) ); | 538 | ListView->addColumn( tr( "Field 3" ) ); |
663 | ListView->addColumn( tr( "Comment" ) ); | 539 | ListView->addColumn( tr( "Comment" ) ); |
664 | ListView->addColumn( tr( "Field 4" ) ); | 540 | ListView->addColumn( tr( "Field 4" ) ); |
665 | ListView->addColumn( tr( "Field 5" ) ); | 541 | ListView->addColumn( tr( "Field 5" ) ); |
666 | ListView->setAllColumnsShowFocus(TRUE); | 542 | ListView->setAllColumnsShowFocus(TRUE); |
667 | 543 | ||
668 | #ifdef DESKTOP | ||
669 | // ListView->setResizePolicy(QScrollView::AutoOneFit); | ||
670 | // ListView->setGeometry( QRect( 0, 22, this->width(), this->height() - 30 ) ); | ||
671 | #else | ||
672 | ListView->setResizePolicy(QScrollView::AutoOneFit); | 544 | ListView->setResizePolicy(QScrollView::AutoOneFit); |
673 | // ListView->setGeometry( QRect( 0, 22, | 545 | // ListView->setGeometry( QRect( 0, 22, |
674 | // this->width(), this->height() - 30 ) ); | 546 | // this->width(), this->height() - 30 ) ); |
675 | // ListView->setMaximumSize( QSize( 440, 290 ) ); | 547 | // ListView->setMaximumSize( QSize( 440, 290 ) ); |
676 | #endif | ||
677 | // ListView->setVScrollBarMode( QListView::Auto ); | 548 | // ListView->setVScrollBarMode( QListView::Auto ); |
678 | 549 | ||
679 | QBoxLayout * l = new QVBoxLayout( this ); | 550 | QBoxLayout * l = new QVBoxLayout( this ); |
680 | l->addWidget (menu); | 551 | l->addWidget (menu); |
681 | l->addWidget (ListView); | 552 | l->addWidget (ListView); |
682 | 553 | ||
683 | #ifndef DESKTOP | ||
684 | // start a timer (100 ms) to load the default document | 554 | // start a timer (100 ms) to load the default document |
685 | docuTimer.start( 100, true ); | 555 | docuTimer.start( 100, true ); |
686 | connect( &docuTimer, SIGNAL(timeout()), SLOT( slotLoadDocu() ) ); | 556 | connect( &docuTimer, SIGNAL(timeout()), SLOT( slotLoadDocu() ) ); |
687 | raiseFlag = true; | 557 | raiseFlag = true; |
688 | connect( &raiseTimer, SIGNAL(timeout()), SLOT( slotRaiseTimer() ) ); | 558 | connect( &raiseTimer, SIGNAL(timeout()), SLOT( slotRaiseTimer() ) ); |
689 | #else | ||
690 | // open the default document | ||
691 | openDocument(filename); | ||
692 | #endif | ||
693 | 559 | ||
694 | // signals and slots connections for QTollButton | 560 | // signals and slots connections for QTollButton |
695 | connect( New, SIGNAL( clicked() ), this, SLOT( newPwd() ) ); | 561 | connect( New, SIGNAL( clicked() ), this, SLOT( newPwd() ) ); |
696 | connect( Edit, SIGNAL( clicked() ), this, SLOT( editPwd() ) ); | 562 | connect( Edit, SIGNAL( clicked() ), this, SLOT( editPwd() ) ); |
697 | connect( Delete, SIGNAL( clicked() ), this, SLOT( deletePwd() ) ); | 563 | connect( Delete, SIGNAL( clicked() ), this, SLOT( deletePwd() ) ); |
698 | connect( Find, SIGNAL( clicked() ), this, SLOT( findPwd() ) ); | 564 | connect( Find, SIGNAL( clicked() ), this, SLOT( findPwd() ) ); |
699 | // signals and slots connections for QListView | 565 | // signals and slots connections for QListView |
700 | connect( ListView, SIGNAL( selectionChanged(QListViewItem*) ), | 566 | connect( ListView, SIGNAL( selectionChanged(QListViewItem*) ), |
701 | this, SLOT( listViewSelected(QListViewItem*) ) ); | 567 | this, SLOT( listViewSelected(QListViewItem*) ) ); |
702 | connect( ListView, SIGNAL( doubleClicked(QListViewItem*) ), | 568 | connect( ListView, SIGNAL( doubleClicked(QListViewItem*) ), |
703 | this, SLOT( showInfo(QListViewItem*) ) ); | 569 | this, SLOT( showInfo(QListViewItem*) ) ); |
704 | connect( ListView, SIGNAL( returnPressed(QListViewItem*) ), | 570 | connect( ListView, SIGNAL( returnPressed(QListViewItem*) ), |
705 | this, SLOT( showInfo(QListViewItem*) ) ); | 571 | this, SLOT( showInfo(QListViewItem*) ) ); |
706 | 572 | ||
707 | #ifndef DESKTOP | 573 | QPEApplication::setStylusOperation( ListView->viewport(),QPEApplication::RightOnHold); |
708 | QPEApplication::setStylusOperation( ListView->viewport(),QPEApplication::RightOnHold); | ||
709 | #endif | ||
710 | connect( ListView, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)), | 574 | connect( ListView, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)), |
711 | this,SLOT( ListPressed(int, QListViewItem *, const QPoint&, int)) ); | 575 | this,SLOT( ListPressed(int, QListViewItem *, const QPoint&, int)) ); |
712 | 576 | ||
713 | this->setIcon( image0); | 577 | this->setIcon( image0); |
714 | #ifdef Q_WS_WIN | ||
715 | ListView->setSelected( ListView->firstChild() , true); | ||
716 | ListView->setSelected( ListView->firstChild() , false); | ||
717 | #endif | ||
718 | } | 578 | } |
719 | 579 | ||
720 | const QColor *ZSafe::evenRowColor = &Qt::white; | 580 | const QColor *ZSafe::evenRowColor = &Qt::white; |
721 | // const QColor *ZSafe::oddRowColor = &Qt::lightGray; | 581 | // const QColor *ZSafe::oddRowColor = &Qt::lightGray; |
722 | const QColor *ZSafe::oddRowColor = new QColor(216,240,255); | 582 | const QColor *ZSafe::oddRowColor = new QColor(216,240,255); |
723 | 583 | ||
724 | /* | 584 | /* |
725 | * Destroys the object and frees any allocated resources | 585 | * Destroys the object and frees any allocated resources |
726 | */ | 586 | */ |
727 | ZSafe::~ZSafe() | 587 | ZSafe::~ZSafe() |
728 | { | 588 | { |
729 | // no need to delete child widgets, Qt does it all for us | 589 | // no need to delete child widgets, Qt does it all for us |
730 | quitMe(); | 590 | quitMe(); |
731 | } | 591 | } |
732 | 592 | ||
733 | // load the default document | 593 | // load the default document |
734 | void ZSafe::slotLoadDocu() | 594 | void ZSafe::slotLoadDocu() |
735 | { | 595 | { |
736 | openDocument (filename); | 596 | openDocument (filename); |
737 | } | 597 | } |
738 | 598 | ||
739 | void ZSafe::deletePwd() | 599 | void ZSafe::deletePwd() |
740 | { | 600 | { |
741 | 601 | ||
742 | if (!selectedItem) | 602 | if (!selectedItem) |
743 | return; | 603 | return; |
744 | if (!isCategory(selectedItem)) | 604 | if (!isCategory(selectedItem)) |
745 | { | 605 | { |
746 | switch( QMessageBox::information( this, tr("ZSafe"), | 606 | switch( QMessageBox::information( this, tr("ZSafe"), |
747 | tr("Do you want to delete?"), | 607 | tr("Do you want to delete?"), |
748 | tr("&Delete"), tr("D&on't Delete"), | 608 | tr("&Delete"), tr("D&on't Delete"), |
749 | 0 // Enter == button 0 | 609 | 0 // Enter == button 0 |
750 | ) ) { // Escape == button 2 | 610 | ) ) { // Escape == button 2 |
751 | case 0: // Delete clicked, Alt-S or Enter pressed. | 611 | case 0: // Delete clicked, Alt-S or Enter pressed. |
752 | // Delete | 612 | // Delete |
753 | modified = true; | 613 | modified = true; |
754 | selectedItem->parent()->takeItem(selectedItem); | 614 | selectedItem->parent()->takeItem(selectedItem); |
755 | selectedItem = NULL; | 615 | selectedItem = NULL; |
756 | break; | 616 | break; |
757 | case 1: // Don't delete | 617 | case 1: // Don't delete |
758 | break; | 618 | break; |
759 | } | 619 | } |
760 | } | 620 | } |
761 | else | 621 | else |
762 | { | 622 | { |
763 | delCategory(); | 623 | delCategory(); |
764 | } | 624 | } |
765 | } | 625 | } |
766 | 626 | ||
767 | void ZSafe::editPwd() | 627 | void ZSafe::editPwd() |
768 | { | 628 | { |
769 | if (!selectedItem) | 629 | if (!selectedItem) |
770 | return; | 630 | return; |
771 | if (!isCategory(selectedItem)) | 631 | if (!isCategory(selectedItem)) |
772 | { | 632 | { |
773 | // open the 'New Entry' dialog | 633 | // open the 'New Entry' dialog |
774 | NewDialog *dialog = new NewDialog(this, "edit_entry", TRUE); | 634 | NewDialog *dialog = new NewDialog(this, "edit_entry", TRUE); |
775 | #ifdef Q_WS_WIN | ||
776 | dialog->setCaption ("Qt " + tr("Edit Entry")); | ||
777 | dialog->setGeometry(200, 250, 220, 310 ); | ||
778 | #endif | ||
779 | 635 | ||
780 | // set the labels | 636 | // set the labels |
781 | dialog->Name->setText(getFieldLabel (selectedItem, "1", tr("Name"))); | 637 | dialog->Name->setText(getFieldLabel (selectedItem, "1", tr("Name"))); |
782 | dialog->Username->setText(getFieldLabel (selectedItem, "2", tr("Username"))); | 638 | dialog->Username->setText(getFieldLabel (selectedItem, "2", tr("Username"))); |
783 | dialog->Password->setText(getFieldLabel (selectedItem, "3", tr("Password"))); | 639 | dialog->Password->setText(getFieldLabel (selectedItem, "3", tr("Password"))); |
784 | dialog->Comment->setText(getFieldLabel (selectedItem, "4", tr("Comment"))); | 640 | dialog->Comment->setText(getFieldLabel (selectedItem, "4", tr("Comment"))); |
785 | dialog->Field5Label->setText(getFieldLabel (selectedItem,"5", tr("Field 4"))); | 641 | dialog->Field5Label->setText(getFieldLabel (selectedItem,"5", tr("Field 4"))); |
786 | dialog->Field6Label->setText(getFieldLabel (selectedItem,"6", tr("Field 5"))); | 642 | dialog->Field6Label->setText(getFieldLabel (selectedItem,"6", tr("Field 5"))); |
787 | 643 | ||
788 | // set the fields | 644 | // set the fields |
789 | dialog->NameField->setText(selectedItem->text (0)); | 645 | dialog->NameField->setText(selectedItem->text (0)); |
790 | dialog->UsernameField->setText(selectedItem->text (1)); | 646 | dialog->UsernameField->setText(selectedItem->text (1)); |
791 | dialog->PasswordField->setText(selectedItem->text (2)); | 647 | dialog->PasswordField->setText(selectedItem->text (2)); |
792 | QString comment = selectedItem->text (3); | 648 | QString comment = selectedItem->text (3); |
793 | comment.replace (QRegExp("<br>"), "\n"); | 649 | comment.replace (QRegExp("<br>"), "\n"); |
794 | dialog->Field5->setText(selectedItem->text (4)); | 650 | dialog->Field5->setText(selectedItem->text (4)); |
795 | dialog->Field6->setText(selectedItem->text (5)); | 651 | dialog->Field6->setText(selectedItem->text (5)); |
796 | dialog->CommentField->insertLine(comment); | 652 | dialog->CommentField->insertLine(comment); |
797 | dialog->CommentField->setCursorPosition(0,0); | 653 | dialog->CommentField->setCursorPosition(0,0); |
798 | 654 | ||
799 | #ifdef Q_WS_QWS | 655 | QDialog::DialogCode result = (QDialog::DialogCode) QPEApplication::execDialog( dialog ); |
800 | DialogCode result = (DialogCode) QPEApplication::execDialog( dialog ); | 656 | if (result == QDialog::Accepted) |
801 | #endif | ||
802 | |||
803 | #ifdef DESKTOP | ||
804 | #ifndef Q_QW_QWIN | ||
805 | dialog->show(); | ||
806 | #endif | ||
807 | #else | ||
808 | dialog->showMaximized(); | ||
809 | #endif | ||
810 | #ifdef DESKTOP | ||
811 | int result = dialog->exec(); | ||
812 | result = QDialog::Accepted; | ||
813 | #endif | ||
814 | if (result == Accepted) | ||
815 | { | 657 | { |
816 | modified = true; | 658 | modified = true; |
817 | // edit the selected item | 659 | // edit the selected item |
818 | QString name = dialog->NameField->text(); | 660 | QString name = dialog->NameField->text(); |
819 | selectedItem->setText (0, tr (name)); | 661 | selectedItem->setText (0, tr (name)); |
820 | QString user = dialog->UsernameField->text(); | 662 | QString user = dialog->UsernameField->text(); |
821 | selectedItem->setText (1, tr (user)); | 663 | selectedItem->setText (1, tr (user)); |
822 | QString pwd = dialog->PasswordField->text(); | 664 | QString pwd = dialog->PasswordField->text(); |
823 | selectedItem->setText (2, tr (pwd)); | 665 | selectedItem->setText (2, tr (pwd)); |
824 | QString comment = dialog->CommentField->text(); | 666 | QString comment = dialog->CommentField->text(); |
825 | comment.replace (QRegExp("\n"), "<br>"); | 667 | comment.replace (QRegExp("\n"), "<br>"); |
826 | selectedItem->setText (3, tr (comment)); | 668 | selectedItem->setText (3, tr (comment)); |
827 | QString f5 = dialog->Field5->text(); | 669 | QString f5 = dialog->Field5->text(); |
828 | selectedItem->setText (4, tr (f5)); | 670 | selectedItem->setText (4, tr (f5)); |
829 | QString f6 = dialog->Field6->text(); | 671 | QString f6 = dialog->Field6->text(); |
830 | selectedItem->setText (5, tr (f6)); | 672 | selectedItem->setText (5, tr (f6)); |
831 | } | 673 | } |
832 | 674 | ||
833 | delete dialog; | 675 | delete dialog; |
834 | } | 676 | } |
835 | else | 677 | else |
836 | { | 678 | { |
837 | editCategory(); | 679 | editCategory(); |
838 | } | 680 | } |
839 | } | 681 | } |
840 | 682 | ||
841 | void ZSafe::newPwd() | 683 | void ZSafe::newPwd() |
842 | { | 684 | { |
843 | if (!selectedItem) | 685 | if (!selectedItem) |
844 | return; | 686 | return; |
845 | qWarning("new item"); | 687 | qWarning("new item"); |
846 | if (!isCategory(selectedItem)) | 688 | if (!isCategory(selectedItem)) |
847 | selectedItem = selectedItem->parent(); | 689 | selectedItem = selectedItem->parent(); |
848 | 690 | ||
849 | if (isCategory(selectedItem)) | 691 | if (isCategory(selectedItem)) |
850 | { | 692 | { |
851 | QString cat = selectedItem->text(0); | 693 | QString cat = selectedItem->text(0); |
852 | qWarning(cat); | 694 | qWarning(cat); |
853 | // open the 'New Entry' dialog | 695 | // open the 'New Entry' dialog |
854 | NewDialog *dialog = new NewDialog(this, "new_entry", TRUE); | 696 | NewDialog *dialog = new NewDialog(this, "new_entry", TRUE); |
855 | #ifdef Q_WS_WIN | ||
856 | dialog->setCaption ("Qt " + tr("New Entry")); | ||
857 | dialog->setGeometry(200, 250, 220, 310 ); | ||
858 | #endif | ||
859 | // set the labels | 697 | // set the labels |
860 | dialog->Name->setText(getFieldLabel (selectedItem, "1", tr("Name"))); | 698 | dialog->Name->setText(getFieldLabel (selectedItem, "1", tr("Name"))); |
861 | dialog->Username->setText(getFieldLabel (selectedItem, "2", tr("Username"))); | 699 | dialog->Username->setText(getFieldLabel (selectedItem, "2", tr("Username"))); |
862 | dialog->Password->setText(getFieldLabel (selectedItem, "3", tr("Password"))); | 700 | dialog->Password->setText(getFieldLabel (selectedItem, "3", tr("Password"))); |
863 | dialog->Comment->setText(getFieldLabel (selectedItem, "4", tr("Comment"))); | 701 | dialog->Comment->setText(getFieldLabel (selectedItem, "4", tr("Comment"))); |
864 | dialog->Field5Label->setText(getFieldLabel (selectedItem,"5", tr("Field 4"))); | 702 | dialog->Field5Label->setText(getFieldLabel (selectedItem,"5", tr("Field 4"))); |
865 | dialog->Field6Label->setText(getFieldLabel (selectedItem,"6", tr("Field 5"))); | 703 | dialog->Field6Label->setText(getFieldLabel (selectedItem,"6", tr("Field 5"))); |
866 | retype: | 704 | retype: |
867 | 705 | ||
868 | #ifdef Q_WS_QWS | 706 | #ifdef Q_WS_QWS |
869 | DialogCode result = (DialogCode) QPEApplication::execDialog( dialog ); | 707 | QDialog::DialogCode result = (QDialog::DialogCode) QPEApplication::execDialog( dialog ); |
870 | #endif | ||
871 | |||
872 | #ifdef DESKTOP | ||
873 | #ifndef Q_QW_QWIN | ||
874 | dialog->show(); | ||
875 | #endif | ||
876 | #else | ||
877 | dialog->showMaximized(); | ||
878 | #endif | ||
879 | #ifdef DESKTOP | ||
880 | int result = dialog->exec(); | ||
881 | result = QDialog::Accepted; | ||
882 | #endif | 708 | #endif |
883 | 709 | if (result == QDialog::Accepted) | |
884 | if (result == Accepted) | ||
885 | { | 710 | { |
886 | 711 | ||
887 | QString name = dialog->NameField->text(); | 712 | QString name = dialog->NameField->text(); |
888 | if (cat == name) | 713 | if (cat == name) |
889 | { | 714 | { |
890 | QMessageBox::critical( 0, tr("ZSafe"), | 715 | QMessageBox::critical( 0, tr("ZSafe"), |
891 | tr("Entry name must be different\nfrom the category name.") ); | 716 | tr("Entry name must be different\nfrom the category name.") ); |
892 | goto retype; // it's not a good programming style :-) | 717 | goto retype; // it's not a good programming style :-) |
893 | } | 718 | } |
894 | 719 | ||
895 | modified = true; | 720 | modified = true; |
896 | // add the new item | 721 | // add the new item |
897 | QListViewItem *i = new ShadedListItem (0, selectedItem); | 722 | QListViewItem *i = new ShadedListItem (0, selectedItem); |
898 | i->setOpen (TRUE); | 723 | i->setOpen (TRUE); |
899 | 724 | ||
900 | i->setText (0, tr (name)); | 725 | i->setText (0, tr (name)); |
901 | QString user = dialog->UsernameField->text(); | 726 | QString user = dialog->UsernameField->text(); |
902 | i->setText (1, tr (user)); | 727 | i->setText (1, tr (user)); |
903 | QString pwd = dialog->PasswordField->text(); | 728 | QString pwd = dialog->PasswordField->text(); |
904 | i->setText (2, tr (pwd)); | 729 | i->setText (2, tr (pwd)); |
905 | QString comment = dialog->CommentField->text(); | 730 | QString comment = dialog->CommentField->text(); |
906 | comment.replace (QRegExp("\n"), "<br>"); | 731 | comment.replace (QRegExp("\n"), "<br>"); |
907 | i->setText (3, tr (comment)); | 732 | i->setText (3, tr (comment)); |
908 | QString f5 = dialog->Field5->text(); | 733 | QString f5 = dialog->Field5->text(); |
909 | i->setText (4, tr (f5)); | 734 | i->setText (4, tr (f5)); |
910 | QString f6 = dialog->Field6->text(); | 735 | QString f6 = dialog->Field6->text(); |
911 | i->setText (5, tr (f6)); | 736 | i->setText (5, tr (f6)); |
912 | } | 737 | } |
913 | 738 | ||
914 | delete dialog; | 739 | delete dialog; |
915 | } | 740 | } |
916 | } | 741 | } |
917 | 742 | ||
918 | void ZSafe::findPwd() | 743 | void ZSafe::findPwd() |
919 | { | 744 | { |
920 | 745 | ||
921 | // open the 'Search' dialog | 746 | // open the 'Search' dialog |
922 | SearchDialog *dialog = new SearchDialog(this, tr("Search"), TRUE); | 747 | SearchDialog *dialog = new SearchDialog(this, tr("Search"), TRUE); |
923 | #ifdef Q_WS_WIN | ||
924 | dialog->setCaption ("Qt " + tr("Search")); | ||
925 | #endif | ||
926 | 748 | ||
927 | #ifdef DESKTOP | ||
928 | #endif | ||
929 | if (lastSearchedName) | 749 | if (lastSearchedName) |
930 | dialog->NameField->setText(lastSearchedName); | 750 | dialog->NameField->setText(lastSearchedName); |
931 | else | 751 | else |
932 | dialog->NameField->setText(""); | 752 | dialog->NameField->setText(""); |
933 | if (lastSearchedUsername) | 753 | if (lastSearchedUsername) |
934 | dialog->UsernameField->setText(lastSearchedUsername); | 754 | dialog->UsernameField->setText(lastSearchedUsername); |
935 | else | 755 | else |
936 | dialog->UsernameField->setText(""); | 756 | dialog->UsernameField->setText(""); |
937 | if (lastSearchedComment) | 757 | if (lastSearchedComment) |
938 | dialog->CommentField->setText(lastSearchedComment); | 758 | dialog->CommentField->setText(lastSearchedComment); |
939 | else | 759 | else |
940 | dialog->CommentField->setText(""); | 760 | dialog->CommentField->setText(""); |
941 | DialogCode result = (DialogCode) dialog->exec(); | 761 | QDialog::DialogCode result = (QDialog::DialogCode) dialog->exec(); |
942 | #ifdef DESKTOP | ||
943 | result = Accepted; | ||
944 | #endif | ||
945 | 762 | ||
946 | QString name; | 763 | QString name; |
947 | QString username; | 764 | QString username; |
948 | QString comment; | 765 | QString comment; |
949 | if (result == Accepted) | 766 | if (result == QDialog::Accepted) |
950 | { | 767 | { |
951 | name = dialog->NameField->text(); | 768 | name = dialog->NameField->text(); |
952 | username = dialog->UsernameField->text(); | 769 | username = dialog->UsernameField->text(); |
953 | comment = dialog->CommentField->text(); | 770 | comment = dialog->CommentField->text(); |
954 | #ifndef NO_OPIE | ||
955 | owarn << name << oendl; | ||
956 | #else | ||
957 | qWarning (name); | ||
958 | #endif | ||
959 | } | 771 | } |
960 | else | 772 | else |
961 | { | 773 | { |
962 | delete dialog; | 774 | delete dialog; |
963 | return; | 775 | return; |
964 | } | 776 | } |
965 | 777 | ||
966 | if (!name.isEmpty() && name != lastSearchedName || | 778 | if (!name.isEmpty() && name != lastSearchedName || |
967 | lastSearchedName.isEmpty() && !name.isEmpty()) | 779 | lastSearchedName.isEmpty() && !name.isEmpty()) |
968 | { | 780 | { |
969 | // set search at the beginning if a new name is given | 781 | // set search at the beginning if a new name is given |
970 | lastSearchedCategory = NULL; | 782 | lastSearchedCategory = NULL; |
971 | lastSearchedItem = NULL; | 783 | lastSearchedItem = NULL; |
972 | } | 784 | } |
973 | lastSearchedName = name; | 785 | lastSearchedName = name; |
974 | if (!username.isEmpty() && username != lastSearchedUsername || | 786 | if (!username.isEmpty() && username != lastSearchedUsername || |
975 | lastSearchedUsername.isEmpty() && !username.isEmpty()) | 787 | lastSearchedUsername.isEmpty() && !username.isEmpty()) |
976 | { | 788 | { |
977 | // set search at the beginning if a new name is given | 789 | // set search at the beginning if a new name is given |
978 | lastSearchedCategory = NULL; | 790 | lastSearchedCategory = NULL; |
979 | lastSearchedItem = NULL; | 791 | lastSearchedItem = NULL; |
980 | } | 792 | } |
981 | lastSearchedUsername = username; | 793 | lastSearchedUsername = username; |
982 | if (!comment.isEmpty() && comment != lastSearchedComment || | 794 | if (!comment.isEmpty() && comment != lastSearchedComment || |
983 | lastSearchedComment.isEmpty() && !comment.isEmpty()) | 795 | lastSearchedComment.isEmpty() && !comment.isEmpty()) |
984 | { | 796 | { |
985 | // set search at the beginning if a new name is given | 797 | // set search at the beginning if a new name is given |
986 | lastSearchedCategory = NULL; | 798 | lastSearchedCategory = NULL; |
987 | lastSearchedItem = NULL; | 799 | lastSearchedItem = NULL; |
988 | } | 800 | } |
989 | lastSearchedComment = comment; | 801 | lastSearchedComment = comment; |
990 | 802 | ||
991 | ListView->clearSelection(); | 803 | ListView->clearSelection(); |
992 | 804 | ||
993 | bool found=FALSE; | 805 | bool found=FALSE; |
994 | // step through all categories | 806 | // step through all categories |
995 | QListViewItem *i; | 807 | QListViewItem *i; |
996 | if (lastSearchedCategory) | 808 | if (lastSearchedCategory) |
997 | i = lastSearchedCategory; | 809 | i = lastSearchedCategory; |
998 | else | 810 | else |
999 | i = ListView->firstChild(); | 811 | i = ListView->firstChild(); |
1000 | for (; | 812 | for (; |
1001 | i != NULL; | 813 | i != NULL; |
1002 | i = i->nextSibling()) | 814 | i = i->nextSibling()) |
1003 | { | 815 | { |
1004 | #ifndef NO_OPIE | ||
1005 | owarn << i->text(0) << oendl; | ||
1006 | #endif | ||
1007 | i->setSelected(FALSE); | 816 | i->setSelected(FALSE); |
1008 | 817 | ||
1009 | // step through all subitems | 818 | // step through all subitems |
1010 | QListViewItem *si; | 819 | QListViewItem *si; |
1011 | if (lastSearchedItem) | 820 | if (lastSearchedItem) |
1012 | si = lastSearchedItem; | 821 | si = lastSearchedItem; |
1013 | else | 822 | else |
1014 | si = i->firstChild(); | 823 | si = i->firstChild(); |
1015 | // for (si = i->firstChild(); | 824 | // for (si = i->firstChild(); |
1016 | for (; | 825 | for (; |
1017 | si != NULL; | 826 | si != NULL; |
1018 | si = si->nextSibling()) | 827 | si = si->nextSibling()) |
1019 | { | 828 | { |
1020 | #ifndef NO_OPIE | ||
1021 | owarn << si->text(0) << oendl; | ||
1022 | #else | ||
1023 | qWarning (si->text(0)); | ||
1024 | #endif | ||
1025 | if (si->isSelected()) | 829 | if (si->isSelected()) |
1026 | si->setSelected(FALSE); | 830 | si->setSelected(FALSE); |
1027 | // ListView->repaintItem(si); | 831 | // ListView->repaintItem(si); |
1028 | 832 | ||
1029 | bool n=TRUE; | 833 | bool n=TRUE; |
1030 | bool u=TRUE; | 834 | bool u=TRUE; |
1031 | bool c=TRUE; | 835 | bool c=TRUE; |
1032 | if (!name.isEmpty()) | 836 | if (!name.isEmpty()) |
1033 | n = (si->text(0)).contains (name, FALSE); | 837 | n = (si->text(0)).contains (name, FALSE); |
1034 | if (!username.isEmpty()) | 838 | if (!username.isEmpty()) |
1035 | u = (si->text(1)).contains (username, FALSE); | 839 | u = (si->text(1)).contains (username, FALSE); |
1036 | if (!comment.isEmpty()) | 840 | if (!comment.isEmpty()) |
1037 | c = (si->text(3)).contains (comment, FALSE); | 841 | c = (si->text(3)).contains (comment, FALSE); |
1038 | 842 | ||
1039 | if ((n && u && c ) && !found) | 843 | if ((n && u && c ) && !found) |
1040 | { | 844 | { |
1041 | #ifndef NO_OPIE | ||
1042 | owarn << "Found" << oendl; | ||
1043 | #else | ||
1044 | qWarning ("Found"); | ||
1045 | #endif | ||
1046 | selectedItem = si; | 845 | selectedItem = si; |
1047 | si->setSelected(TRUE); | 846 | si->setSelected(TRUE); |
1048 | ListView->setCurrentItem(si); | 847 | ListView->setCurrentItem(si); |
1049 | ListView->ensureItemVisible(si); | 848 | ListView->ensureItemVisible(si); |
1050 | ListView->triggerUpdate(); | 849 | ListView->triggerUpdate(); |
1051 | 850 | ||
1052 | lastSearchedCategory = i; | 851 | lastSearchedCategory = i; |
1053 | // set to the next item | 852 | // set to the next item |
1054 | lastSearchedItem = si->nextSibling(); | 853 | lastSearchedItem = si->nextSibling(); |
1055 | if (!lastSearchedItem) | 854 | if (!lastSearchedItem) |
1056 | { | 855 | { |
1057 | // no next item within category -> set next category | 856 | // no next item within category -> set next category |
1058 | lastSearchedCategory = i->nextSibling(); | 857 | lastSearchedCategory = i->nextSibling(); |
1059 | if (!lastSearchedCategory) | 858 | if (!lastSearchedCategory) |
1060 | lastSearchedItem = NULL; // END | 859 | lastSearchedItem = NULL; // END |
1061 | } | 860 | } |
1062 | 861 | ||
1063 | found = TRUE; | 862 | found = TRUE; |
1064 | delete dialog; | 863 | delete dialog; |
1065 | update(); | 864 | update(); |
1066 | return; | 865 | return; |
1067 | } | 866 | } |
1068 | } | 867 | } |
1069 | lastSearchedCategory = i->nextSibling(); | 868 | lastSearchedCategory = i->nextSibling(); |
1070 | lastSearchedItem = NULL; | 869 | lastSearchedItem = NULL; |
1071 | } | 870 | } |
1072 | lastSearchedCategory = NULL; | 871 | lastSearchedCategory = NULL; |
1073 | lastSearchedItem = NULL; | 872 | lastSearchedItem = NULL; |
1074 | delete dialog; | 873 | delete dialog; |
1075 | update(); | 874 | update(); |
1076 | QMessageBox::information( this, tr("ZSafe"), | 875 | QMessageBox::information( this, tr("ZSafe"), |
1077 | tr("Entry not found"), tr("&OK"), 0); | 876 | tr("Entry not found"), tr("&OK"), 0); |
1078 | 877 | ||
1079 | } | 878 | } |
1080 | 879 | ||
1081 | QString ZSafe::getFieldLabel (QListViewItem *_item, QString field, QString def) | 880 | QString ZSafe::getFieldLabel (QListViewItem *_item, QString field, QString def) |
1082 | { | 881 | { |
1083 | QString category; | 882 | QString category; |
1084 | if (_item) | 883 | if (_item) |
1085 | { | 884 | { |
1086 | if (isCategory(_item)) | 885 | if (isCategory(_item)) |
1087 | { | 886 | { |
1088 | category = _item->text(0); | 887 | category = _item->text(0); |
1089 | } | 888 | } |
1090 | else | 889 | else |
1091 | { | 890 | { |
1092 | QListViewItem *cat = _item->parent(); | 891 | QListViewItem *cat = _item->parent(); |
1093 | category = cat->text(0); | 892 | category = cat->text(0); |
1094 | } | 893 | } |
1095 | } | 894 | } |
1096 | else | 895 | else |
1097 | { | 896 | { |
1098 | return def; | 897 | return def; |
1099 | } | 898 | } |
1100 | 899 | ||
1101 | QString app_key = APP_KEY; | 900 | QString app_key = APP_KEY; |
1102 | #ifndef DESKTOP | ||
1103 | #ifndef Q_WS_WIN | ||
1104 | conf->setGroup ("fieldDefs"); | ||
1105 | #endif | ||
1106 | #else | ||
1107 | #ifndef Q_WS_WIN | ||
1108 | app_key += "/fieldDefs/"; | ||
1109 | #endif | ||
1110 | #endif | ||
1111 | // #ifndef Q_WS_WIN | ||
1112 | QString label = conf->readEntry(app_key+category+"-field"+field,def); | ||
1113 | // #else | ||
1114 | // QString label(def); | ||
1115 | // #endif | ||
1116 | 901 | ||
1117 | #ifndef DESKTOP | 902 | conf->setGroup( "fieldDefs" ); |
903 | QString label = conf->readEntry(app_key+category+"-field"+field,def); | ||
1118 | conf->setGroup ("zsafe"); | 904 | conf->setGroup ("zsafe"); |
1119 | #endif | ||
1120 | return label; | 905 | return label; |
1121 | } | 906 | } |
1122 | 907 | ||
1123 | QString ZSafe::getFieldLabel (QString category, QString field, QString def) | 908 | QString ZSafe::getFieldLabel (QString category, QString field, QString def) |
1124 | { | 909 | { |
1125 | QString app_key = APP_KEY; | 910 | QString app_key = APP_KEY; |
1126 | #ifndef DESKTOP | ||
1127 | conf->setGroup ("fieldDefs"); | ||
1128 | #else | ||
1129 | #ifndef Q_WS_WIN | ||
1130 | app_key += "/fieldDefs/"; | ||
1131 | #endif | ||
1132 | #endif | ||
1133 | // #ifndef Q_WS_WIN | 911 | // #ifndef Q_WS_WIN |
912 | conf->setGroup( "fieldDefs" ); | ||
1134 | QString label = conf->readEntry(app_key+category+"-field"+field, | 913 | QString label = conf->readEntry(app_key+category+"-field"+field, |
1135 | def); | 914 | def); |
1136 | // #else | 915 | // #else |
1137 | // QString label(def); | 916 | // QString label(def); |
1138 | // #endif | 917 | // #endif |
1139 | #ifndef DESKTOP | ||
1140 | conf->setGroup ("zsafe"); | 918 | conf->setGroup ("zsafe"); |
1141 | #endif | ||
1142 | return label; | 919 | return label; |
1143 | } | 920 | } |
1144 | 921 | ||
1145 | void ZSafe::showInfo( QListViewItem *_item) | 922 | void ZSafe::showInfo( QListViewItem *_item) |
1146 | { | 923 | { |
1147 | if (!_item) | 924 | if (!_item) |
1148 | return; | 925 | return; |
1149 | if (selectedItem != NULL) | 926 | if (selectedItem != NULL) |
1150 | selectedItem->setSelected(FALSE); | 927 | selectedItem->setSelected(FALSE); |
1151 | 928 | ||
1152 | selectedItem = _item; | 929 | selectedItem = _item; |
1153 | selectedItem->setSelected(TRUE); | 930 | selectedItem->setSelected(TRUE); |
1154 | 931 | ||
1155 | if (!isCategory(_item)) | 932 | if (!isCategory(_item)) |
1156 | { | 933 | { |
1157 | /* | 934 | /* |
1158 | QString label=selectedItem->text(0); | 935 | QString label=selectedItem->text(0); |
1159 | label+="\n"; | 936 | label+="\n"; |
1160 | label+=selectedItem->text(1); | 937 | label+=selectedItem->text(1); |
1161 | label+="\n"; | 938 | label+="\n"; |
1162 | label+=selectedItem->text(2); | 939 | label+=selectedItem->text(2); |
1163 | label+="\n"; | 940 | label+="\n"; |
1164 | label+=selectedItem->text(3); | 941 | label+=selectedItem->text(3); |
1165 | */ | 942 | */ |
1166 | 943 | ||
1167 | QString text; | 944 | QString text; |
1168 | QString entry; | 945 | QString entry; |
1169 | 946 | ||
1170 | text = "<html><body><div align=""center""><u><b>"; | 947 | text = "<html><body><div align=""center""><u><b>"; |
1171 | text += selectedItem->text(0); | 948 | text += selectedItem->text(0); |
1172 | text += "</b></u><br></div><br>"; | 949 | text += "</b></u><br></div><br>"; |
1173 | 950 | ||
@@ -1206,323 +983,251 @@ void ZSafe::showInfo( QListViewItem *_item) | |||
1206 | 983 | ||
1207 | entry = selectedItem->text(5); | 984 | entry = selectedItem->text(5); |
1208 | if (!entry.isEmpty() && entry.compare(" ")) | 985 | if (!entry.isEmpty() && entry.compare(" ")) |
1209 | { | 986 | { |
1210 | text += "<u><b>"; | 987 | text += "<u><b>"; |
1211 | text += getFieldLabel (selectedItem, "6", tr("Field 5")); | 988 | text += getFieldLabel (selectedItem, "6", tr("Field 5")); |
1212 | text += ":<br> </b></u><blockquote>"; | 989 | text += ":<br> </b></u><blockquote>"; |
1213 | text += entry; | 990 | text += entry; |
1214 | text += "</blockquote>"; | 991 | text += "</blockquote>"; |
1215 | // text += "<br>"; | 992 | // text += "<br>"; |
1216 | } | 993 | } |
1217 | 994 | ||
1218 | entry = selectedItem->text(3); | 995 | entry = selectedItem->text(3); |
1219 | if (!entry.isEmpty() && entry.compare(" ")) | 996 | if (!entry.isEmpty() && entry.compare(" ")) |
1220 | { | 997 | { |
1221 | text += "<u><b>"; | 998 | text += "<u><b>"; |
1222 | text += getFieldLabel (selectedItem, "4", tr("Comment")); | 999 | text += getFieldLabel (selectedItem, "4", tr("Comment")); |
1223 | text += ":<br> </b></u>"; | 1000 | text += ":<br> </b></u>"; |
1224 | QString comment = selectedItem->text(3); | 1001 | QString comment = selectedItem->text(3); |
1225 | comment.replace (QRegExp("\n"), "<br>"); | 1002 | comment.replace (QRegExp("\n"), "<br>"); |
1226 | text += comment; | 1003 | text += comment; |
1227 | // text += "<br>"; | 1004 | // text += "<br>"; |
1228 | } | 1005 | } |
1229 | 1006 | ||
1230 | text += "</body></html>"; | 1007 | text += "</body></html>"; |
1231 | 1008 | ||
1232 | infoForm->InfoText->setText(text); | 1009 | infoForm->InfoText->setText(text); |
1233 | // infoForm->hide(); | 1010 | // infoForm->hide(); |
1234 | #ifdef Q_WS_QWS | 1011 | #ifdef Q_WS_QWS |
1235 | QPEApplication::showDialog( infoForm ); | 1012 | QPEApplication::showDialog( infoForm ); |
1236 | #endif | 1013 | #endif |
1237 | 1014 | ||
1238 | #ifdef DESKTOP | ||
1239 | infoForm->show(); | ||
1240 | #endif | ||
1241 | } | 1015 | } |
1242 | } | 1016 | } |
1243 | 1017 | ||
1244 | void ZSafe::listViewSelected( QListViewItem *_item) | 1018 | void ZSafe::listViewSelected( QListViewItem *_item) |
1245 | { | 1019 | { |
1246 | if (!_item) | 1020 | if (!_item) |
1247 | return; | 1021 | return; |
1248 | if (selectedItem != NULL) | 1022 | if (selectedItem != NULL) |
1249 | selectedItem->setSelected(FALSE); | 1023 | selectedItem->setSelected(FALSE); |
1250 | 1024 | ||
1251 | selectedItem = _item; | 1025 | selectedItem = _item; |
1252 | 1026 | ||
1253 | #ifndef DESKTOP | ||
1254 | // set the column text dependent on the selected item | ||
1255 | ListView->setColumnText(0, getFieldLabel (selectedItem, "1", tr("Name"))); | ||
1256 | ListView->setColumnText(1, getFieldLabel (selectedItem, "2", tr("Field 2"))); | ||
1257 | ListView->setColumnText(2, getFieldLabel (selectedItem, "3", tr("Field 3"))); | ||
1258 | ListView->setColumnText(3, getFieldLabel (selectedItem, "4", tr("Comment"))); | ||
1259 | ListView->setColumnText(4, getFieldLabel (selectedItem, "5", tr("Field 4"))); | ||
1260 | ListView->setColumnText(5, getFieldLabel (selectedItem, "6", tr("Field 5"))); | ||
1261 | #endif | ||
1262 | #ifdef Q_WS_WIN | ||
1263 | // set the column text dependent on the selected item | 1027 | // set the column text dependent on the selected item |
1264 | ListView->setColumnText(0, getFieldLabel (selectedItem, "1", tr("Name"))); | 1028 | ListView->setColumnText(0, getFieldLabel (selectedItem, "1", tr("Name"))); |
1265 | ListView->setColumnText(1, getFieldLabel (selectedItem, "2", tr("Field 2"))); | 1029 | ListView->setColumnText(1, getFieldLabel (selectedItem, "2", tr("Field 2"))); |
1266 | ListView->setColumnText(2, getFieldLabel (selectedItem, "3", tr("Field 3"))); | 1030 | ListView->setColumnText(2, getFieldLabel (selectedItem, "3", tr("Field 3"))); |
1267 | ListView->setColumnText(3, getFieldLabel (selectedItem, "4", tr("Comment"))); | 1031 | ListView->setColumnText(3, getFieldLabel (selectedItem, "4", tr("Comment"))); |
1268 | ListView->setColumnText(4, getFieldLabel (selectedItem, "5", tr("Field 4"))); | 1032 | ListView->setColumnText(4, getFieldLabel (selectedItem, "5", tr("Field 4"))); |
1269 | ListView->setColumnText(5, getFieldLabel (selectedItem, "6", tr("Field 5"))); | 1033 | ListView->setColumnText(5, getFieldLabel (selectedItem, "6", tr("Field 5"))); |
1270 | #endif | ||
1271 | |||
1272 | } | 1034 | } |
1273 | 1035 | ||
1274 | bool ZSafe::isCategory(QListViewItem *_item) | 1036 | bool ZSafe::isCategory(QListViewItem *_item) |
1275 | { | 1037 | { |
1276 | if (_item == NULL) | 1038 | if (_item == NULL) |
1277 | return FALSE; | 1039 | return FALSE; |
1278 | 1040 | ||
1279 | QString categoryName = _item->text (0); | 1041 | QString categoryName = _item->text (0); |
1280 | if (categories.find (categoryName)) | 1042 | if (categories.find (categoryName)) |
1281 | return TRUE; | 1043 | return TRUE; |
1282 | else | 1044 | else |
1283 | return FALSE; | 1045 | return FALSE; |
1284 | } | 1046 | } |
1285 | 1047 | ||
1286 | void ZSafe::removeAsciiFile() | 1048 | void ZSafe::removeAsciiFile() |
1287 | { | 1049 | { |
1288 | // QString fn = filename + ".txt"; | 1050 | // QString fn = filename + ".txt"; |
1289 | // open the file dialog | 1051 | // open the file dialog |
1290 | #ifndef DESKTOP | ||
1291 | #ifndef NO_OPIE | ||
1292 | QMap<QString, QStringList> mimeTypes; | 1052 | QMap<QString, QStringList> mimeTypes; |
1293 | mimeTypes.insert(tr("All"), QStringList() ); | 1053 | mimeTypes.insert(tr("All"), QStringList() ); |
1294 | mimeTypes.insert(tr("Text"), "text/*" ); | 1054 | mimeTypes.insert(tr("Text"), "text/*" ); |
1295 | QString fn = OFileDialog::getOpenFileName( OFileSelector::EXTENDED_ALL, | 1055 | QString fn = OFileDialog::getOpenFileName( OFileSelector::EXTENDED_ALL, |
1296 | QDir::homeDirPath() + "/Documents/application/zsafe", | 1056 | QDir::homeDirPath() + "/Documents/application/zsafe", |
1297 | QString::null, | 1057 | QString::null, |
1298 | mimeTypes, | 1058 | mimeTypes, |
1299 | this, | 1059 | this, |
1300 | tr ("Remove text file")); | 1060 | tr ("Remove text file")); |
1301 | #else | ||
1302 | QString fn = ScQtFileEdit::getOpenFileName(this, | ||
1303 | tr ("Remove text file"), | ||
1304 | QDir::homeDirPath() + "/Documents/application/zsafe", | ||
1305 | "*.txt"); | ||
1306 | #endif | ||
1307 | #else | ||
1308 | QString fn = QFileDialog::getOpenFileName( | ||
1309 | QDir::homeDirPath() + "/Documents/application/zsafe", | ||
1310 | "ZSafe (*.txt)", | ||
1311 | this, | ||
1312 | "ZSafe File Dialog" | ||
1313 | "Choose a text file" ); | ||
1314 | #endif | ||
1315 | 1061 | ||
1316 | if (fn && fn.length() > 0 ) | 1062 | if (fn && fn.length() > 0 ) |
1317 | { | 1063 | { |
1318 | QFile f( fn ); | 1064 | QFile f( fn ); |
1319 | if ( !f.remove() ) | 1065 | if ( !f.remove() ) |
1320 | { | 1066 | { |
1321 | #ifndef NO_OPIE | ||
1322 | owarn << "Could not remove file " << fn << oendl; | ||
1323 | #else | ||
1324 | qWarning( QString("Could not remove file %1").arg(fn),2000 ); | ||
1325 | #endif | ||
1326 | QMessageBox::critical( 0, tr("ZSafe"), | 1067 | QMessageBox::critical( 0, tr("ZSafe"), |
1327 | tr("Could not remove text file.") ); | 1068 | tr("Could not remove text file.") ); |
1328 | return; | 1069 | return; |
1329 | } | 1070 | } |
1330 | } | 1071 | } |
1331 | } | 1072 | } |
1332 | 1073 | ||
1333 | void ZSafe::writeAllEntries() | 1074 | void ZSafe::writeAllEntries() |
1334 | { | 1075 | { |
1335 | if (filename.isEmpty()) | 1076 | if (filename.isEmpty()) |
1336 | { | 1077 | { |
1337 | QMessageBox::critical( 0, tr("ZSafe"), | 1078 | QMessageBox::critical( 0, tr("ZSafe"), |
1338 | tr("No document defined.\nYou have to create a new document")); | 1079 | tr("No document defined.\nYou have to create a new document")); |
1339 | return; | 1080 | return; |
1340 | } | 1081 | } |
1341 | 1082 | ||
1342 | // open the file dialog | 1083 | // open the file dialog |
1343 | QString fn = zsaveDialog(); | 1084 | QString fn = zsaveDialog(); |
1344 | // open the new document | 1085 | // open the new document |
1345 | if (fn && fn.length() > 0 ) | 1086 | if (fn && fn.length() > 0 ) |
1346 | { | 1087 | { |
1347 | QFile f( fn ); | 1088 | QFile f( fn ); |
1348 | if ( !f.open( IO_WriteOnly ) ) { | 1089 | if ( !f.open( IO_WriteOnly ) ) { |
1349 | #ifndef NO_OPIE | ||
1350 | owarn << "Could not write to file " << fn << oendl; | ||
1351 | #else | ||
1352 | qWarning( QString("Could not write to file %1").arg(fn),2000 ); | ||
1353 | #endif | ||
1354 | QMessageBox::critical( 0, "ZSafe", | 1090 | QMessageBox::critical( 0, "ZSafe", |
1355 | QString("Could not export to text file.") ); | 1091 | QString("Could not export to text file.") ); |
1356 | return; | 1092 | return; |
1357 | } | 1093 | } |
1358 | QTextStream t( &f ); | 1094 | QTextStream t( &f ); |
1359 | 1095 | ||
1360 | QListViewItem *i; | 1096 | QListViewItem *i; |
1361 | // step through all categories | 1097 | // step through all categories |
1362 | for (i = ListView->firstChild(); | 1098 | for (i = ListView->firstChild(); |
1363 | i != NULL; | 1099 | i != NULL; |
1364 | i = i->nextSibling()) | 1100 | i = i->nextSibling()) |
1365 | { | 1101 | { |
1366 | // step through all subitems | 1102 | // step through all subitems |
1367 | QListViewItem *si; | 1103 | QListViewItem *si; |
1368 | for (si = i->firstChild(); | 1104 | for (si = i->firstChild(); |
1369 | si != NULL; | 1105 | si != NULL; |
1370 | si = si->nextSibling()) | 1106 | si = si->nextSibling()) |
1371 | { | 1107 | { |
1372 | QString oneEntry; | 1108 | QString oneEntry; |
1373 | oneEntry += "\""; | 1109 | oneEntry += "\""; |
1374 | oneEntry += i->text(0); | 1110 | oneEntry += i->text(0); |
1375 | oneEntry += "\";"; | 1111 | oneEntry += "\";"; |
1376 | oneEntry += "\""; | 1112 | oneEntry += "\""; |
1377 | oneEntry += si->text(0); | 1113 | oneEntry += si->text(0); |
1378 | oneEntry += "\";"; | 1114 | oneEntry += "\";"; |
1379 | oneEntry += "\""; | 1115 | oneEntry += "\""; |
1380 | oneEntry += si->text(1); | 1116 | oneEntry += si->text(1); |
1381 | oneEntry += "\";"; | 1117 | oneEntry += "\";"; |
1382 | oneEntry += "\""; | 1118 | oneEntry += "\""; |
1383 | oneEntry += si->text(2); | 1119 | oneEntry += si->text(2); |
1384 | oneEntry += "\";"; | 1120 | oneEntry += "\";"; |
1385 | oneEntry += "\""; | 1121 | oneEntry += "\""; |
1386 | QString comment = si->text(3); | 1122 | QString comment = si->text(3); |
1387 | comment.replace (QRegExp("\n"), "<br>"); | 1123 | comment.replace (QRegExp("\n"), "<br>"); |
1388 | oneEntry += comment; | 1124 | oneEntry += comment; |
1389 | oneEntry += "\";"; | 1125 | oneEntry += "\";"; |
1390 | oneEntry += "\""; | 1126 | oneEntry += "\""; |
1391 | oneEntry += si->text(4); | 1127 | oneEntry += si->text(4); |
1392 | oneEntry += "\";"; | 1128 | oneEntry += "\";"; |
1393 | oneEntry += "\""; | 1129 | oneEntry += "\""; |
1394 | oneEntry += si->text(5); | 1130 | oneEntry += si->text(5); |
1395 | oneEntry += "\""; | 1131 | oneEntry += "\""; |
1396 | // owarn << oneEntry << oendl; | 1132 | // owarn << oneEntry << oendl; |
1397 | t << oneEntry << endl; | 1133 | t << oneEntry << endl; |
1398 | 1134 | ||
1399 | // owarn << si->text(0) << oendl; | 1135 | // owarn << si->text(0) << oendl; |
1400 | } | 1136 | } |
1401 | } | 1137 | } |
1402 | f.close(); | 1138 | f.close(); |
1403 | } | 1139 | } |
1404 | } | 1140 | } |
1405 | 1141 | ||
1406 | void ZSafe::readAllEntries() | 1142 | void ZSafe::readAllEntries() |
1407 | { | 1143 | { |
1408 | if (filename.isEmpty()) | 1144 | if (filename.isEmpty()) |
1409 | { | 1145 | { |
1410 | QMessageBox::critical( 0, tr("ZSafe"), | 1146 | QMessageBox::critical( 0, tr("ZSafe"), |
1411 | tr("No document defined.\nYou have to create a new document")); | 1147 | tr("No document defined.\nYou have to create a new document")); |
1412 | return; | 1148 | return; |
1413 | } | 1149 | } |
1414 | 1150 | ||
1415 | // open the file dialog | 1151 | // open the file dialog |
1416 | #ifndef DESKTOP | ||
1417 | #ifndef NO_OPIE | ||
1418 | QMap<QString, QStringList> mimeTypes; | 1152 | QMap<QString, QStringList> mimeTypes; |
1419 | mimeTypes.insert(tr("All"), QStringList() ); | 1153 | mimeTypes.insert(tr("All"), QStringList() ); |
1420 | mimeTypes.insert(tr("Text"), "text/*" ); | 1154 | mimeTypes.insert(tr("Text"), "text/*" ); |
1421 | QString fn = OFileDialog::getOpenFileName( OFileSelector::EXTENDED_ALL, | 1155 | QString fn = OFileDialog::getOpenFileName( OFileSelector::EXTENDED_ALL, |
1422 | QDir::homeDirPath() + "/Documents/application/zsafe", | 1156 | QDir::homeDirPath() + "/Documents/application/zsafe", |
1423 | QString::null, | 1157 | QString::null, |
1424 | mimeTypes, | 1158 | mimeTypes, |
1425 | this, | 1159 | this, |
1426 | tr ("Import text file")); | 1160 | tr ("Import text file")); |
1427 | #else | ||
1428 | QString fn = ScQtFileEdit::getOpenFileName(this, | ||
1429 | tr ("Import text file"), | ||
1430 | QDir::homeDirPath() + "/Documents/application/zsafe", | ||
1431 | "*.txt"); | ||
1432 | #endif | ||
1433 | #else | ||
1434 | QString fn = QFileDialog::getOpenFileName( | ||
1435 | QDir::homeDirPath() + "/Documents/application/zsafe", | ||
1436 | "ZSafe (*.txt)", | ||
1437 | this, | ||
1438 | "ZSafe File Dialog" | ||
1439 | "Choose a text file" ); | ||
1440 | #endif | ||
1441 | 1161 | ||
1442 | if (fn && fn.length() > 0 ) | 1162 | if (fn && fn.length() > 0 ) |
1443 | { | 1163 | { |
1444 | QFile f( fn ); | 1164 | QFile f( fn ); |
1445 | if ( !f.open( IO_ReadOnly ) ) | 1165 | if ( !f.open( IO_ReadOnly ) ) |
1446 | { | 1166 | { |
1447 | #ifndef NO_OPIE | ||
1448 | owarn << "Could not read file " << fn << oendl; | ||
1449 | #else | ||
1450 | qWarning( QString("Could not read file %1").arg(fn), 2000 ); | ||
1451 | #endif | ||
1452 | QMessageBox::critical( 0, "ZSafe", | 1167 | QMessageBox::critical( 0, "ZSafe", |
1453 | QString("Could not import text file.") ); | 1168 | QString("Could not import text file.") ); |
1454 | return; | 1169 | return; |
1455 | } | 1170 | } |
1456 | 1171 | ||
1457 | modified = true; | 1172 | modified = true; |
1458 | 1173 | ||
1459 | // clear the password list | 1174 | // clear the password list |
1460 | selectedItem = NULL; | 1175 | selectedItem = NULL; |
1461 | QListViewItem *i; | 1176 | QListViewItem *i; |
1462 | // step through all categories | 1177 | // step through all categories |
1463 | for (i = ListView->firstChild(); | 1178 | for (i = ListView->firstChild(); |
1464 | i != NULL; | 1179 | i != NULL; |
1465 | i = i->nextSibling()) | 1180 | i = i->nextSibling()) |
1466 | { | 1181 | { |
1467 | // step through all subitems | 1182 | // step through all subitems |
1468 | QListViewItem *si; | 1183 | QListViewItem *si; |
1469 | for (si = i->firstChild(); | 1184 | for (si = i->firstChild(); |
1470 | si != NULL; ) | 1185 | si != NULL; ) |
1471 | // si = si->nextSibling()) | 1186 | // si = si->nextSibling()) |
1472 | { | 1187 | { |
1473 | QListViewItem *_si = si; | 1188 | QListViewItem *_si = si; |
1474 | si = si->nextSibling(); | 1189 | si = si->nextSibling(); |
1475 | i->takeItem(_si); // remove from view list | 1190 | i->takeItem(_si); // remove from view list |
1476 | if (_si) delete _si; | 1191 | if (_si) delete _si; |
1477 | } | 1192 | } |
1478 | } | 1193 | } |
1479 | 1194 | ||
1480 | #ifndef NO_OPIE | ||
1481 | owarn << "ReadAllEntries(): " << oendl; | ||
1482 | #else | ||
1483 | qWarning ("ReadAllEntries(): "); | ||
1484 | #endif | ||
1485 | |||
1486 | QTextStream t(&f); | 1195 | QTextStream t(&f); |
1487 | while ( !t.eof() ) | 1196 | while ( !t.eof() ) |
1488 | { | 1197 | { |
1489 | QString s = t.readLine(); | 1198 | QString s = t.readLine(); |
1490 | s.replace (QRegExp("\";\""), "\"|\""); | 1199 | s.replace (QRegExp("\";\""), "\"|\""); |
1491 | // char buffer[1024]; | 1200 | // char buffer[1024]; |
1492 | #ifndef Q_WS_WIN | ||
1493 | char buffer[s.length()+1]; | 1201 | char buffer[s.length()+1]; |
1494 | #else | ||
1495 | char buffer[4048]; | ||
1496 | #endif | ||
1497 | 1202 | ||
1498 | 1203 | ||
1499 | /* modify QString -> QCString::utf8 */ | 1204 | /* modify QString -> QCString::utf8 */ |
1500 | 1205 | ||
1501 | strcpy (buffer, s.utf8()); | 1206 | strcpy (buffer, s.utf8()); |
1502 | 1207 | ||
1503 | QString name; | 1208 | QString name; |
1504 | QString user; | 1209 | QString user; |
1505 | QString password; | 1210 | QString password; |
1506 | QString comment; | 1211 | QString comment; |
1507 | QString field5=""; | 1212 | QString field5=""; |
1508 | QString field6=""; | 1213 | QString field6=""; |
1509 | 1214 | ||
1510 | // separete the entries | 1215 | // separete the entries |
1511 | char *i = strtok (buffer, "|"); | 1216 | char *i = strtok (buffer, "|"); |
1512 | QString category(QString::fromUtf8(&i[1])); | 1217 | QString category(QString::fromUtf8(&i[1])); |
1513 | category.truncate(category.length() -1); | 1218 | category.truncate(category.length() -1); |
1514 | 1219 | ||
1515 | int idx=0; | 1220 | int idx=0; |
1516 | while ((i = strtok (NULL, "|")) != NULL) | 1221 | while ((i = strtok (NULL, "|")) != NULL) |
1517 | { | 1222 | { |
1518 | switch (idx) | 1223 | switch (idx) |
1519 | { | 1224 | { |
1520 | case 0: | 1225 | case 0: |
1521 | name = QString::fromUtf8(&i[1]); | 1226 | name = QString::fromUtf8(&i[1]); |
1522 | name.truncate(name.length() -1); | 1227 | name.truncate(name.length() -1); |
1523 | // name | 1228 | // name |
1524 | break; | 1229 | break; |
1525 | case 1: | 1230 | case 1: |
1526 | // user | 1231 | // user |
1527 | user = QString::fromUtf8(&i[1]); | 1232 | user = QString::fromUtf8(&i[1]); |
1528 | user.truncate(user.length() -1); | 1233 | user.truncate(user.length() -1); |
@@ -1610,171 +1315,152 @@ void ZSafe::readAllEntries() | |||
1610 | { | 1315 | { |
1611 | c1->setIcon (*getPredefinedIcon(category)); | 1316 | c1->setIcon (*getPredefinedIcon(category)); |
1612 | } | 1317 | } |
1613 | c1->setListItem (catI); | 1318 | c1->setListItem (catI); |
1614 | c1->initListItem(); | 1319 | c1->initListItem(); |
1615 | categories.insert (c1->getCategoryName(), c1); | 1320 | categories.insert (c1->getCategoryName(), c1); |
1616 | } | 1321 | } |
1617 | 1322 | ||
1618 | } | 1323 | } |
1619 | f.close(); | 1324 | f.close(); |
1620 | 1325 | ||
1621 | } | 1326 | } |
1622 | else | 1327 | else |
1623 | { | 1328 | { |
1624 | } | 1329 | } |
1625 | 1330 | ||
1626 | } | 1331 | } |
1627 | 1332 | ||
1628 | #ifdef UNUSED | 1333 | #ifdef UNUSED |
1629 | void ZSafe::writeAllEntries() | 1334 | void ZSafe::writeAllEntries() |
1630 | { | 1335 | { |
1631 | if (filename.isEmpty()) | 1336 | if (filename.isEmpty()) |
1632 | { | 1337 | { |
1633 | QMessageBox::critical( 0, tr("ZSafe"), | 1338 | QMessageBox::critical( 0, tr("ZSafe"), |
1634 | tr("<P>No document defined. You have to create a new document</P>")); | 1339 | tr("<P>No document defined. You have to create a new document</P>")); |
1635 | return; | 1340 | return; |
1636 | } | 1341 | } |
1637 | 1342 | ||
1638 | // open the file for writing | 1343 | // open the file for writing |
1639 | QString fn = filename + ".txt"; | 1344 | QString fn = filename + ".txt"; |
1640 | QFile f( fn ); | 1345 | QFile f( fn ); |
1641 | if ( !f.open( IO_WriteOnly ) ) { | 1346 | if ( !f.open( IO_WriteOnly ) ) { |
1642 | #ifndef NO_OPIE | ||
1643 | owarn << "Could not write to file " << fn << oendl; | ||
1644 | #else | ||
1645 | qWarning( QString("Could not write to file %1").arg(fn), 2000 ); | ||
1646 | #endif | ||
1647 | QMessageBox::critical( 0, tr("ZSafe"), | 1347 | QMessageBox::critical( 0, tr("ZSafe"), |
1648 | tr("Could not export to text file.") ); | 1348 | tr("Could not export to text file.") ); |
1649 | return; | 1349 | return; |
1650 | } | 1350 | } |
1651 | QTextStream t( &f ); | 1351 | QTextStream t( &f ); |
1652 | 1352 | ||
1653 | QListViewItem *i; | 1353 | QListViewItem *i; |
1654 | // step through all categories | 1354 | // step through all categories |
1655 | for (i = ListView->firstChild(); | 1355 | for (i = ListView->firstChild(); |
1656 | i != NULL; | 1356 | i != NULL; |
1657 | i = i->nextSibling()) | 1357 | i = i->nextSibling()) |
1658 | { | 1358 | { |
1659 | // step through all subitems | 1359 | // step through all subitems |
1660 | QListViewItem *si; | 1360 | QListViewItem *si; |
1661 | for (si = i->firstChild(); | 1361 | for (si = i->firstChild(); |
1662 | si != NULL; | 1362 | si != NULL; |
1663 | si = si->nextSibling()) | 1363 | si = si->nextSibling()) |
1664 | { | 1364 | { |
1665 | QString oneEntry; | 1365 | QString oneEntry; |
1666 | oneEntry += "\""; | 1366 | oneEntry += "\""; |
1667 | oneEntry += i->text(0); | 1367 | oneEntry += i->text(0); |
1668 | oneEntry += "\";"; | 1368 | oneEntry += "\";"; |
1669 | oneEntry += "\""; | 1369 | oneEntry += "\""; |
1670 | oneEntry += si->text(0); | 1370 | oneEntry += si->text(0); |
1671 | oneEntry += "\";"; | 1371 | oneEntry += "\";"; |
1672 | oneEntry += "\""; | 1372 | oneEntry += "\""; |
1673 | oneEntry += si->text(1); | 1373 | oneEntry += si->text(1); |
1674 | oneEntry += "\";"; | 1374 | oneEntry += "\";"; |
1675 | oneEntry += "\""; | 1375 | oneEntry += "\""; |
1676 | oneEntry += si->text(2); | 1376 | oneEntry += si->text(2); |
1677 | oneEntry += "\";"; | 1377 | oneEntry += "\";"; |
1678 | oneEntry += "\""; | 1378 | oneEntry += "\""; |
1679 | // oneEntry += si->text(3); | 1379 | // oneEntry += si->text(3); |
1680 | QString comment = si->text(3); | 1380 | QString comment = si->text(3); |
1681 | comment.replace (QRegExp("\n"), "<br>"); | 1381 | comment.replace (QRegExp("\n"), "<br>"); |
1682 | oneEntry += comment; | 1382 | oneEntry += comment; |
1683 | oneEntry += "\""; | 1383 | oneEntry += "\""; |
1684 | // owarn << oneEntry << oendl; | 1384 | // owarn << oneEntry << oendl; |
1685 | t << oneEntry << endl; | 1385 | t << oneEntry << endl; |
1686 | 1386 | ||
1687 | // owarn << si->text(0) << oendl; | 1387 | // owarn << si->text(0) << oendl; |
1688 | } | 1388 | } |
1689 | } | 1389 | } |
1690 | f.close(); | 1390 | f.close(); |
1691 | } | 1391 | } |
1692 | 1392 | ||
1693 | void ZSafe::readAllEntries() | 1393 | void ZSafe::readAllEntries() |
1694 | { | 1394 | { |
1695 | QString fn = filename + ".txt"; | 1395 | QString fn = filename + ".txt"; |
1696 | QFile f( fn ); | 1396 | QFile f( fn ); |
1697 | if ( !f.open( IO_ReadOnly ) ) | 1397 | if ( !f.open( IO_ReadOnly ) ) |
1698 | { | 1398 | { |
1699 | #ifndef NO_OPIE | ||
1700 | owarn << "Could not read file " << fn << oendl; | ||
1701 | #else | ||
1702 | qWarning( QString("Could not read file %1").arg(fn), 2000 ); | ||
1703 | #endif | ||
1704 | QMessageBox::critical( 0, tr("ZSafe"), | 1399 | QMessageBox::critical( 0, tr("ZSafe"), |
1705 | tr("Could not import text file.") ); | 1400 | tr("Could not import text file.") ); |
1706 | return; | 1401 | return; |
1707 | } | 1402 | } |
1708 | 1403 | ||
1709 | modified = true; | 1404 | modified = true; |
1710 | 1405 | ||
1711 | // clear the password list | 1406 | // clear the password list |
1712 | selectedItem = NULL; | 1407 | selectedItem = NULL; |
1713 | QListViewItem *i; | 1408 | QListViewItem *i; |
1714 | // step through all categories | 1409 | // step through all categories |
1715 | for (i = ListView->firstChild(); | 1410 | for (i = ListView->firstChild(); |
1716 | i != NULL; | 1411 | i != NULL; |
1717 | i = i->nextSibling()) | 1412 | i = i->nextSibling()) |
1718 | { | 1413 | { |
1719 | // step through all subitems | 1414 | // step through all subitems |
1720 | QListViewItem *si; | 1415 | QListViewItem *si; |
1721 | for (si = i->firstChild(); | 1416 | for (si = i->firstChild(); |
1722 | si != NULL; ) | 1417 | si != NULL; ) |
1723 | // si = si->nextSibling()) | 1418 | // si = si->nextSibling()) |
1724 | { | 1419 | { |
1725 | QListViewItem *_si = si; | 1420 | QListViewItem *_si = si; |
1726 | si = si->nextSibling(); | 1421 | si = si->nextSibling(); |
1727 | i->takeItem(_si); // remove from view list | 1422 | i->takeItem(_si); // remove from view list |
1728 | if (_si) delete _si; | 1423 | if (_si) delete _si; |
1729 | } | 1424 | } |
1730 | } | 1425 | } |
1731 | 1426 | ||
1732 | #ifndef NO_OPIE | ||
1733 | owarn << "ReadAllEntries(): " << oendl; | ||
1734 | #else | ||
1735 | qWarning ("ReadAllEntries(): "); | ||
1736 | #endif | ||
1737 | QTextStream t(&f); | 1427 | QTextStream t(&f); |
1738 | while ( !t.eof() ) | 1428 | while ( !t.eof() ) |
1739 | { | 1429 | { |
1740 | QString s = t.readLine(); | 1430 | QString s = t.readLine(); |
1741 | s.replace (QRegExp("\";\""), "\"|\""); | 1431 | s.replace (QRegExp("\";\""), "\"|\""); |
1742 | // char buffer[1024]; | 1432 | // char buffer[1024]; |
1743 | int len=s.length()+1; | 1433 | int len=s.length()+1; |
1744 | #ifdef Q_WS_WIN | ||
1745 | char buffer[512]; | ||
1746 | #else | ||
1747 | char buffer[len]; | 1434 | char buffer[len]; |
1748 | #endif | ||
1749 | strcpy (buffer, s); | 1435 | strcpy (buffer, s); |
1750 | 1436 | ||
1751 | QString name; | 1437 | QString name; |
1752 | QString user; | 1438 | QString user; |
1753 | QString password; | 1439 | QString password; |
1754 | QString comment; | 1440 | QString comment; |
1755 | 1441 | ||
1756 | // separete the entries | 1442 | // separete the entries |
1757 | char *i = strtok (buffer, "|"); | 1443 | char *i = strtok (buffer, "|"); |
1758 | QString category(&i[1]); | 1444 | QString category(&i[1]); |
1759 | category.truncate(category.length() -1); | 1445 | category.truncate(category.length() -1); |
1760 | 1446 | ||
1761 | int idx=0; | 1447 | int idx=0; |
1762 | while (i = strtok (NULL, "|")) | 1448 | while (i = strtok (NULL, "|")) |
1763 | { | 1449 | { |
1764 | switch (idx) | 1450 | switch (idx) |
1765 | { | 1451 | { |
1766 | case 0: | 1452 | case 0: |
1767 | name = &i[1]; | 1453 | name = &i[1]; |
1768 | name.truncate(name.length() -1); | 1454 | name.truncate(name.length() -1); |
1769 | // name | 1455 | // name |
1770 | break; | 1456 | break; |
1771 | case 1: | 1457 | case 1: |
1772 | // user | 1458 | // user |
1773 | user = &i[1]; | 1459 | user = &i[1]; |
1774 | user.truncate(user.length() -1); | 1460 | user.truncate(user.length() -1); |
1775 | break; | 1461 | break; |
1776 | case 2: | 1462 | case 2: |
1777 | // password | 1463 | // password |
1778 | password = &i[1]; | 1464 | password = &i[1]; |
1779 | password.truncate(password.length() -1); | 1465 | password.truncate(password.length() -1); |
1780 | break; | 1466 | break; |
@@ -1827,171 +1513,154 @@ void ZSafe::readAllEntries() | |||
1827 | bool isIconAv = false; | 1513 | bool isIconAv = false; |
1828 | if (!icon.isEmpty() && !icon.isNull()) | 1514 | if (!icon.isEmpty() && !icon.isNull()) |
1829 | { | 1515 | { |
1830 | // build the full path | 1516 | // build the full path |
1831 | fullIconPath = iconPath + icon; | 1517 | fullIconPath = iconPath + icon; |
1832 | pix = new QPixmap (fullIconPath); | 1518 | pix = new QPixmap (fullIconPath); |
1833 | if (!pix->isNull()) | 1519 | if (!pix->isNull()) |
1834 | { | 1520 | { |
1835 | QImage img = pix->convertToImage(); | 1521 | QImage img = pix->convertToImage(); |
1836 | pix->convertFromImage(img.smoothScale(14,14)); | 1522 | pix->convertFromImage(img.smoothScale(14,14)); |
1837 | c1->setIconName (icon); | 1523 | c1->setIconName (icon); |
1838 | c1->setIcon (*pix); | 1524 | c1->setIcon (*pix); |
1839 | isIconAv = true; | 1525 | isIconAv = true; |
1840 | } | 1526 | } |
1841 | } | 1527 | } |
1842 | if (!isIconAv) | 1528 | if (!isIconAv) |
1843 | { | 1529 | { |
1844 | c1->setIcon (*getPredefinedIcon(category)); | 1530 | c1->setIcon (*getPredefinedIcon(category)); |
1845 | } | 1531 | } |
1846 | c1->setListItem (catI); | 1532 | c1->setListItem (catI); |
1847 | c1->initListItem(); | 1533 | c1->initListItem(); |
1848 | categories.insert (c1->getCategoryName(), c1); | 1534 | categories.insert (c1->getCategoryName(), c1); |
1849 | } | 1535 | } |
1850 | 1536 | ||
1851 | } | 1537 | } |
1852 | f.close(); | 1538 | f.close(); |
1853 | 1539 | ||
1854 | } | 1540 | } |
1855 | #endif // UNUSED | 1541 | #endif // UNUSED |
1856 | 1542 | ||
1857 | void ZSafe::resume(int) | 1543 | void ZSafe::resume(int) |
1858 | { | 1544 | { |
1859 | #ifndef NO_OPIE | ||
1860 | owarn << "Resume" << oendl; | ||
1861 | #endif | ||
1862 | // hide the main window | 1545 | // hide the main window |
1863 | 1546 | ||
1864 | if ( !showpwd ) | 1547 | if ( !showpwd ) |
1865 | { | 1548 | { |
1866 | infoForm->hide(); | 1549 | infoForm->hide(); |
1867 | // open zsafe again | 1550 | // open zsafe again |
1868 | m_password = ""; | 1551 | m_password = ""; |
1869 | selectedItem = NULL; | 1552 | selectedItem = NULL; |
1870 | 1553 | ||
1871 | // clear the password list | 1554 | // clear the password list |
1872 | QListViewItem *i; | 1555 | QListViewItem *i; |
1873 | // step through all categories | 1556 | // step through all categories |
1874 | for (i = ListView->firstChild(); | 1557 | for (i = ListView->firstChild(); |
1875 | i != NULL; | 1558 | i != NULL; |
1876 | i = i->nextSibling()) | 1559 | i = i->nextSibling()) |
1877 | { | 1560 | { |
1878 | // step through all subitems | 1561 | // step through all subitems |
1879 | QListViewItem *si; | 1562 | QListViewItem *si; |
1880 | for (si = i->firstChild(); | 1563 | for (si = i->firstChild(); |
1881 | si != NULL; ) | 1564 | si != NULL; ) |
1882 | { | 1565 | { |
1883 | QListViewItem *_si = si; | 1566 | QListViewItem *_si = si; |
1884 | si = si->nextSibling(); | 1567 | si = si->nextSibling(); |
1885 | i->takeItem(_si); // remove from view list | 1568 | i->takeItem(_si); // remove from view list |
1886 | if (_si) delete _si; | 1569 | if (_si) delete _si; |
1887 | } | 1570 | } |
1888 | } | 1571 | } |
1889 | 1572 | ||
1890 | // ask for password and read again | 1573 | // ask for password and read again |
1891 | openDocument(filename); | 1574 | openDocument(filename); |
1892 | } | 1575 | } |
1893 | } | 1576 | } |
1894 | 1577 | ||
1895 | //--------------------------------------------- | 1578 | //--------------------------------------------- |
1896 | 1579 | ||
1897 | 1580 | ||
1898 | bool ZSafe::openDocument(const char* _filename, const char* ) | 1581 | bool ZSafe::openDocument(const char* _filename, const char* ) |
1899 | { | 1582 | { |
1900 | QString name= _filename; | 1583 | QString name= _filename; |
1901 | qWarning("openDocument "+name); | 1584 | qWarning("openDocument "+name); |
1902 | int retval; | 1585 | int retval; |
1903 | char* entry[FIELD_SIZE]; | 1586 | char* entry[FIELD_SIZE]; |
1904 | // #ifndef Q_WS_WIN | 1587 | // #ifndef Q_WS_WIN |
1905 | int validationFlag = conf->readNumEntry(APP_KEY+"valzsafe", 1); | 1588 | int validationFlag = conf->readNumEntry(APP_KEY+"valzsafe", 1); |
1906 | // #else | 1589 | // #else |
1907 | // int validationFlag = 1; | 1590 | // int validationFlag = 1; |
1908 | // #endif | 1591 | // #endif |
1909 | 1592 | ||
1910 | int pwdOk = 0; | 1593 | int pwdOk = 0; |
1911 | int numberOfTries = 3; | 1594 | int numberOfTries = 3; |
1912 | for (int i=0; i < numberOfTries; i++) | 1595 | for (int i=0; i < numberOfTries; i++) |
1913 | { | 1596 | { |
1914 | QFile f(_filename); | 1597 | QFile f(_filename); |
1915 | if (f.exists()) | 1598 | if (f.exists()) |
1916 | { | 1599 | { |
1917 | // ask with a dialog for the password | 1600 | // ask with a dialog for the password |
1918 | if (m_password.isEmpty()) | 1601 | if (m_password.isEmpty()) |
1919 | getDocPassword(tr("Enter Password")); | 1602 | getDocPassword(tr("Enter Password")); |
1920 | if (m_password.isEmpty() && validationFlag == 0) | 1603 | if (m_password.isEmpty() && validationFlag == 0) |
1921 | { | 1604 | { |
1922 | #ifndef NO_OPIE | ||
1923 | owarn << "Wrong password" << oendl; | ||
1924 | #else | ||
1925 | qWarning ("Wrong password"); | ||
1926 | #endif | ||
1927 | QMessageBox::critical( 0, tr("ZSafe"), | 1605 | QMessageBox::critical( 0, tr("ZSafe"), |
1928 | tr("Wrong password.\n\nZSafe will now exit.") ); | 1606 | tr("Wrong password.\n\nZSafe will now exit.") ); |
1929 | exitZs (1); | 1607 | exitZs (1); |
1930 | } | 1608 | } |
1931 | 1609 | ||
1932 | retval = loadInit(_filename, m_password); | 1610 | retval = loadInit(_filename, m_password); |
1933 | if (retval != PWERR_GOOD) | 1611 | if (retval != PWERR_GOOD) |
1934 | { | 1612 | { |
1935 | #ifndef NO_OPIE | ||
1936 | owarn << "Error loading Document" << oendl; | ||
1937 | #else | ||
1938 | qWarning ("Error loading Document"); | ||
1939 | #endif | ||
1940 | return false; | 1613 | return false; |
1941 | } | 1614 | } |
1942 | } | 1615 | } |
1943 | else | 1616 | else |
1944 | { | 1617 | { |
1945 | #ifdef Q_WS_WIN | 1618 | this->setCaption(tr("ZSafe")); |
1946 | this->setCaption("Qt ZSafe"); | ||
1947 | #else | ||
1948 | this->setCaption("ZSafe"); | ||
1949 | #endif | ||
1950 | filename = ""; | 1619 | filename = ""; |
1951 | switch( QMessageBox::warning( this, tr("ZSafe"), | 1620 | switch( QMessageBox::warning( this, tr("ZSafe"), |
1952 | tr("<P>You must create a new document first. Ok to create?</P>"), | 1621 | tr("<P>You must create a new document first. Ok to create?</P>"), |
1953 | tr("&Yes"), tr("&No."), | 1622 | tr("&Yes"), tr("&No."), |
1954 | 0 | 1623 | 0 |
1955 | ) ) | 1624 | ) ) |
1956 | { | 1625 | { |
1957 | case 1: // No | 1626 | case 1: // No |
1958 | return false; | 1627 | return false; |
1959 | break; | 1628 | break; |
1960 | case 0: // Yes | 1629 | case 0: // Yes |
1961 | newDocument(); | 1630 | newDocument(); |
1962 | return false; | 1631 | return false; |
1963 | break; | 1632 | break; |
1964 | } | 1633 | } |
1965 | 1634 | ||
1966 | } | 1635 | } |
1967 | 1636 | ||
1968 | 1637 | ||
1969 | // load the validation entry | 1638 | // load the validation entry |
1970 | if (validationFlag == 0) | 1639 | if (validationFlag == 0) |
1971 | { | 1640 | { |
1972 | pwdOk = 1; | 1641 | pwdOk = 1; |
1973 | break; | 1642 | break; |
1974 | } | 1643 | } |
1975 | 1644 | ||
1976 | retval = loadEntry(entry); | 1645 | retval = loadEntry(entry); |
1977 | if (retval == 1 && | 1646 | if (retval == 1 && |
1978 | !strcmp (entry[0], "ZSAFECATEGORY") && | 1647 | !strcmp (entry[0], "ZSAFECATEGORY") && |
1979 | !strcmp (entry[1], "name") && | 1648 | !strcmp (entry[1], "name") && |
1980 | !strcmp (entry[2], "username") && | 1649 | !strcmp (entry[2], "username") && |
1981 | !strcmp (entry[3], "password") && | 1650 | !strcmp (entry[3], "password") && |
1982 | !strcmp (entry[4], "comment") ) | 1651 | !strcmp (entry[4], "comment") ) |
1983 | { | 1652 | { |
1984 | for (int count = 0; count < FIELD_SIZE; count++) free(entry[count]); | 1653 | for (int count = 0; count < FIELD_SIZE; count++) free(entry[count]); |
1985 | pwdOk = 1; | 1654 | pwdOk = 1; |
1986 | break; | 1655 | break; |
1987 | } | 1656 | } |
1988 | else | 1657 | else |
1989 | // for (int count = 0; count < FIELD_SIZE; count++) free(entry[count]); | 1658 | // for (int count = 0; count < FIELD_SIZE; count++) free(entry[count]); |
1990 | fclose (fd); | 1659 | fclose (fd); |
1991 | m_password = ""; | 1660 | m_password = ""; |
1992 | 1661 | ||
1993 | if (i < numberOfTries - 1) | 1662 | if (i < numberOfTries - 1) |
1994 | { | 1663 | { |
1995 | switch( QMessageBox::warning( this, tr("ZSafe"), | 1664 | switch( QMessageBox::warning( this, tr("ZSafe"), |
1996 | tr("Wrong password.\nEnter again?"), | 1665 | tr("Wrong password.\nEnter again?"), |
1997 | tr("&Yes"), tr("&No."), | 1666 | tr("&Yes"), tr("&No."), |
@@ -2407,96 +2076,86 @@ bool ZSafe::saveDocument(const char* _filename, | |||
2407 | return false; | 2076 | return false; |
2408 | } | 2077 | } |
2409 | 2078 | ||
2410 | } | 2079 | } |
2411 | } | 2080 | } |
2412 | 2081 | ||
2413 | if (saveFinalize() == PWERR_DATA) { | 2082 | if (saveFinalize() == PWERR_DATA) { |
2414 | #ifndef NO_OPIE | 2083 | #ifndef NO_OPIE |
2415 | owarn << "2: Error writing file, contents not saved" << oendl; | 2084 | owarn << "2: Error writing file, contents not saved" << oendl; |
2416 | #else | 2085 | #else |
2417 | qWarning("2: Error writing file, contents not saved"); | 2086 | qWarning("2: Error writing file, contents not saved"); |
2418 | #endif | 2087 | #endif |
2419 | return false; | 2088 | return false; |
2420 | } else { | 2089 | } else { |
2421 | #ifndef DESKTOP | 2090 | #ifndef DESKTOP |
2422 | Global::statusMessage (tr("Password file saved.")); | 2091 | Global::statusMessage (tr("Password file saved.")); |
2423 | #endif | 2092 | #endif |
2424 | modified = false; | 2093 | modified = false; |
2425 | return true; | 2094 | return true; |
2426 | } | 2095 | } |
2427 | } | 2096 | } |
2428 | 2097 | ||
2429 | PasswordForm *newPwdDialog; | 2098 | PasswordForm *newPwdDialog; |
2430 | bool newPwdDialogResult = false; | 2099 | bool newPwdDialogResult = false; |
2431 | void ZSafe::setPasswordDialogDone() | 2100 | void ZSafe::setPasswordDialogDone() |
2432 | { | 2101 | { |
2433 | newPwdDialogResult = true; | 2102 | newPwdDialogResult = true; |
2434 | newPwdDialog->close(); | 2103 | newPwdDialog->close(); |
2435 | } | 2104 | } |
2436 | 2105 | ||
2437 | void ZSafe::getDocPassword(QString title) | 2106 | void ZSafe::getDocPassword(QString title) |
2438 | { | 2107 | { |
2439 | #ifndef NO_OPIE | ||
2440 | owarn << "getDocPassword" << oendl; | ||
2441 | #endif | ||
2442 | // open the 'Password' dialog | 2108 | // open the 'Password' dialog |
2443 | PasswordForm *dialog = new PasswordForm(this, title, TRUE); | 2109 | PasswordForm *dialog = new PasswordForm(this, title, TRUE); |
2444 | newPwdDialog = dialog; | 2110 | newPwdDialog = dialog; |
2445 | newPwdDialogResult = false; | 2111 | newPwdDialogResult = false; |
2446 | 2112 | ||
2447 | QPixmap image0( ( const char** ) zsafe_xpm ); | 2113 | QPixmap image0( ( const char** ) zsafe_xpm ); |
2448 | dialog->setIcon( image0); | 2114 | dialog->setIcon( image0); |
2449 | 2115 | ||
2450 | connect( dialog->PasswordField, SIGNAL( returnPressed() ), | 2116 | connect( dialog->PasswordField, SIGNAL( returnPressed() ), |
2451 | this, SLOT( setPasswordDialogDone() ) ); | 2117 | this, SLOT( setPasswordDialogDone() ) ); |
2452 | 2118 | ||
2453 | // CS: !!! | 2119 | // CS: !!! |
2454 | // int pos = filename.findRev ('/'); | 2120 | // int pos = filename.findRev ('/'); |
2455 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); | 2121 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); |
2456 | #ifdef Q_WS_WIN | ||
2457 | dialog->setCaption("Qt " + ti); | ||
2458 | #else | ||
2459 | dialog->setCaption(ti); | 2122 | dialog->setCaption(ti); |
2460 | #endif | ||
2461 | // dialog->setCaption(title); | 2123 | // dialog->setCaption(title); |
2462 | 2124 | ||
2463 | dialog->PasswordField->setFocus(); | 2125 | dialog->PasswordField->setFocus(); |
2464 | DialogCode result = (DialogCode) dialog->exec(); | 2126 | QDialog::DialogCode result = (QDialog::DialogCode) dialog->exec(); |
2465 | #ifdef DESKTOP | ||
2466 | result = Accepted; | ||
2467 | #endif | ||
2468 | 2127 | ||
2469 | QString password; | 2128 | QString password; |
2470 | if (result == Accepted || newPwdDialogResult) | 2129 | if (result == QDialog::Accepted || newPwdDialogResult) |
2471 | { | 2130 | { |
2472 | m_password = dialog->PasswordField->text(); | 2131 | m_password = dialog->PasswordField->text(); |
2473 | } | 2132 | } |
2474 | else | 2133 | else |
2475 | { | 2134 | { |
2476 | exitZs (1); | 2135 | exitZs (1); |
2477 | } | 2136 | } |
2478 | } | 2137 | } |
2479 | 2138 | ||
2480 | int ZSafe::saveInit(const char *_filename, const char *password) | 2139 | int ZSafe::saveInit(const char *_filename, const char *password) |
2481 | { | 2140 | { |
2482 | char key[128]; | 2141 | char key[128]; |
2483 | unsigned int j = 0; | 2142 | unsigned int j = 0; |
2484 | unsigned int keylength; | 2143 | unsigned int keylength; |
2485 | // int val; | 2144 | // int val; |
2486 | int count2; | 2145 | int count2; |
2487 | Krc2* krc2 = new Krc2(); | 2146 | Krc2* krc2 = new Krc2(); |
2488 | 2147 | ||
2489 | /* first we should check the permissions of the filename */ | 2148 | /* first we should check the permissions of the filename */ |
2490 | /* | 2149 | /* |
2491 | if (QFile::exists(_filename)) { | 2150 | if (QFile::exists(_filename)) { |
2492 | val = checkFile(_filename); | 2151 | val = checkFile(_filename); |
2493 | if (val != PWERR_GOOD) | 2152 | if (val != PWERR_GOOD) |
2494 | return val; | 2153 | return val; |
2495 | } else | 2154 | } else |
2496 | { | 2155 | { |
2497 | val = creat (_filename, (S_IRUSR | S_IWUSR)); | 2156 | val = creat (_filename, (S_IRUSR | S_IWUSR)); |
2498 | if (val == -1) | 2157 | if (val == -1) |
2499 | return PWERR_OPEN; | 2158 | return PWERR_OPEN; |
2500 | else | 2159 | else |
2501 | close(val); | 2160 | close(val); |
2502 | } | 2161 | } |
@@ -2591,274 +2250,214 @@ int ZSafe::saveFinalize(void) | |||
2591 | int count1, retval = PWERR_GOOD; | 2250 | int count1, retval = PWERR_GOOD; |
2592 | unsigned short ciphertext[4]; | 2251 | unsigned short ciphertext[4]; |
2593 | Krc2* krc2 = new Krc2(); | 2252 | Krc2* krc2 = new Krc2(); |
2594 | 2253 | ||
2595 | /* Tack on the PKCS 5 padding | 2254 | /* Tack on the PKCS 5 padding |
2596 | * How it works is we fill up the last n bytes with the value n | 2255 | * How it works is we fill up the last n bytes with the value n |
2597 | * | 2256 | * |
2598 | * So, if we have, say, 13 bytes, 8 of which are used, we have 5 left | 2257 | * So, if we have, say, 13 bytes, 8 of which are used, we have 5 left |
2599 | * over, leaving us 3 short, so we fill it in with 3's. | 2258 | * over, leaving us 3 short, so we fill it in with 3's. |
2600 | * | 2259 | * |
2601 | * If we come out even, we fill it with 8 8s | 2260 | * If we come out even, we fill it with 8 8s |
2602 | * | 2261 | * |
2603 | * um, except that in this instance we are using 4 shorts instead of 8 bytes. | 2262 | * um, except that in this instance we are using 4 shorts instead of 8 bytes. |
2604 | * so, half everything | 2263 | * so, half everything |
2605 | */ | 2264 | */ |
2606 | for (count1 = bufferIndex; count1 < 4; count1++) { | 2265 | for (count1 = bufferIndex; count1 < 4; count1++) { |
2607 | plaintext[count1] = (4 - bufferIndex); | 2266 | plaintext[count1] = (4 - bufferIndex); |
2608 | } | 2267 | } |
2609 | krc2->rc2_encrypt (plaintext); | 2268 | krc2->rc2_encrypt (plaintext); |
2610 | for (count1 = 0; count1 < 4; count1++) { | 2269 | for (count1 = 0; count1 < 4; count1++) { |
2611 | ciphertext[count1] = iv[count1] ^ plaintext[count1]; | 2270 | ciphertext[count1] = iv[count1] ^ plaintext[count1]; |
2612 | if (putc ((unsigned char) (ciphertext[count1] >> 8), fd) == EOF) retval = PWERR_DATA; | 2271 | if (putc ((unsigned char) (ciphertext[count1] >> 8), fd) == EOF) retval = PWERR_DATA; |
2613 | if (putc ((unsigned char) (ciphertext[count1] & 0xff), fd) == EOF) retval = PWERR_DATA; | 2272 | if (putc ((unsigned char) (ciphertext[count1] & 0xff), fd) == EOF) retval = PWERR_DATA; |
2614 | } | 2273 | } |
2615 | 2274 | ||
2616 | fclose (fd); | 2275 | fclose (fd); |
2617 | free(buffer); | 2276 | free(buffer); |
2618 | return retval; | 2277 | return retval; |
2619 | } | 2278 | } |
2620 | 2279 | ||
2621 | void ZSafe::quitMe () | 2280 | void ZSafe::quitMe () |
2622 | { | 2281 | { |
2623 | #ifndef NO_OPIE | ||
2624 | owarn << "QUIT..." << oendl; | ||
2625 | #endif | ||
2626 | |||
2627 | if (modified) | 2282 | if (modified) |
2628 | { | 2283 | { |
2629 | switch( QMessageBox::information( this, tr("ZSafe"), | 2284 | switch( QMessageBox::information( this, tr("ZSafe"), |
2630 | tr("Do you want to save\nbefore exiting?"), | 2285 | tr("Do you want to save\nbefore exiting?"), |
2631 | tr("&Save"), | 2286 | tr("&Save"), |
2632 | tr("S&ave with\nnew\npassword"), | 2287 | tr("S&ave with\nnew\npassword"), |
2633 | tr("&Don't Save"), | 2288 | tr("&Don't Save"), |
2634 | 0 // Enter == button 0 | 2289 | 0 // Enter == button 0 |
2635 | ) ) | 2290 | ) ) |
2636 | { // Escape == button 2 | 2291 | { // Escape == button 2 |
2637 | case 0: // Save clicked, Alt-S or Enter pressed. | 2292 | case 0: // Save clicked, Alt-S or Enter pressed. |
2638 | // save | 2293 | // save |
2639 | modified = false; | 2294 | modified = false; |
2640 | saveDocument(filename, FALSE); | 2295 | saveDocument(filename, FALSE); |
2641 | exitZs (1); | 2296 | exitZs (1); |
2642 | break; | 2297 | break; |
2643 | case 1: // | 2298 | case 1: // |
2644 | // Save with new password | 2299 | // Save with new password |
2645 | modified = false; | 2300 | modified = false; |
2646 | saveDocument(filename, TRUE); | 2301 | saveDocument(filename, TRUE); |
2647 | exitZs (1); | 2302 | exitZs (1); |
2648 | break; | 2303 | break; |
2649 | case 2: // Don't Save clicked or Alt-D pressed | 2304 | case 2: // Don't Save clicked or Alt-D pressed |
2650 | // don't save but exitZs | 2305 | // don't save but exitZs |
2651 | exitZs (1); | 2306 | exitZs (1); |
2652 | break; | 2307 | break; |
2653 | } | 2308 | } |
2654 | } | 2309 | } |
2655 | exitZs (1); | 2310 | exitZs (1); |
2656 | 2311 | ||
2657 | } | 2312 | } |
2658 | 2313 | ||
2659 | void ZSafe::categoryFieldActivated( const QString& category) | 2314 | void ZSafe::categoryFieldActivated( const QString& category) |
2660 | { | 2315 | { |
2661 | if (categoryDialog) | 2316 | if (categoryDialog) |
2662 | setCategoryDialogFields(categoryDialog, category); | 2317 | setCategoryDialogFields(categoryDialog, category); |
2663 | } | 2318 | } |
2664 | 2319 | ||
2665 | void ZSafe::addCategory() | 2320 | void ZSafe::addCategory() |
2666 | { | 2321 | { |
2667 | if (filename.isEmpty()) | 2322 | if (filename.isEmpty()) |
2668 | { | 2323 | { |
2669 | QMessageBox::critical( 0, tr("ZSafe"), | 2324 | QMessageBox::critical( 0, tr("ZSafe"), |
2670 | tr("No document defined.\nYou have to create a new document")); | 2325 | tr("No document defined.\nYou have to create a new document")); |
2671 | return; | 2326 | return; |
2672 | } | 2327 | } |
2673 | else | 2328 | else |
2674 | { | 2329 | { |
2675 | // open the 'Category' dialog | 2330 | // open the 'Category' dialog |
2676 | bool initIcons = false; | 2331 | bool initIcons = false; |
2677 | // open the 'Category' dialog | 2332 | // open the 'Category' dialog |
2678 | CategoryDialog *dialog; | 2333 | CategoryDialog *dialog; |
2679 | if (categoryDialog) | 2334 | if (categoryDialog) |
2680 | { | 2335 | { |
2681 | dialog = categoryDialog; | 2336 | dialog = categoryDialog; |
2682 | } | 2337 | } |
2683 | else | 2338 | else |
2684 | { | 2339 | { |
2685 | categoryDialog = new CategoryDialog(this, tr("Category"), TRUE); | 2340 | categoryDialog = new CategoryDialog(this, tr("Category"), TRUE); |
2686 | #ifdef Q_WS_WIN | ||
2687 | categoryDialog->setCaption ("Qt " + tr("Category")); | ||
2688 | #endif | ||
2689 | dialog = categoryDialog; | 2341 | dialog = categoryDialog; |
2690 | connect( dialog->CategoryField, | 2342 | connect( dialog->CategoryField, |
2691 | SIGNAL( activated(const QString&)), | 2343 | SIGNAL( activated(const QString&)), |
2692 | this, SLOT( categoryFieldActivated(const QString&) ) ); | 2344 | this, SLOT( categoryFieldActivated(const QString&) ) ); |
2693 | initIcons = true; | 2345 | initIcons = true; |
2694 | } | 2346 | } |
2695 | 2347 | ||
2696 | #ifdef DESKTOP | ||
2697 | #ifndef Q_WS_WIN | ||
2698 | QStringList list = conf->entryList( APP_KEY+"/fieldDefs" ); | ||
2699 | #else | ||
2700 | // read all categories from the config file and store | 2348 | // read all categories from the config file and store |
2701 | // into a list | 2349 | // into a list |
2702 | QFile f (cfgFile); | 2350 | QFile f (cfgFile); |
2703 | QStringList list; | 2351 | QStringList list; |
2704 | if ( f.open(IO_ReadOnly) ) { // file opened successfully | 2352 | if ( f.open(IO_ReadOnly) ) { // file opened successfully |
2705 | QTextStream t( &f ); // use a text stream | 2353 | QTextStream t( &f ); // use a text stream |
2706 | QString s; | 2354 | QString s; |
2707 | int n = 1; | ||
2708 | while ( !t.eof() ) { // until end of file... | 2355 | while ( !t.eof() ) { // until end of file... |
2709 | s = t.readLine(); // line of text excluding '\n' | 2356 | s = t.readLine(); // line of text excluding '\n' |
2710 | list.append(s); | 2357 | list.append(s); |
2711 | } | 2358 | } |
2712 | f.close(); | 2359 | f.close(); |
2713 | } | 2360 | } |
2714 | #endif | ||
2715 | #else | ||
2716 | // read all categories from the config file and store | ||
2717 | // into a list | ||
2718 | QFile f (cfgFile); | ||
2719 | QStringList list; | ||
2720 | if ( f.open(IO_ReadOnly) ) { // file opened successfully | ||
2721 | QTextStream t( &f ); // use a text stream | ||
2722 | QString s; | ||
2723 | while ( !t.eof() ) { // until end of file... | ||
2724 | s = t.readLine(); // line of text excluding '\n' | ||
2725 | list.append(s); | ||
2726 | } | ||
2727 | f.close(); | ||
2728 | } | ||
2729 | #endif | ||
2730 | QStringList::Iterator it = list.begin(); | 2361 | QStringList::Iterator it = list.begin(); |
2731 | QString categ; | 2362 | QString categ; |
2732 | QString firstCategory; | 2363 | QString firstCategory; |
2733 | dialog->CategoryField->clear(); // remove all items | 2364 | dialog->CategoryField->clear(); // remove all items |
2734 | while( it != list.end() ) | 2365 | while( it != list.end() ) |
2735 | { | 2366 | { |
2736 | QString *cat = new QString (*it); | 2367 | QString *cat = new QString (*it); |
2737 | if (cat->contains("-field1", FALSE)) | 2368 | if (cat->contains("-field1", FALSE)) |
2738 | { | 2369 | { |
2739 | #ifdef DESKTOP | ||
2740 | #ifndef Q_WS_WIN | ||
2741 | categ = cat->section ("-field1", 0, 0); | ||
2742 | #else | ||
2743 | int pos = cat->find ("-field1"); | ||
2744 | categ = cat->left (pos); | ||
2745 | #endif | ||
2746 | #else | ||
2747 | int pos = cat->find ("-field1"); | 2370 | int pos = cat->find ("-field1"); |
2748 | cat->truncate(pos); | 2371 | cat->truncate(pos); |
2749 | categ = *cat; | 2372 | categ = *cat; |
2750 | #endif | ||
2751 | if (!categ.isEmpty()) | 2373 | if (!categ.isEmpty()) |
2752 | { | 2374 | { |
2753 | dialog->CategoryField->insertItem (categ, -1); | 2375 | dialog->CategoryField->insertItem (categ, -1); |
2754 | if (firstCategory.isEmpty()) | 2376 | if (firstCategory.isEmpty()) |
2755 | firstCategory = categ; | 2377 | firstCategory = categ; |
2756 | } | 2378 | } |
2757 | } | 2379 | } |
2758 | ++it; | 2380 | ++it; |
2759 | } | 2381 | } |
2760 | 2382 | ||
2761 | 2383 | ||
2762 | if (firstCategory.isEmpty()) | 2384 | if (firstCategory.isEmpty()) |
2763 | setCategoryDialogFields(dialog); | 2385 | setCategoryDialogFields(dialog); |
2764 | else | 2386 | else |
2765 | setCategoryDialogFields(dialog, firstCategory); | 2387 | setCategoryDialogFields(dialog, firstCategory); |
2766 | 2388 | ||
2767 | // CategoryDialog *dialog = new CategoryDialog(this, "Category", TRUE); | 2389 | // CategoryDialog *dialog = new CategoryDialog(this, "Category", TRUE); |
2768 | 2390 | ||
2769 | if (initIcons) | 2391 | if (initIcons) |
2770 | { | 2392 | { |
2771 | Wait waitDialog(this, tr("Wait dialog")); | 2393 | Wait waitDialog(this, tr("Wait dialog")); |
2772 | waitDialog.waitLabel->setText(tr("Gathering icons...")); | 2394 | waitDialog.waitLabel->setText(tr("Gathering icons...")); |
2773 | waitDialog.show(); | 2395 | waitDialog.show(); |
2774 | qApp->processEvents(); | 2396 | qApp->processEvents(); |
2775 | 2397 | ||
2776 | #ifdef DESKTOP | ||
2777 | QDir d(iconPath); | ||
2778 | #else | ||
2779 | QDir d(QPEApplication::qpeDir() + "pics/"); | 2398 | QDir d(QPEApplication::qpeDir() + "pics/"); |
2780 | #endif | ||
2781 | d.setFilter( QDir::Files); | 2399 | d.setFilter( QDir::Files); |
2782 | 2400 | ||
2783 | const QFileInfoList *list = d.entryInfoList(); | 2401 | const QFileInfoList *list = d.entryInfoList(); |
2784 | QFileInfoListIterator it( *list ); // create list iterator | 2402 | QFileInfoListIterator it( *list ); // create list iterator |
2785 | QFileInfo *fi; // pointer for traversing | 2403 | QFileInfo *fi; // pointer for traversing |
2786 | 2404 | ||
2787 | dialog->IconField->insertItem("predefined"); | 2405 | dialog->IconField->insertItem("predefined"); |
2788 | while ( (fi=it.current()) ) { // for each file... | 2406 | while ( (fi=it.current()) ) { // for each file... |
2789 | QString fileName = fi->fileName(); | 2407 | QString fileName = fi->fileName(); |
2790 | if(fileName.right(4) == ".png"){ | 2408 | if(fileName.right(4) == ".png"){ |
2791 | fileName = fileName.mid(0,fileName.length()-4); | 2409 | fileName = fileName.mid(0,fileName.length()-4); |
2792 | #ifdef DESKTOP | ||
2793 | QPixmap imageOfFile; | ||
2794 | imageOfFile.load(iconPath + fi->fileName()); | ||
2795 | #else | ||
2796 | QPixmap imageOfFile(Resource::loadPixmap(fileName)); | 2410 | QPixmap imageOfFile(Resource::loadPixmap(fileName)); |
2797 | #endif | ||
2798 | QImage foo = imageOfFile.convertToImage(); | 2411 | QImage foo = imageOfFile.convertToImage(); |
2799 | foo = foo.smoothScale(16,16); | 2412 | foo = foo.smoothScale(16,16); |
2800 | imageOfFile.convertFromImage(foo); | 2413 | imageOfFile.convertFromImage(foo); |
2801 | dialog->IconField->insertItem(imageOfFile,fileName); | 2414 | dialog->IconField->insertItem(imageOfFile,fileName); |
2802 | } | 2415 | } |
2803 | ++it; | 2416 | ++it; |
2804 | } | 2417 | } |
2805 | waitDialog.hide(); | 2418 | waitDialog.hide(); |
2806 | } | 2419 | } |
2807 | 2420 | ||
2808 | #ifndef Q_WS_WIN | 2421 | QDialog::DialogCode result = (QDialog::DialogCode) dialog->exec(); |
2809 | dialog->show(); | ||
2810 | #endif | ||
2811 | #ifndef DESKTOP | ||
2812 | // dialog->move (20, 100); | ||
2813 | #endif | ||
2814 | DialogCode result = (DialogCode) dialog->exec(); | ||
2815 | #ifdef DESKTOP | ||
2816 | result = Accepted; | ||
2817 | #endif | ||
2818 | |||
2819 | QString category; | 2422 | QString category; |
2820 | QString icon; | 2423 | QString icon; |
2821 | QString fullIconPath; | 2424 | QString fullIconPath; |
2822 | QPixmap *pix; | 2425 | QPixmap *pix; |
2823 | if (result == Accepted) | 2426 | if (result == QDialog::Accepted) |
2824 | { | 2427 | { |
2825 | modified = true; | 2428 | modified = true; |
2826 | category = dialog->CategoryField->currentText(); | 2429 | category = dialog->CategoryField->currentText(); |
2827 | icon = dialog->IconField->currentText()+".png"; | 2430 | icon = dialog->IconField->currentText()+".png"; |
2828 | 2431 | ||
2829 | #ifndef NO_OPIE | ||
2830 | owarn << category << oendl; | ||
2831 | #endif | ||
2832 | |||
2833 | QListViewItem *li = new ShadedListItem( 1, ListView ); | 2432 | QListViewItem *li = new ShadedListItem( 1, ListView ); |
2834 | Category *c1 = new Category(); | 2433 | Category *c1 = new Category(); |
2835 | c1->setCategoryName(category); | 2434 | c1->setCategoryName(category); |
2836 | 2435 | ||
2837 | // if (!icon.isEmpty() && !icon.isNull()) | 2436 | // if (!icon.isEmpty() && !icon.isNull()) |
2838 | if (icon != "predefined.png") | 2437 | if (icon != "predefined.png") |
2839 | { | 2438 | { |
2840 | // build the full path | 2439 | // build the full path |
2841 | fullIconPath = iconPath + icon; | 2440 | fullIconPath = iconPath + icon; |
2842 | pix = new QPixmap (fullIconPath); | 2441 | pix = new QPixmap (fullIconPath); |
2843 | // pix->resize(14, 14); | 2442 | // pix->resize(14, 14); |
2844 | if (!pix->isNull()) | 2443 | if (!pix->isNull()) |
2845 | { | 2444 | { |
2846 | // save the full pixmap name into the config file | 2445 | // save the full pixmap name into the config file |
2847 | // #ifndef Q_WS_WIN | 2446 | // #ifndef Q_WS_WIN |
2848 | conf->writeEntry(APP_KEY+category, icon); | 2447 | conf->writeEntry(APP_KEY+category, icon); |
2849 | // #endif | 2448 | // #endif |
2850 | saveConf(); | 2449 | saveConf(); |
2851 | QImage img = pix->convertToImage(); | 2450 | QImage img = pix->convertToImage(); |
2852 | pix->convertFromImage(img.smoothScale(14,14)); | 2451 | pix->convertFromImage(img.smoothScale(14,14)); |
2853 | c1->setIcon (*pix); | 2452 | c1->setIcon (*pix); |
2854 | c1->setIconName(icon); | 2453 | c1->setIconName(icon); |
2855 | } | 2454 | } |
2856 | else | 2455 | else |
2857 | { | 2456 | { |
2858 | QPixmap folder( ( const char** ) general_data ); | 2457 | QPixmap folder( ( const char** ) general_data ); |
2859 | c1->setIcon (folder); | 2458 | c1->setIcon (folder); |
2860 | } | 2459 | } |
2861 | } | 2460 | } |
2862 | else | 2461 | else |
2863 | { | 2462 | { |
2864 | c1->setIcon (*getPredefinedIcon(category)); | 2463 | c1->setIcon (*getPredefinedIcon(category)); |
@@ -2928,452 +2527,372 @@ void ZSafe::setCategoryDialogFields(CategoryDialog *dialog) | |||
2928 | { | 2527 | { |
2929 | if (!dialog) | 2528 | if (!dialog) |
2930 | return; | 2529 | return; |
2931 | 2530 | ||
2932 | QString icon; | 2531 | QString icon; |
2933 | if (selectedItem) | 2532 | if (selectedItem) |
2934 | { | 2533 | { |
2935 | dialog->Field1->setText(getFieldLabel (selectedItem, "1", tr("Name"))); | 2534 | dialog->Field1->setText(getFieldLabel (selectedItem, "1", tr("Name"))); |
2936 | dialog->Field2->setText(getFieldLabel (selectedItem, "2", tr("Username"))); | 2535 | dialog->Field2->setText(getFieldLabel (selectedItem, "2", tr("Username"))); |
2937 | dialog->Field3->setText(getFieldLabel (selectedItem, "3", tr("Password"))); | 2536 | dialog->Field3->setText(getFieldLabel (selectedItem, "3", tr("Password"))); |
2938 | dialog->Field4->setText(getFieldLabel (selectedItem, "4", tr("Comment"))); | 2537 | dialog->Field4->setText(getFieldLabel (selectedItem, "4", tr("Comment"))); |
2939 | dialog->Field5->setText(getFieldLabel (selectedItem, "5", tr("Field 4"))); | 2538 | dialog->Field5->setText(getFieldLabel (selectedItem, "5", tr("Field 4"))); |
2940 | dialog->Field6->setText(getFieldLabel (selectedItem, "6", tr("Field 5"))); | 2539 | dialog->Field6->setText(getFieldLabel (selectedItem, "6", tr("Field 5"))); |
2941 | 2540 | ||
2942 | Category *cat= categories.find (selectedItem->text(0)); | 2541 | Category *cat= categories.find (selectedItem->text(0)); |
2943 | if (cat) | 2542 | if (cat) |
2944 | { | 2543 | { |
2945 | icon = cat->getIconName(); | 2544 | icon = cat->getIconName(); |
2946 | } | 2545 | } |
2947 | else | 2546 | else |
2948 | icon = conf->readEntry(APP_KEY+selectedItem->text(0)); | 2547 | icon = conf->readEntry(APP_KEY+selectedItem->text(0)); |
2949 | } | 2548 | } |
2950 | else | 2549 | else |
2951 | { | 2550 | { |
2952 | dialog->Field1->setText(tr("Name")); | 2551 | dialog->Field1->setText(tr("Name")); |
2953 | dialog->Field2->setText(tr("Username")); | 2552 | dialog->Field2->setText(tr("Username")); |
2954 | dialog->Field3->setText(tr("Password")); | 2553 | dialog->Field3->setText(tr("Password")); |
2955 | dialog->Field4->setText(tr("Comment")); | 2554 | dialog->Field4->setText(tr("Comment")); |
2956 | dialog->Field5->setText(tr("Field 4")); | 2555 | dialog->Field5->setText(tr("Field 4")); |
2957 | dialog->Field6->setText(tr("Field 5")); | 2556 | dialog->Field6->setText(tr("Field 5")); |
2958 | } | 2557 | } |
2959 | 2558 | ||
2960 | #ifdef DESKTOP | ||
2961 | QDir d(iconPath); | ||
2962 | #else | ||
2963 | QDir d(QPEApplication::qpeDir() + "pics/"); | 2559 | QDir d(QPEApplication::qpeDir() + "pics/"); |
2964 | #endif | ||
2965 | d.setFilter( QDir::Files); | 2560 | d.setFilter( QDir::Files); |
2966 | 2561 | ||
2967 | const QFileInfoList *list = d.entryInfoList(); | 2562 | const QFileInfoList *list = d.entryInfoList(); |
2968 | int i=0; | 2563 | int i=0; |
2969 | QFileInfoListIterator it( *list ); // create list iterator | 2564 | QFileInfoListIterator it( *list ); // create list iterator |
2970 | QFileInfo *fi; // pointer for traversing | 2565 | QFileInfo *fi; // pointer for traversing |
2971 | if (icon.isEmpty() || icon.isNull()) | 2566 | if (icon.isEmpty() || icon.isNull()) |
2972 | { | 2567 | { |
2973 | dialog->IconField->setCurrentItem(0); | 2568 | dialog->IconField->setCurrentItem(0); |
2974 | } | 2569 | } |
2975 | else | 2570 | else |
2976 | { | 2571 | { |
2977 | while ( (fi=it.current()) ) | 2572 | while ( (fi=it.current()) ) |
2978 | { // for each file... | 2573 | { // for each file... |
2979 | QString fileName = fi->fileName(); | 2574 | QString fileName = fi->fileName(); |
2980 | if(fileName.right(4) == ".png") | 2575 | if(fileName.right(4) == ".png") |
2981 | { | 2576 | { |
2982 | fileName = fileName.mid(0,fileName.length()-4); | 2577 | fileName = fileName.mid(0,fileName.length()-4); |
2983 | 2578 | ||
2984 | if(fileName+".png"==icon) | 2579 | if(fileName+".png"==icon) |
2985 | { | 2580 | { |
2986 | dialog->IconField->setCurrentItem(i+1); | 2581 | dialog->IconField->setCurrentItem(i+1); |
2987 | break; | 2582 | break; |
2988 | } | 2583 | } |
2989 | ++i; | 2584 | ++i; |
2990 | } | 2585 | } |
2991 | ++it; | 2586 | ++it; |
2992 | } | 2587 | } |
2993 | } | 2588 | } |
2994 | } | 2589 | } |
2995 | 2590 | ||
2996 | void ZSafe::setCategoryDialogFields(CategoryDialog *dialog, QString category) | 2591 | void ZSafe::setCategoryDialogFields(CategoryDialog *dialog, QString category) |
2997 | { | 2592 | { |
2998 | if (!dialog) | 2593 | if (!dialog) |
2999 | return; | 2594 | return; |
3000 | 2595 | ||
3001 | dialog->Field1->setText(getFieldLabel (category, "1", tr("Name"))); | 2596 | dialog->Field1->setText(getFieldLabel (category, "1", tr("Name"))); |
3002 | dialog->Field2->setText(getFieldLabel (category, "2", tr("Username"))); | 2597 | dialog->Field2->setText(getFieldLabel (category, "2", tr("Username"))); |
3003 | dialog->Field3->setText(getFieldLabel (category, "3", tr("Password"))); | 2598 | dialog->Field3->setText(getFieldLabel (category, "3", tr("Password"))); |
3004 | dialog->Field4->setText(getFieldLabel (category, "4", tr("Comment"))); | 2599 | dialog->Field4->setText(getFieldLabel (category, "4", tr("Comment"))); |
3005 | dialog->Field5->setText(getFieldLabel (category, "5", tr("Field 4"))); | 2600 | dialog->Field5->setText(getFieldLabel (category, "5", tr("Field 4"))); |
3006 | dialog->Field6->setText(getFieldLabel (category, "6", tr("Field 5"))); | 2601 | dialog->Field6->setText(getFieldLabel (category, "6", tr("Field 5"))); |
3007 | 2602 | ||
3008 | QString icon; | 2603 | QString icon; |
3009 | Category *cat= categories.find (category); | 2604 | Category *cat= categories.find (category); |
3010 | if (cat) | 2605 | if (cat) |
3011 | { | 2606 | { |
3012 | icon = cat->getIconName(); | 2607 | icon = cat->getIconName(); |
3013 | } | 2608 | } |
3014 | else | 2609 | else |
3015 | icon = conf->readEntry(APP_KEY+category); | 2610 | icon = conf->readEntry(APP_KEY+category); |
3016 | 2611 | ||
3017 | #ifdef DESKTOP | ||
3018 | QDir d(iconPath); | ||
3019 | #else | ||
3020 | QDir d(QPEApplication::qpeDir() + "pics/"); | 2612 | QDir d(QPEApplication::qpeDir() + "pics/"); |
3021 | #endif | ||
3022 | d.setFilter( QDir::Files); | 2613 | d.setFilter( QDir::Files); |
3023 | 2614 | ||
3024 | const QFileInfoList *list = d.entryInfoList(); | 2615 | const QFileInfoList *list = d.entryInfoList(); |
3025 | int i=0; | 2616 | int i=0; |
3026 | QFileInfoListIterator it( *list ); // create list iterator | 2617 | QFileInfoListIterator it( *list ); // create list iterator |
3027 | QFileInfo *fi; // pointer for traversing | 2618 | QFileInfo *fi; // pointer for traversing |
3028 | if (icon.isEmpty() || icon.isNull()) | 2619 | if (icon.isEmpty() || icon.isNull()) |
3029 | { | 2620 | { |
3030 | dialog->IconField->setCurrentItem(0); | 2621 | dialog->IconField->setCurrentItem(0); |
3031 | } | 2622 | } |
3032 | else | 2623 | else |
3033 | { | 2624 | { |
3034 | while ( (fi=it.current()) ) | 2625 | while ( (fi=it.current()) ) |
3035 | { // for each file... | 2626 | { // for each file... |
3036 | QString fileName = fi->fileName(); | 2627 | QString fileName = fi->fileName(); |
3037 | if(fileName.right(4) == ".png") | 2628 | if(fileName.right(4) == ".png") |
3038 | { | 2629 | { |
3039 | fileName = fileName.mid(0,fileName.length()-4); | 2630 | fileName = fileName.mid(0,fileName.length()-4); |
3040 | 2631 | ||
3041 | if(fileName+".png"==icon) | 2632 | if(fileName+".png"==icon) |
3042 | { | 2633 | { |
3043 | dialog->IconField->setCurrentItem(i+1); | 2634 | dialog->IconField->setCurrentItem(i+1); |
3044 | break; | 2635 | break; |
3045 | } | 2636 | } |
3046 | ++i; | 2637 | ++i; |
3047 | } | 2638 | } |
3048 | ++it; | 2639 | ++it; |
3049 | } | 2640 | } |
3050 | } | 2641 | } |
3051 | } | 2642 | } |
3052 | 2643 | ||
3053 | void ZSafe::saveCategoryDialogFields(CategoryDialog *dialog) | 2644 | void ZSafe::saveCategoryDialogFields(CategoryDialog *dialog) |
3054 | { | 2645 | { |
3055 | QString app_key = APP_KEY; | 2646 | QString app_key = APP_KEY; |
3056 | #ifndef DESKTOP | 2647 | conf->setGroup( "fieldDefs" ); |
3057 | conf->setGroup ("fieldDefs"); | ||
3058 | #else | ||
3059 | #ifndef Q_WS_WIN | ||
3060 | app_key += "/fieldDefs/"; | ||
3061 | #endif | ||
3062 | #endif | ||
3063 | QString category = dialog->CategoryField->currentText(); | 2648 | QString category = dialog->CategoryField->currentText(); |
3064 | // #ifndef Q_WS_WIN | 2649 | // #ifndef Q_WS_WIN |
3065 | conf->writeEntry(app_key+category+"-field1", dialog->Field1->text()); | 2650 | conf->writeEntry(app_key+category+"-field1", dialog->Field1->text()); |
3066 | conf->writeEntry(app_key+category+"-field2", dialog->Field2->text()); | 2651 | conf->writeEntry(app_key+category+"-field2", dialog->Field2->text()); |
3067 | conf->writeEntry(app_key+category+"-field3", dialog->Field3->text()); | 2652 | conf->writeEntry(app_key+category+"-field3", dialog->Field3->text()); |
3068 | conf->writeEntry(app_key+category+"-field4", dialog->Field4->text()); | 2653 | conf->writeEntry(app_key+category+"-field4", dialog->Field4->text()); |
3069 | conf->writeEntry(app_key+category+"-field5", dialog->Field5->text()); | 2654 | conf->writeEntry(app_key+category+"-field5", dialog->Field5->text()); |
3070 | conf->writeEntry(app_key+category+"-field6", dialog->Field6->text()); | 2655 | conf->writeEntry(app_key+category+"-field6", dialog->Field6->text()); |
3071 | // #endif | 2656 | // #endif |
3072 | saveConf(); | 2657 | saveConf(); |
3073 | #ifndef DESKTOP | ||
3074 | conf->setGroup ("zsafe"); | 2658 | conf->setGroup ("zsafe"); |
3075 | #endif | ||
3076 | } | 2659 | } |
3077 | 2660 | ||
3078 | void ZSafe::editCategory() | 2661 | void ZSafe::editCategory() |
3079 | { | 2662 | { |
3080 | if (!selectedItem) | 2663 | if (!selectedItem) |
3081 | return; | 2664 | return; |
3082 | if (isCategory(selectedItem)) | 2665 | if (isCategory(selectedItem)) |
3083 | { | 2666 | { |
3084 | QString category = selectedItem->text(0); | 2667 | QString category = selectedItem->text(0); |
3085 | bool initIcons = false; | 2668 | bool initIcons = false; |
3086 | // open the 'Category' dialog | 2669 | // open the 'Category' dialog |
3087 | CategoryDialog *dialog; | 2670 | CategoryDialog *dialog; |
3088 | if (categoryDialog) | 2671 | if (categoryDialog) |
3089 | { | 2672 | { |
3090 | dialog = categoryDialog; | 2673 | dialog = categoryDialog; |
3091 | } | 2674 | } |
3092 | else | 2675 | else |
3093 | { | 2676 | { |
3094 | categoryDialog = new CategoryDialog(this, tr("Category"), TRUE); | 2677 | categoryDialog = new CategoryDialog(this, tr("Category"), TRUE); |
3095 | #ifdef Q_WS_WIN | ||
3096 | categoryDialog->setCaption ("Qt " + tr("Category")); | ||
3097 | #endif | ||
3098 | dialog = categoryDialog; | 2678 | dialog = categoryDialog; |
3099 | connect( dialog->CategoryField, | 2679 | connect( dialog->CategoryField, |
3100 | SIGNAL( activated(const QString&)), | 2680 | SIGNAL( activated(const QString&)), |
3101 | this, SLOT( categoryFieldActivated(const QString&) ) ); | 2681 | this, SLOT( categoryFieldActivated(const QString&) ) ); |
3102 | initIcons = true; | 2682 | initIcons = true; |
3103 | } | 2683 | } |
3104 | setCategoryDialogFields(dialog); | 2684 | setCategoryDialogFields(dialog); |
3105 | 2685 | ||
3106 | #ifdef DESKTOP | ||
3107 | #ifndef Q_WS_WIN | ||
3108 | QStringList list = conf->entryList( APP_KEY+"/fieldDefs" ); | ||
3109 | #else | ||
3110 | // read all categories from the config file and store | ||
3111 | // into a list | ||
3112 | QFile f (cfgFile); | ||
3113 | QStringList list; | ||
3114 | if ( f.open(IO_ReadOnly) ) { // file opened successfully | ||
3115 | QTextStream t( &f ); // use a text stream | ||
3116 | QString s; | ||
3117 | int n = 1; | ||
3118 | while ( !t.eof() ) { // until end of file... | ||
3119 | s = t.readLine(); // line of text excluding '\n' | ||
3120 | list.append(s); | ||
3121 | } | ||
3122 | f.close(); | ||
3123 | } | ||
3124 | #endif | ||
3125 | #else | ||
3126 | // read all categories from the config file and store | 2686 | // read all categories from the config file and store |
3127 | // into a list | 2687 | // into a list |
3128 | QFile f (cfgFile); | 2688 | QFile f (cfgFile); |
3129 | QStringList list; | 2689 | QStringList list; |
3130 | if ( f.open(IO_ReadOnly) ) { // file opened successfully | 2690 | if ( f.open(IO_ReadOnly) ) { // file opened successfully |
3131 | QTextStream t( &f ); // use a text stream | 2691 | QTextStream t( &f ); // use a text stream |
3132 | QString s; | 2692 | QString s; |
3133 | while ( !t.eof() ) { // until end of file... | 2693 | while ( !t.eof() ) { // until end of file... |
3134 | s = t.readLine(); // line of text excluding '\n' | 2694 | s = t.readLine(); // line of text excluding '\n' |
3135 | list.append(s); | 2695 | list.append(s); |
3136 | } | 2696 | } |
3137 | f.close(); | 2697 | f.close(); |
3138 | } | 2698 | } |
3139 | #endif | ||
3140 | QStringList::Iterator it = list.begin(); | 2699 | QStringList::Iterator it = list.begin(); |
3141 | QString categ; | 2700 | QString categ; |
3142 | dialog->CategoryField->clear(); // remove all items | 2701 | dialog->CategoryField->clear(); // remove all items |
3143 | int i=0; | 2702 | int i=0; |
3144 | bool foundCategory = false; | 2703 | bool foundCategory = false; |
3145 | while( it != list.end() ) | 2704 | while( it != list.end() ) |
3146 | { | 2705 | { |
3147 | QString *cat = new QString (*it); | 2706 | QString *cat = new QString (*it); |
3148 | if (cat->contains("-field1", FALSE)) | 2707 | if (cat->contains("-field1", FALSE)) |
3149 | { | 2708 | { |
3150 | #ifdef DESKTOP | ||
3151 | #ifndef Q_WS_WIN | ||
3152 | categ = cat->section ("-field1", 0, 0); | ||
3153 | #else | ||
3154 | int pos = cat->find ("-field1"); | ||
3155 | categ = cat->left (pos); | ||
3156 | #endif | ||
3157 | #else | ||
3158 | int pos = cat->find ("-field1"); | 2709 | int pos = cat->find ("-field1"); |
3159 | cat->truncate(pos); | 2710 | cat->truncate(pos); |
3160 | categ = *cat; | 2711 | categ = *cat; |
3161 | #endif | ||
3162 | if (!categ.isEmpty()) | 2712 | if (!categ.isEmpty()) |
3163 | { | 2713 | { |
3164 | dialog->CategoryField->insertItem (categ, i); | 2714 | dialog->CategoryField->insertItem (categ, i); |
3165 | if (category.compare(categ) == 0) | 2715 | if (category.compare(categ) == 0) |
3166 | { | 2716 | { |
3167 | dialog->CategoryField->setCurrentItem(i); | 2717 | dialog->CategoryField->setCurrentItem(i); |
3168 | foundCategory = true; | 2718 | foundCategory = true; |
3169 | } | 2719 | } |
3170 | i++; | 2720 | i++; |
3171 | } | 2721 | } |
3172 | } | 2722 | } |
3173 | ++it; | 2723 | ++it; |
3174 | } | 2724 | } |
3175 | if (!foundCategory) | 2725 | if (!foundCategory) |
3176 | { | 2726 | { |
3177 | dialog->CategoryField->insertItem (category, i); | 2727 | dialog->CategoryField->insertItem (category, i); |
3178 | dialog->CategoryField->setCurrentItem(i); | 2728 | dialog->CategoryField->setCurrentItem(i); |
3179 | } | 2729 | } |
3180 | 2730 | ||
3181 | QString icon; | 2731 | QString icon; |
3182 | Category *cat= categories.find (selectedItem->text(0)); | 2732 | Category *cat= categories.find (selectedItem->text(0)); |
3183 | if (cat) | 2733 | if (cat) |
3184 | { | 2734 | { |
3185 | icon = cat->getIconName(); | 2735 | icon = cat->getIconName(); |
3186 | } | 2736 | } |
3187 | 2737 | ||
3188 | if (initIcons) | 2738 | if (initIcons) |
3189 | { | 2739 | { |
3190 | 2740 | ||
3191 | Wait waitDialog(this, tr("Wait dialog")); | 2741 | Wait waitDialog(this, tr("Wait dialog")); |
3192 | waitDialog.waitLabel->setText(tr("Gathering icons...")); | 2742 | waitDialog.waitLabel->setText(tr("Gathering icons...")); |
3193 | waitDialog.show(); | 2743 | waitDialog.show(); |
3194 | qApp->processEvents(); | 2744 | qApp->processEvents(); |
3195 | 2745 | ||
3196 | #ifdef DESKTOP | ||
3197 | QDir d(iconPath); | ||
3198 | #else | ||
3199 | QDir d(QPEApplication::qpeDir() + "pics/"); | 2746 | QDir d(QPEApplication::qpeDir() + "pics/"); |
3200 | #endif | ||
3201 | d.setFilter( QDir::Files); | 2747 | d.setFilter( QDir::Files); |
3202 | 2748 | ||
3203 | const QFileInfoList *list = d.entryInfoList(); | 2749 | const QFileInfoList *list = d.entryInfoList(); |
3204 | int i=0; | 2750 | int i=0; |
3205 | QFileInfoListIterator it( *list ); // create list iterator | 2751 | QFileInfoListIterator it( *list ); // create list iterator |
3206 | QFileInfo *fi; // pointer for traversing | 2752 | QFileInfo *fi; // pointer for traversing |
3207 | if (icon.isEmpty() || icon.isNull()) | 2753 | if (icon.isEmpty() || icon.isNull()) |
3208 | { | 2754 | { |
3209 | dialog->IconField->setCurrentItem(0); | 2755 | dialog->IconField->setCurrentItem(0); |
3210 | } | 2756 | } |
3211 | 2757 | ||
3212 | dialog->IconField->insertItem("predefined"); | 2758 | dialog->IconField->insertItem("predefined"); |
3213 | while ( (fi=it.current()) ) { // for each file... | 2759 | while ( (fi=it.current()) ) { // for each file... |
3214 | QString fileName = fi->fileName(); | 2760 | QString fileName = fi->fileName(); |
3215 | if(fileName.right(4) == ".png") | 2761 | if(fileName.right(4) == ".png") |
3216 | { | 2762 | { |
3217 | fileName = fileName.mid(0,fileName.length()-4); | 2763 | fileName = fileName.mid(0,fileName.length()-4); |
3218 | #ifdef DESKTOP | ||
3219 | QPixmap imageOfFile; | ||
3220 | imageOfFile.load(iconPath + fi->fileName()); | ||
3221 | #else | ||
3222 | QPixmap imageOfFile(Resource::loadPixmap(fileName)); | 2764 | QPixmap imageOfFile(Resource::loadPixmap(fileName)); |
3223 | #endif | ||
3224 | QImage foo = imageOfFile.convertToImage(); | 2765 | QImage foo = imageOfFile.convertToImage(); |
3225 | foo = foo.smoothScale(16,16); | 2766 | foo = foo.smoothScale(16,16); |
3226 | imageOfFile.convertFromImage(foo); | 2767 | imageOfFile.convertFromImage(foo); |
3227 | dialog->IconField->insertItem(imageOfFile,fileName); | 2768 | dialog->IconField->insertItem(imageOfFile,fileName); |
3228 | if(fileName+".png"==icon) | 2769 | if(fileName+".png"==icon) |
3229 | dialog->IconField->setCurrentItem(i+1); | 2770 | dialog->IconField->setCurrentItem(i+1); |
3230 | ++i; | 2771 | ++i; |
3231 | } | 2772 | } |
3232 | ++it; | 2773 | ++it; |
3233 | } | 2774 | } |
3234 | waitDialog.hide(); | 2775 | waitDialog.hide(); |
3235 | } | 2776 | } |
3236 | else | 2777 | else |
3237 | { | 2778 | { |
3238 | #ifdef DESKTOP | ||
3239 | // QDir d(QDir::homeDirPath() + "/pics/"); | ||
3240 | QDir d(iconPath); | ||
3241 | #else | ||
3242 | QDir d(QPEApplication::qpeDir() + "pics/"); | 2779 | QDir d(QPEApplication::qpeDir() + "pics/"); |
3243 | #endif | ||
3244 | d.setFilter( QDir::Files); | 2780 | d.setFilter( QDir::Files); |
3245 | 2781 | ||
3246 | const QFileInfoList *list = d.entryInfoList(); | 2782 | const QFileInfoList *list = d.entryInfoList(); |
3247 | int i=0; | 2783 | int i=0; |
3248 | QFileInfoListIterator it( *list ); // create list iterator | 2784 | QFileInfoListIterator it( *list ); // create list iterator |
3249 | QFileInfo *fi; // pointer for traversing | 2785 | QFileInfo *fi; // pointer for traversing |
3250 | if (icon.isEmpty() || icon.isNull()) | 2786 | if (icon.isEmpty() || icon.isNull()) |
3251 | { | 2787 | { |
3252 | dialog->IconField->setCurrentItem(0); | 2788 | dialog->IconField->setCurrentItem(0); |
3253 | } | 2789 | } |
3254 | else | 2790 | else |
3255 | { | 2791 | { |
3256 | 2792 | ||
3257 | while ( (fi=it.current()) ) | 2793 | while ( (fi=it.current()) ) |
3258 | { // for each file... | 2794 | { // for each file... |
3259 | QString fileName = fi->fileName(); | 2795 | QString fileName = fi->fileName(); |
3260 | if(fileName.right(4) == ".png") | 2796 | if(fileName.right(4) == ".png") |
3261 | { | 2797 | { |
3262 | fileName = fileName.mid(0,fileName.length()-4); | 2798 | fileName = fileName.mid(0,fileName.length()-4); |
3263 | 2799 | ||
3264 | 2800 | ||
3265 | if(fileName+".png"==icon) | 2801 | if(fileName+".png"==icon) |
3266 | { | 2802 | { |
3267 | dialog->IconField->setCurrentItem(i+1); | 2803 | dialog->IconField->setCurrentItem(i+1); |
3268 | break; | 2804 | break; |
3269 | } | 2805 | } |
3270 | ++i; | 2806 | ++i; |
3271 | } | 2807 | } |
3272 | ++it; | 2808 | ++it; |
3273 | } | 2809 | } |
3274 | } | 2810 | } |
3275 | } | 2811 | } |
3276 | 2812 | ||
3277 | // dialog->show(); | 2813 | // dialog->show(); |
3278 | #ifndef DESKTOP | 2814 | QDialog::DialogCode result = (QDialog::DialogCode) dialog->exec(); |
3279 | // dialog->move (20, 100); | ||
3280 | #endif | ||
3281 | DialogCode result = (DialogCode) dialog->exec(); | ||
3282 | #ifdef DESKTOP | ||
3283 | result = Accepted; | ||
3284 | #endif | ||
3285 | 2815 | ||
3286 | QString fullIconPath; | 2816 | QString fullIconPath; |
3287 | QPixmap *pix; | 2817 | QPixmap *pix; |
3288 | if (result == Accepted) | 2818 | if (result == QDialog::Accepted) |
3289 | { | 2819 | { |
3290 | modified = true; | 2820 | modified = true; |
3291 | if (category != dialog->CategoryField->currentText()) | 2821 | if (category != dialog->CategoryField->currentText()) |
3292 | { | 2822 | { |
3293 | categories.remove (category); | 2823 | categories.remove (category); |
3294 | // #ifndef Q_WS_WIN | 2824 | // #ifndef Q_WS_WIN |
3295 | conf->removeEntry(category); | 2825 | conf->removeEntry(category); |
3296 | // #endif | 2826 | // #endif |
3297 | saveConf(); | 2827 | saveConf(); |
3298 | } | 2828 | } |
3299 | 2829 | ||
3300 | category = dialog->CategoryField->currentText(); | 2830 | category = dialog->CategoryField->currentText(); |
3301 | icon = dialog->IconField->currentText()+".png"; | 2831 | icon = dialog->IconField->currentText()+".png"; |
3302 | 2832 | ||
3303 | if (cat) | 2833 | if (cat) |
3304 | { | 2834 | { |
3305 | #ifndef NO_OPIE | ||
3306 | owarn << "Category found" << oendl; | ||
3307 | #else | ||
3308 | qWarning("Category found"); | ||
3309 | #endif | ||
3310 | |||
3311 | // if (!icon.isEmpty() && !icon.isNull()) | 2835 | // if (!icon.isEmpty() && !icon.isNull()) |
3312 | if (icon != "predefined.png") | 2836 | if (icon != "predefined.png") |
3313 | { | 2837 | { |
3314 | // build the full path | 2838 | // build the full path |
3315 | fullIconPath = iconPath + icon; | 2839 | fullIconPath = iconPath + icon; |
3316 | pix = new QPixmap (fullIconPath); | 2840 | pix = new QPixmap (fullIconPath); |
3317 | if (!pix->isNull()) | 2841 | if (!pix->isNull()) |
3318 | { | 2842 | { |
3319 | // save the full pixmap name into the config file | 2843 | // save the full pixmap name into the config file |
3320 | // #ifndef Q_WS_WIN | 2844 | // #ifndef Q_WS_WIN |
3321 | conf->writeEntry(APP_KEY+category, icon); | 2845 | conf->writeEntry(APP_KEY+category, icon); |
3322 | // #endif | 2846 | // #endif |
3323 | saveConf(); | 2847 | saveConf(); |
3324 | QImage img = pix->convertToImage(); | 2848 | QImage img = pix->convertToImage(); |
3325 | pix->convertFromImage(img.smoothScale(14,14)); | 2849 | pix->convertFromImage(img.smoothScale(14,14)); |
3326 | cat->setIconName (icon); | 2850 | cat->setIconName (icon); |
3327 | cat->setIcon (*pix); | 2851 | cat->setIcon (*pix); |
3328 | } | 2852 | } |
3329 | } | 2853 | } |
3330 | else | 2854 | else |
3331 | { | 2855 | { |
3332 | // #ifndef Q_WS_WIN | 2856 | // #ifndef Q_WS_WIN |
3333 | conf->removeEntry (category); | 2857 | conf->removeEntry (category); |
3334 | // #endif | 2858 | // #endif |
3335 | saveConf(); | 2859 | saveConf(); |
3336 | cat->setIcon (*getPredefinedIcon(category)); | 2860 | cat->setIcon (*getPredefinedIcon(category)); |
3337 | } | 2861 | } |
3338 | 2862 | ||
3339 | // change the category name of the selected category | 2863 | // change the category name of the selected category |
3340 | QListViewItem *catItem = cat->getListItem(); | 2864 | QListViewItem *catItem = cat->getListItem(); |
3341 | if (catItem) | 2865 | if (catItem) |
3342 | { | 2866 | { |
3343 | #ifndef NO_OPIE | ||
3344 | owarn << category << oendl; | ||
3345 | #else | ||
3346 | qWarning (category); | ||
3347 | #endif | ||
3348 | catItem->setText( 0, tr( category ) ); | 2867 | catItem->setText( 0, tr( category ) ); |
3349 | cat->setCategoryName (tr(category)); | 2868 | cat->setCategoryName (tr(category)); |
3350 | 2869 | ||
3351 | cat->initListItem(); | 2870 | cat->initListItem(); |
3352 | categories.insert (category, cat); | 2871 | categories.insert (category, cat); |
3353 | } | 2872 | } |
3354 | } | 2873 | } |
3355 | saveCategoryDialogFields(dialog); | 2874 | saveCategoryDialogFields(dialog); |
3356 | } | 2875 | } |
3357 | else | 2876 | else |
3358 | { | 2877 | { |
3359 | // delete dialog; | 2878 | // delete dialog; |
3360 | dialog->hide(); | 2879 | dialog->hide(); |
3361 | return; | 2880 | return; |
3362 | } | 2881 | } |
3363 | 2882 | ||
3364 | } | 2883 | } |
3365 | } | 2884 | } |
3366 | 2885 | ||
3367 | void ZSafe::cutItem() | 2886 | void ZSafe::cutItem() |
3368 | { | 2887 | { |
3369 | if (!selectedItem) | 2888 | if (!selectedItem) |
3370 | return; | 2889 | return; |
3371 | if (!isCategory(selectedItem)) | 2890 | if (!isCategory(selectedItem)) |
3372 | { | 2891 | { |
3373 | IsCut = true; | 2892 | IsCut = true; |
3374 | copiedItem = selectedItem; | 2893 | copiedItem = selectedItem; |
3375 | } | 2894 | } |
3376 | } | 2895 | } |
3377 | 2896 | ||
3378 | void ZSafe::copyItem() | 2897 | void ZSafe::copyItem() |
3379 | { | 2898 | { |
@@ -3452,428 +2971,346 @@ void ZSafe::newDocument() | |||
3452 | 2971 | ||
3453 | // clear the password list | 2972 | // clear the password list |
3454 | QListViewItem *i; | 2973 | QListViewItem *i; |
3455 | QListViewItem *c = NULL; | 2974 | QListViewItem *c = NULL; |
3456 | // step through all categories | 2975 | // step through all categories |
3457 | for (i = ListView->firstChild(); | 2976 | for (i = ListView->firstChild(); |
3458 | i != NULL; | 2977 | i != NULL; |
3459 | i = i->nextSibling()) | 2978 | i = i->nextSibling()) |
3460 | { | 2979 | { |
3461 | if (c) delete c; // delete the previous category | 2980 | if (c) delete c; // delete the previous category |
3462 | 2981 | ||
3463 | c = i; | 2982 | c = i; |
3464 | // step through all subitems | 2983 | // step through all subitems |
3465 | QListViewItem *si; | 2984 | QListViewItem *si; |
3466 | for (si = i->firstChild(); | 2985 | for (si = i->firstChild(); |
3467 | si != NULL; ) | 2986 | si != NULL; ) |
3468 | { | 2987 | { |
3469 | QListViewItem *_si = si; | 2988 | QListViewItem *_si = si; |
3470 | si = si->nextSibling(); | 2989 | si = si->nextSibling(); |
3471 | i->takeItem(_si); // remove from view list | 2990 | i->takeItem(_si); // remove from view list |
3472 | if (_si) delete _si; | 2991 | if (_si) delete _si; |
3473 | } | 2992 | } |
3474 | } | 2993 | } |
3475 | if (c) delete c; // delete the previous category | 2994 | if (c) delete c; // delete the previous category |
3476 | categories.clear(); | 2995 | categories.clear(); |
3477 | 2996 | ||
3478 | // m_password = ""; | 2997 | // m_password = ""; |
3479 | selectedItem = NULL; | 2998 | selectedItem = NULL; |
3480 | 2999 | ||
3481 | filename = newFile; | 3000 | filename = newFile; |
3482 | 3001 | ||
3483 | // save the current filename to the config file | 3002 | // save the current filename to the config file |
3003 | conf->setGroup("zsafe"); | ||
3484 | conf->writeEntry(APP_KEY+"document", filename); | 3004 | conf->writeEntry(APP_KEY+"document", filename); |
3485 | saveConf(); | 3005 | saveConf(); |
3486 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); | 3006 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); |
3487 | #ifdef Q_WS_WIN | 3007 | this->setCaption(tr("ZSafe: ") + ti); |
3488 | this->setCaption("Qt ZSafe: " + ti); | ||
3489 | #else | ||
3490 | this->setCaption("ZSafe: " + ti); | ||
3491 | #endif | ||
3492 | 3008 | ||
3493 | // openDocument(filename); | 3009 | // openDocument(filename); |
3494 | 3010 | ||
3495 | QMessageBox::information( this, tr("ZSafe"), | 3011 | QMessageBox::information( this, tr("ZSafe"), |
3496 | tr("Now you have to enter\na password twice for your\nnewly created document."), tr("&OK"), 0); | 3012 | tr("Now you have to enter\na password twice for your\nnewly created document."), tr("&OK"), 0); |
3497 | 3013 | ||
3498 | saveDocumentWithPwd(); | 3014 | saveDocumentWithPwd(); |
3499 | } | 3015 | } |
3500 | } | 3016 | } |
3501 | 3017 | ||
3502 | void ZSafe::loadDocument() | 3018 | void ZSafe::loadDocument() |
3503 | { | 3019 | { |
3504 | 3020 | ||
3505 | // open the file dialog | 3021 | // open the file dialog |
3506 | #ifndef DESKTOP | ||
3507 | #ifndef NO_OPIE | ||
3508 | QMap<QString, QStringList> mimeTypes; | 3022 | QMap<QString, QStringList> mimeTypes; |
3509 | mimeTypes.insert(tr("All"), QStringList() ); | 3023 | mimeTypes.insert(tr("All"), QStringList() ); |
3510 | mimeTypes.insert(tr("ZSafe"), "zsafe/*" ); | 3024 | mimeTypes.insert(tr("ZSafe"), "zsafe/*" ); |
3511 | QString newFile = OFileDialog::getOpenFileName( OFileSelector::EXTENDED_ALL, | 3025 | QString newFile = OFileDialog::getOpenFileName( OFileSelector::EXTENDED_ALL, |
3512 | QDir::homeDirPath() + "/Documents/application/zsafe", | 3026 | QDir::homeDirPath() + "/Documents/application/zsafe", |
3513 | QString::null, | 3027 | QString::null, |
3514 | mimeTypes, | 3028 | mimeTypes, |
3515 | this, | 3029 | this, |
3516 | tr ("Open ZSafe document")); | 3030 | tr ("Open ZSafe document")); |
3517 | #else | ||
3518 | QString newFile = ScQtFileEdit::getOpenFileName(this, | ||
3519 | tr ("Open ZSafe document"), | ||
3520 | QDir::homeDirPath() + "/Documents/application/zsafe", | ||
3521 | "*.zsf"); | ||
3522 | #endif | ||
3523 | #else | ||
3524 | QString newFile = QFileDialog::getOpenFileName( | ||
3525 | QDir::homeDirPath() + "/Documents/application/zsafe", | ||
3526 | "ZSafe (*.zsf)", | ||
3527 | this, | ||
3528 | "ZSafe File Dialog" | ||
3529 | "Choose a ZSafe file" ); | ||
3530 | #endif | ||
3531 | 3031 | ||
3532 | // open the new document | 3032 | // open the new document |
3533 | if (newFile && newFile.length() > 0 ) | 3033 | if (newFile && newFile.length() > 0 ) |
3534 | { | 3034 | { |
3535 | // save the previous opened document | 3035 | // save the previous opened document |
3536 | if (!filename.isEmpty()) | 3036 | if (!filename.isEmpty()) |
3537 | saveDocument(filename, FALSE); | 3037 | saveDocument(filename, FALSE); |
3538 | 3038 | ||
3539 | // clear the password list | 3039 | // clear the password list |
3540 | QListViewItem *i; | 3040 | QListViewItem *i; |
3541 | QListViewItem *c = NULL; | 3041 | QListViewItem *c = NULL; |
3542 | // step through all categories | 3042 | // step through all categories |
3543 | for (i = ListView->firstChild(); | 3043 | for (i = ListView->firstChild(); |
3544 | i != NULL; | 3044 | i != NULL; |
3545 | i = i->nextSibling()) | 3045 | i = i->nextSibling()) |
3546 | { | 3046 | { |
3547 | if (c) delete c; // delete the previous category | 3047 | if (c) delete c; // delete the previous category |
3548 | 3048 | ||
3549 | c = i; | 3049 | c = i; |
3550 | // step through all subitems | 3050 | // step through all subitems |
3551 | QListViewItem *si; | 3051 | QListViewItem *si; |
3552 | for (si = i->firstChild(); | 3052 | for (si = i->firstChild(); |
3553 | si != NULL; ) | 3053 | si != NULL; ) |
3554 | { | 3054 | { |
3555 | QListViewItem *_si = si; | 3055 | QListViewItem *_si = si; |
3556 | si = si->nextSibling(); | 3056 | si = si->nextSibling(); |
3557 | i->takeItem(_si); // remove from view list | 3057 | i->takeItem(_si); // remove from view list |
3558 | if (_si) delete _si; | 3058 | if (_si) delete _si; |
3559 | } | 3059 | } |
3560 | } | 3060 | } |
3561 | if (c) delete c; // delete the previous category | 3061 | if (c) delete c; // delete the previous category |
3562 | categories.clear(); | 3062 | categories.clear(); |
3563 | m_password = ""; | 3063 | m_password = ""; |
3564 | selectedItem = NULL; | 3064 | selectedItem = NULL; |
3565 | filename = newFile; | 3065 | filename = newFile; |
3566 | 3066 | ||
3567 | // save the current filename to the config file | 3067 | // save the current filename to the config file |
3068 | conf->setGroup("zsafe"); | ||
3568 | conf->writeEntry(APP_KEY+"document", filename); | 3069 | conf->writeEntry(APP_KEY+"document", filename); |
3569 | saveConf(); | 3070 | saveConf(); |
3570 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); | 3071 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); |
3571 | #ifdef Q_WS_WIN | 3072 | this->setCaption(tr("ZSafe: ") + ti); |
3572 | this->setCaption("Qt ZSafe: " + ti); | ||
3573 | #else | ||
3574 | this->setCaption("ZSafe: " + ti); | ||
3575 | #endif | ||
3576 | 3073 | ||
3577 | openDocument(filename); | 3074 | openDocument(filename); |
3578 | } | 3075 | } |
3579 | } | 3076 | } |
3580 | 3077 | ||
3581 | void ZSafe::saveDocumentAs() | 3078 | void ZSafe::saveDocumentAs() |
3582 | { | 3079 | { |
3583 | 3080 | ||
3584 | QString newFile = zsaveDialog(); | 3081 | QString newFile = zsaveDialog(); |
3585 | // open the new document | 3082 | // open the new document |
3586 | if (newFile && newFile.length() > 0 ) | 3083 | if (newFile && newFile.length() > 0 ) |
3587 | { | 3084 | { |
3588 | // save the previous opened document | 3085 | // save the previous opened document |
3589 | if (!filename.isEmpty()) | 3086 | if (!filename.isEmpty()) |
3590 | saveDocument(filename, FALSE); | 3087 | saveDocument(filename, FALSE); |
3591 | 3088 | ||
3592 | selectedItem = NULL; | 3089 | selectedItem = NULL; |
3593 | filename = newFile; | 3090 | filename = newFile; |
3594 | 3091 | ||
3595 | // save the current filename to the config file | 3092 | // save the current filename to the config file |
3093 | conf->setGroup("zsafe"); | ||
3596 | conf->writeEntry(APP_KEY+"document", filename); | 3094 | conf->writeEntry(APP_KEY+"document", filename); |
3597 | saveConf(); | 3095 | saveConf(); |
3598 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); | 3096 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); |
3599 | #ifdef Q_WS_WIN | 3097 | this->setCaption(tr("ZSafe: ") + ti); |
3600 | this->setCaption("Qt ZSafe: " + ti); | ||
3601 | #else | ||
3602 | this->setCaption("ZSafe: " + ti); | ||
3603 | #endif | ||
3604 | 3098 | ||
3605 | QMessageBox::information( this, tr("ZSafe"), | 3099 | QMessageBox::information( this, tr("ZSafe"), |
3606 | tr("Now you have to enter\na password twice for your\nnewly created document."), tr("&OK"), 0); | 3100 | tr("Now you have to enter\na password twice for your\nnewly created document."), tr("&OK"), 0); |
3607 | 3101 | ||
3608 | saveDocumentWithPwd(); | 3102 | saveDocumentWithPwd(); |
3609 | } | 3103 | } |
3610 | } | 3104 | } |
3611 | 3105 | ||
3612 | void ZSafe::saveDocumentWithoutPwd() | 3106 | void ZSafe::saveDocumentWithoutPwd() |
3613 | { | 3107 | { |
3614 | saveDocument(filename, FALSE); | 3108 | saveDocument(filename, FALSE); |
3615 | } | 3109 | } |
3616 | 3110 | ||
3617 | void ZSafe::saveDocumentWithPwd() | 3111 | void ZSafe::saveDocumentWithPwd() |
3618 | { | 3112 | { |
3619 | saveDocument(filename, TRUE); | 3113 | saveDocument(filename, TRUE); |
3620 | } | 3114 | } |
3621 | 3115 | ||
3622 | void ZSafe::about() | 3116 | void ZSafe::about() |
3623 | { | 3117 | { |
3624 | QString info; | 3118 | QString info; |
3625 | #ifdef JPATCH_HDE | 3119 | info = tr("<html><body><div align=""center"">" |
3626 | info = "<html><body><div align=""center"">"; | 3120 | "<b>" |
3627 | info += "<b>"; | 3121 | "Zaurus Password Manager<br>" |
3628 | info += tr("Zaurus Password Manager<br>"); | 3122 | "ZSafe version 2.1.2<br>" |
3629 | info += tr("ZSafe version 2.1.2-jv01b<br>"); | 3123 | "</b>" |
3630 | info += "</b>"; | 3124 | "by Carsten Schneider<br>" |
3631 | info += tr("by Carsten Schneider<br>"); | 3125 | "zcarsten@gmx.net<br>" |
3632 | info += "zcarsten@gmx.net<br>"; | 3126 | "http://z-soft.z-portal.info/zsafe" |
3633 | info += "http://z-soft.z-portal.info/zsafe"; | 3127 | "<br>" |
3634 | info += "<br>"; | 3128 | "Translations by Robert Ernst<br>" |
3635 | info += tr("Translations by Robert Ernst<br>"); | 3129 | "robert.ernst@linux-solutions.at<br>" |
3636 | info += "robert.ernst@linux-solutions.at<br>"; | 3130 | "<br></div>" |
3637 | 3131 | "</body></html>"); | |
3638 | info += "<br><br>"; | ||
3639 | info += QString::fromUtf8("æ~W¥æ~\\¬èª~^/VGA Zaurus対å¿~\\ã~C~Qã~C~Cã~C~Aä½~\\æ ~H~P<br>"); | ||
3640 | info += "HADECO R&D<br>"; | ||
3641 | info += "r&d@hadeco.co.jp<br>"; | ||
3642 | info += "http://www.hadeco.co.jp/r&d/<br>"; | ||
3643 | info += "<br></div>"; | ||
3644 | info += "</body></html>"; | ||
3645 | #else | ||
3646 | info = "<html><body><div align=""center"">"; | ||
3647 | info += "<b>"; | ||
3648 | info += tr("Zaurus Password Manager<br>"); | ||
3649 | info += tr("ZSafe version 2.1.2<br>"); | ||
3650 | info += "</b>"; | ||
3651 | info += tr("by Carsten Schneider<br>"); | ||
3652 | info += "zcarsten@gmx.net<br>"; | ||
3653 | info += "http://z-soft.z-portal.info/zsafe"; | ||
3654 | info += "<br>"; | ||
3655 | info += tr("Translations by Robert Ernst<br>"); | ||
3656 | info += "robert.ernst@linux-solutions.at<br>"; | ||
3657 | info += "<br></div>"; | ||
3658 | info += "</body></html>"; | ||
3659 | #endif | ||
3660 | 3132 | ||
3661 | // QMessageBox::information( this, tr("ZSafe"), info, tr("&OK"), 0); | 3133 | // QMessageBox::information( this, tr("ZSafe"), info, tr("&OK"), 0); |
3662 | 3134 | ||
3663 | QMessageBox mb( this, tr("ZSafe")); | 3135 | QMessageBox mb( this, tr("ZSafe")); |
3664 | mb.setText (info); | 3136 | mb.setText (info); |
3665 | mb.setButtonText (QMessageBox::Ok, tr ("&OK")); | 3137 | mb.setButtonText (QMessageBox::Ok, tr ("&OK")); |
3666 | QPixmap zsafe_img((const char**) zsafe_xpm); | 3138 | QPixmap zsafe_img((const char**) zsafe_xpm); |
3667 | mb.setIconPixmap (zsafe_img); | 3139 | mb.setIconPixmap (zsafe_img); |
3668 | mb.exec(); | 3140 | mb.exec(); |
3669 | } | 3141 | } |
3670 | 3142 | ||
3671 | void ZSafe::setExpandFlag() | 3143 | void ZSafe::setExpandFlag() |
3672 | { | 3144 | { |
3673 | expandTree = !expandTree; | 3145 | expandTree = !expandTree; |
3674 | file->setItemChecked('o', expandTree); | 3146 | file->setItemChecked('o', expandTree); |
3675 | #ifndef DESKTOP | ||
3676 | conf->setGroup ("zsafePrefs"); | 3147 | conf->setGroup ("zsafePrefs"); |
3677 | #endif | ||
3678 | // #ifndef Q_WS_WIN | 3148 | // #ifndef Q_WS_WIN |
3679 | conf->writeEntry (APP_KEY+"expandTree", expandTree); | 3149 | conf->writeEntry (APP_KEY+"expandTree", expandTree); |
3680 | // #endif | 3150 | // #endif |
3681 | saveConf(); | 3151 | saveConf(); |
3682 | 3152 | ||
3683 | } | 3153 | } |
3684 | 3154 | ||
3685 | void ZSafe::paintEvent( QPaintEvent * ) | 3155 | void ZSafe::paintEvent( QPaintEvent * ) |
3686 | { | 3156 | { |
3687 | if (raiseFlag) | 3157 | if (raiseFlag) |
3688 | { | 3158 | { |
3689 | raiseFlag = false; | 3159 | raiseFlag = false; |
3690 | raiseTimer.start (1, true); | 3160 | raiseTimer.start (1, true); |
3691 | if (infoForm->isVisible()) | 3161 | if (infoForm->isVisible()) |
3692 | infoForm->raise(); | 3162 | infoForm->raise(); |
3693 | } | 3163 | } |
3694 | } | 3164 | } |
3695 | 3165 | ||
3696 | void ZSafe::resizeEvent ( QResizeEvent * ) | 3166 | void ZSafe::resizeEvent ( QResizeEvent * ) |
3697 | { | 3167 | { |
3698 | // owarn << "resizeEvent" << oendl; | 3168 | // owarn << "resizeEvent" << oendl; |
3699 | #ifndef DESKTOP | ||
3700 | DeskW = appl->desktop()->width(); | 3169 | DeskW = appl->desktop()->width(); |
3701 | DeskH = appl->desktop()->height(); | 3170 | DeskH = appl->desktop()->height(); |
3702 | #else | ||
3703 | DeskW = this->width(); | ||
3704 | DeskH = this->height(); | ||
3705 | #endif | ||
3706 | 3171 | ||
3707 | if (New) | 3172 | if (New) |
3708 | New->setGeometry ( QRect( DeskW-84, 2, 20, 20 ) ); | 3173 | New->setGeometry ( QRect( DeskW-84, 2, 20, 20 ) ); |
3709 | if (Edit) | 3174 | if (Edit) |
3710 | Edit->setGeometry ( QRect( DeskW-64, 2, 20, 20 ) ); | 3175 | Edit->setGeometry ( QRect( DeskW-64, 2, 20, 20 ) ); |
3711 | if (Delete) | 3176 | if (Delete) |
3712 | Delete->setGeometry( QRect( DeskW-44, 2, 20, 20 ) ); | 3177 | Delete->setGeometry( QRect( DeskW-44, 2, 20, 20 ) ); |
3713 | if (Find) | 3178 | if (Find) |
3714 | Find->setGeometry ( QRect( DeskW-24, 2, 20, 20 ) ); | 3179 | Find->setGeometry ( QRect( DeskW-24, 2, 20, 20 ) ); |
3715 | } | 3180 | } |
3716 | 3181 | ||
3717 | void ZSafe::slotRaiseTimer() | 3182 | void ZSafe::slotRaiseTimer() |
3718 | { | 3183 | { |
3719 | if (infoForm->isVisible()) | 3184 | if (infoForm->isVisible()) |
3720 | infoForm->raise(); | 3185 | infoForm->raise(); |
3721 | raiseFlag = true; | 3186 | raiseFlag = true; |
3722 | } | 3187 | } |
3723 | 3188 | ||
3724 | QPixmap * ZSafe::getPredefinedIcon(QString category) | 3189 | QPixmap * ZSafe::getPredefinedIcon(QString category) |
3725 | { | 3190 | { |
3726 | QPixmap *pm; | 3191 | QPixmap *pm; |
3727 | if (category == "Bank cards") | 3192 | if (category == "Bank cards") |
3728 | pm = new QPixmap((const char**)bank_cards_data); | 3193 | pm = new QPixmap((const char**)bank_cards_data); |
3729 | else if (category == "Passwords") | 3194 | else if (category == "Passwords") |
3730 | pm = new QPixmap((const char**)passwords_data); | 3195 | pm = new QPixmap((const char**)passwords_data); |
3731 | else if (category == "Software") | 3196 | else if (category == "Software") |
3732 | pm = new QPixmap((const char**)software_data); | 3197 | pm = new QPixmap((const char**)software_data); |
3733 | else if (category == "General") | 3198 | else if (category == "General") |
3734 | pm = new QPixmap((const char**)general_data); | 3199 | pm = new QPixmap((const char**)general_data); |
3735 | else | 3200 | else |
3736 | pm = new QPixmap((const char**)general_data); | 3201 | pm = new QPixmap((const char**)general_data); |
3737 | return pm; | 3202 | return pm; |
3738 | } | 3203 | } |
3739 | 3204 | ||
3740 | void ZSafe::setDocument(const QString& fileref) | 3205 | void ZSafe::setDocument(const QString& fileref) |
3741 | { | 3206 | { |
3742 | #ifndef DESKTOP | ||
3743 | // stop the timer to prevent loading of the default document | 3207 | // stop the timer to prevent loading of the default document |
3744 | docuTimer.stop(); | 3208 | docuTimer.stop(); |
3745 | 3209 | ||
3746 | DocLnk link(fileref); | 3210 | DocLnk link(fileref); |
3747 | if ( link.isValid() ) | 3211 | if ( link.isValid() ) |
3748 | { | 3212 | { |
3749 | // if (filename != link.file()) | 3213 | // if (filename != link.file()) |
3750 | // saveDocument(filename, FALSE); | 3214 | // saveDocument(filename, FALSE); |
3751 | filename = link.file(); | 3215 | filename = link.file(); |
3752 | } | 3216 | } |
3753 | else | 3217 | else |
3754 | { | 3218 | { |
3755 | // if (filename != fileref) | 3219 | // if (filename != fileref) |
3756 | // saveDocument(filename, FALSE); | 3220 | // saveDocument(filename, FALSE); |
3757 | filename = fileref; | 3221 | filename = fileref; |
3758 | } | 3222 | } |
3759 | // save the current filename to the config file | 3223 | // save the current filename to the config file |
3224 | conf->setGroup("zsafe"); | ||
3760 | conf->writeEntry(APP_KEY+"document", filename); | 3225 | conf->writeEntry(APP_KEY+"document", filename); |
3761 | saveConf(); | 3226 | saveConf(); |
3762 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); | 3227 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); |
3763 | #ifdef Q_WS_WIN | 3228 | this->setCaption(tr("ZSafe: ") + ti); |
3764 | this->setCaption("Qt ZSafe: " + ti); | ||
3765 | #else | ||
3766 | this->setCaption("ZSafe: " + ti); | ||
3767 | #endif | ||
3768 | 3229 | ||
3769 | // clear the password list | 3230 | // clear the password list |
3770 | QListViewItem *i; | 3231 | QListViewItem *i; |
3771 | QListViewItem *c = NULL; | 3232 | QListViewItem *c = NULL; |
3772 | // step through all categories | 3233 | // step through all categories |
3773 | for (i = ListView->firstChild(); | 3234 | for (i = ListView->firstChild(); |
3774 | i != NULL; | 3235 | i != NULL; |
3775 | i = i->nextSibling()) | 3236 | i = i->nextSibling()) |
3776 | { | 3237 | { |
3777 | if (c) delete c; // delete the previous category | 3238 | if (c) delete c; // delete the previous category |
3778 | 3239 | ||
3779 | c = i; | 3240 | c = i; |
3780 | // step through all subitems | 3241 | // step through all subitems |
3781 | QListViewItem *si; | 3242 | QListViewItem *si; |
3782 | for (si = i->firstChild(); | 3243 | for (si = i->firstChild(); |
3783 | si != NULL; ) | 3244 | si != NULL; ) |
3784 | { | 3245 | { |
3785 | QListViewItem *_si = si; | 3246 | QListViewItem *_si = si; |
3786 | si = si->nextSibling(); | 3247 | si = si->nextSibling(); |
3787 | i->takeItem(_si); // remove from view list | 3248 | i->takeItem(_si); // remove from view list |
3788 | if (_si) delete _si; | 3249 | if (_si) delete _si; |
3789 | } | 3250 | } |
3790 | } | 3251 | } |
3791 | if (c) delete c; // delete the previous category | 3252 | if (c) delete c; // delete the previous category |
3792 | categories.clear(); | 3253 | categories.clear(); |
3793 | 3254 | ||
3794 | m_password = ""; | 3255 | m_password = ""; |
3795 | selectedItem = NULL; | 3256 | selectedItem = NULL; |
3796 | 3257 | ||
3797 | openDocument(filename); | 3258 | openDocument(filename); |
3798 | #else | ||
3799 | Q_UNUSED(fileref); | ||
3800 | #endif | ||
3801 | } | 3259 | } |
3802 | 3260 | ||
3803 | 3261 | ||
3804 | void ZSafe::ListPressed(int mouse, QListViewItem *item, const QPoint&, int column) { | 3262 | void ZSafe::ListPressed(int mouse, QListViewItem *item, const QPoint&, int column) { |
3805 | if(item ==0) return; | 3263 | if(item ==0) return; |
3806 | switch (mouse) { | 3264 | switch (mouse) { |
3807 | case 1: | 3265 | case 1: |
3808 | { | ||
3809 | #ifdef DESKTOP | ||
3810 | QDragObject *d = new QTextDrag( item->text(column) , this ); | ||
3811 | d->dragCopy(); | ||
3812 | #endif | ||
3813 | } | ||
3814 | break; | 3266 | break; |
3815 | case 2: | 3267 | case 2: |
3816 | { | 3268 | { |
3817 | QClipboard *cb = QApplication::clipboard(); | 3269 | QClipboard *cb = QApplication::clipboard(); |
3818 | 3270 | ||
3819 | QIconSet copy_img((const char**) copy_xpm); | 3271 | QIconSet copy_img((const char**) copy_xpm); |
3820 | QIconSet edit_img((const char**) edit_xpm); | 3272 | QIconSet edit_img((const char**) edit_xpm); |
3821 | QPixmap folder_open_img((const char**) folder_open_xpm); | 3273 | QPixmap folder_open_img((const char**) folder_open_xpm); |
3822 | QPixmap editdelete_img((const char**) editdelete_xpm); | 3274 | QPixmap editdelete_img((const char**) editdelete_xpm); |
3823 | 3275 | ||
3824 | QPopupMenu *m = new QPopupMenu(this); | 3276 | QPopupMenu *m = new QPopupMenu(this); |
3825 | int copyItem = m->insertItem( copy_img, tr( "Copy to Clipboard" )); | 3277 | int copyItem = m->insertItem( copy_img, tr( "Copy to Clipboard" )); |
3826 | int editItem = m->insertItem(edit_img, tr( "Edit" )); | 3278 | int editItem = m->insertItem(edit_img, tr( "Edit" )); |
3827 | int showItem = m->insertItem(folder_open_img, tr( "Show Info" )); | 3279 | int showItem = m->insertItem(folder_open_img, tr( "Show Info" )); |
3828 | int cancelItem = m->insertItem( editdelete_img, tr( "Cancel" )); | 3280 | int cancelItem = m->insertItem( editdelete_img, tr( "Cancel" )); |
3829 | m->setFocus(); | 3281 | m->setFocus(); |
3830 | int me=m->exec( QPoint( QCursor::pos().x(), QCursor::pos().y() ) ) ; | 3282 | int me=m->exec( QPoint( QCursor::pos().x(), QCursor::pos().y() ) ) ; |
3831 | if(me == copyItem) { | 3283 | if(me == copyItem) { |
3832 | copyClip( item->text(column) ) ; | 3284 | copyClip( item->text(column) ) ; |
3833 | } else if (me == cancelItem) { | 3285 | } else if (me == cancelItem) { |
3834 | cb->clear(); | 3286 | cb->clear(); |
3835 | } else if (me == editItem) { | 3287 | } else if (me == editItem) { |
3836 | editPwd(); | 3288 | editPwd(); |
3837 | } else if (me == showItem) { | 3289 | } else if (me == showItem) { |
3838 | showInfo(item); | 3290 | showInfo(item); |
3839 | } | 3291 | } |
3840 | } | 3292 | } |
3841 | break; | 3293 | break; |
3842 | }; | 3294 | }; |
3843 | } | 3295 | } |
3844 | 3296 | ||
3845 | void ZSafe::copyClip( const QString &text) { | 3297 | void ZSafe::copyClip( const QString &text) { |
3846 | QClipboard *cb = QApplication::clipboard(); | 3298 | QClipboard *cb = QApplication::clipboard(); |
3847 | cb->setText( text); | 3299 | cb->setText( text); |
3848 | } | 3300 | } |
3849 | 3301 | ||
3850 | 3302 | ||
3851 | QString ZSafe::zsaveDialog() { | 3303 | QString ZSafe::zsaveDialog() { |
3852 | 3304 | ||
3853 | QString fn; | 3305 | QString fn; |
3854 | #ifndef DESKTOP | ||
3855 | #ifndef NO_OPIE | ||
3856 | QMap<QString, QStringList> mimeTypes; | 3306 | QMap<QString, QStringList> mimeTypes; |
3857 | mimeTypes.insert(tr("All"), QStringList() ); | 3307 | mimeTypes.insert(tr("All"), QStringList() ); |
3858 | mimeTypes.insert(tr("Text"), "text/*" ); | 3308 | mimeTypes.insert(tr("Text"), "text/*" ); |
3859 | fn = OFileDialog::getSaveFileName( OFileSelector::EXTENDED_ALL, | 3309 | fn = OFileDialog::getSaveFileName( OFileSelector::EXTENDED_ALL, |
3860 | QDir::homeDirPath() + "/Documents/application/zsafe", | 3310 | QDir::homeDirPath() + "/Documents/application/zsafe", |
3861 | QString::null, | 3311 | QString::null, |
3862 | mimeTypes, | 3312 | mimeTypes, |
3863 | this, | 3313 | this, |
3864 | tr ("Export text file")); | 3314 | tr ("Export text file")); |
3865 | #else | 3315 | return fn; |
3866 | fn = ScQtFileEdit::getSaveAsFileName(this, | ||
3867 | tr ("Export text file"), | ||
3868 | QDir::homeDirPath() + "/Documents/application/zsafe", | ||
3869 | "*.txt"); | ||
3870 | #endif | ||
3871 | #else | ||
3872 | fn = QFileDialog::getSaveFileName( | ||
3873 | QDir::homeDirPath() + "/Documents/application/zsafe", | ||
3874 | "ZSafe (*.txt)", | ||
3875 | this, | ||
3876 | "ZSafe"); | ||
3877 | #endif | ||
3878 | return fn; | ||
3879 | } | 3316 | } |
diff --git a/noncore/apps/zsafe/zsafe.h b/noncore/apps/zsafe/zsafe.h index 7419797..3d812f8 100644 --- a/noncore/apps/zsafe/zsafe.h +++ b/noncore/apps/zsafe/zsafe.h | |||
@@ -17,78 +17,79 @@ | |||
17 | #include <stdio.h> | 17 | #include <stdio.h> |
18 | 18 | ||
19 | #include "infoform.h" | 19 | #include "infoform.h" |
20 | #include "categorylist.h" | 20 | #include "categorylist.h" |
21 | #include "shadedlistitem.h" | 21 | #include "shadedlistitem.h" |
22 | 22 | ||
23 | #include <qvariant.h> | 23 | #include <qvariant.h> |
24 | #include <qdialog.h> | 24 | #include <qdialog.h> |
25 | #include <qwidgetstack.h> | 25 | #include <qwidgetstack.h> |
26 | #include <qtimer.h> | 26 | #include <qtimer.h> |
27 | 27 | ||
28 | class QVBoxLayout; | 28 | class QVBoxLayout; |
29 | class QHBoxLayout; | 29 | class QHBoxLayout; |
30 | class QGridLayout; | 30 | class QGridLayout; |
31 | class ZListView; | 31 | class ZListView; |
32 | class QListViewItem; | 32 | class QListViewItem; |
33 | class QToolButton; | 33 | class QToolButton; |
34 | class QTextBrowser; | 34 | class QTextBrowser; |
35 | class QPopupMenu; | 35 | class QPopupMenu; |
36 | #ifdef DESKTOP | 36 | #ifdef DESKTOP |
37 | // #ifndef WIN32 | 37 | // #ifndef WIN32 |
38 | class QSettings; | 38 | class QSettings; |
39 | // #endif | 39 | // #endif |
40 | #else | 40 | #else |
41 | class Config; | 41 | class Config; |
42 | #endif | 42 | #endif |
43 | class CategoryDialog; | 43 | class CategoryDialog; |
44 | class QPixmap; | 44 | class QPixmap; |
45 | 45 | ||
46 | // number of fields for one entry | 46 | // number of fields for one entry |
47 | #define FIELD_SIZE 7 | 47 | #define FIELD_SIZE 7 |
48 | 48 | ||
49 | class ZSafe : public QDialog | 49 | class ZSafe : public QWidget |
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, WFlags fl = 0 ); |
62 | ~ZSafe(); | 62 | ~ZSafe(); |
63 | static QString appName() { return QString::fromLatin1( QUICKAPP_NAME ); } | ||
63 | 64 | ||
64 | static const QColor *evenRowColor; | 65 | static const QColor *evenRowColor; |
65 | static const QColor *oddRowColor; | 66 | static const QColor *oddRowColor; |
66 | 67 | ||
67 | QToolButton* Edit; | 68 | QToolButton* Edit; |
68 | QToolButton* Delete; | 69 | QToolButton* Delete; |
69 | QToolButton* Find; | 70 | QToolButton* Find; |
70 | QToolButton* New; | 71 | QToolButton* New; |
71 | ZListView* ListView; | 72 | ZListView* ListView; |
72 | 73 | ||
73 | QString cfgFile; | 74 | QString cfgFile; |
74 | QString iconPath; | 75 | QString iconPath; |
75 | 76 | ||
76 | InfoForm *infoForm; | 77 | InfoForm *infoForm; |
77 | CategoryDialog *categoryDialog; | 78 | CategoryDialog *categoryDialog; |
78 | 79 | ||
79 | QListViewItem *selectedItem; // current selected item | 80 | QListViewItem *selectedItem; // current selected item |
80 | QListViewItem *copiedItem; // copied item | 81 | QListViewItem *copiedItem; // copied item |
81 | bool IsCopy; | 82 | bool IsCopy; |
82 | bool IsCut; | 83 | bool IsCut; |
83 | bool modified; // true if database is modified | 84 | bool modified; // true if database is modified |
84 | bool showpwd; // show PWD Dialog | 85 | bool showpwd; // show PWD Dialog |
85 | 86 | ||
86 | QListViewItem *lastSearchedCategory; | 87 | QListViewItem *lastSearchedCategory; |
87 | QListViewItem *lastSearchedItem; | 88 | QListViewItem *lastSearchedItem; |
88 | QString lastSearchedName; | 89 | QString lastSearchedName; |
89 | QString lastSearchedUsername; | 90 | QString lastSearchedUsername; |
90 | QString lastSearchedComment; | 91 | QString lastSearchedComment; |
91 | 92 | ||
92 | 93 | ||
93 | CategoryList categories; // list of categories | 94 | CategoryList categories; // list of categories |
94 | 95 | ||
@@ -166,33 +167,38 @@ public slots: | |||
166 | virtual void writeAllEntries(); | 167 | virtual void writeAllEntries(); |
167 | virtual void readAllEntries(); | 168 | virtual void readAllEntries(); |
168 | virtual void removeAsciiFile(); | 169 | virtual void removeAsciiFile(); |
169 | virtual void setPasswordDialogDone(); | 170 | virtual void setPasswordDialogDone(); |
170 | 171 | ||
171 | virtual void addCategory(); | 172 | virtual void addCategory(); |
172 | virtual void delCategory(); | 173 | virtual void delCategory(); |
173 | virtual void editCategory(); | 174 | virtual void editCategory(); |
174 | virtual void cutItem(); | 175 | virtual void cutItem(); |
175 | virtual void copyItem(); | 176 | virtual void copyItem(); |
176 | virtual void pasteItem(); | 177 | virtual void pasteItem(); |
177 | 178 | ||
178 | virtual void newDocument(); | 179 | virtual void newDocument(); |
179 | virtual void loadDocument(); | 180 | virtual void loadDocument(); |
180 | virtual void saveDocumentAs(); | 181 | virtual void saveDocumentAs(); |
181 | virtual void saveDocumentWithoutPwd(); | 182 | virtual void saveDocumentWithoutPwd(); |
182 | virtual void saveDocumentWithPwd(); | 183 | virtual void saveDocumentWithPwd(); |
183 | virtual void about(); | 184 | virtual void about(); |
184 | virtual void setExpandFlag(); | 185 | virtual void setExpandFlag(); |
185 | 186 | ||
186 | virtual void categoryFieldActivated( const QString& str); | 187 | virtual void categoryFieldActivated( const QString& str); |
187 | 188 | ||
188 | virtual void ListPressed(int, QListViewItem *, const QPoint&, int); | 189 | virtual void ListPressed(int, QListViewItem *, const QPoint&, int); |
189 | virtual void copyClip( const QString &text); | 190 | virtual void copyClip( const QString &text); |
190 | 191 | ||
191 | private slots: | 192 | private slots: |
192 | void setDocument(const QString& fileref); | 193 | void setDocument(const QString& fileref); |
193 | void slotLoadDocu(); | 194 | void slotLoadDocu(); |
194 | void slotRaiseTimer(); | 195 | void slotRaiseTimer(); |
195 | 196 | ||
196 | }; | 197 | }; |
197 | 198 | ||
199 | |||
200 | extern ZSafe *zs; | ||
201 | extern QApplication *appl; | ||
202 | extern int DeskW; | ||
203 | extern int DeskH; | ||
198 | #endif // ZSAFE_H | 204 | #endif // ZSAFE_H |