-rw-r--r-- | noncore/apps/zsafe/config.in | 2 | ||||
-rw-r--r-- | noncore/apps/zsafe/zsafe.cpp | 85 | ||||
-rw-r--r-- | noncore/apps/zsafe/zsafe.pro | 2 |
3 files changed, 85 insertions, 4 deletions
diff --git a/noncore/apps/zsafe/config.in b/noncore/apps/zsafe/config.in index 53956ad..4b1e968 100644 --- a/noncore/apps/zsafe/config.in +++ b/noncore/apps/zsafe/config.in | |||
@@ -1,5 +1,5 @@ | |||
1 | config ZSAFE | 1 | config ZSAFE |
2 | boolean "zsafe (Zaurus Password Manager)" | 2 | boolean "zsafe (Zaurus Password Manager)" |
3 | default "y" | 3 | default "y" |
4 | depends ( LIBQPE || LIBQPE-X11 ) | 4 | depends ( LIBQPE || LIBQPE-X11 ) && LIBOPIE |
5 | 5 | ||
diff --git a/noncore/apps/zsafe/zsafe.cpp b/noncore/apps/zsafe/zsafe.cpp index bd03031..abf6511 100644 --- a/noncore/apps/zsafe/zsafe.cpp +++ b/noncore/apps/zsafe/zsafe.cpp | |||
@@ -1,284 +1,289 @@ | |||
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: | 11 | ** Compile Flags: |
12 | ** Zaurus arm : none | 12 | ** Zaurus arm : -DNO_OPIE |
13 | ** Zaurus Opie arm: none | ||
13 | ** Linux Desktop : -DDESKTOP | 14 | ** Linux Desktop : -DDESKTOP |
14 | ** Windows Desktop: -DDESKTOP -DWIN32 | 15 | ** Windows Desktop: -DDESKTOP -DWIN32 |
15 | ** | 16 | ** |
16 | ****************************************************************************/ | 17 | ****************************************************************************/ |
17 | #include "zsafe.h" | 18 | #include "zsafe.h" |
18 | #include "newdialog.h" | 19 | #include "newdialog.h" |
19 | #include "searchdialog.h" | 20 | #include "searchdialog.h" |
20 | #include "categorydialog.h" | 21 | #include "categorydialog.h" |
21 | #include "passworddialog.h" | 22 | #include "passworddialog.h" |
22 | #include "infoform.h" | 23 | #include "infoform.h" |
23 | #include "zlistview.h" | 24 | #include "zlistview.h" |
24 | #include "shadedlistitem.h" | 25 | #include "shadedlistitem.h" |
25 | 26 | ||
26 | #ifndef DESKTOP | 27 | #ifndef DESKTOP |
28 | #ifndef NO_OPIE | ||
29 | #include <opie/ofiledialog.h> | ||
30 | #else | ||
27 | #include "scqtfileedit.h" | 31 | #include "scqtfileedit.h" |
28 | #endif | 32 | #endif |
33 | #endif | ||
29 | 34 | ||
30 | #include <qclipboard.h> | 35 | #include <qclipboard.h> |
31 | 36 | ||
32 | #include <stdio.h> | 37 | #include <stdio.h> |
33 | 38 | ||
34 | #include <sys/types.h> | 39 | #include <sys/types.h> |
35 | #include <sys/stat.h> | 40 | #include <sys/stat.h> |
36 | #include <fcntl.h> | 41 | #include <fcntl.h> |
37 | #include <stdlib.h> | 42 | #include <stdlib.h> |
38 | #ifndef WIN32 | 43 | #ifndef WIN32 |
39 | #include <unistd.h> | 44 | #include <unistd.h> |
40 | #endif | 45 | #endif |
41 | #include <string.h> | 46 | #include <string.h> |
42 | #include <errno.h> | 47 | #include <errno.h> |
43 | 48 | ||
44 | #include <qmenubar.h> | 49 | #include <qmenubar.h> |
45 | #include <qpopupmenu.h> | 50 | #include <qpopupmenu.h> |
46 | 51 | ||
47 | #ifdef DESKTOP | 52 | #ifdef DESKTOP |
48 | #include <qfiledialog.h> | 53 | #include <qfiledialog.h> |
49 | #ifndef WIN32 | 54 | #ifndef WIN32 |
50 | #include <qsettings.h> | 55 | #include <qsettings.h> |
51 | #else | 56 | #else |
52 | #include "qsettings.h" | 57 | #include "qsettings.h" |
53 | #endif | 58 | #endif |
54 | #include <qapplication.h> | 59 | #include <qapplication.h> |
55 | #else | 60 | #else |
56 | #include <qfile.h> | 61 | #include <qfile.h> |
57 | #include <qpe/fileselector.h> | 62 | #include <qpe/fileselector.h> |
58 | #include <qpe/global.h> | 63 | #include <qpe/global.h> |
59 | #include <qpe/qpeapplication.h> | 64 | #include <qpe/qpeapplication.h> |
60 | #include <qpe/resource.h> | 65 | #include <qpe/resource.h> |
61 | #include <qpe/config.h> | 66 | #include <qpe/config.h> |
62 | #endif | 67 | #endif |
63 | 68 | ||
64 | #include <qtimer.h> | 69 | #include <qtimer.h> |
65 | #include <qlayout.h> | 70 | #include <qlayout.h> |
66 | #include <qmessagebox.h> | 71 | #include <qmessagebox.h> |
67 | #include <qfile.h> | 72 | #include <qfile.h> |
68 | #include <qtextstream.h> | 73 | #include <qtextstream.h> |
69 | #include <qheader.h> | 74 | #include <qheader.h> |
70 | #include <qlistview.h> | 75 | #include <qlistview.h> |
71 | #include <qtoolbutton.h> | 76 | #include <qtoolbutton.h> |
72 | #include <qlayout.h> | 77 | #include <qlayout.h> |
73 | #include <qvariant.h> | 78 | #include <qvariant.h> |
74 | #include <qtooltip.h> | 79 | #include <qtooltip.h> |
75 | #include <qwhatsthis.h> | 80 | #include <qwhatsthis.h> |
76 | #include <qimage.h> | 81 | #include <qimage.h> |
77 | #include <qpixmap.h> | 82 | #include <qpixmap.h> |
78 | #include <qlineedit.h> | 83 | #include <qlineedit.h> |
79 | #include <qmultilineedit.h> | 84 | #include <qmultilineedit.h> |
80 | #include <qregexp.h> | 85 | #include <qregexp.h> |
81 | #include <qdir.h> | 86 | #include <qdir.h> |
82 | #include <qtextbrowser.h> | 87 | #include <qtextbrowser.h> |
83 | #include <qlabel.h> | 88 | #include <qlabel.h> |
84 | #include <qcombobox.h> | 89 | #include <qcombobox.h> |
85 | 90 | ||
86 | #include "krc2.h" | 91 | #include "krc2.h" |
87 | 92 | ||
88 | #include "wait.h" | 93 | #include "wait.h" |
89 | 94 | ||
90 | extern int DeskW, DeskH; | 95 | extern int DeskW, DeskH; |
91 | #ifdef DESKTOP | 96 | #ifdef DESKTOP |
92 | extern QApplication *appl; | 97 | extern QApplication *appl; |
93 | #else | 98 | #else |
94 | extern QPEApplication *appl; | 99 | extern QPEApplication *appl; |
95 | #endif | 100 | #endif |
96 | 101 | ||
97 | 102 | ||
98 | #ifdef DESKTOP | 103 | #ifdef DESKTOP |
99 | #ifndef WIN32 | 104 | #ifndef WIN32 |
100 | const QString APP_KEY="/.zsafe/"; | 105 | const QString APP_KEY="/.zsafe/"; |
101 | #else | 106 | #else |
102 | const QString APP_KEY=""; | 107 | const QString APP_KEY=""; |
103 | #endif | 108 | #endif |
104 | #else | 109 | #else |
105 | const QString APP_KEY=""; | 110 | const QString APP_KEY=""; |
106 | #endif | 111 | #endif |
107 | 112 | ||
108 | // include xmp images | 113 | // include xmp images |
109 | #include "pics/zsafe/copy.xpm" | 114 | #include "pics/zsafe/copy.xpm" |
110 | #include "pics/zsafe/cut.xpm" | 115 | #include "pics/zsafe/cut.xpm" |
111 | #include "pics/zsafe/edit.xpm" | 116 | #include "pics/zsafe/edit.xpm" |
112 | #include "pics/zsafe/editdelete.xpm" | 117 | #include "pics/zsafe/editdelete.xpm" |
113 | #include "pics/zsafe/find.xpm" | 118 | #include "pics/zsafe/find.xpm" |
114 | #include "pics/zsafe/folder_open.xpm" | 119 | #include "pics/zsafe/folder_open.xpm" |
115 | #include "pics/zsafe/help_icon.xpm" | 120 | #include "pics/zsafe/help_icon.xpm" |
116 | #include "pics/zsafe/new.xpm" | 121 | #include "pics/zsafe/new.xpm" |
117 | #include "pics/zsafe/paste.xpm" | 122 | #include "pics/zsafe/paste.xpm" |
118 | #include "pics/zsafe/quit_icon.xpm" | 123 | #include "pics/zsafe/quit_icon.xpm" |
119 | #include "pics/zsafe/save.xpm" | 124 | #include "pics/zsafe/save.xpm" |
120 | #include "pics/zsafe/trash.xpm" | 125 | #include "pics/zsafe/trash.xpm" |
121 | #include "pics/zsafe/expand.xpm" | 126 | #include "pics/zsafe/expand.xpm" |
122 | #include "pics/zsafe/export.xpm" | 127 | #include "pics/zsafe/export.xpm" |
123 | #include "pics/zsafe/import.xpm" | 128 | #include "pics/zsafe/import.xpm" |
124 | #include "pics/zsafe/zsafe.xpm" | 129 | #include "pics/zsafe/zsafe.xpm" |
125 | 130 | ||
126 | static const char* const bank_cards_data[] = { | 131 | static const char* const bank_cards_data[] = { |
127 | "14 14 16 1", | 132 | "14 14 16 1", |
128 | ". c None", | 133 | ". c None", |
129 | "# c #000000", | 134 | "# c #000000", |
130 | "b c #0000de", | 135 | "b c #0000de", |
131 | "a c #0000e6", | 136 | "a c #0000e6", |
132 | "j c #41de83", | 137 | "j c #41de83", |
133 | "k c #4acecd", | 138 | "k c #4acecd", |
134 | "h c #4aced5", | 139 | "h c #4aced5", |
135 | "g c #5a40cd", | 140 | "g c #5a40cd", |
136 | "d c #5a44d5", | 141 | "d c #5a44d5", |
137 | "l c #9440d5", | 142 | "l c #9440d5", |
138 | "m c #b4ce4a", | 143 | "m c #b4ce4a", |
139 | "n c #cd4883", | 144 | "n c #cd4883", |
140 | "e c #d5ae10", | 145 | "e c #d5ae10", |
141 | "f c #de3ce6", | 146 | "f c #de3ce6", |
142 | "i c #e640e6", | 147 | "i c #e640e6", |
143 | "c c #ffffff", | 148 | "c c #ffffff", |
144 | "..............", | 149 | "..............", |
145 | ".###########..", | 150 | ".###########..", |
146 | ".#ababababa#..", | 151 | ".#ababababa#..", |
147 | ".#babbbabbb#..", | 152 | ".#babbbabbb#..", |
148 | ".#ccccccccc#..", | 153 | ".#ccccccccc#..", |
149 | ".#cdcefcghc#..", | 154 | ".#cdcefcghc#..", |
150 | ".#ccccccccc#..", | 155 | ".#ccccccccc#..", |
151 | ".#cicjkclic#..", | 156 | ".#cicjkclic#..", |
152 | ".#ccccccccc#..", | 157 | ".#ccccccccc#..", |
153 | ".#cmchlcnec#..", | 158 | ".#cmchlcnec#..", |
154 | ".#ccccccccc#..", | 159 | ".#ccccccccc#..", |
155 | ".###########..", | 160 | ".###########..", |
156 | "..............", | 161 | "..............", |
157 | ".............."}; | 162 | ".............."}; |
158 | 163 | ||
159 | 164 | ||
160 | static const char* const passwords_data[] = { | 165 | static const char* const passwords_data[] = { |
161 | "16 16 20 1", | 166 | "16 16 20 1", |
162 | ". c None", | 167 | ". c None", |
163 | "# c #000000", | 168 | "# c #000000", |
164 | "r c #000083", | 169 | "r c #000083", |
165 | "p c #0000c5", | 170 | "p c #0000c5", |
166 | "q c #0000ff", | 171 | "q c #0000ff", |
167 | "n c #008100", | 172 | "n c #008100", |
168 | "l c #00c200", | 173 | "l c #00c200", |
169 | "m c #00ff00", | 174 | "m c #00ff00", |
170 | "j c #838100", | 175 | "j c #838100", |
171 | "a c #c55900", | 176 | "a c #c55900", |
172 | "h c #c5c200", | 177 | "h c #c5c200", |
173 | "o c #c5c2ff", | 178 | "o c #c5c2ff", |
174 | "k c #c5ffc5", | 179 | "k c #c5ffc5", |
175 | "f c #ff0000", | 180 | "f c #ff0000", |
176 | "d c #ff8100", | 181 | "d c #ff8100", |
177 | "b c #ffaa5a", | 182 | "b c #ffaa5a", |
178 | "e c #ffc2c5", | 183 | "e c #ffc2c5", |
179 | "c c #ffdeac", | 184 | "c c #ffdeac", |
180 | "i c #ffff00", | 185 | "i c #ffff00", |
181 | "g c #ffffc5", | 186 | "g c #ffffc5", |
182 | "............###.", | 187 | "............###.", |
183 | "...........#abb#", | 188 | "...........#abb#", |
184 | "..........#cbab#", | 189 | "..........#cbab#", |
185 | ".........#cbdd#.", | 190 | ".........#cbdd#.", |
186 | "######..#cbdd#..", | 191 | "######..#cbdd#..", |
187 | "#eeff#..#add#...", | 192 | "#eeff#..#add#...", |
188 | "#eeff#######....", | 193 | "#eeff#######....", |
189 | "#ccdbdd#........", | 194 | "#ccdbdd#........", |
190 | "#dddbdd###......", | 195 | "#dddbdd###......", |
191 | "#gghihhjj#......", | 196 | "#gghihhjj#......", |
192 | "#hhhihhjj###....", | 197 | "#hhhihhjj###....", |
193 | "#kklmllnnnn#....", | 198 | "#kklmllnnnn#....", |
194 | "#lllmllnnnn#....", | 199 | "#lllmllnnnn#....", |
195 | "#oopqpprprr#....", | 200 | "#oopqpprprr#....", |
196 | "#oopqpprprr#....", | 201 | "#oopqpprprr#....", |
197 | "############...."}; | 202 | "############...."}; |
198 | 203 | ||
199 | static const char* const software_data[] = { | 204 | static const char* const software_data[] = { |
200 | "16 16 5 1", | 205 | "16 16 5 1", |
201 | ". c None", | 206 | ". c None", |
202 | "# c #000000", | 207 | "# c #000000", |
203 | "b c #838183", | 208 | "b c #838183", |
204 | "c c #c5ffff", | 209 | "c c #c5ffff", |
205 | "a c #ffffff", | 210 | "a c #ffffff", |
206 | "................", | 211 | "................", |
207 | ".##############.", | 212 | ".##############.", |
208 | "#aaaaaaaaaaaaaa#", | 213 | "#aaaaaaaaaaaaaa#", |
209 | "#abbbbbbbbbbbbb#", | 214 | "#abbbbbbbbbbbbb#", |
210 | "#ab##########ab#", | 215 | "#ab##########ab#", |
211 | "#ab#c########ab#", | 216 | "#ab#c########ab#", |
212 | "#ab#c#c######ab#", | 217 | "#ab#c#c######ab#", |
213 | "#ab##########ab#", | 218 | "#ab##########ab#", |
214 | "#ab##########ab#", | 219 | "#ab##########ab#", |
215 | "#ab##########ab#", | 220 | "#ab##########ab#", |
216 | "#ab##########ab#", | 221 | "#ab##########ab#", |
217 | "#ab##########ab#", | 222 | "#ab##########ab#", |
218 | "#aaaaaaaaaaaaab#", | 223 | "#aaaaaaaaaaaaab#", |
219 | "#bbbbbbbbbbbbbb#", | 224 | "#bbbbbbbbbbbbbb#", |
220 | ".##############.", | 225 | ".##############.", |
221 | "................"}; | 226 | "................"}; |
222 | 227 | ||
223 | static const char* const general_data[] = { | 228 | static const char* const general_data[] = { |
224 | "14 14 98 2", | 229 | "14 14 98 2", |
225 | "Qt c None", | 230 | "Qt c None", |
226 | ".k c #000000", | 231 | ".k c #000000", |
227 | "#x c #080808", | 232 | "#x c #080808", |
228 | "#F c #101008", | 233 | "#F c #101008", |
229 | "#q c #101010", | 234 | "#q c #101010", |
230 | "#i c #101410", | 235 | "#i c #101410", |
231 | "## c #101810", | 236 | "## c #101810", |
232 | ".m c #181818", | 237 | ".m c #181818", |
233 | ".3 c #181c18", | 238 | ".3 c #181c18", |
234 | ".I c #182018", | 239 | ".I c #182018", |
235 | ".T c #202420", | 240 | ".T c #202420", |
236 | "#D c #202820", | 241 | "#D c #202820", |
237 | "#y c #292c29", | 242 | "#y c #292c29", |
238 | ".c c #293029", | 243 | ".c c #293029", |
239 | ".d c #313031", | 244 | ".d c #313031", |
240 | "#E c #313429", | 245 | "#E c #313429", |
241 | "#r c #313831", | 246 | "#r c #313831", |
242 | ".j c #393c31", | 247 | ".j c #393c31", |
243 | "#j c #394039", | 248 | "#j c #394039", |
244 | "#C c #414841", | 249 | "#C c #414841", |
245 | ".w c #4a554a", | 250 | ".w c #4a554a", |
246 | ".a c #4a594a", | 251 | ".a c #4a594a", |
247 | ".# c #525052", | 252 | ".# c #525052", |
248 | ".l c #52594a", | 253 | ".l c #52594a", |
249 | "#f c #525952", | 254 | "#f c #525952", |
250 | "#v c #525d52", | 255 | "#v c #525d52", |
251 | ".O c #5a4c4a", | 256 | ".O c #5a4c4a", |
252 | ".9 c #5a595a", | 257 | ".9 c #5a595a", |
253 | ".A c #5a5d52", | 258 | ".A c #5a5d52", |
254 | ".B c #624c52", | 259 | ".B c #624c52", |
255 | ".0 c #625552", | 260 | ".0 c #625552", |
256 | "#o c #626562", | 261 | "#o c #626562", |
257 | ".R c #626962", | 262 | ".R c #626962", |
258 | "#. c #626d5a", | 263 | "#. c #626d5a", |
259 | "#p c #626d62", | 264 | "#p c #626d62", |
260 | ".2 c #627162", | 265 | ".2 c #627162", |
261 | "#h c #6a6d62", | 266 | "#h c #6a6d62", |
262 | "#z c #6a7562", | 267 | "#z c #6a7562", |
263 | "#w c #6a756a", | 268 | "#w c #6a756a", |
264 | ".C c #73656a", | 269 | ".C c #73656a", |
265 | ".P c #73696a", | 270 | ".P c #73696a", |
266 | "#a c #737d6a", | 271 | "#a c #737d6a", |
267 | ".U c #738573", | 272 | ".U c #738573", |
268 | ".E c #7b817b", | 273 | ".E c #7b817b", |
269 | "#B c #7b857b", | 274 | "#B c #7b857b", |
270 | "#s c #7b897b", | 275 | "#s c #7b897b", |
271 | "#n c #7b917b", | 276 | "#n c #7b917b", |
272 | ".b c #838d83", | 277 | ".b c #838d83", |
273 | ".7 c #839583", | 278 | ".7 c #839583", |
274 | ".n c #8b7d7b", | 279 | ".n c #8b7d7b", |
275 | "#g c #8b8583", | 280 | "#g c #8b8583", |
276 | ".g c #8b858b", | 281 | ".g c #8b858b", |
277 | ".r c #8b898b", | 282 | ".r c #8b898b", |
278 | ".s c #8b8d8b", | 283 | ".s c #8b8d8b", |
279 | ".i c #8b9183", | 284 | ".i c #8b9183", |
280 | ".8 c #8b918b", | 285 | ".8 c #8b918b", |
281 | "#A c #8b9d8b", | 286 | "#A c #8b9d8b", |
282 | ".S c #8ba183", | 287 | ".S c #8ba183", |
283 | ".Z c #94918b", | 288 | ".Z c #94918b", |
284 | ".N c #949994", | 289 | ".N c #949994", |
@@ -942,649 +947,688 @@ void ZSafe::findPwd() | |||
942 | if (lastSearchedItem) | 947 | if (lastSearchedItem) |
943 | si = lastSearchedItem; | 948 | si = lastSearchedItem; |
944 | else | 949 | else |
945 | si = i->firstChild(); | 950 | si = i->firstChild(); |
946 | // for (si = i->firstChild(); | 951 | // for (si = i->firstChild(); |
947 | for (; | 952 | for (; |
948 | si != NULL; | 953 | si != NULL; |
949 | si = si->nextSibling()) | 954 | si = si->nextSibling()) |
950 | { | 955 | { |
951 | qWarning (si->text(0)); | 956 | qWarning (si->text(0)); |
952 | if (si->isSelected()) | 957 | if (si->isSelected()) |
953 | si->setSelected(FALSE); | 958 | si->setSelected(FALSE); |
954 | // ListView->repaintItem(si); | 959 | // ListView->repaintItem(si); |
955 | 960 | ||
956 | bool n=TRUE; | 961 | bool n=TRUE; |
957 | bool u=TRUE; | 962 | bool u=TRUE; |
958 | bool c=TRUE; | 963 | bool c=TRUE; |
959 | if (!name.isEmpty()) | 964 | if (!name.isEmpty()) |
960 | n = (si->text(0)).contains (name, FALSE); | 965 | n = (si->text(0)).contains (name, FALSE); |
961 | if (!username.isEmpty()) | 966 | if (!username.isEmpty()) |
962 | u = (si->text(1)).contains (username, FALSE); | 967 | u = (si->text(1)).contains (username, FALSE); |
963 | if (!comment.isEmpty()) | 968 | if (!comment.isEmpty()) |
964 | c = (si->text(3)).contains (comment, FALSE); | 969 | c = (si->text(3)).contains (comment, FALSE); |
965 | 970 | ||
966 | if ((n && u && c ) && !found) | 971 | if ((n && u && c ) && !found) |
967 | { | 972 | { |
968 | qWarning ("Found"); | 973 | qWarning ("Found"); |
969 | selectedItem = si; | 974 | selectedItem = si; |
970 | si->setSelected(TRUE); | 975 | si->setSelected(TRUE); |
971 | ListView->setCurrentItem(si); | 976 | ListView->setCurrentItem(si); |
972 | ListView->ensureItemVisible(si); | 977 | ListView->ensureItemVisible(si); |
973 | ListView->triggerUpdate(); | 978 | ListView->triggerUpdate(); |
974 | 979 | ||
975 | lastSearchedCategory = i; | 980 | lastSearchedCategory = i; |
976 | // set to the next item | 981 | // set to the next item |
977 | lastSearchedItem = si->nextSibling(); | 982 | lastSearchedItem = si->nextSibling(); |
978 | if (!lastSearchedItem) | 983 | if (!lastSearchedItem) |
979 | { | 984 | { |
980 | // no next item within category -> set next category | 985 | // no next item within category -> set next category |
981 | lastSearchedCategory = i->nextSibling(); | 986 | lastSearchedCategory = i->nextSibling(); |
982 | if (!lastSearchedCategory) | 987 | if (!lastSearchedCategory) |
983 | lastSearchedItem = NULL; // END | 988 | lastSearchedItem = NULL; // END |
984 | } | 989 | } |
985 | 990 | ||
986 | found = TRUE; | 991 | found = TRUE; |
987 | delete dialog; | 992 | delete dialog; |
988 | update(); | 993 | update(); |
989 | return; | 994 | return; |
990 | } | 995 | } |
991 | } | 996 | } |
992 | lastSearchedCategory = i->nextSibling(); | 997 | lastSearchedCategory = i->nextSibling(); |
993 | lastSearchedItem = NULL; | 998 | lastSearchedItem = NULL; |
994 | } | 999 | } |
995 | lastSearchedCategory = NULL; | 1000 | lastSearchedCategory = NULL; |
996 | lastSearchedItem = NULL; | 1001 | lastSearchedItem = NULL; |
997 | delete dialog; | 1002 | delete dialog; |
998 | update(); | 1003 | update(); |
999 | QMessageBox::information( this, tr("ZSafe"), | 1004 | QMessageBox::information( this, tr("ZSafe"), |
1000 | tr("Entry not found"), tr("&OK"), 0); | 1005 | tr("Entry not found"), tr("&OK"), 0); |
1001 | 1006 | ||
1002 | } | 1007 | } |
1003 | 1008 | ||
1004 | QString ZSafe::getFieldLabel (QListViewItem *_item, QString field, QString def) | 1009 | QString ZSafe::getFieldLabel (QListViewItem *_item, QString field, QString def) |
1005 | { | 1010 | { |
1006 | QString category; | 1011 | QString category; |
1007 | if (_item) | 1012 | if (_item) |
1008 | { | 1013 | { |
1009 | if (isCategory(_item)) | 1014 | if (isCategory(_item)) |
1010 | { | 1015 | { |
1011 | category = _item->text(0); | 1016 | category = _item->text(0); |
1012 | } | 1017 | } |
1013 | else | 1018 | else |
1014 | { | 1019 | { |
1015 | QListViewItem *cat = _item->parent(); | 1020 | QListViewItem *cat = _item->parent(); |
1016 | category = cat->text(0); | 1021 | category = cat->text(0); |
1017 | } | 1022 | } |
1018 | } | 1023 | } |
1019 | else | 1024 | else |
1020 | { | 1025 | { |
1021 | return def; | 1026 | return def; |
1022 | } | 1027 | } |
1023 | 1028 | ||
1024 | QString app_key = APP_KEY; | 1029 | QString app_key = APP_KEY; |
1025 | #ifndef DESKTOP | 1030 | #ifndef DESKTOP |
1026 | #ifndef WIN32 | 1031 | #ifndef WIN32 |
1027 | conf->setGroup ("fieldDefs"); | 1032 | conf->setGroup ("fieldDefs"); |
1028 | #endif | 1033 | #endif |
1029 | #else | 1034 | #else |
1030 | #ifndef WIN32 | 1035 | #ifndef WIN32 |
1031 | app_key += "/fieldDefs/"; | 1036 | app_key += "/fieldDefs/"; |
1032 | #endif | 1037 | #endif |
1033 | #endif | 1038 | #endif |
1034 | // #ifndef WIN32 | 1039 | // #ifndef WIN32 |
1035 | QString label = conf->readEntry(app_key+category+"-field"+field,def); | 1040 | QString label = conf->readEntry(app_key+category+"-field"+field,def); |
1036 | // #else | 1041 | // #else |
1037 | // QString label(def); | 1042 | // QString label(def); |
1038 | // #endif | 1043 | // #endif |
1039 | 1044 | ||
1040 | #ifndef DESKTOP | 1045 | #ifndef DESKTOP |
1041 | conf->setGroup ("zsafe"); | 1046 | conf->setGroup ("zsafe"); |
1042 | #endif | 1047 | #endif |
1043 | return label; | 1048 | return label; |
1044 | } | 1049 | } |
1045 | 1050 | ||
1046 | QString ZSafe::getFieldLabel (QString category, QString field, QString def) | 1051 | QString ZSafe::getFieldLabel (QString category, QString field, QString def) |
1047 | { | 1052 | { |
1048 | QString app_key = APP_KEY; | 1053 | QString app_key = APP_KEY; |
1049 | #ifndef DESKTOP | 1054 | #ifndef DESKTOP |
1050 | conf->setGroup ("fieldDefs"); | 1055 | conf->setGroup ("fieldDefs"); |
1051 | #else | 1056 | #else |
1052 | #ifndef WIN32 | 1057 | #ifndef WIN32 |
1053 | app_key += "/fieldDefs/"; | 1058 | app_key += "/fieldDefs/"; |
1054 | #endif | 1059 | #endif |
1055 | #endif | 1060 | #endif |
1056 | // #ifndef WIN32 | 1061 | // #ifndef WIN32 |
1057 | QString label = conf->readEntry(app_key+category+"-field"+field, | 1062 | QString label = conf->readEntry(app_key+category+"-field"+field, |
1058 | def); | 1063 | def); |
1059 | // #else | 1064 | // #else |
1060 | // QString label(def); | 1065 | // QString label(def); |
1061 | // #endif | 1066 | // #endif |
1062 | #ifndef DESKTOP | 1067 | #ifndef DESKTOP |
1063 | conf->setGroup ("zsafe"); | 1068 | conf->setGroup ("zsafe"); |
1064 | #endif | 1069 | #endif |
1065 | return label; | 1070 | return label; |
1066 | } | 1071 | } |
1067 | 1072 | ||
1068 | void ZSafe::showInfo( QListViewItem *_item) | 1073 | void ZSafe::showInfo( QListViewItem *_item) |
1069 | { | 1074 | { |
1070 | if (!_item) | 1075 | if (!_item) |
1071 | return; | 1076 | return; |
1072 | if (selectedItem != NULL) | 1077 | if (selectedItem != NULL) |
1073 | selectedItem->setSelected(FALSE); | 1078 | selectedItem->setSelected(FALSE); |
1074 | 1079 | ||
1075 | selectedItem = _item; | 1080 | selectedItem = _item; |
1076 | selectedItem->setSelected(TRUE); | 1081 | selectedItem->setSelected(TRUE); |
1077 | 1082 | ||
1078 | if (!isCategory(_item)) | 1083 | if (!isCategory(_item)) |
1079 | { | 1084 | { |
1080 | /* | 1085 | /* |
1081 | QString label=selectedItem->text(0); | 1086 | QString label=selectedItem->text(0); |
1082 | label+="\n"; | 1087 | label+="\n"; |
1083 | label+=selectedItem->text(1); | 1088 | label+=selectedItem->text(1); |
1084 | label+="\n"; | 1089 | label+="\n"; |
1085 | label+=selectedItem->text(2); | 1090 | label+=selectedItem->text(2); |
1086 | label+="\n"; | 1091 | label+="\n"; |
1087 | label+=selectedItem->text(3); | 1092 | label+=selectedItem->text(3); |
1088 | */ | 1093 | */ |
1089 | 1094 | ||
1090 | QString text; | 1095 | QString text; |
1091 | QString entry; | 1096 | QString entry; |
1092 | 1097 | ||
1093 | text = "<html><body><div align=""center""><u><b>"; | 1098 | text = "<html><body><div align=""center""><u><b>"; |
1094 | text += selectedItem->text(0); | 1099 | text += selectedItem->text(0); |
1095 | text += "</b></u><br></div><br>"; | 1100 | text += "</b></u><br></div><br>"; |
1096 | 1101 | ||
1097 | entry = selectedItem->text(1); | 1102 | entry = selectedItem->text(1); |
1098 | if (!entry.isEmpty() && entry.compare(" ")) | 1103 | if (!entry.isEmpty() && entry.compare(" ")) |
1099 | { | 1104 | { |
1100 | text += "<u><b>"; | 1105 | text += "<u><b>"; |
1101 | text += getFieldLabel (selectedItem, "2", tr("Username")); | 1106 | text += getFieldLabel (selectedItem, "2", tr("Username")); |
1102 | text += ":<br></b></u><blockquote>"; | 1107 | text += ":<br></b></u><blockquote>"; |
1103 | text += entry; | 1108 | text += entry; |
1104 | text += "</blockquote>"; | 1109 | text += "</blockquote>"; |
1105 | // text += "<br>"; | 1110 | // text += "<br>"; |
1106 | } | 1111 | } |
1107 | 1112 | ||
1108 | entry = selectedItem->text(2); | 1113 | entry = selectedItem->text(2); |
1109 | if (!entry.isEmpty() && entry.compare(" ")) | 1114 | if (!entry.isEmpty() && entry.compare(" ")) |
1110 | { | 1115 | { |
1111 | text += "<u><b>"; | 1116 | text += "<u><b>"; |
1112 | text += getFieldLabel (selectedItem, "3", tr("Password")); | 1117 | text += getFieldLabel (selectedItem, "3", tr("Password")); |
1113 | text += ":<br> </b></u><blockquote>"; | 1118 | text += ":<br> </b></u><blockquote>"; |
1114 | text += entry; | 1119 | text += entry; |
1115 | text += "</blockquote>"; | 1120 | text += "</blockquote>"; |
1116 | // text += "<br>"; | 1121 | // text += "<br>"; |
1117 | } | 1122 | } |
1118 | 1123 | ||
1119 | entry = selectedItem->text(4); | 1124 | entry = selectedItem->text(4); |
1120 | if (!entry.isEmpty() && entry.compare(" ")) | 1125 | if (!entry.isEmpty() && entry.compare(" ")) |
1121 | { | 1126 | { |
1122 | text += "<u><b>"; | 1127 | text += "<u><b>"; |
1123 | text += getFieldLabel (selectedItem, "5", tr("Field 4")); | 1128 | text += getFieldLabel (selectedItem, "5", tr("Field 4")); |
1124 | text += ":<br> </b></u><blockquote>"; | 1129 | text += ":<br> </b></u><blockquote>"; |
1125 | text += entry; | 1130 | text += entry; |
1126 | text += "</blockquote>"; | 1131 | text += "</blockquote>"; |
1127 | // text += "<br>"; | 1132 | // text += "<br>"; |
1128 | } | 1133 | } |
1129 | 1134 | ||
1130 | entry = selectedItem->text(5); | 1135 | entry = selectedItem->text(5); |
1131 | if (!entry.isEmpty() && entry.compare(" ")) | 1136 | if (!entry.isEmpty() && entry.compare(" ")) |
1132 | { | 1137 | { |
1133 | text += "<u><b>"; | 1138 | text += "<u><b>"; |
1134 | text += getFieldLabel (selectedItem, "6", tr("Field 5")); | 1139 | text += getFieldLabel (selectedItem, "6", tr("Field 5")); |
1135 | text += ":<br> </b></u><blockquote>"; | 1140 | text += ":<br> </b></u><blockquote>"; |
1136 | text += entry; | 1141 | text += entry; |
1137 | text += "</blockquote>"; | 1142 | text += "</blockquote>"; |
1138 | // text += "<br>"; | 1143 | // text += "<br>"; |
1139 | } | 1144 | } |
1140 | 1145 | ||
1141 | entry = selectedItem->text(3); | 1146 | entry = selectedItem->text(3); |
1142 | if (!entry.isEmpty() && entry.compare(" ")) | 1147 | if (!entry.isEmpty() && entry.compare(" ")) |
1143 | { | 1148 | { |
1144 | text += "<u><b>"; | 1149 | text += "<u><b>"; |
1145 | text += getFieldLabel (selectedItem, "4", tr("Comment")); | 1150 | text += getFieldLabel (selectedItem, "4", tr("Comment")); |
1146 | text += ":<br> </b></u>"; | 1151 | text += ":<br> </b></u>"; |
1147 | QString comment = selectedItem->text(3); | 1152 | QString comment = selectedItem->text(3); |
1148 | comment.replace (QRegExp("\n"), "<br>"); | 1153 | comment.replace (QRegExp("\n"), "<br>"); |
1149 | text += comment; | 1154 | text += comment; |
1150 | // text += "<br>"; | 1155 | // text += "<br>"; |
1151 | } | 1156 | } |
1152 | 1157 | ||
1153 | text += "</body></html>"; | 1158 | text += "</body></html>"; |
1154 | 1159 | ||
1155 | infoForm->InfoText->setText(text); | 1160 | infoForm->InfoText->setText(text); |
1156 | infoForm->hide(); | 1161 | infoForm->hide(); |
1157 | #ifdef DESKTOP | 1162 | #ifdef DESKTOP |
1158 | infoForm->show(); | 1163 | infoForm->show(); |
1159 | #else | 1164 | #else |
1160 | infoForm->showMaximized(); | 1165 | infoForm->showMaximized(); |
1161 | #endif | 1166 | #endif |
1162 | 1167 | ||
1163 | } | 1168 | } |
1164 | } | 1169 | } |
1165 | 1170 | ||
1166 | void ZSafe::listViewSelected( QListViewItem *_item) | 1171 | void ZSafe::listViewSelected( QListViewItem *_item) |
1167 | { | 1172 | { |
1168 | if (!_item) | 1173 | if (!_item) |
1169 | return; | 1174 | return; |
1170 | if (selectedItem != NULL) | 1175 | if (selectedItem != NULL) |
1171 | selectedItem->setSelected(FALSE); | 1176 | selectedItem->setSelected(FALSE); |
1172 | 1177 | ||
1173 | selectedItem = _item; | 1178 | selectedItem = _item; |
1174 | 1179 | ||
1175 | #ifndef DESKTOP | 1180 | #ifndef DESKTOP |
1176 | // set the column text dependent on the selected item | 1181 | // set the column text dependent on the selected item |
1177 | ListView->setColumnText(0, getFieldLabel (selectedItem, "1", tr("Name"))); | 1182 | ListView->setColumnText(0, getFieldLabel (selectedItem, "1", tr("Name"))); |
1178 | ListView->setColumnText(1, getFieldLabel (selectedItem, "2", tr("Field 2"))); | 1183 | ListView->setColumnText(1, getFieldLabel (selectedItem, "2", tr("Field 2"))); |
1179 | ListView->setColumnText(2, getFieldLabel (selectedItem, "3", tr("Field 3"))); | 1184 | ListView->setColumnText(2, getFieldLabel (selectedItem, "3", tr("Field 3"))); |
1180 | ListView->setColumnText(3, getFieldLabel (selectedItem, "4", tr("Comment"))); | 1185 | ListView->setColumnText(3, getFieldLabel (selectedItem, "4", tr("Comment"))); |
1181 | ListView->setColumnText(4, getFieldLabel (selectedItem, "5", tr("Field 4"))); | 1186 | ListView->setColumnText(4, getFieldLabel (selectedItem, "5", tr("Field 4"))); |
1182 | ListView->setColumnText(5, getFieldLabel (selectedItem, "6", tr("Field 5"))); | 1187 | ListView->setColumnText(5, getFieldLabel (selectedItem, "6", tr("Field 5"))); |
1183 | #endif | 1188 | #endif |
1184 | #ifdef WIN32 | 1189 | #ifdef WIN32 |
1185 | // set the column text dependent on the selected item | 1190 | // set the column text dependent on the selected item |
1186 | ListView->setColumnText(0, getFieldLabel (selectedItem, "1", tr("Name"))); | 1191 | ListView->setColumnText(0, getFieldLabel (selectedItem, "1", tr("Name"))); |
1187 | ListView->setColumnText(1, getFieldLabel (selectedItem, "2", tr("Field 2"))); | 1192 | ListView->setColumnText(1, getFieldLabel (selectedItem, "2", tr("Field 2"))); |
1188 | ListView->setColumnText(2, getFieldLabel (selectedItem, "3", tr("Field 3"))); | 1193 | ListView->setColumnText(2, getFieldLabel (selectedItem, "3", tr("Field 3"))); |
1189 | ListView->setColumnText(3, getFieldLabel (selectedItem, "4", tr("Comment"))); | 1194 | ListView->setColumnText(3, getFieldLabel (selectedItem, "4", tr("Comment"))); |
1190 | ListView->setColumnText(4, getFieldLabel (selectedItem, "5", tr("Field 4"))); | 1195 | ListView->setColumnText(4, getFieldLabel (selectedItem, "5", tr("Field 4"))); |
1191 | ListView->setColumnText(5, getFieldLabel (selectedItem, "6", tr("Field 5"))); | 1196 | ListView->setColumnText(5, getFieldLabel (selectedItem, "6", tr("Field 5"))); |
1192 | #endif | 1197 | #endif |
1193 | 1198 | ||
1194 | } | 1199 | } |
1195 | 1200 | ||
1196 | bool ZSafe::isCategory(QListViewItem *_item) | 1201 | bool ZSafe::isCategory(QListViewItem *_item) |
1197 | { | 1202 | { |
1203 | if (_item == NULL) | ||
1204 | return FALSE; | ||
1205 | |||
1198 | QString categoryName = _item->text (0); | 1206 | QString categoryName = _item->text (0); |
1199 | if (categories.find ((const char *)categoryName)) | 1207 | if (categories.find ((const char *)categoryName)) |
1200 | return TRUE; | 1208 | return TRUE; |
1201 | else | 1209 | else |
1202 | return FALSE; | 1210 | return FALSE; |
1203 | } | 1211 | } |
1204 | 1212 | ||
1205 | void ZSafe::removeAsciiFile() | 1213 | void ZSafe::removeAsciiFile() |
1206 | { | 1214 | { |
1207 | // QString fn = filename + ".txt"; | 1215 | // QString fn = filename + ".txt"; |
1208 | // open the file dialog | 1216 | // open the file dialog |
1209 | #ifndef DESKTOP | 1217 | #ifndef DESKTOP |
1218 | #ifndef NO_OPIE | ||
1219 | QMap<QString, QStringList> mimeTypes; | ||
1220 | mimeTypes.insert(tr("All"), QStringList() ); | ||
1221 | mimeTypes.insert(tr("Text"), "text/*" ); | ||
1222 | QString fn = OFileDialog::getOpenFileName( OFileSelector::EXTENDED_ALL, | ||
1223 | QDir::homeDirPath() + "/Documents/application/zsafe", | ||
1224 | QString::null, | ||
1225 | mimeTypes, | ||
1226 | this, | ||
1227 | tr ("Remove text file")); | ||
1228 | #else | ||
1210 | QString fn = ScQtFileEdit::getOpenFileName(this, | 1229 | QString fn = ScQtFileEdit::getOpenFileName(this, |
1211 | tr ("Remove text file"), | 1230 | tr ("Remove text file"), |
1212 | QDir::homeDirPath() + "/Documents/application/zsafe", | 1231 | QDir::homeDirPath() + "/Documents/application/zsafe", |
1213 | "*.txt"); | 1232 | "*.txt"); |
1233 | #endif | ||
1214 | #else | 1234 | #else |
1215 | QString fn = QFileDialog::getOpenFileName( | 1235 | QString fn = QFileDialog::getOpenFileName( |
1216 | QDir::homeDirPath() + "/Documents/application/zsafe", | 1236 | QDir::homeDirPath() + "/Documents/application/zsafe", |
1217 | "ZSafe (*.txt)", | 1237 | "ZSafe (*.txt)", |
1218 | this, | 1238 | this, |
1219 | "ZSafe File Dialog" | 1239 | "ZSafe File Dialog" |
1220 | "Choose a text file" ); | 1240 | "Choose a text file" ); |
1221 | #endif | 1241 | #endif |
1222 | 1242 | ||
1223 | if (fn && fn.length() > 0 ) | 1243 | if (fn && fn.length() > 0 ) |
1224 | { | 1244 | { |
1225 | QFile f( fn ); | 1245 | QFile f( fn ); |
1226 | if ( !f.remove() ) | 1246 | if ( !f.remove() ) |
1227 | { | 1247 | { |
1228 | qWarning( QString("Could not remove file %1").arg(fn), | 1248 | qWarning( QString("Could not remove file %1").arg(fn), |
1229 | 2000 ); | 1249 | 2000 ); |
1230 | QMessageBox::critical( 0, tr("ZSafe"), | 1250 | QMessageBox::critical( 0, tr("ZSafe"), |
1231 | tr("Could not remove text file.") ); | 1251 | tr("Could not remove text file.") ); |
1232 | return; | 1252 | return; |
1233 | } | 1253 | } |
1234 | } | 1254 | } |
1235 | } | 1255 | } |
1236 | 1256 | ||
1237 | void ZSafe::writeAllEntries() | 1257 | void ZSafe::writeAllEntries() |
1238 | { | 1258 | { |
1239 | if (filename.isEmpty()) | 1259 | if (filename.isEmpty()) |
1240 | { | 1260 | { |
1241 | QMessageBox::critical( 0, tr("ZSafe"), | 1261 | QMessageBox::critical( 0, tr("ZSafe"), |
1242 | tr("No document defined.\nYou have to create a new document")); | 1262 | tr("No document defined.\nYou have to create a new document")); |
1243 | return; | 1263 | return; |
1244 | } | 1264 | } |
1245 | 1265 | ||
1246 | // open the file dialog | 1266 | // open the file dialog |
1247 | #ifndef DESKTOP | 1267 | #ifndef DESKTOP |
1268 | #ifndef NO_OPIE | ||
1269 | QMap<QString, QStringList> mimeTypes; | ||
1270 | mimeTypes.insert(tr("All"), QStringList() ); | ||
1271 | mimeTypes.insert(tr("Text"), "text/*" ); | ||
1272 | QString fn = OFileDialog::getSaveFileName( OFileSelector::EXTENDED_ALL, | ||
1273 | QDir::homeDirPath() + "/Documents/application/zsafe", | ||
1274 | QString::null, | ||
1275 | mimeTypes, | ||
1276 | this, | ||
1277 | tr ("Export text file")); | ||
1278 | #else | ||
1248 | QString fn = ScQtFileEdit::getSaveAsFileName(this, | 1279 | QString fn = ScQtFileEdit::getSaveAsFileName(this, |
1249 | tr ("Export text file"), | 1280 | tr ("Export text file"), |
1250 | QDir::homeDirPath() + "/Documents/application/zsafe", | 1281 | QDir::homeDirPath() + "/Documents/application/zsafe", |
1251 | "*.txt"); | 1282 | "*.txt"); |
1283 | #endif | ||
1252 | #else | 1284 | #else |
1253 | QString fn = QFileDialog::getSaveFileName( | 1285 | QString fn = QFileDialog::getSaveFileName( |
1254 | QDir::homeDirPath() + "/Documents/application/zsafe", | 1286 | QDir::homeDirPath() + "/Documents/application/zsafe", |
1255 | "ZSafe (*.txt)", | 1287 | "ZSafe (*.txt)", |
1256 | this, | 1288 | this, |
1257 | "ZSafe File Dialog" | 1289 | "ZSafe File Dialog" |
1258 | "Choose a text file" ); | 1290 | "Choose a text file" ); |
1259 | #endif | 1291 | #endif |
1260 | 1292 | ||
1261 | // open the new document | 1293 | // open the new document |
1262 | if (fn && fn.length() > 0 ) | 1294 | if (fn && fn.length() > 0 ) |
1263 | { | 1295 | { |
1264 | QFile f( fn ); | 1296 | QFile f( fn ); |
1265 | if ( !f.open( IO_WriteOnly ) ) { | 1297 | if ( !f.open( IO_WriteOnly ) ) { |
1266 | qWarning( QString("Could not write to file %1").arg(fn), | 1298 | qWarning( QString("Could not write to file %1").arg(fn), |
1267 | 2000 ); | 1299 | 2000 ); |
1268 | QMessageBox::critical( 0, "ZSafe", | 1300 | QMessageBox::critical( 0, "ZSafe", |
1269 | QString("Could not export to text file.") ); | 1301 | QString("Could not export to text file.") ); |
1270 | return; | 1302 | return; |
1271 | } | 1303 | } |
1272 | QTextStream t( &f ); | 1304 | QTextStream t( &f ); |
1273 | 1305 | ||
1274 | QListViewItem *i; | 1306 | QListViewItem *i; |
1275 | // step through all categories | 1307 | // step through all categories |
1276 | for (i = ListView->firstChild(); | 1308 | for (i = ListView->firstChild(); |
1277 | i != NULL; | 1309 | i != NULL; |
1278 | i = i->nextSibling()) | 1310 | i = i->nextSibling()) |
1279 | { | 1311 | { |
1280 | // step through all subitems | 1312 | // step through all subitems |
1281 | QListViewItem *si; | 1313 | QListViewItem *si; |
1282 | for (si = i->firstChild(); | 1314 | for (si = i->firstChild(); |
1283 | si != NULL; | 1315 | si != NULL; |
1284 | si = si->nextSibling()) | 1316 | si = si->nextSibling()) |
1285 | { | 1317 | { |
1286 | QString oneEntry; | 1318 | QString oneEntry; |
1287 | oneEntry += "\""; | 1319 | oneEntry += "\""; |
1288 | oneEntry += i->text(0); | 1320 | oneEntry += i->text(0); |
1289 | oneEntry += "\";"; | 1321 | oneEntry += "\";"; |
1290 | oneEntry += "\""; | 1322 | oneEntry += "\""; |
1291 | oneEntry += si->text(0); | 1323 | oneEntry += si->text(0); |
1292 | oneEntry += "\";"; | 1324 | oneEntry += "\";"; |
1293 | oneEntry += "\""; | 1325 | oneEntry += "\""; |
1294 | oneEntry += si->text(1); | 1326 | oneEntry += si->text(1); |
1295 | oneEntry += "\";"; | 1327 | oneEntry += "\";"; |
1296 | oneEntry += "\""; | 1328 | oneEntry += "\""; |
1297 | oneEntry += si->text(2); | 1329 | oneEntry += si->text(2); |
1298 | oneEntry += "\";"; | 1330 | oneEntry += "\";"; |
1299 | oneEntry += "\""; | 1331 | oneEntry += "\""; |
1300 | QString comment = si->text(3); | 1332 | QString comment = si->text(3); |
1301 | comment.replace (QRegExp("\n"), "<br>"); | 1333 | comment.replace (QRegExp("\n"), "<br>"); |
1302 | oneEntry += comment; | 1334 | oneEntry += comment; |
1303 | oneEntry += "\";"; | 1335 | oneEntry += "\";"; |
1304 | oneEntry += "\""; | 1336 | oneEntry += "\""; |
1305 | oneEntry += si->text(4); | 1337 | oneEntry += si->text(4); |
1306 | oneEntry += "\";"; | 1338 | oneEntry += "\";"; |
1307 | oneEntry += "\""; | 1339 | oneEntry += "\""; |
1308 | oneEntry += si->text(5); | 1340 | oneEntry += si->text(5); |
1309 | oneEntry += "\""; | 1341 | oneEntry += "\""; |
1310 | // qWarning (oneEntry); | 1342 | // qWarning (oneEntry); |
1311 | t << oneEntry << endl; | 1343 | t << oneEntry << endl; |
1312 | 1344 | ||
1313 | // qWarning (si->text(0)); | 1345 | // qWarning (si->text(0)); |
1314 | } | 1346 | } |
1315 | } | 1347 | } |
1316 | f.close(); | 1348 | f.close(); |
1317 | } | 1349 | } |
1318 | } | 1350 | } |
1319 | 1351 | ||
1320 | void ZSafe::readAllEntries() | 1352 | void ZSafe::readAllEntries() |
1321 | { | 1353 | { |
1322 | if (filename.isEmpty()) | 1354 | if (filename.isEmpty()) |
1323 | { | 1355 | { |
1324 | QMessageBox::critical( 0, tr("ZSafe"), | 1356 | QMessageBox::critical( 0, tr("ZSafe"), |
1325 | tr("No document defined.\nYou have to create a new document")); | 1357 | tr("No document defined.\nYou have to create a new document")); |
1326 | return; | 1358 | return; |
1327 | } | 1359 | } |
1328 | 1360 | ||
1329 | // open the file dialog | 1361 | // open the file dialog |
1330 | #ifndef DESKTOP | 1362 | #ifndef DESKTOP |
1363 | #ifndef NO_OPIE | ||
1364 | QMap<QString, QStringList> mimeTypes; | ||
1365 | mimeTypes.insert(tr("All"), QStringList() ); | ||
1366 | mimeTypes.insert(tr("Text"), "text/*" ); | ||
1367 | QString fn = OFileDialog::getOpenFileName( OFileSelector::EXTENDED_ALL, | ||
1368 | QDir::homeDirPath() + "/Documents/application/zsafe", | ||
1369 | QString::null, | ||
1370 | mimeTypes, | ||
1371 | this, | ||
1372 | tr ("Import text file")); | ||
1373 | #else | ||
1331 | QString fn = ScQtFileEdit::getOpenFileName(this, | 1374 | QString fn = ScQtFileEdit::getOpenFileName(this, |
1332 | tr ("Import text file"), | 1375 | tr ("Import text file"), |
1333 | QDir::homeDirPath() + "/Documents/application/zsafe", | 1376 | QDir::homeDirPath() + "/Documents/application/zsafe", |
1334 | "*.txt"); | 1377 | "*.txt"); |
1378 | #endif | ||
1335 | #else | 1379 | #else |
1336 | QString fn = QFileDialog::getOpenFileName( | 1380 | QString fn = QFileDialog::getOpenFileName( |
1337 | QDir::homeDirPath() + "/Documents/application/zsafe", | 1381 | QDir::homeDirPath() + "/Documents/application/zsafe", |
1338 | "ZSafe (*.txt)", | 1382 | "ZSafe (*.txt)", |
1339 | this, | 1383 | this, |
1340 | "ZSafe File Dialog" | 1384 | "ZSafe File Dialog" |
1341 | "Choose a text file" ); | 1385 | "Choose a text file" ); |
1342 | #endif | 1386 | #endif |
1343 | 1387 | ||
1344 | if (fn && fn.length() > 0 ) | 1388 | if (fn && fn.length() > 0 ) |
1345 | { | 1389 | { |
1346 | QFile f( fn ); | 1390 | QFile f( fn ); |
1347 | if ( !f.open( IO_ReadOnly ) ) | 1391 | if ( !f.open( IO_ReadOnly ) ) |
1348 | { | 1392 | { |
1349 | qWarning( QString("Could not read file %1").arg(fn), | 1393 | qWarning( QString("Could not read file %1").arg(fn), |
1350 | 2000 ); | 1394 | 2000 ); |
1351 | QMessageBox::critical( 0, "ZSafe", | 1395 | QMessageBox::critical( 0, "ZSafe", |
1352 | QString("Could not import text file.") ); | 1396 | QString("Could not import text file.") ); |
1353 | return; | 1397 | return; |
1354 | } | 1398 | } |
1355 | 1399 | ||
1356 | modified = true; | 1400 | modified = true; |
1357 | 1401 | ||
1358 | // clear the password list | 1402 | // clear the password list |
1359 | selectedItem = NULL; | 1403 | selectedItem = NULL; |
1360 | QListViewItem *i; | 1404 | QListViewItem *i; |
1361 | // step through all categories | 1405 | // step through all categories |
1362 | for (i = ListView->firstChild(); | 1406 | for (i = ListView->firstChild(); |
1363 | i != NULL; | 1407 | i != NULL; |
1364 | i = i->nextSibling()) | 1408 | i = i->nextSibling()) |
1365 | { | 1409 | { |
1366 | // step through all subitems | 1410 | // step through all subitems |
1367 | QListViewItem *si; | 1411 | QListViewItem *si; |
1368 | for (si = i->firstChild(); | 1412 | for (si = i->firstChild(); |
1369 | si != NULL; ) | 1413 | si != NULL; ) |
1370 | // si = si->nextSibling()) | 1414 | // si = si->nextSibling()) |
1371 | { | 1415 | { |
1372 | QListViewItem *_si = si; | 1416 | QListViewItem *_si = si; |
1373 | si = si->nextSibling(); | 1417 | si = si->nextSibling(); |
1374 | i->takeItem(_si); // remove from view list | 1418 | i->takeItem(_si); // remove from view list |
1375 | if (_si) delete _si; | 1419 | if (_si) delete _si; |
1376 | } | 1420 | } |
1377 | } | 1421 | } |
1378 | 1422 | ||
1379 | qWarning ("ReadAllEntries(): "); | 1423 | qWarning ("ReadAllEntries(): "); |
1380 | 1424 | ||
1381 | QTextStream t(&f); | 1425 | QTextStream t(&f); |
1382 | while ( !t.eof() ) | 1426 | while ( !t.eof() ) |
1383 | { | 1427 | { |
1384 | QString s = t.readLine(); | 1428 | QString s = t.readLine(); |
1385 | s.replace (QRegExp("\";\""), "\"|\""); | 1429 | s.replace (QRegExp("\";\""), "\"|\""); |
1386 | // char buffer[1024]; | 1430 | // char buffer[1024]; |
1387 | #ifndef WIN32 | 1431 | #ifndef WIN32 |
1388 | char buffer[s.length()+1]; | 1432 | char buffer[s.length()+1]; |
1389 | #else | 1433 | #else |
1390 | char buffer[4048]; | 1434 | char buffer[4048]; |
1391 | #endif | 1435 | #endif |
1392 | strcpy (buffer, s); | 1436 | strcpy (buffer, s); |
1393 | 1437 | ||
1394 | QString name; | 1438 | QString name; |
1395 | QString user; | 1439 | QString user; |
1396 | QString password; | 1440 | QString password; |
1397 | QString comment; | 1441 | QString comment; |
1398 | QString field5=""; | 1442 | QString field5=""; |
1399 | QString field6=""; | 1443 | QString field6=""; |
1400 | 1444 | ||
1401 | // separete the entries | 1445 | // separete the entries |
1402 | char *i = strtok (buffer, "|"); | 1446 | char *i = strtok (buffer, "|"); |
1403 | QString category(&i[1]); | 1447 | QString category(&i[1]); |
1404 | category.truncate(category.length() -1); | 1448 | category.truncate(category.length() -1); |
1405 | 1449 | ||
1406 | int idx=0; | 1450 | int idx=0; |
1407 | while ((i = strtok (NULL, "|")) != NULL) | 1451 | while ((i = strtok (NULL, "|")) != NULL) |
1408 | { | 1452 | { |
1409 | switch (idx) | 1453 | switch (idx) |
1410 | { | 1454 | { |
1411 | case 0: | 1455 | case 0: |
1412 | name = &i[1]; | 1456 | name = &i[1]; |
1413 | name.truncate(name.length() -1); | 1457 | name.truncate(name.length() -1); |
1414 | // name | 1458 | // name |
1415 | break; | 1459 | break; |
1416 | case 1: | 1460 | case 1: |
1417 | // user | 1461 | // user |
1418 | user = &i[1]; | 1462 | user = &i[1]; |
1419 | user.truncate(user.length() -1); | 1463 | user.truncate(user.length() -1); |
1420 | break; | 1464 | break; |
1421 | case 2: | 1465 | case 2: |
1422 | // password | 1466 | // password |
1423 | password = &i[1]; | 1467 | password = &i[1]; |
1424 | password.truncate(password.length() -1); | 1468 | password.truncate(password.length() -1); |
1425 | break; | 1469 | break; |
1426 | case 3: | 1470 | case 3: |
1427 | // comment | 1471 | // comment |
1428 | comment = &i[1]; | 1472 | comment = &i[1]; |
1429 | comment.truncate(comment.length() -1); | 1473 | comment.truncate(comment.length() -1); |
1430 | break; | 1474 | break; |
1431 | case 4: | 1475 | case 4: |
1432 | // field5 | 1476 | // field5 |
1433 | field5 = &i[1]; | 1477 | field5 = &i[1]; |
1434 | field5.truncate(field5.length() -1); | 1478 | field5.truncate(field5.length() -1); |
1435 | break; | 1479 | break; |
1436 | case 5: | 1480 | case 5: |
1437 | // field6 | 1481 | // field6 |
1438 | field6 = &i[1]; | 1482 | field6 = &i[1]; |
1439 | field6.truncate(field6.length() -1); | 1483 | field6.truncate(field6.length() -1); |
1440 | break; | 1484 | break; |
1441 | } | 1485 | } |
1442 | idx++; | 1486 | idx++; |
1443 | } | 1487 | } |
1444 | 1488 | ||
1445 | Category *cat= categories.find (category); | 1489 | Category *cat= categories.find (category); |
1446 | if (cat) | 1490 | if (cat) |
1447 | { | 1491 | { |
1448 | // use the existend item | 1492 | // use the existend item |
1449 | QListViewItem *catItem = cat->getListItem(); | 1493 | QListViewItem *catItem = cat->getListItem(); |
1450 | if (catItem) | 1494 | if (catItem) |
1451 | { | 1495 | { |
1452 | QListViewItem * item = new ShadedListItem( 0, catItem ); | 1496 | QListViewItem * item = new ShadedListItem( 0, catItem ); |
1453 | item->setText( 0, tr( name ) ); | 1497 | item->setText( 0, tr( name ) ); |
1454 | item->setText( 1, tr( user ) ); | 1498 | item->setText( 1, tr( user ) ); |
1455 | item->setText( 2, tr( password ) ); | 1499 | item->setText( 2, tr( password ) ); |
1456 | item->setText( 3, tr( comment ) ); | 1500 | item->setText( 3, tr( comment ) ); |
1457 | item->setText( 4, tr( field5 ) ); | 1501 | item->setText( 4, tr( field5 ) ); |
1458 | item->setText( 5, tr( field6 ) ); | 1502 | item->setText( 5, tr( field6 ) ); |
1459 | catItem->setOpen( TRUE ); | 1503 | catItem->setOpen( TRUE ); |
1460 | } | 1504 | } |
1461 | } | 1505 | } |
1462 | else | 1506 | else |
1463 | { | 1507 | { |
1464 | QListViewItem *catI = new ShadedListItem( 1, ListView ); | 1508 | QListViewItem *catI = new ShadedListItem( 1, ListView ); |
1465 | // create and insert a new item | 1509 | // create and insert a new item |
1466 | QListViewItem * item = new ShadedListItem( 0, catI ); | 1510 | QListViewItem * item = new ShadedListItem( 0, catI ); |
1467 | item->setText( 0, tr( name ) ); | 1511 | item->setText( 0, tr( name ) ); |
1468 | item->setText( 1, tr( user ) ); | 1512 | item->setText( 1, tr( user ) ); |
1469 | item->setText( 2, tr( password ) ); | 1513 | item->setText( 2, tr( password ) ); |
1470 | item->setText( 3, tr( comment ) ); | 1514 | item->setText( 3, tr( comment ) ); |
1471 | item->setText( 4, tr( field5 ) ); | 1515 | item->setText( 4, tr( field5 ) ); |
1472 | item->setText( 5, tr( field6 ) ); | 1516 | item->setText( 5, tr( field6 ) ); |
1473 | catI->setOpen( TRUE ); | 1517 | catI->setOpen( TRUE ); |
1474 | 1518 | ||
1475 | Category *c1 = new Category(); | 1519 | Category *c1 = new Category(); |
1476 | c1->setCategoryName(category); | 1520 | c1->setCategoryName(category); |
1477 | 1521 | ||
1478 | QString icon; | 1522 | QString icon; |
1479 | QString fullIconPath; | 1523 | QString fullIconPath; |
1480 | QPixmap *pix; | 1524 | QPixmap *pix; |
1481 | // #ifndef WIN32 | 1525 | // #ifndef WIN32 |
1482 | icon = conf->readEntry(APP_KEY+category); | 1526 | icon = conf->readEntry(APP_KEY+category); |
1483 | // #endif | 1527 | // #endif |
1484 | bool isIconAv = false; | 1528 | bool isIconAv = false; |
1485 | if (!icon.isEmpty() && !icon.isNull()) | 1529 | if (!icon.isEmpty() && !icon.isNull()) |
1486 | { | 1530 | { |
1487 | // build the full path | 1531 | // build the full path |
1488 | fullIconPath = iconPath + icon; | 1532 | fullIconPath = iconPath + icon; |
1489 | pix = new QPixmap (fullIconPath); | 1533 | pix = new QPixmap (fullIconPath); |
1490 | if (pix) | 1534 | if (pix) |
1491 | { | 1535 | { |
1492 | QImage img = pix->convertToImage(); | 1536 | QImage img = pix->convertToImage(); |
1493 | pix->convertFromImage(img.smoothScale(14,14)); | 1537 | pix->convertFromImage(img.smoothScale(14,14)); |
1494 | c1->setIconName (icon); | 1538 | c1->setIconName (icon); |
1495 | c1->setIcon (*pix); | 1539 | c1->setIcon (*pix); |
1496 | isIconAv = true; | 1540 | isIconAv = true; |
1497 | } | 1541 | } |
1498 | } | 1542 | } |
1499 | if (!isIconAv) | 1543 | if (!isIconAv) |
1500 | { | 1544 | { |
1501 | c1->setIcon (*getPredefinedIcon(category)); | 1545 | c1->setIcon (*getPredefinedIcon(category)); |
1502 | } | 1546 | } |
1503 | c1->setListItem (catI); | 1547 | c1->setListItem (catI); |
1504 | c1->initListItem(); | 1548 | c1->initListItem(); |
1505 | categories.insert (c1->getCategoryName(), c1); | 1549 | categories.insert (c1->getCategoryName(), c1); |
1506 | } | 1550 | } |
1507 | 1551 | ||
1508 | } | 1552 | } |
1509 | f.close(); | 1553 | f.close(); |
1510 | 1554 | ||
1511 | } | 1555 | } |
1512 | else | 1556 | else |
1513 | { | 1557 | { |
1514 | } | 1558 | } |
1515 | 1559 | ||
1516 | } | 1560 | } |
1517 | 1561 | ||
1518 | #ifdef UNUSED | 1562 | #ifdef UNUSED |
1519 | void ZSafe::writeAllEntries() | 1563 | void ZSafe::writeAllEntries() |
1520 | { | 1564 | { |
1521 | // open the file for writing | 1565 | // open the file for writing |
1522 | QString fn = filename + ".txt"; | 1566 | QString fn = filename + ".txt"; |
1523 | QFile f( fn ); | 1567 | QFile f( fn ); |
1524 | if ( !f.open( IO_WriteOnly ) ) { | 1568 | if ( !f.open( IO_WriteOnly ) ) { |
1525 | qWarning( QString("Could not write to file %1").arg(fn), | 1569 | qWarning( QString("Could not write to file %1").arg(fn), |
1526 | 2000 ); | 1570 | 2000 ); |
1527 | QMessageBox::critical( 0, tr("ZSafe"), | 1571 | QMessageBox::critical( 0, tr("ZSafe"), |
1528 | tr("Could not export to text file.") ); | 1572 | tr("Could not export to text file.") ); |
1529 | return; | 1573 | return; |
1530 | } | 1574 | } |
1531 | QTextStream t( &f ); | 1575 | QTextStream t( &f ); |
1532 | 1576 | ||
1533 | QListViewItem *i; | 1577 | QListViewItem *i; |
1534 | // step through all categories | 1578 | // step through all categories |
1535 | for (i = ListView->firstChild(); | 1579 | for (i = ListView->firstChild(); |
1536 | i != NULL; | 1580 | i != NULL; |
1537 | i = i->nextSibling()) | 1581 | i = i->nextSibling()) |
1538 | { | 1582 | { |
1539 | // step through all subitems | 1583 | // step through all subitems |
1540 | QListViewItem *si; | 1584 | QListViewItem *si; |
1541 | for (si = i->firstChild(); | 1585 | for (si = i->firstChild(); |
1542 | si != NULL; | 1586 | si != NULL; |
1543 | si = si->nextSibling()) | 1587 | si = si->nextSibling()) |
1544 | { | 1588 | { |
1545 | QString oneEntry; | 1589 | QString oneEntry; |
1546 | oneEntry += "\""; | 1590 | oneEntry += "\""; |
1547 | oneEntry += i->text(0); | 1591 | oneEntry += i->text(0); |
1548 | oneEntry += "\";"; | 1592 | oneEntry += "\";"; |
1549 | oneEntry += "\""; | 1593 | oneEntry += "\""; |
1550 | oneEntry += si->text(0); | 1594 | oneEntry += si->text(0); |
1551 | oneEntry += "\";"; | 1595 | oneEntry += "\";"; |
1552 | oneEntry += "\""; | 1596 | oneEntry += "\""; |
1553 | oneEntry += si->text(1); | 1597 | oneEntry += si->text(1); |
1554 | oneEntry += "\";"; | 1598 | oneEntry += "\";"; |
1555 | oneEntry += "\""; | 1599 | oneEntry += "\""; |
1556 | oneEntry += si->text(2); | 1600 | oneEntry += si->text(2); |
1557 | oneEntry += "\";"; | 1601 | oneEntry += "\";"; |
1558 | oneEntry += "\""; | 1602 | oneEntry += "\""; |
1559 | // oneEntry += si->text(3); | 1603 | // oneEntry += si->text(3); |
1560 | QString comment = si->text(3); | 1604 | QString comment = si->text(3); |
1561 | comment.replace (QRegExp("\n"), "<br>"); | 1605 | comment.replace (QRegExp("\n"), "<br>"); |
1562 | oneEntry += comment; | 1606 | oneEntry += comment; |
1563 | oneEntry += "\""; | 1607 | oneEntry += "\""; |
1564 | // qWarning (oneEntry); | 1608 | // qWarning (oneEntry); |
1565 | t << oneEntry << endl; | 1609 | t << oneEntry << endl; |
1566 | 1610 | ||
1567 | // qWarning (si->text(0)); | 1611 | // qWarning (si->text(0)); |
1568 | } | 1612 | } |
1569 | } | 1613 | } |
1570 | f.close(); | 1614 | f.close(); |
1571 | } | 1615 | } |
1572 | 1616 | ||
1573 | void ZSafe::readAllEntries() | 1617 | void ZSafe::readAllEntries() |
1574 | { | 1618 | { |
1575 | QString fn = filename + ".txt"; | 1619 | QString fn = filename + ".txt"; |
1576 | QFile f( fn ); | 1620 | QFile f( fn ); |
1577 | if ( !f.open( IO_ReadOnly ) ) | 1621 | if ( !f.open( IO_ReadOnly ) ) |
1578 | { | 1622 | { |
1579 | qWarning( QString("Could not read file %1").arg(fn), | 1623 | qWarning( QString("Could not read file %1").arg(fn), |
1580 | 2000 ); | 1624 | 2000 ); |
1581 | QMessageBox::critical( 0, tr("ZSafe"), | 1625 | QMessageBox::critical( 0, tr("ZSafe"), |
1582 | tr("Could not import text file.") ); | 1626 | tr("Could not import text file.") ); |
1583 | return; | 1627 | return; |
1584 | } | 1628 | } |
1585 | 1629 | ||
1586 | modified = true; | 1630 | modified = true; |
1587 | 1631 | ||
1588 | // clear the password list | 1632 | // clear the password list |
1589 | selectedItem = NULL; | 1633 | selectedItem = NULL; |
1590 | QListViewItem *i; | 1634 | QListViewItem *i; |
@@ -2888,605 +2932,642 @@ void ZSafe::editCategory() | |||
2888 | dialog->CategoryField->setCurrentItem(i); | 2932 | dialog->CategoryField->setCurrentItem(i); |
2889 | } | 2933 | } |
2890 | 2934 | ||
2891 | QString icon; | 2935 | QString icon; |
2892 | Category *cat= categories.find (selectedItem->text(0)); | 2936 | Category *cat= categories.find (selectedItem->text(0)); |
2893 | if (cat) | 2937 | if (cat) |
2894 | { | 2938 | { |
2895 | icon = cat->getIconName(); | 2939 | icon = cat->getIconName(); |
2896 | } | 2940 | } |
2897 | 2941 | ||
2898 | if (initIcons) | 2942 | if (initIcons) |
2899 | { | 2943 | { |
2900 | 2944 | ||
2901 | Wait waitDialog(this, tr("Wait dialog")); | 2945 | Wait waitDialog(this, tr("Wait dialog")); |
2902 | waitDialog.waitLabel->setText(tr("Gathering icons...")); | 2946 | waitDialog.waitLabel->setText(tr("Gathering icons...")); |
2903 | waitDialog.show(); | 2947 | waitDialog.show(); |
2904 | qApp->processEvents(); | 2948 | qApp->processEvents(); |
2905 | 2949 | ||
2906 | #ifdef DESKTOP | 2950 | #ifdef DESKTOP |
2907 | QDir d(iconPath); | 2951 | QDir d(iconPath); |
2908 | #else | 2952 | #else |
2909 | QDir d(QPEApplication::qpeDir() + "/pics/"); | 2953 | QDir d(QPEApplication::qpeDir() + "/pics/"); |
2910 | #endif | 2954 | #endif |
2911 | d.setFilter( QDir::Files); | 2955 | d.setFilter( QDir::Files); |
2912 | 2956 | ||
2913 | const QFileInfoList *list = d.entryInfoList(); | 2957 | const QFileInfoList *list = d.entryInfoList(); |
2914 | int i=0; | 2958 | int i=0; |
2915 | QFileInfoListIterator it( *list ); // create list iterator | 2959 | QFileInfoListIterator it( *list ); // create list iterator |
2916 | QFileInfo *fi; // pointer for traversing | 2960 | QFileInfo *fi; // pointer for traversing |
2917 | if (icon.isEmpty() || icon.isNull()) | 2961 | if (icon.isEmpty() || icon.isNull()) |
2918 | { | 2962 | { |
2919 | dialog->IconField->setCurrentItem(0); | 2963 | dialog->IconField->setCurrentItem(0); |
2920 | } | 2964 | } |
2921 | 2965 | ||
2922 | dialog->IconField->insertItem("predefined"); | 2966 | dialog->IconField->insertItem("predefined"); |
2923 | while ( (fi=it.current()) ) { // for each file... | 2967 | while ( (fi=it.current()) ) { // for each file... |
2924 | QString fileName = fi->fileName(); | 2968 | QString fileName = fi->fileName(); |
2925 | if(fileName.right(4) == ".png") | 2969 | if(fileName.right(4) == ".png") |
2926 | { | 2970 | { |
2927 | fileName = fileName.mid(0,fileName.length()-4); | 2971 | fileName = fileName.mid(0,fileName.length()-4); |
2928 | #ifdef DESKTOP | 2972 | #ifdef DESKTOP |
2929 | QPixmap imageOfFile; | 2973 | QPixmap imageOfFile; |
2930 | imageOfFile.load(iconPath + fi->fileName()); | 2974 | imageOfFile.load(iconPath + fi->fileName()); |
2931 | #else | 2975 | #else |
2932 | QPixmap imageOfFile(Resource::loadPixmap(fileName)); | 2976 | QPixmap imageOfFile(Resource::loadPixmap(fileName)); |
2933 | #endif | 2977 | #endif |
2934 | QImage foo = imageOfFile.convertToImage(); | 2978 | QImage foo = imageOfFile.convertToImage(); |
2935 | foo = foo.smoothScale(16,16); | 2979 | foo = foo.smoothScale(16,16); |
2936 | imageOfFile.convertFromImage(foo); | 2980 | imageOfFile.convertFromImage(foo); |
2937 | dialog->IconField->insertItem(imageOfFile,fileName); | 2981 | dialog->IconField->insertItem(imageOfFile,fileName); |
2938 | if(fileName+".png"==icon) | 2982 | if(fileName+".png"==icon) |
2939 | dialog->IconField->setCurrentItem(i+1); | 2983 | dialog->IconField->setCurrentItem(i+1); |
2940 | ++i; | 2984 | ++i; |
2941 | } | 2985 | } |
2942 | ++it; | 2986 | ++it; |
2943 | } | 2987 | } |
2944 | waitDialog.hide(); | 2988 | waitDialog.hide(); |
2945 | } | 2989 | } |
2946 | else | 2990 | else |
2947 | { | 2991 | { |
2948 | #ifdef DESKTOP | 2992 | #ifdef DESKTOP |
2949 | // QDir d(QDir::homeDirPath() + "/pics/"); | 2993 | // QDir d(QDir::homeDirPath() + "/pics/"); |
2950 | QDir d(iconPath); | 2994 | QDir d(iconPath); |
2951 | #else | 2995 | #else |
2952 | QDir d(QPEApplication::qpeDir() + "/pics/"); | 2996 | QDir d(QPEApplication::qpeDir() + "/pics/"); |
2953 | #endif | 2997 | #endif |
2954 | d.setFilter( QDir::Files); | 2998 | d.setFilter( QDir::Files); |
2955 | 2999 | ||
2956 | const QFileInfoList *list = d.entryInfoList(); | 3000 | const QFileInfoList *list = d.entryInfoList(); |
2957 | int i=0; | 3001 | int i=0; |
2958 | QFileInfoListIterator it( *list ); // create list iterator | 3002 | QFileInfoListIterator it( *list ); // create list iterator |
2959 | QFileInfo *fi; // pointer for traversing | 3003 | QFileInfo *fi; // pointer for traversing |
2960 | if (icon.isEmpty() || icon.isNull()) | 3004 | if (icon.isEmpty() || icon.isNull()) |
2961 | { | 3005 | { |
2962 | dialog->IconField->setCurrentItem(0); | 3006 | dialog->IconField->setCurrentItem(0); |
2963 | } | 3007 | } |
2964 | else | 3008 | else |
2965 | { | 3009 | { |
2966 | 3010 | ||
2967 | while ( (fi=it.current()) ) | 3011 | while ( (fi=it.current()) ) |
2968 | { // for each file... | 3012 | { // for each file... |
2969 | QString fileName = fi->fileName(); | 3013 | QString fileName = fi->fileName(); |
2970 | if(fileName.right(4) == ".png") | 3014 | if(fileName.right(4) == ".png") |
2971 | { | 3015 | { |
2972 | fileName = fileName.mid(0,fileName.length()-4); | 3016 | fileName = fileName.mid(0,fileName.length()-4); |
2973 | 3017 | ||
2974 | 3018 | ||
2975 | if(fileName+".png"==icon) | 3019 | if(fileName+".png"==icon) |
2976 | { | 3020 | { |
2977 | dialog->IconField->setCurrentItem(i+1); | 3021 | dialog->IconField->setCurrentItem(i+1); |
2978 | break; | 3022 | break; |
2979 | } | 3023 | } |
2980 | ++i; | 3024 | ++i; |
2981 | } | 3025 | } |
2982 | ++it; | 3026 | ++it; |
2983 | } | 3027 | } |
2984 | } | 3028 | } |
2985 | } | 3029 | } |
2986 | 3030 | ||
2987 | // dialog->show(); | 3031 | // dialog->show(); |
2988 | #ifndef DESKTOP | 3032 | #ifndef DESKTOP |
2989 | // dialog->move (20, 100); | 3033 | // dialog->move (20, 100); |
2990 | #endif | 3034 | #endif |
2991 | DialogCode result = (DialogCode) dialog->exec(); | 3035 | DialogCode result = (DialogCode) dialog->exec(); |
2992 | #ifdef DESKTOP | 3036 | #ifdef DESKTOP |
2993 | result = Accepted; | 3037 | result = Accepted; |
2994 | #endif | 3038 | #endif |
2995 | 3039 | ||
2996 | QString fullIconPath; | 3040 | QString fullIconPath; |
2997 | QPixmap *pix; | 3041 | QPixmap *pix; |
2998 | if (result == Accepted) | 3042 | if (result == Accepted) |
2999 | { | 3043 | { |
3000 | modified = true; | 3044 | modified = true; |
3001 | if (category != dialog->CategoryField->currentText()) | 3045 | if (category != dialog->CategoryField->currentText()) |
3002 | { | 3046 | { |
3003 | categories.remove (category); | 3047 | categories.remove (category); |
3004 | // #ifndef WIN32 | 3048 | // #ifndef WIN32 |
3005 | conf->removeEntry(category); | 3049 | conf->removeEntry(category); |
3006 | // #endif | 3050 | // #endif |
3007 | saveConf(); | 3051 | saveConf(); |
3008 | } | 3052 | } |
3009 | 3053 | ||
3010 | category = dialog->CategoryField->currentText(); | 3054 | category = dialog->CategoryField->currentText(); |
3011 | icon = dialog->IconField->currentText()+".png"; | 3055 | icon = dialog->IconField->currentText()+".png"; |
3012 | 3056 | ||
3013 | if (cat) | 3057 | if (cat) |
3014 | { | 3058 | { |
3015 | qWarning("Category found"); | 3059 | qWarning("Category found"); |
3016 | 3060 | ||
3017 | // if (!icon.isEmpty() && !icon.isNull()) | 3061 | // if (!icon.isEmpty() && !icon.isNull()) |
3018 | if (icon != "predefined.png") | 3062 | if (icon != "predefined.png") |
3019 | { | 3063 | { |
3020 | // build the full path | 3064 | // build the full path |
3021 | fullIconPath = iconPath + icon; | 3065 | fullIconPath = iconPath + icon; |
3022 | pix = new QPixmap (fullIconPath); | 3066 | pix = new QPixmap (fullIconPath); |
3023 | if (pix) | 3067 | if (pix) |
3024 | { | 3068 | { |
3025 | // save the full pixmap name into the config file | 3069 | // save the full pixmap name into the config file |
3026 | // #ifndef WIN32 | 3070 | // #ifndef WIN32 |
3027 | conf->writeEntry(APP_KEY+category, icon); | 3071 | conf->writeEntry(APP_KEY+category, icon); |
3028 | // #endif | 3072 | // #endif |
3029 | saveConf(); | 3073 | saveConf(); |
3030 | QImage img = pix->convertToImage(); | 3074 | QImage img = pix->convertToImage(); |
3031 | pix->convertFromImage(img.smoothScale(14,14)); | 3075 | pix->convertFromImage(img.smoothScale(14,14)); |
3032 | cat->setIconName (icon); | 3076 | cat->setIconName (icon); |
3033 | cat->setIcon (*pix); | 3077 | cat->setIcon (*pix); |
3034 | } | 3078 | } |
3035 | } | 3079 | } |
3036 | else | 3080 | else |
3037 | { | 3081 | { |
3038 | // #ifndef WIN32 | 3082 | // #ifndef WIN32 |
3039 | conf->removeEntry (category); | 3083 | conf->removeEntry (category); |
3040 | // #endif | 3084 | // #endif |
3041 | saveConf(); | 3085 | saveConf(); |
3042 | cat->setIcon (*getPredefinedIcon(category)); | 3086 | cat->setIcon (*getPredefinedIcon(category)); |
3043 | } | 3087 | } |
3044 | 3088 | ||
3045 | // change the category name of the selected category | 3089 | // change the category name of the selected category |
3046 | QListViewItem *catItem = cat->getListItem(); | 3090 | QListViewItem *catItem = cat->getListItem(); |
3047 | if (catItem) | 3091 | if (catItem) |
3048 | { | 3092 | { |
3049 | qWarning (category); | 3093 | qWarning (category); |
3050 | catItem->setText( 0, tr( category ) ); | 3094 | catItem->setText( 0, tr( category ) ); |
3051 | cat->setCategoryName (tr(category)); | 3095 | cat->setCategoryName (tr(category)); |
3052 | cat->initListItem(); | 3096 | cat->initListItem(); |
3053 | categories.insert (category, cat); | 3097 | categories.insert (category, cat); |
3054 | } | 3098 | } |
3055 | } | 3099 | } |
3056 | saveCategoryDialogFields(dialog); | 3100 | saveCategoryDialogFields(dialog); |
3057 | } | 3101 | } |
3058 | else | 3102 | else |
3059 | { | 3103 | { |
3060 | // delete dialog; | 3104 | // delete dialog; |
3061 | dialog->hide(); | 3105 | dialog->hide(); |
3062 | return; | 3106 | return; |
3063 | } | 3107 | } |
3064 | 3108 | ||
3065 | } | 3109 | } |
3066 | } | 3110 | } |
3067 | 3111 | ||
3068 | void ZSafe::cutItem() | 3112 | void ZSafe::cutItem() |
3069 | { | 3113 | { |
3070 | if (!selectedItem) | 3114 | if (!selectedItem) |
3071 | return; | 3115 | return; |
3072 | if (!isCategory(selectedItem)) | 3116 | if (!isCategory(selectedItem)) |
3073 | { | 3117 | { |
3074 | IsCut = true; | 3118 | IsCut = true; |
3075 | copiedItem = selectedItem; | 3119 | copiedItem = selectedItem; |
3076 | } | 3120 | } |
3077 | } | 3121 | } |
3078 | 3122 | ||
3079 | void ZSafe::copyItem() | 3123 | void ZSafe::copyItem() |
3080 | { | 3124 | { |
3081 | if (!selectedItem) | 3125 | if (!selectedItem) |
3082 | return; | 3126 | return; |
3083 | if (!isCategory(selectedItem)) | 3127 | if (!isCategory(selectedItem)) |
3084 | { | 3128 | { |
3085 | IsCopy = true; | 3129 | IsCopy = true; |
3086 | copiedItem = selectedItem; | 3130 | copiedItem = selectedItem; |
3087 | } | 3131 | } |
3088 | } | 3132 | } |
3089 | 3133 | ||
3090 | // paste item into category | 3134 | // paste item into category |
3091 | void ZSafe::pasteItem() | 3135 | void ZSafe::pasteItem() |
3092 | { | 3136 | { |
3093 | if (!selectedItem) | 3137 | if (!selectedItem) |
3094 | return; | 3138 | return; |
3095 | if (isCategory(selectedItem)) | 3139 | if (isCategory(selectedItem)) |
3096 | { | 3140 | { |
3097 | modified = true; | 3141 | modified = true; |
3098 | if (IsCut) | 3142 | if (IsCut) |
3099 | { | 3143 | { |
3100 | if (copiedItem) | 3144 | if (copiedItem) |
3101 | { | 3145 | { |
3102 | // add the new item | 3146 | // add the new item |
3103 | QListViewItem *i = new ShadedListItem (0, selectedItem); | 3147 | QListViewItem *i = new ShadedListItem (0, selectedItem); |
3104 | // i->setOpen (TRUE); | 3148 | // i->setOpen (TRUE); |
3105 | i->setText (0, copiedItem->text(0)); | 3149 | i->setText (0, copiedItem->text(0)); |
3106 | i->setText (1, copiedItem->text(1)); | 3150 | i->setText (1, copiedItem->text(1)); |
3107 | i->setText (2, copiedItem->text(2)); | 3151 | i->setText (2, copiedItem->text(2)); |
3108 | i->setText (3, copiedItem->text(3)); | 3152 | i->setText (3, copiedItem->text(3)); |
3109 | i->setText (4, copiedItem->text(4)); | 3153 | i->setText (4, copiedItem->text(4)); |
3110 | i->setText (5, copiedItem->text(5)); | 3154 | i->setText (5, copiedItem->text(5)); |
3111 | selectedItem->setOpen( TRUE ); | 3155 | selectedItem->setOpen( TRUE ); |
3112 | 3156 | ||
3113 | // remove the cutted item | 3157 | // remove the cutted item |
3114 | copiedItem->parent()->takeItem(copiedItem); | 3158 | copiedItem->parent()->takeItem(copiedItem); |
3115 | selectedItem = NULL; | 3159 | selectedItem = NULL; |
3116 | } | 3160 | } |
3117 | } | 3161 | } |
3118 | else if (IsCopy) | 3162 | else if (IsCopy) |
3119 | { | 3163 | { |
3120 | if (copiedItem) | 3164 | if (copiedItem) |
3121 | { | 3165 | { |
3122 | // add the new item | 3166 | // add the new item |
3123 | QListViewItem *i = new ShadedListItem (0, selectedItem); | 3167 | QListViewItem *i = new ShadedListItem (0, selectedItem); |
3124 | // i->setOpen (TRUE); | 3168 | // i->setOpen (TRUE); |
3125 | i->setText (0, copiedItem->text(0)); | 3169 | i->setText (0, copiedItem->text(0)); |
3126 | i->setText (1, copiedItem->text(1)); | 3170 | i->setText (1, copiedItem->text(1)); |
3127 | i->setText (2, copiedItem->text(2)); | 3171 | i->setText (2, copiedItem->text(2)); |
3128 | i->setText (3, copiedItem->text(3)); | 3172 | i->setText (3, copiedItem->text(3)); |
3129 | i->setText (4, copiedItem->text(4)); | 3173 | i->setText (4, copiedItem->text(4)); |
3130 | i->setText (5, copiedItem->text(5)); | 3174 | i->setText (5, copiedItem->text(5)); |
3131 | selectedItem->setOpen( TRUE ); | 3175 | selectedItem->setOpen( TRUE ); |
3132 | } | 3176 | } |
3133 | } | 3177 | } |
3134 | } | 3178 | } |
3135 | IsCut = false; | 3179 | IsCut = false; |
3136 | IsCopy = false; | 3180 | IsCopy = false; |
3137 | } | 3181 | } |
3138 | 3182 | ||
3139 | void ZSafe::newDocument() | 3183 | void ZSafe::newDocument() |
3140 | { | 3184 | { |
3141 | 3185 | ||
3142 | // open the file dialog | 3186 | // open the file dialog |
3143 | #ifndef DESKTOP | 3187 | #ifndef DESKTOP |
3188 | #ifndef NO_OPIE | ||
3189 | QMap<QString, QStringList> mimeTypes; | ||
3190 | mimeTypes.insert(tr("All"), QStringList() ); | ||
3191 | mimeTypes.insert(tr("ZSafe"), "zsafe/*" ); | ||
3192 | QString newFile = OFileDialog::getSaveFileName( OFileSelector::EXTENDED_ALL, | ||
3193 | QDir::homeDirPath() + "/Documents/application/zsafe", | ||
3194 | QString::null, | ||
3195 | mimeTypes, | ||
3196 | this, | ||
3197 | tr ("Create new ZSafe document")); | ||
3198 | #else | ||
3144 | QString newFile = ScQtFileEdit::getSaveAsFileName(this, | 3199 | QString newFile = ScQtFileEdit::getSaveAsFileName(this, |
3145 | tr ("Create new ZSafe document"), | 3200 | tr ("Create new ZSafe document"), |
3146 | QDir::homeDirPath() + "/Documents/application/zsafe", | 3201 | QDir::homeDirPath() + "/Documents/application/zsafe", |
3147 | "*.zsf"); | 3202 | "*.zsf"); |
3203 | #endif | ||
3148 | #else | 3204 | #else |
3149 | QString newFile = QFileDialog::getSaveFileName( | 3205 | QString newFile = QFileDialog::getSaveFileName( |
3150 | QDir::homeDirPath() + "/Documents/application/zsafe", | 3206 | QDir::homeDirPath() + "/Documents/application/zsafe", |
3151 | "ZSafe (*.zsf)", | 3207 | "ZSafe (*.zsf)", |
3152 | this, | 3208 | this, |
3153 | "ZSafe File Dialog" | 3209 | "ZSafe File Dialog" |
3154 | "Choose a ZSafe file" ); | 3210 | "Choose a ZSafe file" ); |
3155 | #endif | 3211 | #endif |
3156 | 3212 | ||
3157 | // open the new document | 3213 | // open the new document |
3158 | if (newFile && newFile.length() > 0 ) | 3214 | if (newFile && newFile.length() > 0 ) |
3159 | { | 3215 | { |
3160 | // save the previous opened document | 3216 | // save the previous opened document |
3161 | if (!filename.isEmpty()) | 3217 | if (!filename.isEmpty()) |
3162 | saveDocument(filename, FALSE); | 3218 | saveDocument(filename, FALSE); |
3163 | 3219 | ||
3164 | modified = true; | 3220 | modified = true; |
3165 | 3221 | ||
3166 | // clear the password list | 3222 | // clear the password list |
3167 | QListViewItem *i; | 3223 | QListViewItem *i; |
3168 | QListViewItem *c = NULL; | 3224 | QListViewItem *c = NULL; |
3169 | // step through all categories | 3225 | // step through all categories |
3170 | for (i = ListView->firstChild(); | 3226 | for (i = ListView->firstChild(); |
3171 | i != NULL; | 3227 | i != NULL; |
3172 | i = i->nextSibling()) | 3228 | i = i->nextSibling()) |
3173 | { | 3229 | { |
3174 | if (c) delete c; // delete the previous category | 3230 | if (c) delete c; // delete the previous category |
3175 | 3231 | ||
3176 | c = i; | 3232 | c = i; |
3177 | // step through all subitems | 3233 | // step through all subitems |
3178 | QListViewItem *si; | 3234 | QListViewItem *si; |
3179 | for (si = i->firstChild(); | 3235 | for (si = i->firstChild(); |
3180 | si != NULL; ) | 3236 | si != NULL; ) |
3181 | { | 3237 | { |
3182 | QListViewItem *_si = si; | 3238 | QListViewItem *_si = si; |
3183 | si = si->nextSibling(); | 3239 | si = si->nextSibling(); |
3184 | i->takeItem(_si); // remove from view list | 3240 | i->takeItem(_si); // remove from view list |
3185 | if (_si) delete _si; | 3241 | if (_si) delete _si; |
3186 | } | 3242 | } |
3187 | } | 3243 | } |
3188 | if (c) delete c; // delete the previous category | 3244 | if (c) delete c; // delete the previous category |
3189 | categories.clear(); | 3245 | categories.clear(); |
3190 | 3246 | ||
3191 | // m_password = ""; | 3247 | // m_password = ""; |
3192 | // selectedItem = NULL; | 3248 | selectedItem = NULL; |
3193 | 3249 | ||
3194 | filename = newFile; | 3250 | filename = newFile; |
3195 | 3251 | ||
3196 | // save the current filename to the config file | 3252 | // save the current filename to the config file |
3197 | conf->writeEntry(APP_KEY+"document", filename); | 3253 | conf->writeEntry(APP_KEY+"document", filename); |
3198 | saveConf(); | 3254 | saveConf(); |
3199 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); | 3255 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); |
3200 | #ifdef WIN32 | 3256 | #ifdef WIN32 |
3201 | this->setCaption("Qt ZSafe: " + ti); | 3257 | this->setCaption("Qt ZSafe: " + ti); |
3202 | #else | 3258 | #else |
3203 | this->setCaption("ZSafe: " + ti); | 3259 | this->setCaption("ZSafe: " + ti); |
3204 | #endif | 3260 | #endif |
3205 | 3261 | ||
3206 | // openDocument(filename); | 3262 | // openDocument(filename); |
3207 | 3263 | ||
3208 | QMessageBox::information( this, tr("ZSafe"), | 3264 | QMessageBox::information( this, tr("ZSafe"), |
3209 | tr("Now you have to enter\na password twice for your\nnewly created document."), tr("&OK"), 0); | 3265 | tr("Now you have to enter\na password twice for your\nnewly created document."), tr("&OK"), 0); |
3210 | 3266 | ||
3211 | saveDocumentWithPwd(); | 3267 | saveDocumentWithPwd(); |
3212 | } | 3268 | } |
3213 | } | 3269 | } |
3214 | 3270 | ||
3215 | void ZSafe::loadDocument() | 3271 | void ZSafe::loadDocument() |
3216 | { | 3272 | { |
3217 | 3273 | ||
3218 | // open the file dialog | 3274 | // open the file dialog |
3219 | #ifndef DESKTOP | 3275 | #ifndef DESKTOP |
3276 | #ifndef NO_OPIE | ||
3277 | QMap<QString, QStringList> mimeTypes; | ||
3278 | mimeTypes.insert(tr("All"), QStringList() ); | ||
3279 | mimeTypes.insert(tr("ZSafe"), "zsafe/*" ); | ||
3280 | QString newFile = OFileDialog::getOpenFileName( OFileSelector::EXTENDED_ALL, | ||
3281 | QDir::homeDirPath() + "/Documents/application/zsafe", | ||
3282 | QString::null, | ||
3283 | mimeTypes, | ||
3284 | this, | ||
3285 | tr ("Open ZSafe document")); | ||
3286 | #else | ||
3220 | QString newFile = ScQtFileEdit::getOpenFileName(this, | 3287 | QString newFile = ScQtFileEdit::getOpenFileName(this, |
3221 | tr ("Open ZSafe document"), | 3288 | tr ("Open ZSafe document"), |
3222 | QDir::homeDirPath() + "/Documents/application/zsafe", | 3289 | QDir::homeDirPath() + "/Documents/application/zsafe", |
3223 | "*.zsf"); | 3290 | "*.zsf"); |
3291 | #endif | ||
3224 | #else | 3292 | #else |
3225 | QString newFile = QFileDialog::getOpenFileName( | 3293 | QString newFile = QFileDialog::getOpenFileName( |
3226 | QDir::homeDirPath() + "/Documents/application/zsafe", | 3294 | QDir::homeDirPath() + "/Documents/application/zsafe", |
3227 | "ZSafe (*.zsf)", | 3295 | "ZSafe (*.zsf)", |
3228 | this, | 3296 | this, |
3229 | "ZSafe File Dialog" | 3297 | "ZSafe File Dialog" |
3230 | "Choose a ZSafe file" ); | 3298 | "Choose a ZSafe file" ); |
3231 | #endif | 3299 | #endif |
3232 | 3300 | ||
3233 | // open the new document | 3301 | // open the new document |
3234 | if (newFile && newFile.length() > 0 ) | 3302 | if (newFile && newFile.length() > 0 ) |
3235 | { | 3303 | { |
3236 | // save the previous opened document | 3304 | // save the previous opened document |
3237 | if (!filename.isEmpty()) | 3305 | if (!filename.isEmpty()) |
3238 | saveDocument(filename, FALSE); | 3306 | saveDocument(filename, FALSE); |
3239 | 3307 | ||
3240 | // clear the password list | 3308 | // clear the password list |
3241 | QListViewItem *i; | 3309 | QListViewItem *i; |
3242 | QListViewItem *c = NULL; | 3310 | QListViewItem *c = NULL; |
3243 | // step through all categories | 3311 | // step through all categories |
3244 | for (i = ListView->firstChild(); | 3312 | for (i = ListView->firstChild(); |
3245 | i != NULL; | 3313 | i != NULL; |
3246 | i = i->nextSibling()) | 3314 | i = i->nextSibling()) |
3247 | { | 3315 | { |
3248 | if (c) delete c; // delete the previous category | 3316 | if (c) delete c; // delete the previous category |
3249 | 3317 | ||
3250 | c = i; | 3318 | c = i; |
3251 | // step through all subitems | 3319 | // step through all subitems |
3252 | QListViewItem *si; | 3320 | QListViewItem *si; |
3253 | for (si = i->firstChild(); | 3321 | for (si = i->firstChild(); |
3254 | si != NULL; ) | 3322 | si != NULL; ) |
3255 | { | 3323 | { |
3256 | QListViewItem *_si = si; | 3324 | QListViewItem *_si = si; |
3257 | si = si->nextSibling(); | 3325 | si = si->nextSibling(); |
3258 | i->takeItem(_si); // remove from view list | 3326 | i->takeItem(_si); // remove from view list |
3259 | if (_si) delete _si; | 3327 | if (_si) delete _si; |
3260 | } | 3328 | } |
3261 | } | 3329 | } |
3262 | if (c) delete c; // delete the previous category | 3330 | if (c) delete c; // delete the previous category |
3263 | categories.clear(); | 3331 | categories.clear(); |
3264 | m_password = ""; | 3332 | m_password = ""; |
3265 | selectedItem = NULL; | 3333 | selectedItem = NULL; |
3266 | filename = newFile; | 3334 | filename = newFile; |
3267 | 3335 | ||
3268 | // save the current filename to the config file | 3336 | // save the current filename to the config file |
3269 | conf->writeEntry(APP_KEY+"document", filename); | 3337 | conf->writeEntry(APP_KEY+"document", filename); |
3270 | saveConf(); | 3338 | saveConf(); |
3271 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); | 3339 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); |
3272 | #ifdef WIN32 | 3340 | #ifdef WIN32 |
3273 | this->setCaption("Qt ZSafe: " + ti); | 3341 | this->setCaption("Qt ZSafe: " + ti); |
3274 | #else | 3342 | #else |
3275 | this->setCaption("ZSafe: " + ti); | 3343 | this->setCaption("ZSafe: " + ti); |
3276 | #endif | 3344 | #endif |
3277 | 3345 | ||
3278 | openDocument(filename); | 3346 | openDocument(filename); |
3279 | } | 3347 | } |
3280 | } | 3348 | } |
3281 | 3349 | ||
3282 | void ZSafe::saveDocumentAs() | 3350 | void ZSafe::saveDocumentAs() |
3283 | { | 3351 | { |
3284 | 3352 | ||
3285 | #ifndef DESKTOP | 3353 | #ifndef DESKTOP |
3354 | #ifndef NO_OPIE | ||
3355 | QMap<QString, QStringList> mimeTypes; | ||
3356 | mimeTypes.insert(tr("All"), QStringList() ); | ||
3357 | mimeTypes.insert(tr("ZSafe"), "zsafe/*" ); | ||
3358 | QString newFile = OFileDialog::getSaveFileName( OFileSelector::EXTENDED_ALL, | ||
3359 | QDir::homeDirPath() + "/Documents/application/zsafe", | ||
3360 | QString::null, | ||
3361 | mimeTypes, | ||
3362 | this, | ||
3363 | tr ("Save ZSafe document as..")); | ||
3364 | #else | ||
3286 | QString newFile = ScQtFileEdit::getSaveAsFileName(this, | 3365 | QString newFile = ScQtFileEdit::getSaveAsFileName(this, |
3287 | tr ("Save ZSafe document as.."), | 3366 | tr ("Save ZSafe document as.."), |
3288 | QDir::homeDirPath() + "/Documents/application/zsafe", | 3367 | QDir::homeDirPath() + "/Documents/application/zsafe", |
3289 | "*.zsf"); | 3368 | "*.zsf"); |
3369 | #endif | ||
3290 | #else | 3370 | #else |
3291 | // open the file dialog | 3371 | // open the file dialog |
3292 | QString newFile = QFileDialog::getSaveFileName( | 3372 | QString newFile = QFileDialog::getSaveFileName( |
3293 | QDir::homeDirPath() + "/Documents/application/zsafe", | 3373 | QDir::homeDirPath() + "/Documents/application/zsafe", |
3294 | "ZSafe (*.zsf)", | 3374 | "ZSafe (*.zsf)", |
3295 | this, | 3375 | this, |
3296 | "ZSafe File Dialog" | 3376 | "ZSafe File Dialog" |
3297 | "Choose a ZSafe file" ); | 3377 | "Choose a ZSafe file" ); |
3298 | #endif | 3378 | #endif |
3299 | 3379 | ||
3300 | // open the new document | 3380 | // open the new document |
3301 | if (newFile && newFile.length() > 0 ) | 3381 | if (newFile && newFile.length() > 0 ) |
3302 | { | 3382 | { |
3303 | // save the previous opened document | 3383 | // save the previous opened document |
3304 | if (!filename.isEmpty()) | 3384 | if (!filename.isEmpty()) |
3305 | saveDocument(filename, FALSE); | 3385 | saveDocument(filename, FALSE); |
3306 | 3386 | ||
3387 | selectedItem = NULL; | ||
3307 | filename = newFile; | 3388 | filename = newFile; |
3308 | 3389 | ||
3309 | // save the current filename to the config file | 3390 | // save the current filename to the config file |
3310 | conf->writeEntry(APP_KEY+"document", filename); | 3391 | conf->writeEntry(APP_KEY+"document", filename); |
3311 | saveConf(); | 3392 | saveConf(); |
3312 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); | 3393 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); |
3313 | #ifdef WIN32 | 3394 | #ifdef WIN32 |
3314 | this->setCaption("Qt ZSafe: " + ti); | 3395 | this->setCaption("Qt ZSafe: " + ti); |
3315 | #else | 3396 | #else |
3316 | this->setCaption("ZSafe: " + ti); | 3397 | this->setCaption("ZSafe: " + ti); |
3317 | #endif | 3398 | #endif |
3318 | 3399 | ||
3319 | QMessageBox::information( this, tr("ZSafe"), | 3400 | QMessageBox::information( this, tr("ZSafe"), |
3320 | tr("Now you have to enter\na password twice for your\nnewly created document."), tr("&OK"), 0); | 3401 | tr("Now you have to enter\na password twice for your\nnewly created document."), tr("&OK"), 0); |
3321 | 3402 | ||
3322 | saveDocumentWithPwd(); | 3403 | saveDocumentWithPwd(); |
3323 | } | 3404 | } |
3324 | } | 3405 | } |
3325 | 3406 | ||
3326 | void ZSafe::saveDocumentWithoutPwd() | 3407 | void ZSafe::saveDocumentWithoutPwd() |
3327 | { | 3408 | { |
3328 | saveDocument(filename, FALSE); | 3409 | saveDocument(filename, FALSE); |
3329 | } | 3410 | } |
3330 | 3411 | ||
3331 | void ZSafe::saveDocumentWithPwd() | 3412 | void ZSafe::saveDocumentWithPwd() |
3332 | { | 3413 | { |
3333 | saveDocument(filename, TRUE); | 3414 | saveDocument(filename, TRUE); |
3334 | } | 3415 | } |
3335 | 3416 | ||
3336 | void ZSafe::about() | 3417 | void ZSafe::about() |
3337 | { | 3418 | { |
3338 | QString info; | 3419 | QString info; |
3339 | info = "<html><body><div align=""center"">"; | 3420 | info = "<html><body><div align=""center"">"; |
3340 | info += "<b>"; | 3421 | info += "<b>"; |
3341 | info += tr("Zaurus Password Manager<br>"); | 3422 | info += tr("Zaurus Password Manager<br>"); |
3342 | info += tr("ZSafe version 2.1.2<br>"); | 3423 | info += tr("ZSafe version 2.1.2<br>"); |
3343 | info += "</b>"; | 3424 | info += "</b>"; |
3344 | info += tr("by Carsten Schneider<br>"); | 3425 | info += tr("by Carsten Schneider<br>"); |
3345 | info += "zcarsten@gmx.net<br>"; | 3426 | info += "zcarsten@gmx.net<br>"; |
3346 | info += "http://z-soft.z-portal.info/zsafe"; | 3427 | info += "http://z-soft.z-portal.info/zsafe"; |
3347 | info += "<br>"; | 3428 | info += "<br>"; |
3348 | info += tr("Translations by Robert Ernst<br>"); | 3429 | info += tr("Translations by Robert Ernst<br>"); |
3349 | info += "robert.ernst@linux-solutions.at<br>"; | 3430 | info += "robert.ernst@linux-solutions.at<br>"; |
3350 | info += "<br></div>"; | 3431 | info += "<br></div>"; |
3351 | info += "</body></html>"; | 3432 | info += "</body></html>"; |
3352 | 3433 | ||
3353 | // QMessageBox::information( this, tr("ZSafe"), info, tr("&OK"), 0); | 3434 | // QMessageBox::information( this, tr("ZSafe"), info, tr("&OK"), 0); |
3354 | 3435 | ||
3355 | QMessageBox mb( this, tr("ZSafe")); | 3436 | QMessageBox mb( this, tr("ZSafe")); |
3356 | mb.setText (info); | 3437 | mb.setText (info); |
3357 | mb.setButtonText (QMessageBox::Ok, tr ("&OK")); | 3438 | mb.setButtonText (QMessageBox::Ok, tr ("&OK")); |
3358 | QPixmap zsafe_img((const char**) zsafe_xpm); | 3439 | QPixmap zsafe_img((const char**) zsafe_xpm); |
3359 | mb.setIconPixmap (zsafe_img); | 3440 | mb.setIconPixmap (zsafe_img); |
3360 | mb.exec(); | 3441 | mb.exec(); |
3361 | } | 3442 | } |
3362 | 3443 | ||
3363 | void ZSafe::setExpandFlag() | 3444 | void ZSafe::setExpandFlag() |
3364 | { | 3445 | { |
3365 | expandTree = !expandTree; | 3446 | expandTree = !expandTree; |
3366 | file->setItemChecked('o', expandTree); | 3447 | file->setItemChecked('o', expandTree); |
3367 | #ifndef DESKTOP | 3448 | #ifndef DESKTOP |
3368 | conf->setGroup ("zsafePrefs"); | 3449 | conf->setGroup ("zsafePrefs"); |
3369 | #endif | 3450 | #endif |
3370 | // #ifndef WIN32 | 3451 | // #ifndef WIN32 |
3371 | conf->writeEntry (APP_KEY+"expandTree", expandTree); | 3452 | conf->writeEntry (APP_KEY+"expandTree", expandTree); |
3372 | // #endif | 3453 | // #endif |
3373 | saveConf(); | 3454 | saveConf(); |
3374 | 3455 | ||
3375 | } | 3456 | } |
3376 | 3457 | ||
3377 | void ZSafe::paintEvent( QPaintEvent * ) | 3458 | void ZSafe::paintEvent( QPaintEvent * ) |
3378 | { | 3459 | { |
3379 | if (raiseFlag) | 3460 | if (raiseFlag) |
3380 | { | 3461 | { |
3381 | raiseFlag = false; | 3462 | raiseFlag = false; |
3382 | raiseTimer.start (1, true); | 3463 | raiseTimer.start (1, true); |
3383 | if (infoForm->isVisible()) | 3464 | if (infoForm->isVisible()) |
3384 | infoForm->raise(); | 3465 | infoForm->raise(); |
3385 | } | 3466 | } |
3386 | } | 3467 | } |
3387 | 3468 | ||
3388 | void ZSafe::resizeEvent ( QResizeEvent * ) | 3469 | void ZSafe::resizeEvent ( QResizeEvent * ) |
3389 | { | 3470 | { |
3390 | // qWarning ("resizeEvent"); | 3471 | // qWarning ("resizeEvent"); |
3391 | #ifndef DESKTOP | 3472 | #ifndef DESKTOP |
3392 | DeskW = appl->desktop()->width(); | 3473 | DeskW = appl->desktop()->width(); |
3393 | DeskH = appl->desktop()->height(); | 3474 | DeskH = appl->desktop()->height(); |
3394 | #else | 3475 | #else |
3395 | DeskW = this->width(); | 3476 | DeskW = this->width(); |
3396 | DeskH = this->height(); | 3477 | DeskH = this->height(); |
3397 | #endif | 3478 | #endif |
3398 | qWarning( QString("Width : %1").arg(DeskW), 2000 ); | 3479 | qWarning( QString("Width : %1").arg(DeskW), 2000 ); |
3399 | qWarning( QString("Height: %1").arg(DeskH), 2000 ); | 3480 | qWarning( QString("Height: %1").arg(DeskH), 2000 ); |
3400 | 3481 | ||
3401 | New->setGeometry ( QRect( DeskW-84, 2, 20, 20 ) ); | 3482 | New->setGeometry ( QRect( DeskW-84, 2, 20, 20 ) ); |
3402 | Edit->setGeometry ( QRect( DeskW-64, 2, 20, 20 ) ); | 3483 | Edit->setGeometry ( QRect( DeskW-64, 2, 20, 20 ) ); |
3403 | Delete->setGeometry( QRect( DeskW-44, 2, 20, 20 ) ); | 3484 | Delete->setGeometry( QRect( DeskW-44, 2, 20, 20 ) ); |
3404 | Find->setGeometry ( QRect( DeskW-24, 2, 20, 20 ) ); | 3485 | Find->setGeometry ( QRect( DeskW-24, 2, 20, 20 ) ); |
3405 | } | 3486 | } |
3406 | 3487 | ||
3407 | void ZSafe::slotRaiseTimer() | 3488 | void ZSafe::slotRaiseTimer() |
3408 | { | 3489 | { |
3409 | if (infoForm->isVisible()) | 3490 | if (infoForm->isVisible()) |
3410 | infoForm->raise(); | 3491 | infoForm->raise(); |
3411 | raiseFlag = true; | 3492 | raiseFlag = true; |
3412 | } | 3493 | } |
3413 | 3494 | ||
3414 | QPixmap * ZSafe::getPredefinedIcon(QString category) | 3495 | QPixmap * ZSafe::getPredefinedIcon(QString category) |
3415 | { | 3496 | { |
3416 | QPixmap *pm; | 3497 | QPixmap *pm; |
3417 | if (category == "Bank cards") | 3498 | if (category == "Bank cards") |
3418 | pm = new QPixmap((const char**)bank_cards_data); | 3499 | pm = new QPixmap((const char**)bank_cards_data); |
3419 | else if (category == "Passwords") | 3500 | else if (category == "Passwords") |
3420 | pm = new QPixmap((const char**)passwords_data); | 3501 | pm = new QPixmap((const char**)passwords_data); |
3421 | else if (category == "Software") | 3502 | else if (category == "Software") |
3422 | pm = new QPixmap((const char**)software_data); | 3503 | pm = new QPixmap((const char**)software_data); |
3423 | else if (category == "General") | 3504 | else if (category == "General") |
3424 | pm = new QPixmap((const char**)general_data); | 3505 | pm = new QPixmap((const char**)general_data); |
3425 | else | 3506 | else |
3426 | pm = new QPixmap((const char**)general_data); | 3507 | pm = new QPixmap((const char**)general_data); |
3427 | return pm; | 3508 | return pm; |
3428 | } | 3509 | } |
3429 | 3510 | ||
3430 | void ZSafe::setDocument(const QString& fileref) | 3511 | void ZSafe::setDocument(const QString& fileref) |
3431 | { | 3512 | { |
3432 | #ifndef DESKTOP | 3513 | #ifndef DESKTOP |
3433 | // stop the timer to prevent loading of the default document | 3514 | // stop the timer to prevent loading of the default document |
3434 | docuTimer.stop(); | 3515 | docuTimer.stop(); |
3435 | 3516 | ||
3436 | DocLnk link(fileref); | 3517 | DocLnk link(fileref); |
3437 | if ( link.isValid() ) | 3518 | if ( link.isValid() ) |
3438 | { | 3519 | { |
3439 | // if (filename != link.file()) | 3520 | // if (filename != link.file()) |
3440 | // saveDocument(filename, FALSE); | 3521 | // saveDocument(filename, FALSE); |
3441 | filename = link.file(); | 3522 | filename = link.file(); |
3442 | } | 3523 | } |
3443 | else | 3524 | else |
3444 | { | 3525 | { |
3445 | // if (filename != fileref) | 3526 | // if (filename != fileref) |
3446 | // saveDocument(filename, FALSE); | 3527 | // saveDocument(filename, FALSE); |
3447 | filename = fileref; | 3528 | filename = fileref; |
3448 | } | 3529 | } |
3449 | // save the current filename to the config file | 3530 | // save the current filename to the config file |
3450 | conf->writeEntry(APP_KEY+"document", filename); | 3531 | conf->writeEntry(APP_KEY+"document", filename); |
3451 | saveConf(); | 3532 | saveConf(); |
3452 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); | 3533 | QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); |
3453 | #ifdef WIN32 | 3534 | #ifdef WIN32 |
3454 | this->setCaption("Qt ZSafe: " + ti); | 3535 | this->setCaption("Qt ZSafe: " + ti); |
3455 | #else | 3536 | #else |
3456 | this->setCaption("ZSafe: " + ti); | 3537 | this->setCaption("ZSafe: " + ti); |
3457 | #endif | 3538 | #endif |
3458 | 3539 | ||
3459 | // clear the password list | 3540 | // clear the password list |
3460 | QListViewItem *i; | 3541 | QListViewItem *i; |
3461 | QListViewItem *c = NULL; | 3542 | QListViewItem *c = NULL; |
3462 | // step through all categories | 3543 | // step through all categories |
3463 | for (i = ListView->firstChild(); | 3544 | for (i = ListView->firstChild(); |
3464 | i != NULL; | 3545 | i != NULL; |
3465 | i = i->nextSibling()) | 3546 | i = i->nextSibling()) |
3466 | { | 3547 | { |
3467 | if (c) delete c; // delete the previous category | 3548 | if (c) delete c; // delete the previous category |
3468 | 3549 | ||
3469 | c = i; | 3550 | c = i; |
3470 | // step through all subitems | 3551 | // step through all subitems |
3471 | QListViewItem *si; | 3552 | QListViewItem *si; |
3472 | for (si = i->firstChild(); | 3553 | for (si = i->firstChild(); |
3473 | si != NULL; ) | 3554 | si != NULL; ) |
3474 | { | 3555 | { |
3475 | QListViewItem *_si = si; | 3556 | QListViewItem *_si = si; |
3476 | si = si->nextSibling(); | 3557 | si = si->nextSibling(); |
3477 | i->takeItem(_si); // remove from view list | 3558 | i->takeItem(_si); // remove from view list |
3478 | if (_si) delete _si; | 3559 | if (_si) delete _si; |
3479 | } | 3560 | } |
3480 | } | 3561 | } |
3481 | if (c) delete c; // delete the previous category | 3562 | if (c) delete c; // delete the previous category |
3482 | categories.clear(); | 3563 | categories.clear(); |
3483 | 3564 | ||
3484 | m_password = ""; | 3565 | m_password = ""; |
3485 | selectedItem = NULL; | 3566 | selectedItem = NULL; |
3486 | 3567 | ||
3487 | openDocument(filename); | 3568 | openDocument(filename); |
3488 | #endif | 3569 | #endif |
3489 | } | 3570 | } |
3490 | 3571 | ||
3491 | 3572 | ||
3492 | 3573 | ||
diff --git a/noncore/apps/zsafe/zsafe.pro b/noncore/apps/zsafe/zsafe.pro index ae4c793..5cb74dd 100644 --- a/noncore/apps/zsafe/zsafe.pro +++ b/noncore/apps/zsafe/zsafe.pro | |||
@@ -1,22 +1,22 @@ | |||
1 | TEMPLATE = app | 1 | TEMPLATE = app |
2 | CONFIG = qt warn_on release | 2 | CONFIG = qt warn_on release |
3 | DESTDIR = $(OPIEDIR)/bin | 3 | DESTDIR = $(OPIEDIR)/bin |
4 | HEADERS = zsafe.h krc2.h category.h categorylist.h zlistview.h \ | 4 | HEADERS = zsafe.h krc2.h category.h categorylist.h zlistview.h \ |
5 | scqtfiledlg.h | 5 | scqtfiledlg.h |
6 | SOURCES = main.cpp zsafe.cpp krc2.cpp category.cpp \ | 6 | SOURCES = main.cpp zsafe.cpp krc2.cpp category.cpp \ |
7 | categorylist.cpp zlistview.cpp shadedlistitem.cpp\ | 7 | categorylist.cpp zlistview.cpp shadedlistitem.cpp\ |
8 | scqtfileedit.cpp scqtfileedit.moc.cpp \ | 8 | scqtfileedit.cpp scqtfileedit.moc.cpp \ |
9 | scqtfiledlg.cpp | 9 | scqtfiledlg.cpp |
10 | INTERFACES = newdialog.ui searchdialog.ui passworddialog.ui categorydialog.ui | 10 | INTERFACES = newdialog.ui searchdialog.ui passworddialog.ui categorydialog.ui |
11 | INTERFACES += infoform.ui wait.ui | 11 | INTERFACES += infoform.ui wait.ui |
12 | 12 | ||
13 | INCLUDEPATH+= $(OPIEDIR)/include | 13 | INCLUDEPATH+= $(OPIEDIR)/include |
14 | INCLUDEPATH+= . | 14 | INCLUDEPATH+= . |
15 | INCLUDEPATH+= $(OPIEDIR)/noncore/apps/zsafe | 15 | INCLUDEPATH+= $(OPIEDIR)/noncore/apps/zsafe |
16 | DEPENDPATH+= $(OPIEDIR)/include | 16 | DEPENDPATH+= $(OPIEDIR)/include |
17 | LIBS += -Wl,-rpath,$(OPIEDIR)/lib -L$(OPIEDIR)/lib -lqpe | 17 | LIBS += -Wl,-rpath,$(OPIEDIR)/lib -L$(OPIEDIR)/lib -lqpe -lopie |
18 | TARGET = zsafe | 18 | TARGET = zsafe |
19 | TRANSLATIONS = $(OPIEDIR)/noncore/apps/zsafe/i18n/de/zsafe.ts | 19 | TRANSLATIONS = $(OPIEDIR)/noncore/apps/zsafe/i18n/de/zsafe.ts |
20 | 20 | ||
21 | #include ( $(OPIEDIR)/include.pro ) | 21 | #include ( $(OPIEDIR)/include.pro ) |
22 | 22 | ||