summaryrefslogtreecommitdiffabout
authorzautrix <zautrix>2005-03-01 13:30:51 (UTC)
committer zautrix <zautrix>2005-03-01 13:30:51 (UTC)
commit81e2fbd0c031a3db209de68c190ddf4c0350d14a (patch) (unidiff)
tree14c071ce0a6c81c28480f3e9480d1c24a96c9b78
parent43c5ba9a16a0ea0ec80c920d9161d6c49bf0f674 (diff)
downloadkdepimpi-81e2fbd0c031a3db209de68c190ddf4c0350d14a.zip
kdepimpi-81e2fbd0c031a3db209de68c190ddf4c0350d14a.tar.gz
kdepimpi-81e2fbd0c031a3db209de68c190ddf4c0350d14a.tar.bz2
pwm gui enhancements
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--bin/kdepim/pwmanager/germantranslation.txt7
-rw-r--r--pwmanager/pwmanager/commentbox.cpp4
-rw-r--r--pwmanager/pwmanager/pwm.cpp41
3 files changed, 33 insertions, 19 deletions
diff --git a/bin/kdepim/pwmanager/germantranslation.txt b/bin/kdepim/pwmanager/germantranslation.txt
index 0ebc644..d481c42 100644
--- a/bin/kdepim/pwmanager/germantranslation.txt
+++ b/bin/kdepim/pwmanager/germantranslation.txt
@@ -1,353 +1,354 @@
1{ " Local Time","Ortszeit" }, 1{ " Local Time","Ortszeit" },
2{ "Default","Voreinstellungen" }, 2{ "Default","Default" },
3{ "Configure...","Konfigurieren..." }, 3{ "Configure...","Konfigurieren..." },
4{ "Remove sync info","Entferne Sync Info" }, 4{ "Remove sync info","Entferne Sync Info" },
5{ "For all profiles","Für alle Profile" }, 5{ "For all profiles","Für alle Profile" },
6{ "Enable Pi-Sync","Aktiviere Pi-Sync" }, 6{ "Enable Pi-Sync","Aktiviere Pi-Sync" },
7{ "Multiple sync","Multi Sync" }, 7{ "Multiple sync","Multi Sync" },
8{ "&Save","&Speichern" }, 8{ "&Save","&Speichern" },
9{ "&Print...","Drucken..." }, 9{ "&Print...","Drucken..." },
10{ "&File","Datei" }, 10{ "&File","Datei" },
11{ "&Edit","Bearbeite" }, 11{ "&Edit","Bearbeite" },
12{ "&View","Ansicht" }, 12{ "&View","Ansicht" },
13{ "&Help","Hilfe" }, 13{ "&Help","Hilfe" },
14{ "Description","Beschreibungen" }, 14{ "Description","Beschreibungen" },
15{ "URL","URL" }, 15{ "URL","URL" },
16{ "Name:","Name:" }, 16{ "Name:","Name:" },
17{ "Documents","Dokumente" }, 17{ "Documents","Dokumente" },
18{ "Files","Dateien" }, 18{ "Files","Dateien" },
19{ "All Files","Alle Dateien" }, 19{ "All Files","Alle Dateien" },
20{ "Name","Name" }, 20{ "Name","Name" },
21{ "Size","Größe" }, 21{ "Size","Größe" },
22{ "Date","Datum" }, 22{ "Date","Datum" },
23{ "Mime Type","Mime Typ" }, 23{ "Mime Type","Mime Typ" },
24{ "Ok","Ok" }, 24{ "Ok","Ok" },
25{ "Cancel","Abbrechen" }, 25{ "Cancel","Abbrechen" },
26{ "1","1" }, 26{ "1","1" },
27{ "Synchronization Preferences","Einstellungen der Synchronisationsprofile" }, 27{ "Synchronization Preferences","Einstellungen der Synchronisationsprofile" },
28{ "Local device name:","Name dieses Gerätes:" }, 28{ "Local device name:","Name dieses Gerätes:" },
29{ "New profile","Neues Profil" }, 29{ "New profile","Neues Profil" },
30{ "Clone profile","Klone Profil" }, 30{ "Clone profile","Klone Profil" },
31{ "Delete profile","Lösche Profil" }, 31{ "Delete profile","Lösche Profil" },
32{ "Profile:","Profil:" }, 32{ "Profile:","Profil:" },
33{ "Multiple Sync options","Multi Sync Optionen" }, 33{ "Multiple Sync options","Multi Sync Optionen" },
34{ "Include in multiple ","Beziehe in mehrfach " }, 34{ "Include in multiple ","Beziehe in mehrfach " },
35{ "calendar ","Kalender " }, 35{ "calendar ","Kalender " },
36{ "addressbook ","Adressbuch " }, 36{ "addressbook ","Adressbuch " },
37{ "pwmanager","PWmanager" }, 37{ "pwmanager","PWmanager" },
38{ " sync"," Sync ein" }, 38{ " sync"," Sync ein" },
39{ "Sync algo options","Sync Ablauf Optionen" }, 39{ "Sync algo options","Sync Ablauf Optionen" },
40{ "Ask for preferences before sync","Frage nach Synchronisationseinstellungen vor dem Syncen" }, 40{ "Ask for preferences before sync","Frage nach Synchronisationseinstellungen vor dem Syncen" },
41{ "Sync preferences","Synchronisations Einstellungen" }, 41{ "Sync preferences","Synchronisations Einstellungen" },
42{ "Take local entry on conflict","Nimm lokalen Eintrag beim Konflikt" }, 42{ "Take local entry on conflict","Nimm lokalen Eintrag beim Konflikt" },
43{ "Take remote entry on conflict","Nimm fernen Eintrag beim Konflikt" }, 43{ "Take remote entry on conflict","Nimm fernen Eintrag beim Konflikt" },
44{ "Take newest entry on conflict","Nimm neuesten Eintrag beim Konflikt" }, 44{ "Take newest entry on conflict","Nimm neuesten Eintrag beim Konflikt" },
45{ "Ask for every entry on conflict","Frage bei Konflikten nach" }, 45{ "Ask for every entry on conflict","Frage bei Konflikten nach" },
46{ "Force: Take local entry always","Erzwinge: Nimm immer lokalen Eintrag" }, 46{ "Force: Take local entry always","Erzwinge: Nimm immer lokalen Eintrag" },
47{ "Force: Take remote entry always","Erzwinge: Nimm immer fernen Eintrag" }, 47{ "Force: Take remote entry always","Erzwinge: Nimm immer fernen Eintrag" },
48{ "Show summary after sync","Zeige Zusammenfassung nach dem Synchronisieren" }, 48{ "Show summary after sync","Zeige Zusammenfassung nach dem Synchronisieren" },
49{ "Apply filter when adding data to local:","Filter für das Hinzufügen von Daten zu Lokal:" }, 49{ "Apply filter when adding data to local:","Filter für das Hinzufügen von Daten zu Lokal:" },
50{ "Incoming calendar filter:","Eingehender Kalender Filter:" }, 50{ "Incoming calendar filter:","Eingehender Kalender Filter:" },
51{ "Incoming addressbook filter:","Eingehender Adressbuch Filter:" }, 51{ "Incoming addressbook filter:","Eingehender Adressbuch Filter:" },
52{ "Write back synced data","Schreibe gesyncte Daten zurück" }, 52{ "Write back synced data","Schreibe gesyncte Daten zurück" },
53{ "Write back options","Optionen zum Zurückschreiben" }, 53{ "Write back options","Optionen zum Zurückschreiben" },
54{ "Write back (on remote) existing entries only","Schreibe nur existierende (auf Entfernt) Einträge zurück" }, 54{ "Write back (on remote) existing entries only","Schreibe nur existierende (auf Entfernt) Einträge zurück" },
55{ "Apply filter when adding data to remote:","Filter für das Hinzufügen von Daten zu Entfernt:" }, 55{ "Apply filter when adding data to remote:","Filter für das Hinzufügen von Daten zu Entfernt:" },
56{ "Outgoing calendar filter:","Ausgehender Kalender Filter:" }, 56{ "Outgoing calendar filter:","Ausgehender Kalender Filter:" },
57{ "Outgoing addressbook filter:","Ausgehender Adressbuch Filter:" }, 57{ "Outgoing addressbook filter:","Ausgehender Adressbuch Filter:" },
58{ "Write back (calendar) entries for time period only","Schreibe nur Kalender Einträge für Zeitspanne zurück" }, 58{ "Write back (calendar) entries for time period only","Schreibe nur Kalender Einträge für Zeitspanne zurück" },
59{ "Time period","Zeitspanne" }, 59{ "Time period","Zeitspanne" },
60{ "From ","Von " }, 60{ "From ","Von " },
61{ " weeks in the past to "," Wochen in der Vergangenheit bis zu " }, 61{ " weeks in the past to "," Wochen in der Vergangenheit bis zu " },
62{ " weeks in the future "," Wochen in der Zukunft " }, 62{ " weeks in the future "," Wochen in der Zukunft " },
63{ "Profile kind","Profil Art" }, 63{ "Profile kind","Profil Art" },
64{ "Local file","Lokale Datei" }, 64{ "Local file","Lokale Datei" },
65{ "Pi-Sync ( direct Kx/Pi to Kx/Pi sync )","Pi-Sync ( direktes Kx/Pi zu Kx/Pi sync )" }, 65{ "Pi-Sync ( direct Kx/Pi to Kx/Pi sync )","Pi-Sync ( direktes Kx/Pi zu Kx/Pi sync )" },
66{ "Remote file (w down/upload command)","Entfernte Datei (via down/upload Kommando)" }, 66{ "Remote file (w down/upload command)","Entfernte Datei (via down/upload Kommando)" },
67{ "Mobile device (cell phone)","Mobiles Gerät (Handy)" }, 67{ "Mobile device (cell phone)","Mobiles Gerät (Handy)" },
68{ "Profile kind specific settings","Profil Art abhängige Einstellungen" }, 68{ "Profile kind specific settings","Profil Art abhängige Einstellungen" },
69{ "I/O device: ","I/O device: " }, 69{ "I/O device: ","I/O device: " },
70{ "Help...","Hilfe..." }, 70{ "Help...","Hilfe..." },
71{ "Connection: ","Connection: " }, 71{ "Connection: ","Connection: " },
72{ "Model(opt.): ","Model(opt.): " }, 72{ "Model(opt.): ","Model(opt.): " },
73{ "Local file Cal:","Lokale Datei Kal:" }, 73{ "Local file Cal:","Lokale Datei Kal:" },
74{ "Local file ABook:","Lokale Datei ABuch:" }, 74{ "Local file ABook:","Lokale Datei ABuch:" },
75{ "Local file PWMgr:","Lokale Datei PWMgr:" }, 75{ "Local file PWMgr:","Lokale Datei PWMgr:" },
76{ "Choose...","Wähle..." }, 76{ "Choose...","Wähle..." },
77{ "Addressbook file (*.vcf) is used by KA/Pi","Adressbuch Datei (*.vcf) wird von KA/Pi genutzt" }, 77{ "Addressbook file (*.vcf) is used by KA/Pi","Adressbuch Datei (*.vcf) wird von KA/Pi genutzt" },
78{ "Calendar:","Kalender:" }, 78{ "Calendar:","Kalender:" },
79{ "AddressBook:","AdressBuch:" }, 79{ "AddressBook:","AdressBuch:" },
80{ "PWManager:","PWManager:" }, 80{ "PWManager:","PWManager:" },
81{ "Pre sync (download) command:","Bevor Sync (download) Kommando:" }, 81{ "Pre sync (download) command:","Bevor Sync (download) Kommando:" },
82{ "Local temp file:","Lokale temp Datei:" }, 82{ "Local temp file:","Lokale temp Datei:" },
83{ "Post sync (upload) command:","Nach Sync (upload) Kommando:" }, 83{ "Post sync (upload) command:","Nach Sync (upload) Kommando:" },
84{ "Addressbook file is used by KA/Pi","Adressbuch Datei wird von KA/Pi genutzt" }, 84{ "Addressbook file is used by KA/Pi","Adressbuch Datei wird von KA/Pi genutzt" },
85{ "Fill in default values for:","Setze Beispiel Werte ein für:" }, 85{ "Fill in default values for:","Setze Beispiel Werte ein für:" },
86{ "ssh/scp","ssh/scp" }, 86{ "ssh/scp","ssh/scp" },
87{ "ftp","ftp" }, 87{ "ftp","ftp" },
88{ "Hint: Use $PWD$ for placeholder of password!","Hinweis: Benutze $PWD$ als Platzhalter für ein Passwort!" }, 88{ "Hint: Use $PWD$ for placeholder of password!","Hinweis: Benutze $PWD$ als Platzhalter für ein Passwort!" },
89{ "Password for remote access: (could be the same for each)","Passwort für entfernten Zugriff: (kann dasselbe sein für alle)" }, 89{ "Password for remote access: (could be the same for each)","Passwort für entfernten Zugriff: (kann dasselbe sein für alle)" },
90{ "Remote IP address: (could be the same for each)","Entfernte IP Adresse: (kann dasselbe sein für alle)" }, 90{ "Remote IP address: (could be the same for each)","Entfernte IP Adresse: (kann dasselbe sein für alle)" },
91{ "Remote port number: (should be different for each)","Entfernte Port Nummer: (Sollte für alle unterschiedlich sein)" }, 91{ "Remote port number: (should be different for each)","Entfernte Port Nummer: (Sollte für alle unterschiedlich sein)" },
92{ "command for downloading remote file to local device","Kommando zum Download der entfernten Datei zum lokalen Gerät" }, 92{ "command for downloading remote file to local device","Kommando zum Download der entfernten Datei zum lokalen Gerät" },
93{ "command for uploading local temp file to remote device","Kommando zum Upload der lokalen temp. Datei zum entfernten Gerät" }, 93{ "command for uploading local temp file to remote device","Kommando zum Upload der lokalen temp. Datei zum entfernten Gerät" },
94{ "No Filter","Kein Filter" }, 94{ "No Filter","Kein Filter" },
95{ "KO/Pi config error","KO/Pi Konfig. Fehler" }, 95{ "KO/Pi config error","KO/Pi Konfig. Fehler" },
96{ "Local device name undefined!\nPlease define device name!","Name dieses Gerätes undefiniert!\nBitte Namen angeben!" }, 96{ "Local device name undefined!\nPlease define device name!","Name dieses Gerätes undefiniert!\nBitte Namen angeben!" },
97{ "Multiple profiles with same name!\nPlease use unique profile names!","Mehrere Profile mit demselben Namen!\nBitte verschiedene Namen benutzen!" }, 97{ "Multiple profiles with same name!\nPlease use unique profile names!","Mehrere Profile mit demselben Namen!\nBitte verschiedene Namen benutzen!" },
98{ "Configure","Konfiguriere" }, 98{ "Configure","Konfiguriere" },
99{ "Apply","Anwenden" }, 99{ "Apply","Anwenden" },
100{ "None","Kein" }, 100{ "None","Kein" },
101{ "Global","Allgemein" }, 101{ "Global","Allgemein" },
102{ "Email","E-Mail" }, 102{ "Email","E-Mail" },
103{ "Phone","Telefon" }, 103{ "Phone","Telefon" },
104{ "SMS","SMS" }, 104{ "SMS","SMS" },
105{ "Fax","Fax" }, 105{ "Fax","Fax" },
106{ "Pager","Pager" }, 106{ "Pager","Pager" },
107{ "SIP","SIP" }, 107{ "SIP","SIP" },
108{ "Language:(needs restart)","Sprache:(Neustart)" }, 108{ "Language:(needs restart)","Sprache:(Neustart)" },
109{ "English","English" }, 109{ "English","English" },
110{ "German","Deutsch" }, 110{ "German","Deutsch" },
111{ "French","Französisch" }, 111{ "French","Französisch" },
112{ "Italian","Italienisch" }, 112{ "Italian","Italienisch" },
113{ "User defined (usertranslation.txt)","Benutzerdef. (usertranslation.txt)" }, 113{ "User defined (usertranslation.txt)","Benutzerdef. (usertranslation.txt)" },
114{ "Language","Sprache" }, 114{ "Language","Sprache" },
115{ "Time Format(nr):","Zeit Format(nr):" }, 115{ "Time Format(nr):","Zeit Format(nr):" },
116{ "24:00","24:00" }, 116{ "24:00","24:00" },
117{ "12:00am","12:00am" }, 117{ "12:00am","12:00am" },
118{ "Week starts on Sunday","Woche beginnt Sonntags" }, 118{ "Week starts on Sunday","Woche beginnt Sonntags" },
119{ "Time Format","Zeit Format" }, 119{ "Time Format","Zeit Format" },
120{ "Date Format:","Datums Format:" }, 120{ "Date Format:","Datums Format:" },
121{ "24.03.2004 (%d.%m.%Y|%A %d %B %Y)","24.03.2004 (%d.%m.%Y|%A %d %B %Y)" }, 121{ "24.03.2004 (%d.%m.%Y|%A %d %B %Y)","24.03.2004 (%d.%m.%Y|%A %d %B %Y)" },
122{ "03.24.2004 (%m.%d.%Y|%A %B %d %Y)","03.24.2004 (%m.%d.%Y|%A %B %d %Y)" }, 122{ "03.24.2004 (%m.%d.%Y|%A %B %d %Y)","03.24.2004 (%m.%d.%Y|%A %B %d %Y)" },
123{ "2004-03-24 (%Y-%m-%d|%A %Y %B %d)","2004-03-24 (%Y-%m-%d|%A %Y %B %d)" }, 123{ "2004-03-24 (%Y-%m-%d|%A %Y %B %d)","2004-03-24 (%Y-%m-%d|%A %Y %B %d)" },
124{ "User defined","Benutzerdefiniert" }, 124{ "User defined","Benutzerdefiniert" },
125{ "User long date:","Format langes Datum:" }, 125{ "User long date:","Format langes Datum:" },
126{ "User short date:","Format kurzes Datum:" }, 126{ "User short date:","Format kurzes Datum:" },
127{ "Monday 19 April 2004: %A %d %B %Y","Monday 19 April 2004: %A %d %B %Y" }, 127{ "Monday 19 April 2004: %A %d %B %Y","Monday 19 April 2004: %A %d %B %Y" },
128{ "Mon 19.04.04: %a %d.%m.%y","Mon 19.04.04: %a %d.%m.%y" }, 128{ "Mon 19.04.04: %a %d.%m.%y","Mon 19.04.04: %a %d.%m.%y" },
129{ "Mon, 19.Apr.04: %a, %d.%b.%y","Mon, 19.Apr.04: %a, %d.%b.%y" }, 129{ "Mon, 19.Apr.04: %a, %d.%b.%y","Mon, 19.Apr.04: %a, %d.%b.%y" },
130{ "Date Format","Datums Format" }, 130{ "Date Format","Datums Format" },
131{ "Timezone:","Zeitzone:" }, 131{ "Timezone:","Zeitzone:" },
132{ "Add 30 min to selected Timezone","Addiere 30 min zur Zeitzone" }, 132{ "Add 30 min to selected Timezone","Addiere 30 min zur Zeitzone" },
133{ "Timezone has daylight saving","Zeitzone hat Sommerzeit" }, 133{ "Timezone has daylight saving","Zeitzone hat Sommerzeit" },
134{ "Actual start and end is the\nsunday before this date.","Tatsächlicher Beginn/Ende ist der\nSonntag vor diesem Datum!" }, 134{ "Actual start and end is the\nsunday before this date.","Tatsächlicher Beginn/Ende ist der\nSonntag vor diesem Datum!" },
135{ "The year in the date is ignored.","Das Jahr vom Datum wird ignoriert." }, 135{ "The year in the date is ignored.","Das Jahr vom Datum wird ignoriert." },
136{ "Daylight start:","Sommerzeit Beginn:" }, 136{ "Daylight start:","Sommerzeit Beginn:" },
137{ "Mon","Mo" }, 137{ "Mon","Mo" },
138{ "Tue","Di" }, 138{ "Tue","Di" },
139{ "Wed","Mi" }, 139{ "Wed","Mi" },
140{ "Thu","Do" }, 140{ "Thu","Do" },
141{ "Fri","Fr" }, 141{ "Fri","Fr" },
142{ "Sat","Sa" }, 142{ "Sat","Sa" },
143{ "Sun","So" }, 143{ "Sun","So" },
144{ "January","Januar" }, 144{ "January","Januar" },
145{ "February","Februar" }, 145{ "February","Februar" },
146{ "March","März" }, 146{ "March","März" },
147{ "April","April" }, 147{ "April","April" },
148{ "May","Mai" }, 148{ "May","Mai" },
149{ "June","Juni" }, 149{ "June","Juni" },
150{ "July","July" }, 150{ "July","July" },
151{ "August","August" }, 151{ "August","August" },
152{ "September","September" }, 152{ "September","September" },
153{ "October","October" }, 153{ "October","October" },
154{ "November","November" }, 154{ "November","November" },
155{ "December","Dezember" }, 155{ "December","Dezember" },
156{ "tomorrow","Morgen" }, 156{ "tomorrow","Morgen" },
157{ "today","Heute" }, 157{ "today","Heute" },
158{ "yesterday","Gestern" }, 158{ "yesterday","Gestern" },
159{ "Monday","Montag" }, 159{ "Monday","Montag" },
160{ "Tuesday","Dienstag" }, 160{ "Tuesday","Dienstag" },
161{ "Wednesday","Mittwoch" }, 161{ "Wednesday","Mittwoch" },
162{ "Thursday","Donnerstag" }, 162{ "Thursday","Donnerstag" },
163{ "Friday","Freitag" }, 163{ "Friday","Freitag" },
164{ "Saturday","Samstag" }, 164{ "Saturday","Samstag" },
165{ "Sunday","Sonntag" }, 165{ "Sunday","Sonntag" },
166{ "Daylight end:","Sommerzeit Ende:" }, 166{ "Daylight end:","Sommerzeit Ende:" },
167{ "Time Zone","Zeit Zone" }, 167{ "Time Zone","Zeit Zone" },
168{ "Used Mail Client","Benutzter Mail Client" }, 168{ "Used Mail Client","Benutzter Mail Client" },
169{ "Channel:","Channel:" }, 169{ "Channel:","Channel:" },
170{ "Message:","Message:" }, 170{ "Message:","Message:" },
171{ "Parameters:","Parameter:" }, 171{ "Parameters:","Parameter:" },
172{ "HINT: Delimiter=; Name=%1,Email=%2","Hinweis: Begrenzer=; Name=%1,Email=%2" }, 172{ "HINT: Delimiter=; Name=%1,Email=%2","Hinweis: Begrenzer=; Name=%1,Email=%2" },
173{ "extra Message:","extra Message:" }, 173{ "extra Message:","extra Message:" },
174{ "extra Parameters:","extra Parameter:" }, 174{ "extra Parameters:","extra Parameter:" },
175{ "HINT: Emails=%1,Attachments=%2","Hinweis: Emails=%1,Attachments=%2" }, 175{ "HINT: Emails=%1,Attachments=%2","Hinweis: Emails=%1,Attachments=%2" },
176{ "External Apps.","Externe Appl." }, 176{ "External Apps.","Externe Appl." },
177{ "Your current storage dir is:\n%1\nYour mail is stored in:\n(storagedir)/apps/kopiemail/localmail","Aktuelles Speicherverzeichnis ist:\n%1\nIhre Mail wird gespeichert in:\n(speicherverz.)/apps/kopiemail/localmail" }, 177{ "Your current storage dir is:\n%1\nYour mail is stored in:\n(storagedir)/apps/kopiemail/localmail","Aktuelles Speicherverzeichnis ist:\n%1\nIhre Mail wird gespeichert in:\n(speicherverz.)/apps/kopiemail/localmail" },
178{ "<b>New data storage dir:</b>","<b>Neues Datenspeicherverzeichnis:</b>" }, 178{ "<b>New data storage dir:</b>","<b>Neues Datenspeicherverzeichnis:</b>" },
179{ "New dirs are created automatically","Neue Verzeichnisse werden aut. erstellt" }, 179{ "New dirs are created automatically","Neue Verzeichnisse werden aut. erstellt" },
180{ "Save settings","Speichere Einstellungen" }, 180{ "Save settings","Speichere Einstellungen" },
181{ "Save standard","Speichere Standard" }, 181{ "Save standard","Speichere Standard" },
182{ "<b>New settings are used\nafter a restart</b>","<b>Neue Einstellungen werden nach\neinem Neustart genutzt</b>" }, 182{ "<b>New settings are used\nafter a restart</b>","<b>Neue Einstellungen werden nach\neinem Neustart genutzt</b>" },
183{ "Settings are stored in\n%1","Einstellungen werden gespeichert in:\n%1" }, 183{ "Settings are stored in\n%1","Einstellungen werden gespeichert in:\n%1" },
184{ "Data storage path","Daten Speicherpfad" }, 184{ "Data storage path","Daten Speicherpfad" },
185{ "Used %1 Client","Benutzer %1 Client" }, 185{ "Used %1 Client","Benutzer %1 Client" },
186{ "No email client installed","Keine Email Client installiert" }, 186{ "No email client installed","Keine Email Client installiert" },
187{ "Userdefined email client","Benutzerdef. Email Client" }, 187{ "Userdefined email client","Benutzerdef. Email Client" },
188{ "OM/Pi email client","OM/Pi Email Client" }, 188{ "OM/Pi email client","OM/Pi Email Client" },
189{ "URL:","URL:" }, 189{ "URL:","URL:" },
190{ "No","Nein" }, 190{ "No","Nein" },
191{ "Yes","Ja" }, 191{ "Yes","Ja" },
192{ "Untitled","Unbenannt" }, 192{ "Untitled","Unbenannt" },
193{ "&New","&Neu" }, 193{ "&New","&Neu" },
194{ "&Open","&Öffne" }, 194{ "&Open","&Öffne" },
195{ "&Close","Schließen" }, 195{ "&Close","Schließen" },
196{ "Save &as...","Speichere &als..." }, 196{ "Save &as...","Speichere &als..." },
197{ "&Text-file...","&Text-Datei..." }, 197{ "&Text-file...","&Text-Datei..." },
198{ "&Gpasman / Kpasman ...","&Gpasman / Kpasman ..." }, 198{ "&Gpasman / Kpasman ...","&Gpasman / Kpasman ..." },
199{ "&CSV (Comma Separated Value) ...","&CSV (Komma getrennte Werte) ..." }, 199{ "&CSV (Comma Separated Value) ...","&CSV (Komma getrennte Werte) ..." },
200{ "E&xport","E&xport" }, 200{ "E&xport","E&xport" },
201{ "I&mport","I&mport" }, 201{ "I&mport","I&mport" },
202{ "&Quit","Beenden" }, 202{ "&Quit","Beenden" },
203{ "&Add password","&Passwort hinzufügen" }, 203{ "&Add password","&Passwort hinzufügen" },
204{ "&Delete","Lösche" }, 204{ "&Delete","Lösche" },
205{ "Change &Master Password","Ändere &Master Passwort" }, 205{ "Change &Master Password","Ändere &Master Passwort" },
206{ "&Manage","Verwalte" }, 206{ "&Manage","Verwalte" },
207{ "&Find","&Finde" }, 207{ "&Find","&Finde" },
208{ "&Lock all entries","Sperre alle Einträge" }, 208{ "&Lock all entries","Sperre alle Einträge" },
209{ "&Deep-lock all entries","Sperre total alle Einträge" }, 209{ "&Deep-lock all entries","Sperre total alle Einträge" },
210{ "&Unlock all entries","Entsperre alle Einträge" }, 210{ "&Unlock all entries","Entsperre alle Einträge" },
211{ "&Configure...","Konfiguriere..." }, 211{ "&Configure...","Konfiguriere..." },
212{ "&Options","Konfig" }, 212{ "&Options","Konfig" },
213{ "C&ategories...","K&ategorien..." }, 213{ "C&ategories...","K&ategorien..." },
214{ "&Sync","&Sync" }, 214{ "&Sync","&Sync" },
215{ "&License","&Lizenz" }, 215{ "&License","&Lizenz" },
216{ "&Faq","&Faq" }, 216{ "&Faq","&Faq" },
217{ "&About PwManager","Über PwManager" }, 217{ "&About PwManager","Über PwManager" },
218{ "&Sync HowTo","&Sync HowTo" }, 218{ "&Sync HowTo","&Sync HowTo" },
219{ "&What's New","Was ist neu?" }, 219{ "&What's New","Was ist neu?" },
220{ "New","Neu" }, 220{ "New","Neu" },
221{ "Open","Öffnen" }, 221{ "Open","Öffnen" },
222{ "Save","Speichern" }, 222{ "Save","Speichern" },
223{ "Save as","Speichern als" }, 223{ "Save as","Speichern als" },
224{ "Print...","Drucke..." }, 224{ "Print...","Drucke..." },
225{ "Add password","Passwort hinzufügen" }, 225{ "Add password","Passwort hinzufügen" },
226{ "Edit password","Passwort ändern" }, 226{ "Edit password","Passwort ändern" },
227{ "Delete password","Passwort löschen" }, 227{ "Delete password","Passwort löschen" },
228{ "Find entry","Finde Eintrag" }, 228{ "Find entry","Finde Eintrag" },
229{ "Lock all entries","Sperre alle Einträge" }, 229{ "Lock all entries","Sperre alle Einträge" },
230{ "Deep-Lock all entries","Sperre total alle Einträge" }, 230{ "Deep-Lock all entries","Sperre total alle Einträge" },
231{ "Unlock all entries","Entsperre alle Einträge" }, 231{ "Unlock all entries","Entsperre alle Einträge" },
232{ "Categories:","Kategorien:" }, 232{ "Categories:","Kategorien:" },
233{ "&Rename","&Umbenennen" }, 233{ "&Rename","&Umbenennen" },
234{ "Username","Benutzername" }, 234{ "Username","Benutzername" },
235{ "Password","Passwort" }, 235{ "Password","Passwort" },
236{ "Launcher","Launcher" }, 236{ "Launcher","Launcher" },
237{ "copy password to clipboard","Kopiere Passwort ins Clipboard" }, 237{ "copy password to clipboard","Kopiere Passwort ins Clipboard" },
238{ "copy username to clipboard","Kopiere Benutzername ins Clipboard" }, 238{ "copy username to clipboard","Kopiere Benutzername ins Clipboard" },
239{ "copy description to clipboard","Kopiere Beschreibung ins Clipboard" }, 239{ "copy description to clipboard","Kopiere Beschreibung ins Clipboard" },
240{ "copy url to clipboard","Kopiere URL ins Clipboard" }, 240{ "copy url to clipboard","Kopiere URL ins Clipboard" },
241{ "copy launcher to clipboard","Kopiere Launcher ins Clipboard" }, 241{ "copy launcher to clipboard","Kopiere Launcher ins Clipboard" },
242{ "copy comment to clipboard","Kopiere Kommentare ins Clipboard" }, 242{ "copy comment to clipboard","Kopiere Kommentare ins Clipboard" },
243{ "Execute "Launcher"",""Launcher" ausführen" }, 243{ "Execute "Launcher"",""Launcher" ausführen" },
244{ "Go to "URL"","Gehe zu "URL"" }, 244{ "Go to "URL"","Gehe zu "URL"" },
245{ "Ready.","Fertig." }, 245{ "Ready.","Fertig." },
246{ "password filename(*.pwm)","passwort dateiname(*.pwm)" }, 246{ "password filename(*.pwm)","passwort dateiname(*.pwm)" },
247{ "File error","Datei Fehler" }, 247{ "File error","Datei Fehler" },
248{ "Could not read file!","Kann Datei nicht lesen!" }, 248{ "Could not read file!","Kann Datei nicht lesen!" },
249{ "Master-password","Master-Passwort" }, 249{ "Master-password","Master-Passwort" },
250{ "Please enter the master-password:","Bitter Master-Passwort eingeben:" }, 250{ "Please enter the master-password:","Bitter Master-Passwort eingeben:" },
251{ "Wrong master-password!\nPlease try again.","Falsches Master-Passwort!\nBitte erneut versuchen." }, 251{ "Wrong master-password!\nPlease try again.","Falsches Master-Passwort!\nBitte erneut versuchen." },
252{ "password error","Passwort Fehler" }, 252{ "password error","Passwort Fehler" },
253{ "Successfully opened file.","Datei erfolgreich geöffnet." }, 253{ "Successfully opened file.","Datei erfolgreich geöffnet." },
254{ "DEEP-LOCKED","DEEP-LOCKED" }, 254{ "DEEP-LOCKED","DEEP-LOCKED" },
255{ "This file is DEEP-LOCKED!\nThat means all data has been encrypted\nand written out to the file. If you want\nto see the entries, please UNLOCK the file.\nWhile unlocking, you will be prompted for the\nmaster-password or the key-card.","This file is DEEP-LOCKED!\nThat means all data has been encrypted\nand written out to the file. If you want\nto see the entries, please UNLOCK the file.\nWhile unlocking, you will be prompted for the\nmaster-password or the key-card." }, 255{ "This file is DEEP-LOCKED!\nThat means all data has been encrypted\nand written out to the file. If you want\nto see the entries, please UNLOCK the file.\nWhile unlocking, you will be prompted for the\nmaster-password or the key-card.","This file is DEEP-LOCKED!\nThat means all data has been encrypted\nand written out to the file. If you want\nto see the entries, please UNLOCK the file.\nWhile unlocking, you will be prompted for the\nmaster-password or the key-card." },
256{ "<LOCKED>","<GESPERRT>" }, 256{ "<LOCKED>","<GESPERRT>" },
257{ "To unlock click the icon on the left.","Zum Entsperren klicke auf das linke Icon." }, 257{ "To unlock click the icon on the left.","Zum Entsperren klicke auf das linke Icon." },
258{ "PwManager","PwManager" }, 258{ "PwManager","PwManager" },
259{ "Window-style:","Window-style:" }, 259{ "Window-style:","Window-style:" },
260{ "Category on top","Kategorien oben" }, 260{ "Category on top","Kategorien oben" },
261{ "Category-list left/top","Kategorien links oben" }, 261{ "Category-list left/top","Kategorien links oben" },
262{ "<b>Font for Password entries:</b>","<b>Schrift für Passwort Einträge:</b>" }, 262{ "<b>Font for Password entries:</b>","<b>Schrift für Passwort Einträge:</b>" },
263{ "Font:","Schriftart:" }, 263{ "Font:","Schriftart:" },
264{ "Compression:","Kompression:" }, 264{ "Compression:","Kompression:" },
265{ "gzip","gzip" }, 265{ "gzip","gzip" },
266{ "Encryption:","Verschlüsselung:" }, 266{ "Encryption:","Verschlüsselung:" },
267{ "Blowfish (128 bit)","Blowfish (128 bit)" }, 267{ "Blowfish (128 bit)","Blowfish (128 bit)" },
268{ "AES-128, Rijndael (128 bit)","AES-128, Rijndael (128 bit)" }, 268{ "AES-128, Rijndael (128 bit)","AES-128, Rijndael (128 bit)" },
269{ "AES-192, Rijndael (192 bit)","AES-192, Rijndael (192 bit)" }, 269{ "AES-192, Rijndael (192 bit)","AES-192, Rijndael (192 bit)" },
270{ "AES-256, Rijndael (256 bit)","AES-256, Rijndael (256 bit)" }, 270{ "AES-256, Rijndael (256 bit)","AES-256, Rijndael (256 bit)" },
271{ "Triple-DES (168 bit)","Triple-DES (168 bit)" }, 271{ "Triple-DES (168 bit)","Triple-DES (168 bit)" },
272{ "Twofish (256 bit)","Twofish (256 bit)" }, 272{ "Twofish (256 bit)","Twofish (256 bit)" },
273{ "Twofish-128 (128 bit)","Twofish-128 (128 bit)" }, 273{ "Twofish-128 (128 bit)","Twofish-128 (128 bit)" },
274{ "Hashing:","Hashing:" }, 274{ "Hashing:","Hashing:" },
275{ "SHA-160, SHA1 (160 bit)","SHA-160, SHA1 (160 bit)" }, 275{ "SHA-160, SHA1 (160 bit)","SHA-160, SHA1 (160 bit)" },
276{ "SHA-256 (256 bit)","SHA-256 (256 bit)" }, 276{ "SHA-256 (256 bit)","SHA-256 (256 bit)" },
277{ "SHA-384 (384 bit)","SHA-384 (384 bit)" }, 277{ "SHA-384 (384 bit)","SHA-384 (384 bit)" },
278{ "SHA-512 (512 bit)","SHA-512 (512 bit)" }, 278{ "SHA-512 (512 bit)","SHA-512 (512 bit)" },
279{ "MD5 (128 bit)","MD5 (128 bit)" }, 279{ "MD5 (128 bit)","MD5 (128 bit)" },
280{ "RIPE-MD-160 (160 bit)","RIPE-MD-160 (160 bit)" }, 280{ "RIPE-MD-160 (160 bit)","RIPE-MD-160 (160 bit)" },
281{ "Tiger (192 bit)","Tiger (192 bit)" }, 281{ "Tiger (192 bit)","Tiger (192 bit)" },
282{ "Permissions:","Zugriffsrechte:" }, 282{ "Permissions:","Zugriffsrechte:" },
283{ "Make backup before saving","Mache Backup vor dem Speichern" }, 283{ "Make backup before saving","Mache Backup vor dem Speichern" },
284{ "Password timeout\n(timeout to hold password in\nmemory,so you don't have to\nre-enter it,if you\nalready have entered it)\n[set to 0 to disable]:","Passwort Timeout\n(Timeout um das Passwort\nim Speicher zu halten,\nso dass es nicht noch mal\neingegeben werden muß.)\n[Setze auf 0 zum deaktivieren]:" }, 284{ "Password timeout\n(timeout to hold password in\nmemory,so you don't have to\nre-enter it,if you\nalready have entered it)\n[set to 0 to disable]:","Passwort Timeout\n(Timeout um das Passwort\nim Speicher zu halten,\nso dass es nicht noch mal\neingegeben werden muß.)\n[Setze auf 0 zum deaktivieren]:" },
285{ "Auto-lock timeout\n(auto lock document after this\namount of seconds)\n[set to 0 to disable]:","(Total-)Sperr-Timeout\n(Sperre Dokument total nach\ndieser Anzahl Sekunden)\n[Setze auf 0 zum deaktivieren]:" }, 285{ "Auto-lock timeout\n(auto lock document after this\namount of seconds)\n[set to 0 to disable]:","(Total-)Sperr-Timeout\n(Sperre Dokument total nach\ndieser Anzahl Sekunden)\n[Setze auf 0 zum deaktivieren]:" },
286{ "deep-lock on autolock","Sperre total beim Sperr-Timeout" }, 286{ "deep-lock on autolock","Sperre total beim Sperr-Timeout" },
287{ "open deeplocked","Öffne total gesperrt" }, 287{ "open deeplocked","Öffne total gesperrt" },
288{ "Favourite browser:","Bevorzugter Browser:" }, 288{ "Favourite browser:","Bevorzugter Browser:" },
289{ "Favourite x-terminal:","Bevorzugtes x-terminal:" }, 289{ "Favourite x-terminal:","Bevorzugtes x-terminal:" },
290{ "Open document with passwords unlocked","Öffne Dokument mit Passwort ungesperrt" }, 290{ "Open document with passwords unlocked","Öffne Dokument mit Passwort ungesperrt" },
291{ "Look && feel","Aussehen" }, 291{ "Look && feel","Aussehen" },
292{ "File","Datei" }, 292{ "File","Datei" },
293{ "Timeout","Timeout" }, 293{ "Timeout","Timeout" },
294{ "Autostart","Autostart" }, 294{ "Autostart","Autostart" },
295{ "External apps","Externe Applik." }, 295{ "External apps","Externe Applik." },
296{ "Miscellaneous","Verschiedenes" }, 296{ "Miscellaneous","Verschiedenes" },
297{ "+01:00 Europe/Oslo(CET)","+01:00 Europe/Oslo(CET)" }, 297{ "+01:00 Europe/Oslo(CET)","+01:00 Europe/Oslo(CET)" },
298{ "edit category descriptions","Ändere Label für Kategorie" }, 298{ "edit category descriptions","Ändere Label für Kategorie" },
299{ "Close","Schließen" }, 299{ "Close","Schließen" },
300{ "Category:","Category:" }, 300{ "Category:","Category:" },
301{ "Text1 (Description):","Text1 (Beschreibung):" }, 301{ "Text1 (Description):","Text1 (Beschreibung):" },
302{ "Text2 (Username):","Text2 (Benutzername):" }, 302{ "Text2 (Username):","Text2 (Benutzername):" },
303{ "Text3 (Password):","Text3 (Passwort):" }, 303{ "Text3 (Password):","Text3 (Passwort):" },
304{ "edit/add a password entry","Ändere/hinzufüge Passwort Eintrag" }, 304{ "edit/add a password entry","Ändere/hinzufüge Passwort Eintrag" },
305{ "Description:","Beschreibung:" }, 305{ "Description:","Beschreibung:" },
306{ "Username:","Benutzername:" }, 306{ "Username:","Benutzername:" },
307{ "Password:","Passwort:" }, 307{ "Password:","Passwort:" },
308{ "&Reveal","&Offen zeigen" }, 308{ "&Reveal","&Offen zeigen" },
309{ "&Generate","&Generiere" }, 309{ "&Generate","&Generiere" },
310{ "&Password","&Passwort" }, 310{ "&Password","&Passwort" },
311{ "&Comments","Kommentare" }, 311{ "&Comments","Kommentar" },
312{ "Launcher:","Launcher:" }, 312{ "Launcher:","Launcher:" },
313{ "$d = Description","$d = Beschreibung" }, 313{ "$d = Description","$d = Beschreibung" },
314{ "$n = Username","$n = Benutzername" }, 314{ "$n = Username","$n = Benutzername" },
315{ "$c = Comment","$c = Kommentar" }, 315{ "$c = Comment","$c = Kommentar" },
316{ "$u = URL","$u = URL" }, 316{ "$u = URL","$u = URL" },
317{ "$p = Password","$p = Passwort" }, 317{ "$p = Password","$p = Passwort" },
318{ "&Launcher","&Launcher" }, 318{ "&Launcher","&Launcher" },
319{ "Password generator","Passwort Generator" }, 319{ "Password generator","Passwort Generator" },
320{ "Character set:","Buchstaben Set:" }, 320{ "Character set:","Buchstaben Set:" },
321{ "Lowercase (abc)","Klein (abc)" }, 321{ "Lowercase (abc)","Klein (abc)" },
322{ "Uppercase (ABC)","Groß (ABC)" }, 322{ "Uppercase (ABC)","Groß (ABC)" },
323{ "Numbers (123)","Nummmern (123)" }, 323{ "Numbers (123)","Nummmern (123)" },
324{ "Special characters:","Spezielle Buchstaben:" }, 324{ "Special characters:","Spezielle Buchstaben:" },
325{ "Spaces (blank characters)","Leerzeichen" }, 325{ "Spaces (blank characters)","Leerzeichen" },
326{ "User defined:","Benutzer definiert:" }, 326{ "User defined:","Benutzer definiert:" },
327{ "Password Length:","Passwort Länge:" }, 327{ "Password Length:","Passwort Länge:" },
328{ "Enable Filtering to get better passwords","Enable Filtering to get better passwords" }, 328{ "Enable Filtering to get better passwords","Enable Filtering to get better passwords" },
329{ "no password","Kein Passwort" }, 329{ "no password","Kein Passwort" },
330{ "Sorry, you haven't set a password.","Sorry, Sie haben kein Passwort angegeben." }, 330{ "Sorry, you haven't set a password.","Sorry, Sie haben kein Passwort angegeben." },
331{ "not saved, yet","not saved, yet" }, 331{ "not saved, yet","not saved, yet" },
332{ "Can't deep-lock, because the document\nhasn't been saved, yet. Please save\nto a file and try again.","Kann nicht tiefsperren, weil das\nDokument noch nicht gespeichert wurde.\nBitte speichern und noch einmal versuchen." }, 332{ "Can't deep-lock, because the document\nhasn't been saved, yet. Please save\nto a file and try again.","Kann nicht tiefsperren, weil das\nDokument noch nicht gespeichert wurde.\nBitte speichern und noch einmal versuchen." },
333{ "Find","Finde" }, 333{ "Find","Finde" },
334{ "&Exact match","Genaue Übereinstimmung" }, 334{ "&Exact match","Genaue Übereinstimmung" },
335{ "&Case sensitive","Großschrift abhängig" }, 335{ "&Case sensitive","Großschrift abhängig" },
336{ "Search in Column","Suche in Spalten" }, 336{ "Search in Column","Suche in Spalten" },
337{ "&Description","Beschreibung" }, 337{ "&Description","Beschreibung" },
338{ "C&omment","Kommentar" }, 338{ "C&omment","Kommentar" },
339{ "&Username","Benutzername" }, 339{ "&Username","Benutzername" },
340{ "U&RL","URL" }, 340{ "U&RL","URL" },
341{ "delete?","Löschen?" }, 341{ "delete?","Löschen?" },
342{ "Do you really want to delete\nthe selected entry","Wollen Sie wirklich\nden Eintrag löschen:" }, 342{ "Do you really want to delete\nthe selected entry","Wollen Sie wirklich\nden Eintrag löschen:" },
343{ "Save?","Speichern?" }, 343{ "Save?","Speichern?" },
344{ ""\nhas been modified.\nDo you want to save it?",""\nwurde geändert.\nMöchten Sie speichern?" }, 344{ ""\nhas been modified.\nDo you want to save it?",""\nwurde geändert.\nMöchten Sie speichern?" },
345{ "The list\n "","Die Liste\n "" }, 345{ "The list\n "","Die Liste\n "" },
346{ "nothing to do","Nichts zu tun" }, 346{ "nothing to do","Nichts zu tun" },
347{ "Sorry, there's nothing to save.\nPlease first add some passwords.","Sorry, es gibt nichts zu speichern.\nBitte erst Passwörter hinzufügen." }, 347{ "Sorry, there's nothing to save.\nPlease first add some passwords.","Sorry, es gibt nichts zu speichern.\nBitte erst Passwörter hinzufügen." },
348{ "","" }, 348{ "Add new password","Passwort hinzufügen" },
349{ "Successfully saved data.","Datei gespeichert." },
349{ "","" }, 350{ "","" },
350{ "","" }, 351{ "","" },
351{ "","" }, 352{ "","" },
352{ "","" }, 353{ "","" },
353 354
diff --git a/pwmanager/pwmanager/commentbox.cpp b/pwmanager/pwmanager/commentbox.cpp
index 4a76f36..e2d2d2b 100644
--- a/pwmanager/pwmanager/commentbox.cpp
+++ b/pwmanager/pwmanager/commentbox.cpp
@@ -1,281 +1,281 @@
1/*************************************************************************** 1/***************************************************************************
2 * * 2 * *
3 * copyright (C) 2004 by Michael Buesch * 3 * copyright (C) 2004 by Michael Buesch *
4 * email: mbuesch@freenet.de * 4 * email: mbuesch@freenet.de *
5 * * 5 * *
6 * This program is free software; you can redistribute it and/or modify * 6 * This program is free software; you can redistribute it and/or modify *
7 * it under the terms of the GNU General Public License version 2 * 7 * it under the terms of the GNU General Public License version 2 *
8 * as published by the Free Software Foundation. * 8 * as published by the Free Software Foundation. *
9 * * 9 * *
10 ***************************************************************************/ 10 ***************************************************************************/
11 11
12/*************************************************************************** 12/***************************************************************************
13 * copyright (C) 2004 by Ulf Schenk 13 * copyright (C) 2004 by Ulf Schenk
14 * This file is originaly based on version 1.0.1 of pwmanager 14 * This file is originaly based on version 1.0.1 of pwmanager
15 * and was modified to run on embedded devices that run microkde 15 * and was modified to run on embedded devices that run microkde
16 * 16 *
17 * $Id$ 17 * $Id$
18 **************************************************************************/ 18 **************************************************************************/
19 19
20#include "commentbox.h" 20#include "commentbox.h"
21#include "pwmexception.h" 21#include "pwmexception.h"
22#include "htmlgen.h" 22#include "htmlgen.h"
23 23
24#include <klocale.h> 24#include <klocale.h>
25 25
26#ifndef PWM_EMBEDDED 26#ifndef PWM_EMBEDDED
27#include <khtml_part.h> 27#include <khtml_part.h>
28#include <khtmlview.h> 28#include <khtmlview.h>
29#include <qtextedit.h> 29#include <qtextedit.h>
30#else 30#else
31#include <qmultilineedit.h> 31#include <qmultilineedit.h>
32#endif 32#endif
33 33
34 34
35 35
36#ifndef PWM_EMBEDDED 36#ifndef PWM_EMBEDDED
37CommentBox::CommentBox(QWidget *_parentWidget) 37CommentBox::CommentBox(QWidget *_parentWidget)
38{ 38{
39 PWM_ASSERT(_parentWidget); 39 PWM_ASSERT(_parentWidget);
40 parentWidget = _parentWidget; 40 parentWidget = _parentWidget;
41 textDta = 0; 41 textDta = 0;
42 htmlDta = 0; 42 htmlDta = 0;
43 mode = mode_notSet; 43 mode = mode_notSet;
44} 44}
45 45
46CommentBox::~CommentBox() 46CommentBox::~CommentBox()
47{ 47{
48 clearText(); 48 clearText();
49 clearHtml(); 49 clearHtml();
50} 50}
51 51
52void CommentBox::clear() 52void CommentBox::clear()
53{ 53{
54 clearText(); 54 clearText();
55 clearHtml(); 55 clearHtml();
56 mode = mode_notSet; 56 mode = mode_notSet;
57 this->hide(); 57 this->hide();
58} 58}
59 59
60void CommentBox::clearText() 60void CommentBox::clearText()
61{ 61{
62 delete_ifnot_null(textDta); 62 delete_ifnot_null(textDta);
63} 63}
64 64
65void CommentBox::clearHtml() 65void CommentBox::clearHtml()
66{ 66{
67 delete_ifnot_null(htmlDta); 67 delete_ifnot_null(htmlDta);
68} 68}
69 69
70void CommentBox::setText(const QString &text) 70void CommentBox::setText(const QString &text)
71{ 71{
72 switchTo(mode_text); 72 switchTo(mode_text);
73 PWM_ASSERT(textDta); 73 PWM_ASSERT(textDta);
74 textDta->setText(i18n("Comment") + ": " + text); 74 textDta->setText( text);
75 if (!textDta->isVisible()) 75 if (!textDta->isVisible())
76 textDta->show(); 76 textDta->show();
77} 77}
78 78
79bool CommentBox::getText(QString *text) 79bool CommentBox::getText(QString *text)
80{ 80{
81 if (mode != mode_text) 81 if (mode != mode_text)
82 return false; 82 return false;
83 PWM_ASSERT(text); 83 PWM_ASSERT(text);
84 if (!textDta) { 84 if (!textDta) {
85 *text = ""; 85 *text = "";
86 return true; 86 return true;
87 } 87 }
88 *text = textDta->text(); 88 *text = textDta->text();
89 return true; 89 return true;
90} 90}
91 91
92void CommentBox::setHtml(QString code) 92void CommentBox::setHtml(QString code)
93{ 93{
94 switchTo(mode_html); 94 switchTo(mode_html);
95 PWM_ASSERT(htmlDta); 95 PWM_ASSERT(htmlDta);
96 if (!HtmlGen::replaceSSDummy(&code)) 96 if (!HtmlGen::replaceSSDummy(&code))
97 printWarn("CommentBox::setHtml(): replaceSSDummy() failed!"); 97 printWarn("CommentBox::setHtml(): replaceSSDummy() failed!");
98 htmlDta->begin(); 98 htmlDta->begin();
99 htmlDta->write(code); 99 htmlDta->write(code);
100 htmlDta->end(); 100 htmlDta->end();
101 htmlDta->show(); 101 htmlDta->show();
102} 102}
103 103
104void CommentBox::setContent(const QString &dta) 104void CommentBox::setContent(const QString &dta)
105{ 105{
106 // if there's no data, hide the comment-box 106 // if there's no data, hide the comment-box
107 if (dta.isEmpty()) { 107 if (dta.isEmpty()) {
108 clear(); 108 clear();
109 return; 109 return;
110 } 110 }
111 if (HtmlGen::isHtml(dta)) { 111 if (HtmlGen::isHtml(dta)) {
112 setHtml(dta); 112 setHtml(dta);
113 return; 113 return;
114 } 114 }
115 // we assume it's plain text 115 // we assume it's plain text
116 setText(dta); 116 setText(dta);
117} 117}
118 118
119void CommentBox::switchTo(commentBoxMode newMode) 119void CommentBox::switchTo(commentBoxMode newMode)
120{ 120{
121 if (newMode == mode) 121 if (newMode == mode)
122 return; 122 return;
123 123
124 // cleanup old mode 124 // cleanup old mode
125 switch (mode) { 125 switch (mode) {
126 case mode_text: 126 case mode_text:
127 clearText(); 127 clearText();
128 break; 128 break;
129 case mode_html: 129 case mode_html:
130 clearHtml(); 130 clearHtml();
131 break; 131 break;
132 default: 132 default:
133 break; 133 break;
134 } 134 }
135 135
136 // setup new mode 136 // setup new mode
137 switch (newMode) { 137 switch (newMode) {
138 case mode_text: 138 case mode_text:
139 textDta = new QTextEdit(parentWidget); 139 textDta = new QTextEdit(parentWidget);
140 textDta->setTextFormat(Qt::PlainText); 140 textDta->setTextFormat(Qt::PlainText);
141 textDta->setReadOnly(true); 141 textDta->setReadOnly(true);
142 textDta->show(); 142 textDta->show();
143 break; 143 break;
144 case mode_html: 144 case mode_html:
145 htmlDta = new KHTMLPart(parentWidget, 0, 145 htmlDta = new KHTMLPart(parentWidget, 0,
146 parentWidget); 146 parentWidget);
147 htmlDta->show(); 147 htmlDta->show();
148 break; 148 break;
149 default: 149 default:
150 BUG(); 150 BUG();
151 break; 151 break;
152 } 152 }
153 153
154 mode = newMode; 154 mode = newMode;
155} 155}
156 156
157void CommentBox::show() 157void CommentBox::show()
158{ 158{
159 switch (mode) { 159 switch (mode) {
160 case mode_text: 160 case mode_text:
161 PWM_ASSERT(textDta); 161 PWM_ASSERT(textDta);
162 textDta->show(); 162 textDta->show();
163 break; 163 break;
164 case mode_html: 164 case mode_html:
165 PWM_ASSERT(htmlDta); 165 PWM_ASSERT(htmlDta);
166 htmlDta->show(); 166 htmlDta->show();
167 break; 167 break;
168 default: 168 default:
169 break; 169 break;
170 } 170 }
171 171
172} 172}
173 173
174void CommentBox::hide() 174void CommentBox::hide()
175{ 175{
176 switch (mode) { 176 switch (mode) {
177 case mode_text: 177 case mode_text:
178 PWM_ASSERT(textDta); 178 PWM_ASSERT(textDta);
179 textDta->hide(); 179 textDta->hide();
180 break; 180 break;
181 case mode_html: 181 case mode_html:
182 PWM_ASSERT(htmlDta); 182 PWM_ASSERT(htmlDta);
183 htmlDta->hide(); 183 htmlDta->hide();
184 break; 184 break;
185 default: 185 default:
186 break; 186 break;
187 } 187 }
188} 188}
189 189
190void CommentBox::resize(const QSize &size) 190void CommentBox::resize(const QSize &size)
191{ 191{
192 switch (mode) { 192 switch (mode) {
193 case mode_text: 193 case mode_text:
194 PWM_ASSERT(textDta); 194 PWM_ASSERT(textDta);
195 textDta->resize(size); 195 textDta->resize(size);
196 break; 196 break;
197 case mode_html: 197 case mode_html:
198 PWM_ASSERT(htmlDta); 198 PWM_ASSERT(htmlDta);
199 htmlDta->view()->resize(size); 199 htmlDta->view()->resize(size);
200 break; 200 break;
201 default: 201 default:
202 break; 202 break;
203 } 203 }
204 204
205} 205}
206 206
207QSize CommentBox::size() 207QSize CommentBox::size()
208{ 208{
209 switch (mode) { 209 switch (mode) {
210 case mode_text: 210 case mode_text:
211 PWM_ASSERT(textDta); 211 PWM_ASSERT(textDta);
212 return textDta->size(); 212 return textDta->size();
213 break; 213 break;
214 case mode_html: 214 case mode_html:
215 PWM_ASSERT(htmlDta); 215 PWM_ASSERT(htmlDta);
216 return htmlDta->view()->size(); 216 return htmlDta->view()->size();
217 break; 217 break;
218 default: 218 default:
219 break; 219 break;
220 } 220 }
221 221
222 return QSize(); 222 return QSize();
223} 223}
224 224
225 225
226//////////////////////////////////////////////////////////////////////// 226////////////////////////////////////////////////////////////////////////
227 227
228#else 228#else
229 229
230CommentBox::CommentBox(QWidget *_parentWidget) 230CommentBox::CommentBox(QWidget *_parentWidget)
231 : QMultiLineEdit(_parentWidget) 231 : QMultiLineEdit(_parentWidget)
232 232
233{ 233{
234 this->setReadOnly(true); 234 this->setReadOnly(true);
235} 235}
236 236
237CommentBox::~CommentBox() 237CommentBox::~CommentBox()
238{ 238{
239} 239}
240 240
241void CommentBox::clear() 241void CommentBox::clear()
242{ 242{
243 this->hide(); 243 this->hide();
244} 244}
245 245
246 246
247void CommentBox::setText(const QString &text) 247void CommentBox::setText(const QString &text)
248{ 248{
249 QMultiLineEdit::setText(i18n("Comment") + ": " + text); 249 QMultiLineEdit::setText( text);
250 if (!this->isVisible()) 250 if (!this->isVisible())
251 this->show(); 251 this->show();
252} 252}
253 253
254bool CommentBox::getText(QString *text) 254bool CommentBox::getText(QString *text)
255{ 255{
256 *text = this->text(); 256 *text = this->text();
257 return true; 257 return true;
258} 258}
259 259
260void CommentBox::setContent(const QString &dta) 260void CommentBox::setContent(const QString &dta)
261{ 261{
262 // if there's no data, hide the comment-box 262 // if there's no data, hide the comment-box
263 if (dta.isEmpty()) { 263 if (dta.isEmpty()) {
264 clear(); 264 clear();
265 return; 265 return;
266 } 266 }
267 267
268 // we assume it's plain text 268 // we assume it's plain text
269 setText(dta); 269 setText(dta);
270} 270}
271 271
272#endif 272#endif
273 273
274 274
275 275
276 276
277 277
278 278
279 279
280 280
281 281
diff --git a/pwmanager/pwmanager/pwm.cpp b/pwmanager/pwmanager/pwm.cpp
index 48257ef..fc6837f 100644
--- a/pwmanager/pwmanager/pwm.cpp
+++ b/pwmanager/pwmanager/pwm.cpp
@@ -1,1503 +1,1516 @@
1/*************************************************************************** 1/***************************************************************************
2 * * 2 * *
3 * copyright (C) 2003, 2004 by Michael Buesch * 3 * copyright (C) 2003, 2004 by Michael Buesch *
4 * email: mbuesch@freenet.de * 4 * email: mbuesch@freenet.de *
5 * * 5 * *
6 * This program is free software; you can redistribute it and/or modify * 6 * This program is free software; you can redistribute it and/or modify *
7 * it under the terms of the GNU General Public License version 2 * 7 * it under the terms of the GNU General Public License version 2 *
8 * as published by the Free Software Foundation. * 8 * as published by the Free Software Foundation. *
9 * * 9 * *
10 ***************************************************************************/ 10 ***************************************************************************/
11 11
12/*************************************************************************** 12/***************************************************************************
13 * copyright (C) 2004 by Ulf Schenk 13 * copyright (C) 2004 by Ulf Schenk
14 * This file is originaly based on version 1.0.1 of pwmanager 14 * This file is originaly based on version 1.0.1 of pwmanager
15 * and was modified to run on embedded devices that run microkde 15 * and was modified to run on embedded devices that run microkde
16 * 16 *
17 * $Id$ 17 * $Id$
18 **************************************************************************/ 18 **************************************************************************/
19 19
20#include <klocale.h> 20#include <klocale.h>
21#include <klistview.h> 21#include <klistview.h>
22#include <ktoolbar.h> 22#include <ktoolbar.h>
23#include <kfiledialog.h> 23#include <kfiledialog.h>
24#include <kiconloader.h> 24#include <kiconloader.h>
25#include <kmessagebox.h> 25#include <kmessagebox.h>
26 26
27#include <qstatusbar.h> 27#include <qstatusbar.h>
28 28
29#ifndef PWM_EMBEDDED 29#ifndef PWM_EMBEDDED
30#include <kmenubar.h> 30#include <kmenubar.h>
31#include <kstatusbar.h> 31#include <kstatusbar.h>
32#include <dcopclient.h> 32#include <dcopclient.h>
33#include "configwndimpl.h" 33#include "configwndimpl.h"
34#include "configuration.h" 34#include "configuration.h"
35#else 35#else
36#include <qmenubar.h> 36#include <qmenubar.h>
37#include <qmessagebox.h> 37#include <qmessagebox.h>
38#include <pwmprefs.h> 38#include <pwmprefs.h>
39#include <kpimglobalprefs.h> 39#include <kpimglobalprefs.h>
40#include <kcmconfigs/kcmpwmconfig.h> 40#include <kcmconfigs/kcmpwmconfig.h>
41#include <kcmconfigs/kcmkdepimconfig.h> 41#include <kcmconfigs/kcmkdepimconfig.h>
42#include <kcmultidialog.h> 42#include <kcmultidialog.h>
43#include "editcategory.h" 43#include "editcategory.h"
44#endif 44#endif
45 45
46 46
47#ifndef DESKTOP_VERSION 47#ifndef DESKTOP_VERSION
48#include <qpe/global.h> 48#include <qpe/global.h>
49#endif 49#endif
50 50
51#include <qpixmap.h> 51#include <qpixmap.h>
52#include <qcheckbox.h> 52#include <qcheckbox.h>
53#include <qspinbox.h> 53#include <qspinbox.h>
54#include <qlineedit.h> 54#include <qlineedit.h>
55#include <qfileinfo.h> 55#include <qfileinfo.h>
56#include <qclipboard.h> 56#include <qclipboard.h>
57 57
58 58
59#include <stdio.h> 59#include <stdio.h>
60 60
61#include "pwm.h" 61#include "pwm.h"
62#include "pwminit.h" 62#include "pwminit.h"
63#include "pwmprint.h" 63#include "pwmprint.h"
64#include "addentrywndimpl.h" 64#include "addentrywndimpl.h"
65#include "globalstuff.h" 65#include "globalstuff.h"
66#include "findwndimpl.h" 66#include "findwndimpl.h"
67#include "csv.h" 67#include "csv.h"
68 68
69#ifdef CONFIG_KWALLETIF 69#ifdef CONFIG_KWALLETIF
70# include "kwalletif.h" 70# include "kwalletif.h"
71# include "kwalletemu.h" 71# include "kwalletemu.h"
72#endif 72#endif
73#ifdef CONFIG_KEYCARD 73#ifdef CONFIG_KEYCARD
74# include "pwmkeycard.h" 74# include "pwmkeycard.h"
75#endif 75#endif
76 76
77 77
78 #define DEFAULT_SIZE (QSize(700, 400)) 78 #define DEFAULT_SIZE (QSize(700, 400))
79 79
80// Button IDs for "file" popup menu 80// Button IDs for "file" popup menu
81enum { 81enum {
82 BUTTON_POPUP_FILE_NEW = 0, 82 BUTTON_POPUP_FILE_NEW = 0,
83 BUTTON_POPUP_FILE_OPEN, 83 BUTTON_POPUP_FILE_OPEN,
84 BUTTON_POPUP_FILE_CLOSE, 84 BUTTON_POPUP_FILE_CLOSE,
85 BUTTON_POPUP_FILE_SAVE, 85 BUTTON_POPUP_FILE_SAVE,
86 BUTTON_POPUP_FILE_SAVEAS, 86 BUTTON_POPUP_FILE_SAVEAS,
87 BUTTON_POPUP_FILE_EXPORT, 87 BUTTON_POPUP_FILE_EXPORT,
88 BUTTON_POPUP_FILE_IMPORT, 88 BUTTON_POPUP_FILE_IMPORT,
89 BUTTON_POPUP_FILE_PRINT, 89 BUTTON_POPUP_FILE_PRINT,
90 BUTTON_POPUP_FILE_QUIT 90 BUTTON_POPUP_FILE_QUIT
91}; 91};
92// Button IDs for "manage" popup menu 92// Button IDs for "manage" popup menu
93enum { 93enum {
94 BUTTON_POPUP_MANAGE_ADD = 0, 94 BUTTON_POPUP_MANAGE_ADD = 0,
95 BUTTON_POPUP_MANAGE_EDIT, 95 BUTTON_POPUP_MANAGE_EDIT,
96 BUTTON_POPUP_MANAGE_DEL, 96 BUTTON_POPUP_MANAGE_DEL,
97 BUTTON_POPUP_MANAGE_CHANGEMP 97 BUTTON_POPUP_MANAGE_CHANGEMP
98}; 98};
99// Button IDs for chipcard popup menu 99// Button IDs for chipcard popup menu
100enum { 100enum {
101#ifdef CONFIG_KEYCARD 101#ifdef CONFIG_KEYCARD
102 BUTTON_POPUP_CHIPCARD_GENNEW = 0, 102 BUTTON_POPUP_CHIPCARD_GENNEW = 0,
103 BUTTON_POPUP_CHIPCARD_DEL, 103 BUTTON_POPUP_CHIPCARD_DEL,
104 BUTTON_POPUP_CHIPCARD_READID, 104 BUTTON_POPUP_CHIPCARD_READID,
105 BUTTON_POPUP_CHIPCARD_SAVEBACKUP, 105 BUTTON_POPUP_CHIPCARD_SAVEBACKUP,
106 BUTTON_POPUP_CHIPCARD_REPLAYBACKUP 106 BUTTON_POPUP_CHIPCARD_REPLAYBACKUP
107#else // CONFIG_KEYCARD 107#else // CONFIG_KEYCARD
108 BUTTON_POPUP_CHIPCARD_NO = 0 108 BUTTON_POPUP_CHIPCARD_NO = 0
109#endif // CONFIG_KEYCARD 109#endif // CONFIG_KEYCARD
110}; 110};
111// Button IDs for "view" popup menu 111// Button IDs for "view" popup menu
112enum { 112enum {
113 BUTTON_POPUP_VIEW_FIND = 0, 113 BUTTON_POPUP_VIEW_FIND = 0,
114 BUTTON_POPUP_VIEW_LOCK, 114 BUTTON_POPUP_VIEW_LOCK,
115 BUTTON_POPUP_VIEW_DEEPLOCK, 115 BUTTON_POPUP_VIEW_DEEPLOCK,
116 BUTTON_POPUP_VIEW_UNLOCK 116 BUTTON_POPUP_VIEW_UNLOCK
117}; 117};
118// Button IDs for "options" popup menu 118// Button IDs for "options" popup menu
119enum { 119enum {
120 BUTTON_POPUP_OPTIONS_CONFIG = 0 120 BUTTON_POPUP_OPTIONS_CONFIG = 0
121#ifdef PWM_EMBEDDED 121#ifdef PWM_EMBEDDED
122 ,BUTTON_POPUP_OPTIONS_CATEGORY 122 ,BUTTON_POPUP_OPTIONS_CATEGORY
123#endif 123#endif
124}; 124};
125// Button IDs for "export" popup menu (in "file" popup menu) 125// Button IDs for "export" popup menu (in "file" popup menu)
126enum { 126enum {
127 BUTTON_POPUP_EXPORT_TEXT = 0, 127 BUTTON_POPUP_EXPORT_TEXT = 0,
128 BUTTON_POPUP_EXPORT_GPASMAN, 128 BUTTON_POPUP_EXPORT_GPASMAN,
129 BUTTON_POPUP_EXPORT_CSV 129 BUTTON_POPUP_EXPORT_CSV
130#ifdef CONFIG_KWALLETIF 130#ifdef CONFIG_KWALLETIF
131 ,BUTTON_POPUP_EXPORT_KWALLET 131 ,BUTTON_POPUP_EXPORT_KWALLET
132#endif 132#endif
133}; 133};
134// Button IDs for "import" popup menu (in "file" popup menu) 134// Button IDs for "import" popup menu (in "file" popup menu)
135enum { 135enum {
136 BUTTON_POPUP_IMPORT_TEXT = 0, 136 BUTTON_POPUP_IMPORT_TEXT = 0,
137 BUTTON_POPUP_IMPORT_GPASMAN, 137 BUTTON_POPUP_IMPORT_GPASMAN,
138 BUTTON_POPUP_IMPORT_CSV 138 BUTTON_POPUP_IMPORT_CSV
139#ifdef CONFIG_KWALLETIF 139#ifdef CONFIG_KWALLETIF
140 ,BUTTON_POPUP_IMPORT_KWALLET 140 ,BUTTON_POPUP_IMPORT_KWALLET
141#endif 141#endif
142}; 142};
143 143
144#ifdef PWM_EMBEDDED 144#ifdef PWM_EMBEDDED
145// Button IDs for "help" popup menu 145// Button IDs for "help" popup menu
146enum { 146enum {
147 BUTTON_POPUP_HELP_LICENSE = 0, 147 BUTTON_POPUP_HELP_LICENSE = 0,
148 BUTTON_POPUP_HELP_FAQ, 148 BUTTON_POPUP_HELP_FAQ,
149 BUTTON_POPUP_HELP_ABOUT, 149 BUTTON_POPUP_HELP_ABOUT,
150 BUTTON_POPUP_HELP_SYNC, 150 BUTTON_POPUP_HELP_SYNC,
151 BUTTON_POPUP_HELP_WHATSNEW 151 BUTTON_POPUP_HELP_WHATSNEW
152}; 152};
153#endif 153#endif
154 154
155// Button IDs for toolbar 155// Button IDs for toolbar
156enum { 156enum {
157 BUTTON_TOOL_NEW = 0, 157 BUTTON_TOOL_NEW = 0,
158 BUTTON_TOOL_OPEN, 158 BUTTON_TOOL_OPEN,
159 BUTTON_TOOL_SAVE, 159 BUTTON_TOOL_SAVE,
160 BUTTON_TOOL_SAVEAS, 160 BUTTON_TOOL_SAVEAS,
161 BUTTON_TOOL_PRINT, 161 BUTTON_TOOL_PRINT,
162 BUTTON_TOOL_ADD, 162 BUTTON_TOOL_ADD,
163 BUTTON_TOOL_EDIT, 163 BUTTON_TOOL_EDIT,
164 BUTTON_TOOL_DEL, 164 BUTTON_TOOL_DEL,
165 BUTTON_TOOL_FIND, 165 BUTTON_TOOL_FIND,
166 BUTTON_TOOL_LOCK, 166 BUTTON_TOOL_LOCK,
167 BUTTON_TOOL_DEEPLOCK, 167 BUTTON_TOOL_DEEPLOCK,
168 BUTTON_TOOL_UNLOCK 168 BUTTON_TOOL_UNLOCK
169}; 169};
170 170
171 171
172PwM::PwM(PwMInit *_init, PwMDoc *doc, 172PwM::PwM(PwMInit *_init, PwMDoc *doc,
173 bool virginity, 173 bool virginity,
174 QWidget *parent, const char *name) 174 QWidget *parent, const char *name)
175 : KMainWindow(parent, "HALLO") 175 : KMainWindow(parent, "HALLO")
176 , forceQuit (false) 176 , forceQuit (false)
177 , forceMinimizeToTray (false) 177 , forceMinimizeToTray (false)
178{ 178{
179 syncManager = 0; 179 syncManager = 0;
180 virgin = !virginity; 180 virgin = !virginity;
181 init = _init; 181 init = _init;
182 connect(doc, SIGNAL(docClosed(PwMDoc *)), 182 connect(doc, SIGNAL(docClosed(PwMDoc *)),
183 this, SLOT(docClosed(PwMDoc *))); 183 this, SLOT(docClosed(PwMDoc *)));
184 initMenubar(); 184 initMenubar();
185 initToolbar(); 185 initToolbar();
186 initMetrics(); 186 initMetrics();
187 setVirgin(virginity); 187 setVirgin(virginity);
188 setFocusPolicy(QWidget::WheelFocus); 188 setFocusPolicy(QWidget::WheelFocus);
189#ifndef PWM_EMBEDDED 189#ifndef PWM_EMBEDDED
190 statusBar()->show(); 190 statusBar()->show();
191#endif 191#endif
192 view = makeNewListView(doc); 192 view = makeNewListView(doc);
193 setCentralWidget(view); 193 setCentralWidget(view);
194 updateCaption(); 194 updateCaption();
195 showStatMsg(i18n("Ready.")); 195 showStatMsg(i18n("Ready."));
196} 196}
197 197
198PwM::~PwM() 198PwM::~PwM()
199{ 199{
200 //qDebug("PwM::~PwM() %x", this); 200 //qDebug("PwM::~PwM() %x", this);
201 disconnect(curDoc(), SIGNAL(docClosed(PwMDoc *)), 201 disconnect(curDoc(), SIGNAL(docClosed(PwMDoc *)),
202 this, SLOT(docClosed(PwMDoc *))); 202 this, SLOT(docClosed(PwMDoc *)));
203 conf()->confWndMainWndSize(size()); 203 conf()->confWndMainWndSize(size());
204 //LR closing of windows changed 204 //LR closing of windows changed
205 //needed for fastload option on PDA 205 //needed for fastload option on PDA
206 //emit closed(this); 206 //emit closed(this);
207 //qDebug("PwM::~PwM() emited closed(this)"); 207 //qDebug("PwM::~PwM() emited closed(this)");
208 delete view; 208 delete view;
209 delete syncManager; 209 delete syncManager;
210} 210}
211 211
212void PwM::initMenubar() 212void PwM::initMenubar()
213{ 213{
214 KIconLoader* picons; 214 KIconLoader* picons;
215#ifndef PWM_EMBEDDED 215#ifndef PWM_EMBEDDED
216 KIconLoader icons; 216 KIconLoader icons;
217 picons = &icons; 217 picons = &icons;
218#else 218#else
219 picons = KGlobal::iconLoader(); 219 picons = KGlobal::iconLoader();
220 220
221 221
222 syncPopup = new KPopupMenu(this); 222 syncPopup = new KPopupMenu(this);
223 223
224 syncManager = new KSyncManager((QWidget*)this, (KSyncInterface*)this, KSyncManager::PWMPI, PWMPrefs::instance(), syncPopup); 224 syncManager = new KSyncManager((QWidget*)this, (KSyncInterface*)this, KSyncManager::PWMPI, PWMPrefs::instance(), syncPopup);
225 syncManager->setBlockSave(false); 225 syncManager->setBlockSave(false);
226 226
227 connect ( syncPopup, SIGNAL( activated ( int ) ), syncManager, SLOT (slotSyncMenu( int ) ) ); 227 connect ( syncPopup, SIGNAL( activated ( int ) ), syncManager, SLOT (slotSyncMenu( int ) ) );
228 syncManager->fillSyncMenu(); 228 syncManager->fillSyncMenu();
229 229
230#endif 230#endif
231 filePopup = new KPopupMenu(this); 231 filePopup = new KPopupMenu(this);
232 importPopup = new KPopupMenu(filePopup); 232 importPopup = new KPopupMenu(filePopup);
233 exportPopup = new KPopupMenu(filePopup); 233 exportPopup = new KPopupMenu(filePopup);
234 managePopup = new KPopupMenu(this); 234 managePopup = new KPopupMenu(this);
235#ifdef CONFIG_KEYCARD 235#ifdef CONFIG_KEYCARD
236 chipcardPopup = new KPopupMenu(this); 236 chipcardPopup = new KPopupMenu(this);
237#endif // CONFIG_KEYCARD 237#endif // CONFIG_KEYCARD
238 viewPopup = new KPopupMenu(this); 238 viewPopup = new KPopupMenu(this);
239 optionsPopup = new KPopupMenu(this); 239 optionsPopup = new KPopupMenu(this);
240 240
241// "file" popup menu 241// "file" popup menu
242 filePopup->insertItem(QIconSet(picons->loadIcon("filenew", KIcon::Small)), 242 filePopup->insertItem(QIconSet(picons->loadIcon("filenew", KIcon::Small)),
243 i18n("&New"), this, 243 i18n("&New"), this,
244 SLOT(new_slot()), 0, BUTTON_POPUP_FILE_NEW); 244 SLOT(new_slot()), 0, BUTTON_POPUP_FILE_NEW);
245 filePopup->insertItem(QIconSet(picons->loadIcon("fileopen", KIcon::Small)), 245 filePopup->insertItem(QIconSet(picons->loadIcon("fileopen", KIcon::Small)),
246 i18n("&Open"), this, 246 i18n("&Open"), this,
247 SLOT(open_slot()), 0, BUTTON_POPUP_FILE_OPEN); 247 SLOT(open_slot()), 0, BUTTON_POPUP_FILE_OPEN);
248 filePopup->insertItem(QIconSet(picons->loadIcon("fileclose", KIcon::Small)), 248 filePopup->insertItem(QIconSet(picons->loadIcon("fileclose", KIcon::Small)),
249 i18n("&Close"), this, 249 i18n("&Close"), this,
250 SLOT(close_slot()), 0, BUTTON_POPUP_FILE_CLOSE); 250 SLOT(close_slot()), 0, BUTTON_POPUP_FILE_CLOSE);
251 filePopup->insertSeparator(); 251 filePopup->insertSeparator();
252 filePopup->insertItem(QIconSet(picons->loadIcon("pencil", KIcon::Small)),
253 i18n("&Add password"), this,
254 SLOT(addPwd_slot()), 0,
255 BUTTON_POPUP_MANAGE_ADD);
256 filePopup->insertSeparator();
252 filePopup->insertItem(QIconSet(picons->loadIcon("filesave", KIcon::Small)), 257 filePopup->insertItem(QIconSet(picons->loadIcon("filesave", KIcon::Small)),
253 i18n("&Save"), this, 258 i18n("&Save"), this,
254 SLOT(save_slot()), 0, BUTTON_POPUP_FILE_SAVE); 259 SLOT(save_slot()), 0, BUTTON_POPUP_FILE_SAVE);
255 filePopup->insertItem(QIconSet(picons->loadIcon("filesaveas", KIcon::Small)), 260 filePopup->insertItem(QIconSet(picons->loadIcon("filesaveas", KIcon::Small)),
256 i18n("Save &as..."), 261 i18n("Save &as..."),
257 this, SLOT(saveAs_slot()), 0, 262 this, SLOT(saveAs_slot()), 0,
258 BUTTON_POPUP_FILE_SAVEAS); 263 BUTTON_POPUP_FILE_SAVEAS);
259 filePopup->insertSeparator(); 264 filePopup->insertSeparator();
260 // "file/export" popup menu 265 // "file/export" popup menu
261 exportPopup->insertItem(i18n("&Text-file..."), this, 266 exportPopup->insertItem(i18n("&Text-file..."), this,
262 SLOT(exportToText()), 0, BUTTON_POPUP_EXPORT_TEXT); 267 SLOT(exportToText()), 0, BUTTON_POPUP_EXPORT_TEXT);
263 exportPopup->insertItem(i18n("&Gpasman / Kpasman ..."), this, 268 exportPopup->insertItem(i18n("&Gpasman / Kpasman ..."), this,
264 SLOT(exportToGpasman()), 0, BUTTON_POPUP_EXPORT_GPASMAN); 269 SLOT(exportToGpasman()), 0, BUTTON_POPUP_EXPORT_GPASMAN);
265 exportPopup->insertItem(i18n("&CSV (Comma Separated Value) ..."), this, 270 exportPopup->insertItem(i18n("&CSV (Comma Separated Value) ..."), this,
266 SLOT(exportToCsv()), 0, BUTTON_POPUP_EXPORT_CSV); 271 SLOT(exportToCsv()), 0, BUTTON_POPUP_EXPORT_CSV);
267#ifdef CONFIG_KWALLETIF 272#ifdef CONFIG_KWALLETIF
268 exportPopup->insertItem(i18n("&KWallet..."), this, 273 exportPopup->insertItem(i18n("&KWallet..."), this,
269 SLOT(exportToKWallet()), 0, BUTTON_POPUP_EXPORT_KWALLET); 274 SLOT(exportToKWallet()), 0, BUTTON_POPUP_EXPORT_KWALLET);
270#endif 275#endif
271 filePopup->insertItem(QIconSet(picons->loadIcon("fileexport", KIcon::Small)), 276 filePopup->insertItem(QIconSet(picons->loadIcon("fileexport", KIcon::Small)),
272 i18n("E&xport"), exportPopup, 277 i18n("E&xport"), exportPopup,
273 BUTTON_POPUP_FILE_EXPORT); 278 BUTTON_POPUP_FILE_EXPORT);
274 // "file/import" popup menu 279 // "file/import" popup menu
275 importPopup->insertItem(i18n("&Text-file..."), this, 280 importPopup->insertItem(i18n("&Text-file..."), this,
276 SLOT(importFromText()), 0, BUTTON_POPUP_IMPORT_TEXT); 281 SLOT(importFromText()), 0, BUTTON_POPUP_IMPORT_TEXT);
277 importPopup->insertItem(i18n("&Gpasman / Kpasman ..."), this, 282 importPopup->insertItem(i18n("&Gpasman / Kpasman ..."), this,
278 SLOT(importFromGpasman()), 0, BUTTON_POPUP_IMPORT_GPASMAN); 283 SLOT(importFromGpasman()), 0, BUTTON_POPUP_IMPORT_GPASMAN);
279 importPopup->insertItem(i18n("&CSV (Comma Separated Value) ..."), this, 284 importPopup->insertItem(i18n("&CSV (Comma Separated Value) ..."), this,
280 SLOT(importCsv()), 0, BUTTON_POPUP_IMPORT_CSV); 285 SLOT(importCsv()), 0, BUTTON_POPUP_IMPORT_CSV);
281#ifdef CONFIG_KWALLETIF 286#ifdef CONFIG_KWALLETIF
282 importPopup->insertItem(i18n("&KWallet..."), this, 287 importPopup->insertItem(i18n("&KWallet..."), this,
283 SLOT(importKWallet()), 0, BUTTON_POPUP_IMPORT_KWALLET); 288 SLOT(importKWallet()), 0, BUTTON_POPUP_IMPORT_KWALLET);
284#endif 289#endif
285 filePopup->insertItem(QIconSet(picons->loadIcon("fileimport", KIcon::Small)), 290 filePopup->insertItem(QIconSet(picons->loadIcon("fileimport", KIcon::Small)),
286 i18n("I&mport"), importPopup, 291 i18n("I&mport"), importPopup,
287 BUTTON_POPUP_FILE_IMPORT); 292 BUTTON_POPUP_FILE_IMPORT);
288 filePopup->insertSeparator(); 293 filePopup->insertSeparator();
294#if 0
289 filePopup->insertItem(QIconSet(picons->loadIcon("fileprint", KIcon::Small)), 295 filePopup->insertItem(QIconSet(picons->loadIcon("fileprint", KIcon::Small)),
290 i18n("&Print..."), this, 296 i18n("&Print..."), this,
291 SLOT(print_slot()), 0, BUTTON_POPUP_FILE_PRINT); 297 SLOT(print_slot()), 0, BUTTON_POPUP_FILE_PRINT);
292 filePopup->insertSeparator(); 298 filePopup->insertSeparator();
299#endif
293 filePopup->insertItem(QIconSet(picons->loadIcon("exit", KIcon::Small)), 300 filePopup->insertItem(QIconSet(picons->loadIcon("exit", KIcon::Small)),
294 i18n("&Quit"), this, 301 i18n("&Quit"), this,
295 SLOT(quitButton_slot()), 0, BUTTON_POPUP_FILE_QUIT); 302 SLOT(quitButton_slot()), 0, BUTTON_POPUP_FILE_QUIT);
296 menuBar()->insertItem(i18n("&File"), filePopup); 303 menuBar()->insertItem(i18n("&File"), filePopup);
297// "manage" popup menu 304// "manage" popup menu
298 managePopup->insertItem(QIconSet(picons->loadIcon("pencil", KIcon::Small)), 305 managePopup->insertItem(QIconSet(picons->loadIcon("pencil", KIcon::Small)),
299 i18n("&Add password"), this, 306 i18n("&Add password"), this,
300 SLOT(addPwd_slot()), 0, 307 SLOT(addPwd_slot()), 0,
301 BUTTON_POPUP_MANAGE_ADD); 308 BUTTON_POPUP_MANAGE_ADD);
309 managePopup->insertSeparator();
302 managePopup->insertItem(QIconSet(picons->loadIcon("edit", KIcon::Small)), 310 managePopup->insertItem(QIconSet(picons->loadIcon("edit", KIcon::Small)),
303 i18n("&Edit"), this, SLOT(editPwd_slot()), 0, 311 i18n("&Edit"), this, SLOT(editPwd_slot()), 0,
304 BUTTON_POPUP_MANAGE_EDIT); 312 BUTTON_POPUP_MANAGE_EDIT);
305 managePopup->insertItem(QIconSet(picons->loadIcon("editdelete", KIcon::Small)), 313 managePopup->insertItem(QIconSet(picons->loadIcon("editdelete", KIcon::Small)),
306 i18n("&Delete"), this, SLOT(deletePwd_slot()), 314 i18n("&Delete"), this, SLOT(deletePwd_slot()),
307 0, BUTTON_POPUP_MANAGE_DEL); 315 0, BUTTON_POPUP_MANAGE_DEL);
308 managePopup->insertSeparator(); 316 managePopup->insertSeparator();
309 managePopup->insertItem(QIconSet(picons->loadIcon("rotate", KIcon::Small)), 317 managePopup->insertItem(QIconSet(picons->loadIcon("rotate", KIcon::Small)),
310 i18n("Change &Master Password"), this, 318 i18n("Change &Master Password"), this,
311 SLOT(changeMasterPwd_slot()), 0, 319 SLOT(changeMasterPwd_slot()), 0,
312 BUTTON_POPUP_MANAGE_CHANGEMP); 320 BUTTON_POPUP_MANAGE_CHANGEMP);
313 menuBar()->insertItem(i18n("&Manage"), managePopup); 321 menuBar()->insertItem(i18n("&Manage"), managePopup);
314// "chipcard" popup menu 322// "chipcard" popup menu
315#ifdef CONFIG_KEYCARD 323#ifdef CONFIG_KEYCARD
316 chipcardPopup->insertItem(QIconSet(picons->loadIcon("filenew", KIcon::Small)), 324 chipcardPopup->insertItem(QIconSet(picons->loadIcon("filenew", KIcon::Small)),
317 i18n("&Generate new key-card"), this, 325 i18n("&Generate new key-card"), this,
318 SLOT(genNewCard_slot()), 0, 326 SLOT(genNewCard_slot()), 0,
319 BUTTON_POPUP_CHIPCARD_GENNEW); 327 BUTTON_POPUP_CHIPCARD_GENNEW);
320 chipcardPopup->insertItem(QIconSet(picons->loadIcon("editdelete", KIcon::Small)), 328 chipcardPopup->insertItem(QIconSet(picons->loadIcon("editdelete", KIcon::Small)),
321 i18n("&Erase key-card"), this, 329 i18n("&Erase key-card"), this,
322 SLOT(eraseCard_slot()), 0, 330 SLOT(eraseCard_slot()), 0,
323 BUTTON_POPUP_CHIPCARD_DEL); 331 BUTTON_POPUP_CHIPCARD_DEL);
324 chipcardPopup->insertItem(QIconSet(picons->loadIcon("", KIcon::Small)), 332 chipcardPopup->insertItem(QIconSet(picons->loadIcon("", KIcon::Small)),
325 i18n("Read card-&ID"), this, 333 i18n("Read card-&ID"), this,
326 SLOT(readCardId_slot()), 0, 334 SLOT(readCardId_slot()), 0,
327 BUTTON_POPUP_CHIPCARD_READID); 335 BUTTON_POPUP_CHIPCARD_READID);
328 chipcardPopup->insertSeparator(); 336 chipcardPopup->insertSeparator();
329 chipcardPopup->insertItem(QIconSet(picons->loadIcon("2rightarrow", KIcon::Small)), 337 chipcardPopup->insertItem(QIconSet(picons->loadIcon("2rightarrow", KIcon::Small)),
330 i18n("&Make card backup-image"), this, 338 i18n("&Make card backup-image"), this,
331 SLOT(makeCardBackup_slot()), 0, 339 SLOT(makeCardBackup_slot()), 0,
332 BUTTON_POPUP_CHIPCARD_SAVEBACKUP); 340 BUTTON_POPUP_CHIPCARD_SAVEBACKUP);
333 chipcardPopup->insertItem(QIconSet(picons->loadIcon("2leftarrow", KIcon::Small)), 341 chipcardPopup->insertItem(QIconSet(picons->loadIcon("2leftarrow", KIcon::Small)),
334 i18n("&Replay card backup-image"), this, 342 i18n("&Replay card backup-image"), this,
335 SLOT(replayCardBackup_slot()), 0, 343 SLOT(replayCardBackup_slot()), 0,
336 BUTTON_POPUP_CHIPCARD_REPLAYBACKUP); 344 BUTTON_POPUP_CHIPCARD_REPLAYBACKUP);
337 menuBar()->insertItem(i18n("&Chipcard manager"), chipcardPopup); 345 menuBar()->insertItem(i18n("&Chipcard manager"), chipcardPopup);
338#endif // CONFIG_KEYCARD 346#endif // CONFIG_KEYCARD
339// "view" popup menu 347// "view" popup menu
340 viewPopup->insertItem(QIconSet(picons->loadIcon("find", KIcon::Small)), 348 viewPopup->insertItem(QIconSet(picons->loadIcon("find", KIcon::Small)),
341 i18n("&Find"), this, 349 i18n("&Find"), this,
342 SLOT(find_slot()), 0, BUTTON_POPUP_VIEW_FIND); 350 SLOT(find_slot()), 0, BUTTON_POPUP_VIEW_FIND);
343 viewPopup->insertSeparator(); 351 viewPopup->insertSeparator();
344 viewPopup->insertItem(QIconSet(picons->loadIcon("halfencrypted", KIcon::Small)), 352 viewPopup->insertItem(QIconSet(picons->loadIcon("halfencrypted", KIcon::Small)),
345 i18n("&Lock all entries"), this, 353 i18n("&Lock all entries"), this,
346 SLOT(lockWnd_slot()), 0, 354 SLOT(lockWnd_slot()), 0,
347 BUTTON_POPUP_VIEW_LOCK); 355 BUTTON_POPUP_VIEW_LOCK);
348 viewPopup->insertItem(QIconSet(picons->loadIcon("encrypted", KIcon::Small)), 356 viewPopup->insertItem(QIconSet(picons->loadIcon("encrypted", KIcon::Small)),
349 i18n("&Deep-lock all entries"), this, 357 i18n("&Deep-lock all entries"), this,
350 SLOT(deepLockWnd_slot()), 0, 358 SLOT(deepLockWnd_slot()), 0,
351 BUTTON_POPUP_VIEW_DEEPLOCK); 359 BUTTON_POPUP_VIEW_DEEPLOCK);
352 viewPopup->insertItem(QIconSet(picons->loadIcon("decrypted", KIcon::Small)), 360 viewPopup->insertItem(QIconSet(picons->loadIcon("decrypted", KIcon::Small)),
353 i18n("&Unlock all entries"), this, 361 i18n("&Unlock all entries"), this,
354 SLOT(unlockWnd_slot()), 0, 362 SLOT(unlockWnd_slot()), 0,
355 BUTTON_POPUP_VIEW_UNLOCK); 363 BUTTON_POPUP_VIEW_UNLOCK);
356 menuBar()->insertItem(i18n("&View"), viewPopup); 364 menuBar()->insertItem(i18n("&View"), viewPopup);
357// "options" popup menu 365// "options" popup menu
358 optionsPopup->insertItem(QIconSet(picons->loadIcon("configure", KIcon::Small)), 366 optionsPopup->insertItem(QIconSet(picons->loadIcon("configure", KIcon::Small)),
359 i18n("&Configure..."), this, 367 i18n("&Configure..."), this,
360 SLOT(config_slot()),0, 368 SLOT(config_slot()),0,
361 BUTTON_POPUP_OPTIONS_CONFIG); 369 BUTTON_POPUP_OPTIONS_CONFIG);
362 menuBar()->insertItem(i18n("&Options"), optionsPopup); 370 menuBar()->insertItem(i18n("&Options"), optionsPopup);
363// "help" popup menu 371// "help" popup menu
364#ifndef PWM_EMBEDDED 372#ifndef PWM_EMBEDDED
365 helpPopup = helpMenu(QString::null, false); 373 helpPopup = helpMenu(QString::null, false);
366#else 374#else
367 optionsPopup->insertItem(QIconSet(picons->loadIcon("configure", KIcon::Small)), 375 optionsPopup->insertItem(QIconSet(picons->loadIcon("configure", KIcon::Small)),
368 i18n("C&ategories..."), this, 376 i18n("C&ategories..."), this,
369 SLOT(category_slot()),0, 377 SLOT(category_slot()),0,
370 BUTTON_POPUP_OPTIONS_CATEGORY); 378 BUTTON_POPUP_OPTIONS_CATEGORY);
371 379
372 380
373 menuBar()->insertItem(i18n("&Sync"), syncPopup); 381 menuBar()->insertItem(i18n("&Sync"), syncPopup);
374 382
375 383
376 384
377 385
378 386
379 helpPopup = new KPopupMenu(this); 387 helpPopup = new KPopupMenu(this);
380 388
381 389
382 helpPopup->insertItem(i18n("&License"), this, 390 helpPopup->insertItem(i18n("&License"), this,
383 SLOT(showLicense_slot()), 0, 391 SLOT(showLicense_slot()), 0,
384 BUTTON_POPUP_HELP_LICENSE); 392 BUTTON_POPUP_HELP_LICENSE);
385 393
386 helpPopup->insertItem(i18n("&Faq"), this, 394 helpPopup->insertItem(i18n("&Faq"), this,
387 SLOT(faq_slot()), 0, 395 SLOT(faq_slot()), 0,
388 BUTTON_POPUP_HELP_FAQ); 396 BUTTON_POPUP_HELP_FAQ);
389 397
390 helpPopup->insertItem(i18n("&About PwManager"), this, 398 helpPopup->insertItem(i18n("&About PwManager"), this,
391 SLOT(createAboutData_slot()), 0, 399 SLOT(createAboutData_slot()), 0,
392 BUTTON_POPUP_HELP_ABOUT); 400 BUTTON_POPUP_HELP_ABOUT);
393 401
394 helpPopup->insertItem(i18n("&Sync HowTo"), this, 402 helpPopup->insertItem(i18n("&Sync HowTo"), this,
395 SLOT(syncHowTo_slot()), 0, 403 SLOT(syncHowTo_slot()), 0,
396 BUTTON_POPUP_HELP_SYNC); 404 BUTTON_POPUP_HELP_SYNC);
397 405
398 helpPopup->insertItem(i18n("&What's New"), this, 406 helpPopup->insertItem(i18n("&What's New"), this,
399 SLOT(whatsnew_slot()), 0, 407 SLOT(whatsnew_slot()), 0,
400 BUTTON_POPUP_HELP_WHATSNEW); 408 BUTTON_POPUP_HELP_WHATSNEW);
401 409
402#endif 410#endif
403 menuBar()->insertItem(i18n("&Help"), helpPopup); 411 menuBar()->insertItem(i18n("&Help"), helpPopup);
404 412
405} 413}
406 414
407void PwM::initToolbar() 415void PwM::initToolbar()
408{ 416{
409 KIconLoader* picons; 417 KIconLoader* picons;
410#ifndef PWM_EMBEDDED 418#ifndef PWM_EMBEDDED
411 KIconLoader icons; 419 KIconLoader icons;
412 picons = &icons; 420 picons = &icons;
413#else 421#else
414 picons = KGlobal::iconLoader(); 422 picons = KGlobal::iconLoader();
415#endif 423#endif
416 424
417#ifdef PWM_EMBEDDED 425#if 0
418 if ( QApplication::desktop()->width() > 320 )
419#endif
420 {
421 toolBar()->insertButton(picons->loadIcon("filenew", KIcon::Toolbar), 426 toolBar()->insertButton(picons->loadIcon("filenew", KIcon::Toolbar),
422 BUTTON_TOOL_NEW, SIGNAL(clicked(int)), this, 427 BUTTON_TOOL_NEW, SIGNAL(clicked(int)), this,
423 SLOT(new_slot()), true, i18n("New")); 428 SLOT(new_slot()), true, i18n("New"));
429#endif
424 toolBar()->insertButton(picons->loadIcon("fileopen", KIcon::Toolbar), 430 toolBar()->insertButton(picons->loadIcon("fileopen", KIcon::Toolbar),
425 BUTTON_TOOL_OPEN, SIGNAL(clicked(int)), this, 431 BUTTON_TOOL_OPEN, SIGNAL(clicked(int)), this,
426 SLOT(open_slot()), true, i18n("Open")); 432 SLOT(open_slot()), true, i18n("Open"));
433 toolBar()->insertButton(picons->loadIcon("pencil", KIcon::Toolbar),
434 BUTTON_TOOL_ADD, SIGNAL(clicked(int)), this,
435 SLOT(addPwd_slot()), true,
436 i18n("Add password"));
437 toolBar()->insertSeparator();
438
439 toolBar()->insertButton(picons->loadIcon("find", KIcon::Toolbar),
440 BUTTON_TOOL_FIND, SIGNAL(clicked(int)), this,
441 SLOT(find_slot()), true, i18n("Find entry"));
427 toolBar()->insertSeparator(); 442 toolBar()->insertSeparator();
428 }
429 toolBar()->insertButton(picons->loadIcon("filesave", KIcon::Toolbar), 443 toolBar()->insertButton(picons->loadIcon("filesave", KIcon::Toolbar),
430 BUTTON_TOOL_SAVE, SIGNAL(clicked(int)), this, 444 BUTTON_TOOL_SAVE, SIGNAL(clicked(int)), this,
431 SLOT(save_slot()), true, i18n("Save")); 445 SLOT(save_slot()), true, i18n("Save"));
446#if 0
432 toolBar()->insertButton(picons->loadIcon("filesaveas", KIcon::Toolbar), 447 toolBar()->insertButton(picons->loadIcon("filesaveas", KIcon::Toolbar),
433 BUTTON_TOOL_SAVEAS, SIGNAL(clicked(int)), this, 448 BUTTON_TOOL_SAVEAS, SIGNAL(clicked(int)), this,
434 SLOT(saveAs_slot()), true, i18n("Save as")); 449 SLOT(saveAs_slot()), true, i18n("Save as"));
450#endif
451
452
453#if 0
435 toolBar()->insertButton(picons->loadIcon("fileprint", KIcon::Toolbar), 454 toolBar()->insertButton(picons->loadIcon("fileprint", KIcon::Toolbar),
436 BUTTON_TOOL_PRINT, SIGNAL(clicked(int)), this, 455 BUTTON_TOOL_PRINT, SIGNAL(clicked(int)), this,
437 SLOT(print_slot()), true, i18n("Print...")); 456 SLOT(print_slot()), true, i18n("Print..."));
457#endif
438 toolBar()->insertSeparator(); 458 toolBar()->insertSeparator();
439 toolBar()->insertButton(picons->loadIcon("pencil", KIcon::Toolbar),
440 BUTTON_TOOL_ADD, SIGNAL(clicked(int)), this,
441 SLOT(addPwd_slot()), true,
442 i18n("Add password"));
443 toolBar()->insertButton(picons->loadIcon("edit", KIcon::Toolbar), 459 toolBar()->insertButton(picons->loadIcon("edit", KIcon::Toolbar),
444 BUTTON_TOOL_EDIT, SIGNAL(clicked(int)), this, 460 BUTTON_TOOL_EDIT, SIGNAL(clicked(int)), this,
445 SLOT(editPwd_slot()), true, 461 SLOT(editPwd_slot()), true,
446 i18n("Edit password")); 462 i18n("Edit password"));
447 toolBar()->insertButton(picons->loadIcon("editdelete", KIcon::Toolbar), 463 toolBar()->insertButton(picons->loadIcon("editdelete", KIcon::Toolbar),
448 BUTTON_TOOL_DEL, SIGNAL(clicked(int)), this, 464 BUTTON_TOOL_DEL, SIGNAL(clicked(int)), this,
449 SLOT(deletePwd_slot()), true, 465 SLOT(deletePwd_slot()), true,
450 i18n("Delete password")); 466 i18n("Delete password"));
451 toolBar()->insertSeparator(); 467 toolBar()->insertSeparator();
452 toolBar()->insertButton(picons->loadIcon("find", KIcon::Toolbar),
453 BUTTON_TOOL_FIND, SIGNAL(clicked(int)), this,
454 SLOT(find_slot()), true, i18n("Find entry"));
455 toolBar()->insertSeparator();
456 toolBar()->insertButton(picons->loadIcon("halfencrypted", KIcon::Toolbar), 468 toolBar()->insertButton(picons->loadIcon("halfencrypted", KIcon::Toolbar),
457 BUTTON_TOOL_LOCK, SIGNAL(clicked(int)), this, 469 BUTTON_TOOL_LOCK, SIGNAL(clicked(int)), this,
458 SLOT(lockWnd_slot()), true, 470 SLOT(lockWnd_slot()), true,
459 i18n("Lock all entries")); 471 i18n("Lock all entries"));
460 toolBar()->insertButton(picons->loadIcon("encrypted", KIcon::Toolbar), 472 toolBar()->insertButton(picons->loadIcon("encrypted", KIcon::Toolbar),
461 BUTTON_TOOL_DEEPLOCK, SIGNAL(clicked(int)), this, 473 BUTTON_TOOL_DEEPLOCK, SIGNAL(clicked(int)), this,
462 SLOT(deepLockWnd_slot()), true, 474 SLOT(deepLockWnd_slot()), true,
463 i18n("Deep-Lock all entries")); 475 i18n("Deep-Lock all entries"));
464 toolBar()->insertButton(picons->loadIcon("decrypted", KIcon::Toolbar), 476 toolBar()->insertButton(picons->loadIcon("decrypted", KIcon::Toolbar),
465 BUTTON_TOOL_UNLOCK, SIGNAL(clicked(int)), this, 477 BUTTON_TOOL_UNLOCK, SIGNAL(clicked(int)), this,
466 SLOT(unlockWnd_slot()), true, 478 SLOT(unlockWnd_slot()), true,
467 i18n("Unlock all entries")); 479 i18n("Unlock all entries"));
468} 480}
469 481
470void PwM::initMetrics() 482void PwM::initMetrics()
471{ 483{
472 QSize s = conf()->confWndMainWndSize(); 484 QSize s = conf()->confWndMainWndSize();
473 if (s.isValid()) 485 if (s.isValid())
474 resize(s); 486 resize(s);
475 else 487 else
476 resize(DEFAULT_SIZE); 488 resize(DEFAULT_SIZE);
477} 489}
478 490
479void PwM::updateCaption() 491void PwM::updateCaption()
480{ 492{
481 setPlainCaption(curDoc()->getTitle() + " - " PROG_NAME " " PACKAGE_VER); 493 setPlainCaption(curDoc()->getTitle() + " - " PROG_NAME " " PACKAGE_VER);
482} 494}
483 495
484void PwM::hideEvent(QHideEvent *) 496void PwM::hideEvent(QHideEvent *)
485{ 497{
486 if (isMinimized()) { 498 if (isMinimized()) {
487 if (init->tray()) { 499 if (init->tray()) {
488 forceMinimizeToTray = true; 500 forceMinimizeToTray = true;
489 close(); 501 close();
490 } 502 }
491 int mmlock = conf()->confGlobMinimizeLock(); 503 int mmlock = conf()->confGlobMinimizeLock();
492 switch (mmlock) { 504 switch (mmlock) {
493 case 0: // don't lock anything 505 case 0: // don't lock anything
494 break; 506 break;
495 case 1: {// normal lock 507 case 1: {// normal lock
496 curDoc()->lockAll(true); 508 curDoc()->lockAll(true);
497 break; 509 break;
498 } case 2: {// deep-lock 510 } case 2: {// deep-lock
499 curDoc()->deepLock(); 511 curDoc()->deepLock();
500 break; 512 break;
501 } default: 513 } default:
502 WARN(); 514 WARN();
503 } 515 }
504 } 516 }
505} 517}
506 518
507void PwM::setVirgin(bool v) 519void PwM::setVirgin(bool v)
508{ 520{
509 if (virgin == v) 521 if (virgin == v)
510 return; 522 return;
511 virgin = v; 523 virgin = v;
512 filePopup->setItemEnabled(BUTTON_POPUP_FILE_SAVE, !v); 524 filePopup->setItemEnabled(BUTTON_POPUP_FILE_SAVE, !v);
513 filePopup->setItemEnabled(BUTTON_POPUP_FILE_SAVEAS, !v); 525 filePopup->setItemEnabled(BUTTON_POPUP_FILE_SAVEAS, !v);
514 filePopup->setItemEnabled(BUTTON_POPUP_FILE_EXPORT, !v); 526 filePopup->setItemEnabled(BUTTON_POPUP_FILE_EXPORT, !v);
515 filePopup->setItemEnabled(BUTTON_POPUP_FILE_PRINT, !v); 527 filePopup->setItemEnabled(BUTTON_POPUP_FILE_PRINT, !v);
516 managePopup->setItemEnabled(BUTTON_POPUP_MANAGE_EDIT, !v); 528 managePopup->setItemEnabled(BUTTON_POPUP_MANAGE_EDIT, !v);
517 managePopup->setItemEnabled(BUTTON_POPUP_MANAGE_DEL, !v); 529 managePopup->setItemEnabled(BUTTON_POPUP_MANAGE_DEL, !v);
518 managePopup->setItemEnabled(BUTTON_POPUP_MANAGE_CHANGEMP, !v); 530 managePopup->setItemEnabled(BUTTON_POPUP_MANAGE_CHANGEMP, !v);
519 viewPopup->setItemEnabled(BUTTON_POPUP_VIEW_LOCK, !v); 531 viewPopup->setItemEnabled(BUTTON_POPUP_VIEW_LOCK, !v);
520 viewPopup->setItemEnabled(BUTTON_POPUP_VIEW_DEEPLOCK, !v); 532 viewPopup->setItemEnabled(BUTTON_POPUP_VIEW_DEEPLOCK, !v);
521 viewPopup->setItemEnabled(BUTTON_POPUP_VIEW_UNLOCK, !v); 533 viewPopup->setItemEnabled(BUTTON_POPUP_VIEW_UNLOCK, !v);
522 viewPopup->setItemEnabled(BUTTON_POPUP_VIEW_FIND, !v); 534 viewPopup->setItemEnabled(BUTTON_POPUP_VIEW_FIND, !v);
523 toolBar()->setItemEnabled(BUTTON_TOOL_SAVE, !v); 535 toolBar()->setItemEnabled(BUTTON_TOOL_SAVE, !v);
524 toolBar()->setItemEnabled(BUTTON_TOOL_SAVEAS, !v); 536 toolBar()->setItemEnabled(BUTTON_TOOL_SAVEAS, !v);
525 toolBar()->setItemEnabled(BUTTON_TOOL_PRINT, !v); 537 toolBar()->setItemEnabled(BUTTON_TOOL_PRINT, !v);
526 toolBar()->setItemEnabled(BUTTON_TOOL_EDIT, !v); 538 toolBar()->setItemEnabled(BUTTON_TOOL_EDIT, !v);
527 toolBar()->setItemEnabled(BUTTON_TOOL_DEL, !v); 539 toolBar()->setItemEnabled(BUTTON_TOOL_DEL, !v);
528 toolBar()->setItemEnabled(BUTTON_TOOL_LOCK, !v); 540 toolBar()->setItemEnabled(BUTTON_TOOL_LOCK, !v);
529 toolBar()->setItemEnabled(BUTTON_TOOL_DEEPLOCK, !v); 541 toolBar()->setItemEnabled(BUTTON_TOOL_DEEPLOCK, !v);
530 toolBar()->setItemEnabled(BUTTON_TOOL_UNLOCK, !v); 542 toolBar()->setItemEnabled(BUTTON_TOOL_UNLOCK, !v);
531 toolBar()->setItemEnabled(BUTTON_TOOL_FIND, !v); 543 toolBar()->setItemEnabled(BUTTON_TOOL_FIND, !v);
532} 544}
533 545
534void PwM::new_slot() 546void PwM::new_slot()
535{ 547{
536 init->createMainWnd(); 548 init->createMainWnd();
537} 549}
538 550
539//US ENH 551//US ENH
540void PwM::open_slot() 552void PwM::open_slot()
541{ 553{
542 open_slot(""); 554 open_slot("");
543} 555}
544 556
545void PwM::open_slot(QString fn) 557void PwM::open_slot(QString fn)
546{ 558{
547 openDoc(fn); 559 openDoc(fn);
548} 560}
549 561
550PwMDoc * PwM::openDoc(QString filename, bool openDeepLocked) 562PwMDoc * PwM::openDoc(QString filename, bool openDeepLocked)
551{ 563{
552 if (!isVirgin()) { 564 if (!isVirgin()) {
553 // open the document in a new window. 565 // open the document in a new window.
554 PwM *newInstance = init->createMainWnd(); 566 PwM *newInstance = init->createMainWnd();
555 PwMDoc *newDoc = newInstance->openDoc(filename, openDeepLocked); 567 PwMDoc *newDoc = newInstance->openDoc(filename, openDeepLocked);
556 if (!newDoc) { 568 if (!newDoc) {
557 newInstance->setForceQuit(true); 569 newInstance->setForceQuit(true);
558 delete_and_null(newInstance); 570 delete_and_null(newInstance);
559 } 571 }
560 return newDoc; 572 return newDoc;
561 } 573 }
562 574
563 if (!curDoc()->openDocUi(curDoc(), filename, openDeepLocked)) 575 if (!curDoc()->openDocUi(curDoc(), filename, openDeepLocked))
564 return 0; 576 return 0;
565 showStatMsg(i18n("Successfully opened file.")); 577 showStatMsg(i18n("Successfully opened file."));
566 updateCaption(); 578 updateCaption();
567 setVirgin(false); 579 setVirgin(false);
568 return curDoc(); 580 return curDoc();
569} 581}
570 582
571PwMView * PwM::makeNewListView(PwMDoc *doc) 583PwMView * PwM::makeNewListView(PwMDoc *doc)
572{ 584{
573 PwMView *ret = new PwMView(this, this, doc); 585 PwMView *ret = new PwMView(this, this, doc);
574 ret->setFont(conf()->confGlobEntryFont()); 586 ret->setFont(conf()->confGlobEntryFont());
575 ret->show(); 587 ret->show();
576 return ret; 588 return ret;
577} 589}
578 590
579void PwM::close_slot() 591void PwM::close_slot()
580{ 592{
581 close(); 593 close();
582} 594}
583 595
584void PwM::quitButton_slot() 596void PwM::quitButton_slot()
585{ 597{
586 init->shutdownApp(0); 598 init->shutdownApp(0);
587} 599}
588 600
589void PwM::save_slot() 601void PwM::save_slot()
590{ 602{
591 save(); 603 save();
592} 604}
593 605
594bool PwM::save() 606bool PwM::save()
595{ 607{
596 if (!curDoc()->saveDocUi(curDoc())) 608 if (!curDoc()->saveDocUi(curDoc()))
597 return false; 609 return false;
598 showStatMsg(i18n("Successfully saved data.")); 610 showStatMsg(i18n("Successfully saved data."));
599 updateCaption(); 611 updateCaption();
600 return true; 612 return true;
601} 613}
602 614
603void PwM::saveAs_slot() 615void PwM::saveAs_slot()
604{ 616{
605 saveAs(); 617 saveAs();
606} 618}
607 619
608bool PwM::saveAs() 620bool PwM::saveAs()
609{ 621{
610 if (!curDoc()->saveAsDocUi(curDoc())) 622 if (!curDoc()->saveAsDocUi(curDoc()))
611 return false; 623 return false;
612 showStatMsg(i18n("Successfully saved data.")); 624 showStatMsg(i18n("Successfully saved data."));
613 updateCaption(); 625 updateCaption();
614 return true; 626 return true;
615} 627}
616 628
617//US ENH : changed code to run with older MOC 629//US ENH : changed code to run with older MOC
618void PwM::addPwd_slot() 630void PwM::addPwd_slot()
619{ 631{
620 addPwd_slot1(0, 0); 632 addPwd_slot1(0, 0);
621} 633}
622 634
623void PwM::addPwd_slot1(QString *pw, PwMDoc *_doc) 635void PwM::addPwd_slot1(QString *pw, PwMDoc *_doc)
624{ 636{
625 PwMDoc *doc; 637 PwMDoc *doc;
626 if (_doc) { 638 if (_doc) {
627 doc = _doc; 639 doc = _doc;
628 } else { 640 } else {
629 doc = curDoc(); 641 doc = curDoc();
630 } 642 }
631 PWM_ASSERT(doc); 643 PWM_ASSERT(doc);
632 doc->timer()->getLock(DocTimer::id_autoLockTimer); 644 doc->timer()->getLock(DocTimer::id_autoLockTimer);
633#ifndef PWM_EMBEDDED 645#ifndef PWM_EMBEDDED
634 AddEntryWndImpl w; 646 AddEntryWndImpl w;
635#else 647#else
636 AddEntryWndImpl w(doc, this, "addentrywndimpl"); 648 AddEntryWndImpl w(doc, this, "addentrywndimpl");
637#endif 649#endif
638 650 w.setCaption( i18n ("Add new password") );
639 vector<string> catList; 651 vector<string> catList;
640 doc->getCategoryList(&catList); 652 doc->getCategoryList(&catList);
641 unsigned i, size = catList.size(); 653 unsigned i, size = catList.size();
642 for (i = 0; i < size; ++i) { 654 for (i = 0; i < size; ++i) {
643 w.addCategory(catList[i].c_str()); 655 w.addCategory(catList[i].c_str());
644 } 656 }
645 w.setCurrCategory(view->getCurrentCategory()); 657 w.setCurrCategory(view->getCurrentCategory());
646 if (pw) 658 if (pw)
647 w.pwLineEdit->setText(*pw); 659 w.pwLineEdit->setText(*pw);
648 660
649 tryAgain: 661 tryAgain:
650 if (w.exec() == 1) 662 if (w.exec() == 1)
651 { 663 {
652 PwMDataItem d; 664 PwMDataItem d;
653 665
654 //US BUG: to initialize all values of curEntr with meaningfulldata, 666 //US BUG: to initialize all values of curEntr with meaningfulldata,
655 // we call clear on it. Reason: Metadata will be uninitialized otherwise. 667 // we call clear on it. Reason: Metadata will be uninitialized otherwise.
656 // another option would be to create a constructor for PwMDataItem 668 // another option would be to create a constructor for PwMDataItem
657 d.clear(true); 669 d.clear(true);
658 670
659 d.desc = w.getDescription().latin1(); 671 d.desc = w.getDescription().latin1();
660 d.name = w.getUsername().latin1(); 672 d.name = w.getUsername().latin1();
661 d.pw = w.getPassword().latin1(); 673 d.pw = w.getPassword().latin1();
662 d.comment = w.getComment().latin1(); 674 d.comment = w.getComment().latin1();
663 d.url = w.getUrl().latin1(); 675 d.url = w.getUrl().latin1();
664 d.launcher = w.getLauncher().latin1(); 676 d.launcher = w.getLauncher().latin1();
665 PwMerror ret = doc->addEntry(w.getCategory(), &d); 677 PwMerror ret = doc->addEntry(w.getCategory(), &d);
666 if (ret == e_entryExists) { 678 if (ret == e_entryExists) {
667 KMessageBox::error(this, 679 KMessageBox::error(this,
668 i18n 680 i18n
669 ("An entry with this \"Description\",\n" 681 ("An entry with this \"Description\",\n"
670 "does already exist.\n" 682 "does already exist.\n"
671 "Please select another description."), 683 "Please select another description."),
672 i18n("entry already exists.")); 684 i18n("entry already exists."));
673 goto tryAgain; 685 goto tryAgain;
674 } else if (ret == e_maxAllowedEntr) { 686 } else if (ret == e_maxAllowedEntr) {
675 KMessageBox::error(this, i18n("The maximum possible number of\nentries" 687 KMessageBox::error(this, i18n("The maximum possible number of\nentries"
676 "has been reached.\nYou can't add more entries."), 688 "has been reached.\nYou can't add more entries."),
677 i18n("maximum number of entries")); 689 i18n("maximum number of entries"));
678 doc->timer()->putLock(DocTimer::id_autoLockTimer); 690 doc->timer()->putLock(DocTimer::id_autoLockTimer);
679 return; 691 return;
680 } 692 }
681 } 693 }
682 setVirgin(false); 694 setVirgin(false);
683 doc->timer()->putLock(DocTimer::id_autoLockTimer); 695 doc->timer()->putLock(DocTimer::id_autoLockTimer);
684} 696}
685 697
686//US ENH : changed code to run with older MOC 698//US ENH : changed code to run with older MOC
687void PwM::editPwd_slot() 699void PwM::editPwd_slot()
688{ 700{
689 editPwd_slot3(0,0,0); 701 editPwd_slot3(0,0,0);
690} 702}
691 703
692void PwM::editPwd_slot1(const QString *category) 704void PwM::editPwd_slot1(const QString *category)
693{ 705{
694 editPwd_slot3(category, 0, 0); 706 editPwd_slot3(category, 0, 0);
695} 707}
696 708
697void PwM::editPwd_slot3(const QString *category, const int *index, 709void PwM::editPwd_slot3(const QString *category, const int *index,
698 PwMDoc *_doc) 710 PwMDoc *_doc)
699{ 711{
700 PwMDoc *doc; 712 PwMDoc *doc;
701 if (_doc) { 713 if (_doc) {
702 doc = _doc; 714 doc = _doc;
703 } else { 715 } else {
704 doc = curDoc(); 716 doc = curDoc();
705 } 717 }
706 PWM_ASSERT(doc); 718 PWM_ASSERT(doc);
707 if (doc->isDocEmpty()) 719 if (doc->isDocEmpty())
708 return; 720 return;
709 if (doc->isDeepLocked()) 721 if (doc->isDeepLocked())
710 return; 722 return;
711 doc->timer()->getLock(DocTimer::id_autoLockTimer); 723 doc->timer()->getLock(DocTimer::id_autoLockTimer);
712 unsigned int curEntryIndex; 724 unsigned int curEntryIndex;
713 if (index) { 725 if (index) {
714 curEntryIndex = *index; 726 curEntryIndex = *index;
715 } else { 727 } else {
716 if (!(view->getCurEntryIndex(&curEntryIndex))) { 728 if (!(view->getCurEntryIndex(&curEntryIndex))) {
717 printDebug("couldn't get index. Maybe we have a binary entry here."); 729 printDebug("couldn't get index. Maybe we have a binary entry here.");
718 doc->timer()->putLock(DocTimer::id_autoLockTimer); 730 doc->timer()->putLock(DocTimer::id_autoLockTimer);
719 return; 731 return;
720 } 732 }
721 } 733 }
722 QString curCategory; 734 QString curCategory;
723 if (category) { 735 if (category) {
724 curCategory = *category; 736 curCategory = *category;
725 } else { 737 } else {
726 curCategory = view->getCurrentCategory(); 738 curCategory = view->getCurrentCategory();
727 } 739 }
728 PwMDataItem currItem; 740 PwMDataItem currItem;
729 if (!doc->getEntry(curCategory, curEntryIndex, &currItem, true)) { 741 if (!doc->getEntry(curCategory, curEntryIndex, &currItem, true)) {
730 doc->timer()->putLock(DocTimer::id_autoLockTimer); 742 doc->timer()->putLock(DocTimer::id_autoLockTimer);
731 return; 743 return;
732 } 744 }
733 BUG_ON(currItem.binary); 745 BUG_ON(currItem.binary);
734 746
735 AddEntryWndImpl w(doc); 747 AddEntryWndImpl w(doc);
748 w.setCaption( i18n ("Edit password") );
736 vector<string> catList; 749 vector<string> catList;
737 doc->getCategoryList(&catList); 750 doc->getCategoryList(&catList);
738 unsigned i, size = catList.size(); 751 unsigned i, size = catList.size();
739 for (i = 0; i < size; ++i) { 752 for (i = 0; i < size; ++i) {
740 w.addCategory(catList[i].c_str()); 753 w.addCategory(catList[i].c_str());
741 } 754 }
742 w.setCurrCategory(curCategory); 755 w.setCurrCategory(curCategory);
743 w.setDescription(currItem.desc.c_str()); 756 w.setDescription(currItem.desc.c_str());
744 w.setUsername(currItem.name.c_str()); 757 w.setUsername(currItem.name.c_str());
745 w.setPassword(currItem.pw.c_str()); 758 w.setPassword(currItem.pw.c_str());
746 w.setUrl(currItem.url.c_str()); 759 w.setUrl(currItem.url.c_str());
747 w.setLauncher(currItem.launcher.c_str()); 760 w.setLauncher(currItem.launcher.c_str());
748 w.setComment(currItem.comment.c_str()); 761 w.setComment(currItem.comment.c_str());
749 if (w.exec() == 1) { 762 if (w.exec() == 1) {
750 currItem.desc = w.getDescription().latin1(); 763 currItem.desc = w.getDescription().latin1();
751 currItem.name = w.getUsername().latin1(); 764 currItem.name = w.getUsername().latin1();
752 currItem.pw = w.getPassword().latin1(); 765 currItem.pw = w.getPassword().latin1();
753 currItem.comment = w.getComment().latin1(); 766 currItem.comment = w.getComment().latin1();
754 currItem.url = w.getUrl().latin1(); 767 currItem.url = w.getUrl().latin1();
755 currItem.launcher = w.getLauncher().latin1(); 768 currItem.launcher = w.getLauncher().latin1();
756 if (!doc->editEntry(curCategory, w.getCategory(), 769 if (!doc->editEntry(curCategory, w.getCategory(),
757 curEntryIndex, &currItem)) { 770 curEntryIndex, &currItem)) {
758 KMessageBox::error(this, 771 KMessageBox::error(this,
759 i18n("Couldn't edit the entry.\n" 772 i18n("Couldn't edit the entry.\n"
760 "Maybe you changed the category and\n" 773 "Maybe you changed the category and\n"
761 "this entry is already present\nin the new " 774 "this entry is already present\nin the new "
762 "category?"), 775 "category?"),
763 i18n("couldn't edit entry.")); 776 i18n("couldn't edit entry."));
764 doc->timer()->putLock(DocTimer::id_autoLockTimer); 777 doc->timer()->putLock(DocTimer::id_autoLockTimer);
765 return; 778 return;
766 } 779 }
767 } 780 }
768 doc->timer()->putLock(DocTimer::id_autoLockTimer); 781 doc->timer()->putLock(DocTimer::id_autoLockTimer);
769} 782}
770 783
771void PwM::deletePwd_slot() 784void PwM::deletePwd_slot()
772{ 785{
773 PWM_ASSERT(curDoc()); 786 PWM_ASSERT(curDoc());
774 if (curDoc()->isDocEmpty()) 787 if (curDoc()->isDocEmpty())
775 return; 788 return;
776 if (curDoc()->isDeepLocked()) 789 if (curDoc()->isDeepLocked())
777 return; 790 return;
778 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer); 791 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer);
779 unsigned int curEntryIndex = 0; 792 unsigned int curEntryIndex = 0;
780 if (!(view->getCurEntryIndex(&curEntryIndex))) { 793 if (!(view->getCurEntryIndex(&curEntryIndex))) {
781 printDebug("couldn't get index"); 794 printDebug("couldn't get index");
782 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 795 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
783 return; 796 return;
784 } 797 }
785 798
786 PwMDataItem currItem; 799 PwMDataItem currItem;
787 QString curCategory = view->getCurrentCategory(); 800 QString curCategory = view->getCurrentCategory();
788 if (!curDoc()->getEntry(curCategory, curEntryIndex, &currItem)) { 801 if (!curDoc()->getEntry(curCategory, curEntryIndex, &currItem)) {
789 printDebug("couldn't get entry"); 802 printDebug("couldn't get entry");
790 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 803 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
791 return; 804 return;
792 } 805 }
793 if (KMessageBox:: 806 if (KMessageBox::
794 questionYesNo(this, 807 questionYesNo(this,
795 i18n 808 i18n
796 ("Do you really want to delete\nthe selected entry") + 809 ("Do you really want to delete\nthe selected entry") +
797 " \n\"" + QString(currItem.desc.c_str()) 810 " \n\"" + QString(currItem.desc.c_str())
798 + "\" ?", i18n("delete?")) 811 + "\" ?", i18n("delete?"))
799 == KMessageBox::Yes) { 812 == KMessageBox::Yes) {
800 813
801 curDoc()->delEntry(curCategory, curEntryIndex); 814 curDoc()->delEntry(curCategory, curEntryIndex);
802 } 815 }
803 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 816 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
804} 817}
805 818
806void PwM::changeMasterPwd_slot() 819void PwM::changeMasterPwd_slot()
807{ 820{
808 PWM_ASSERT(curDoc()); 821 PWM_ASSERT(curDoc());
809 curDoc()->changeCurrentPw(); 822 curDoc()->changeCurrentPw();
810} 823}
811 824
812void PwM::lockWnd_slot() 825void PwM::lockWnd_slot()
813{ 826{
814 PWM_ASSERT(curDoc()); 827 PWM_ASSERT(curDoc());
815 curDoc()->lockAll(true); 828 curDoc()->lockAll(true);
816} 829}
817 830
818void PwM::deepLockWnd_slot() 831void PwM::deepLockWnd_slot()
819{ 832{
820 PWM_ASSERT(curDoc()); 833 PWM_ASSERT(curDoc());
821 curDoc()->deepLock(); 834 curDoc()->deepLock();
822} 835}
823 836
824void PwM::unlockWnd_slot() 837void PwM::unlockWnd_slot()
825{ 838{
826 PWM_ASSERT(curDoc()); 839 PWM_ASSERT(curDoc());
827 curDoc()->lockAll(false); 840 curDoc()->lockAll(false);
828} 841}
829 842
830void PwM::config_slot() 843void PwM::config_slot()
831{ 844{
832 int oldStyle = conf()->confWndMainViewStyle(); 845 int oldStyle = conf()->confWndMainViewStyle();
833#ifdef PWM_EMBEDDED 846#ifdef PWM_EMBEDDED
834 KCMultiDialog* ConfigureDialog = new KCMultiDialog( "PIM", this ,"pwmconfigdialog", true ); 847 KCMultiDialog* ConfigureDialog = new KCMultiDialog( "PIM", this ,"pwmconfigdialog", true );
835 848
836 KCMPwmConfig* pwmcfg = new KCMPwmConfig( ConfigureDialog->getNewVBoxPage(i18n( "PwManager")) , "KCMPwmConfig" ); 849 KCMPwmConfig* pwmcfg = new KCMPwmConfig( ConfigureDialog->getNewVBoxPage(i18n( "PwManager")) , "KCMPwmConfig" );
837 ConfigureDialog->addModule(pwmcfg ); 850 ConfigureDialog->addModule(pwmcfg );
838 851
839 KCMKdePimConfig* kdelibcfg = new KCMKdePimConfig( ConfigureDialog->getNewVBoxPage(i18n( "Global")) , "KCMKdeLibConfig" ); 852 KCMKdePimConfig* kdelibcfg = new KCMKdePimConfig( ConfigureDialog->getNewVBoxPage(i18n( "Global")) , "KCMKdeLibConfig" );
840 ConfigureDialog->addModule(kdelibcfg ); 853 ConfigureDialog->addModule(kdelibcfg );
841 854
842#ifndef DESKTOP_VERSION 855#ifndef DESKTOP_VERSION
843 ConfigureDialog->showMaximized(); 856 ConfigureDialog->showMaximized();
844#endif 857#endif
845 if ( ConfigureDialog->exec() ) 858 if ( ConfigureDialog->exec() )
846 KMessageBox::information( this, i18n("Some changes are only\neffective after a restart!\n") ); 859 KMessageBox::information( this, i18n("Some changes are only\neffective after a restart!\n") );
847 delete ConfigureDialog; 860 delete ConfigureDialog;
848 861
849#else //PWM_EMBEDDED 862#else //PWM_EMBEDDED
850 // display the configuration window (modal mode) 863 // display the configuration window (modal mode)
851 if (!conf()->showConfWnd(this)) 864 if (!conf()->showConfWnd(this))
852 return; 865 return;
853#endif 866#endif
854 867
855 int newStyle = conf()->confWndMainViewStyle(); 868 int newStyle = conf()->confWndMainViewStyle();
856 // reinitialize tray 869 // reinitialize tray
857 init->initTray(); 870 init->initTray();
858 // reinitialize KWallet emulation 871 // reinitialize KWallet emulation
859 init->initKWalletEmu(); 872 init->initKWalletEmu();
860 873
861 PwMDocList *_dl = PwMDoc::getOpenDocList(); 874 PwMDocList *_dl = PwMDoc::getOpenDocList();
862 const vector<PwMDocList::listItem> *dl = _dl->getList(); 875 const vector<PwMDocList::listItem> *dl = _dl->getList();
863 vector<PwMDocList::listItem>::const_iterator i = dl->begin(), 876 vector<PwMDocList::listItem>::const_iterator i = dl->begin(),
864 end = dl->end(); 877 end = dl->end();
865 PwMDoc *doc; 878 PwMDoc *doc;
866 while (i != end) { 879 while (i != end) {
867 doc = (*i).doc; 880 doc = (*i).doc;
868 // unlock-without-mpw timeout 881 // unlock-without-mpw timeout
869 doc->timer()->start(DocTimer::id_mpwTimer); 882 doc->timer()->start(DocTimer::id_mpwTimer);
870 // auto-lock timeout 883 // auto-lock timeout
871 doc->timer()->start(DocTimer::id_autoLockTimer); 884 doc->timer()->start(DocTimer::id_autoLockTimer);
872 ++i; 885 ++i;
873 } 886 }
874 887
875 const QValueList<PwM *> *ml = init->mainWndList(); 888 const QValueList<PwM *> *ml = init->mainWndList();
876#ifndef PWM_EMBEDDED 889#ifndef PWM_EMBEDDED
877 QValueList<PwM *>::const_iterator i2 = ml->begin(), 890 QValueList<PwM *>::const_iterator i2 = ml->begin(),
878 end2 = ml->end(); 891 end2 = ml->end();
879#else 892#else
880 QValueList<PwM *>::ConstIterator i2 = ml->begin(), 893 QValueList<PwM *>::ConstIterator i2 = ml->begin(),
881 end2 = ml->end(); 894 end2 = ml->end();
882#endif 895#endif
883 PwM *pwm; 896 PwM *pwm;
884 while (i2 != end2) { 897 while (i2 != end2) {
885 pwm = *i2; 898 pwm = *i2;
886 // reinitialize the window style. 899 // reinitialize the window style.
887 if (oldStyle != newStyle) 900 if (oldStyle != newStyle)
888 pwm->curView()->initStyle(newStyle); 901 pwm->curView()->initStyle(newStyle);
889 // set the new font 902 // set the new font
890 pwm->curView()->setFont(conf()->confGlobEntryFont()); 903 pwm->curView()->setFont(conf()->confGlobEntryFont());
891 ++i2; 904 ++i2;
892 } 905 }
893} 906}
894 907
895void PwM::activateMpButton(bool activate) 908void PwM::activateMpButton(bool activate)
896{ 909{
897 managePopup->setItemEnabled(BUTTON_POPUP_MANAGE_CHANGEMP, activate); 910 managePopup->setItemEnabled(BUTTON_POPUP_MANAGE_CHANGEMP, activate);
898} 911}
899 912
900void PwM::closeEvent(QCloseEvent *e) 913void PwM::closeEvent(QCloseEvent *e)
901{ 914{
902 //qDebug("PwM::closeEvent "); 915 //qDebug("PwM::closeEvent ");
903 emit closed( this ); 916 emit closed( this );
904 return; 917 return;
905 e->accept(); 918 e->accept();
906} 919}
907 920
908void PwM::docClosed(PwMDoc *doc) 921void PwM::docClosed(PwMDoc *doc)
909{ 922{
910 //qDebug("PwM::docClosed "); 923 //qDebug("PwM::docClosed ");
911 PARAM_UNUSED(doc); 924 PARAM_UNUSED(doc);
912 PWM_ASSERT(doc == curDoc()); 925 PWM_ASSERT(doc == curDoc());
913 close(); 926 close();
914} 927}
915 928
916void PwM::find_slot() 929void PwM::find_slot()
917{ 930{
918 PWM_ASSERT(curDoc()); 931 PWM_ASSERT(curDoc());
919 if (curDoc()->isDocEmpty()) 932 if (curDoc()->isDocEmpty())
920 return; 933 return;
921 if (curDoc()->isDeepLocked()) 934 if (curDoc()->isDeepLocked())
922 return; 935 return;
923 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer); 936 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer);
924 FindWndImpl findWnd(view); 937 FindWndImpl findWnd(view);
925 findWnd.exec(); 938 findWnd.exec();
926 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 939 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
927} 940}
928 941
929void PwM::exportToText() 942void PwM::exportToText()
930{ 943{
931 PWM_ASSERT(curDoc()); 944 PWM_ASSERT(curDoc());
932 if (curDoc()->isDocEmpty()) { 945 if (curDoc()->isDocEmpty()) {
933 KMessageBox::information(this, 946 KMessageBox::information(this,
934 i18n 947 i18n
935 ("Sorry, there's nothing to export.\n" 948 ("Sorry, there's nothing to export.\n"
936 "Please first add some passwords."), 949 "Please first add some passwords."),
937 i18n("nothing to do")); 950 i18n("nothing to do"));
938 return; 951 return;
939 } 952 }
940 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer); 953 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer);
941 QString fn(KFileDialog::getSaveFileName(QString::null, 954 QString fn(KFileDialog::getSaveFileName(QString::null,
942 i18n("*|plain-text file"), 955 i18n("*|plain-text file"),
943 this)); 956 this));
944 if (fn == "") { 957 if (fn == "") {
945 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 958 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
946 return; 959 return;
947 } 960 }
948 961
949 PwMerror ret = curDoc()->exportToText(&fn); 962 PwMerror ret = curDoc()->exportToText(&fn);
950 if (ret != e_success) { 963 if (ret != e_success) {
951 KMessageBox::error(this, 964 KMessageBox::error(this,
952 i18n("Error: Couldn't write to file.\n" 965 i18n("Error: Couldn't write to file.\n"
953 "Please check if you have permission to write\n" 966 "Please check if you have permission to write\n"
954 "to the file in that directory."), 967 "to the file in that directory."),
955 i18n("error while writing")); 968 i18n("error while writing"));
956 } else 969 } else
957 showStatMsg(i18n("Successfully exported data.")); 970 showStatMsg(i18n("Successfully exported data."));
958 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 971 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
959} 972}
960 973
961bool PwM::importFromText() 974bool PwM::importFromText()
962{ 975{
963 if (!isVirgin()) { 976 if (!isVirgin()) {
964 if (KMessageBox::questionYesNo(this, 977 if (KMessageBox::questionYesNo(this,
965 i18n("Do you want to import the data\n" 978 i18n("Do you want to import the data\n"
966 "into the current document? (If you\n" 979 "into the current document? (If you\n"
967 "select \"no\", a new document will be\n" 980 "select \"no\", a new document will be\n"
968 "opened.)"), 981 "opened.)"),
969 i18n("import into this document?")) 982 i18n("import into this document?"))
970 == KMessageBox::No) { 983 == KMessageBox::No) {
971 // import the data to a new window. 984 // import the data to a new window.
972 PwM *newInstance = init->createMainWnd(); 985 PwM *newInstance = init->createMainWnd();
973 bool ok = newInstance->importFromText(); 986 bool ok = newInstance->importFromText();
974 if (!ok) { 987 if (!ok) {
975 newInstance->setForceQuit(true); 988 newInstance->setForceQuit(true);
976 delete_and_null(newInstance); 989 delete_and_null(newInstance);
977 } 990 }
978 return ok; 991 return ok;
979 } 992 }
980 } 993 }
981 994
982 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer); 995 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer);
983 PwMerror ret; 996 PwMerror ret;
984 QString path(KFileDialog::getOpenFileName(QString::null, 997 QString path(KFileDialog::getOpenFileName(QString::null,
985 i18n("*|PWM-exported text file"), 998 i18n("*|PWM-exported text file"),
986 this)); 999 this));
987 if (path == "") 1000 if (path == "")
988 goto cancelImport; 1001 goto cancelImport;
989 1002
990 ret = curDoc()->importFromText(&path, 0); 1003 ret = curDoc()->importFromText(&path, 0);
991 if (ret == e_fileFormat) { 1004 if (ret == e_fileFormat) {
992 KMessageBox::error(this, 1005 KMessageBox::error(this,
993 i18n("Could not read file-format.\n" 1006 i18n("Could not read file-format.\n"
994 "This seems to be _not_ a valid file\n" 1007 "This seems to be _not_ a valid file\n"
995 "exported by PwM."), 1008 "exported by PwM."),
996 i18n("invalid file-format")); 1009 i18n("invalid file-format"));
997 goto cancelImport; 1010 goto cancelImport;
998 } else if (ret == e_invalidArg) { 1011 } else if (ret == e_invalidArg) {
999 BUG(); 1012 BUG();
1000 goto cancelImport; 1013 goto cancelImport;
1001 } else if (ret != e_success) { 1014 } else if (ret != e_success) {
1002 KMessageBox::error(this, 1015 KMessageBox::error(this,
1003 i18n("Could not import file!\n" 1016 i18n("Could not import file!\n"
1004 "Do you have permission to read this file?\n" 1017 "Do you have permission to read this file?\n"
1005 "Do you have enough free memory?"), 1018 "Do you have enough free memory?"),
1006 i18n("import failed")); 1019 i18n("import failed"));
1007 goto cancelImport; 1020 goto cancelImport;
1008 } 1021 }
1009 setVirgin(false); 1022 setVirgin(false);
1010 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 1023 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
1011 return true; 1024 return true;
1012 1025
1013cancelImport: 1026cancelImport:
1014 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 1027 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
1015 return false; 1028 return false;
1016} 1029}
1017 1030
1018void PwM::exportToGpasman() 1031void PwM::exportToGpasman()
1019{ 1032{
1020 PWM_ASSERT(curDoc()); 1033 PWM_ASSERT(curDoc());
1021 if (curDoc()->isDocEmpty()) { 1034 if (curDoc()->isDocEmpty()) {
1022 KMessageBox::information(this, 1035 KMessageBox::information(this,
1023 i18n 1036 i18n
1024 ("Sorry, there's nothing to export.\n" 1037 ("Sorry, there's nothing to export.\n"
1025 "Please first add some passwords."), 1038 "Please first add some passwords."),
1026 i18n("nothing to do")); 1039 i18n("nothing to do"));
1027 return; 1040 return;
1028 } 1041 }
1029 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer); 1042 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer);
1030 QString fn(KFileDialog::getSaveFileName(QString::null, 1043 QString fn(KFileDialog::getSaveFileName(QString::null,
1031 i18n("*|Gpasman or Kpasman file"), 1044 i18n("*|Gpasman or Kpasman file"),
1032 this)); 1045 this));
1033 if (fn == "") { 1046 if (fn == "") {
1034 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 1047 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
1035 return; 1048 return;
1036 } 1049 }
1037 1050
1038 PwMerror ret = curDoc()->exportToGpasman(&fn); 1051 PwMerror ret = curDoc()->exportToGpasman(&fn);
1039 if (ret != e_success) { 1052 if (ret != e_success) {
1040 if (ret == e_noPw) { 1053 if (ret == e_noPw) {
1041 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 1054 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
1042 return; 1055 return;
1043 } 1056 }
1044 KMessageBox::error(this, 1057 KMessageBox::error(this,
1045 i18n("Error: Couldn't write to file.\n" 1058 i18n("Error: Couldn't write to file.\n"
1046 "Please check if you have permission to write " 1059 "Please check if you have permission to write "
1047 "to the file in that directory."), 1060 "to the file in that directory."),
1048 i18n("error while writing")); 1061 i18n("error while writing"));
1049 } else 1062 } else
1050 showStatMsg(i18n("Successfully exported data.")); 1063 showStatMsg(i18n("Successfully exported data."));
1051 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 1064 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
1052} 1065}
1053 1066
1054 1067
1055 1068
1056void PwM::exportToCsv() 1069void PwM::exportToCsv()
1057{ 1070{
1058 PWM_ASSERT(curDoc()); 1071 PWM_ASSERT(curDoc());
1059 if (curDoc()->isDocEmpty()) { 1072 if (curDoc()->isDocEmpty()) {
1060 KMessageBox::information(this, 1073 KMessageBox::information(this,
1061 i18n 1074 i18n
1062 ("Sorry, there is nothing to export;\n" 1075 ("Sorry, there is nothing to export;\n"
1063 "please add some passwords first."), 1076 "please add some passwords first."),
1064 i18n("Nothing to Do")); 1077 i18n("Nothing to Do"));
1065 return; 1078 return;
1066 } 1079 }
1067 1080
1068 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer); 1081 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer);
1069 QString fn(KFileDialog::getSaveFileName("*.csv", i18n("*|CSV Text File"), this)); 1082 QString fn(KFileDialog::getSaveFileName("*.csv", i18n("*|CSV Text File"), this));
1070 if (fn.isEmpty()) { 1083 if (fn.isEmpty()) {
1071 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 1084 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
1072 return; 1085 return;
1073 } 1086 }
1074 1087
1075 Csv csv(this); 1088 Csv csv(this);
1076 if (!csv.exportData(fn, curDoc())) { 1089 if (!csv.exportData(fn, curDoc())) {
1077 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 1090 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
1078 showStatMsg(i18n("CSV file export failed.")); 1091 showStatMsg(i18n("CSV file export failed."));
1079 return; 1092 return;
1080 } 1093 }
1081 showStatMsg(i18n("Successfully exported data.")); 1094 showStatMsg(i18n("Successfully exported data."));
1082 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 1095 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
1083} 1096}
1084 1097
1085bool PwM::importCsv() 1098bool PwM::importCsv()
1086{ 1099{
1087 Csv csv(this); 1100 Csv csv(this);
1088 if (!isVirgin()) { 1101 if (!isVirgin()) {
1089 if (KMessageBox::questionYesNo(this, 1102 if (KMessageBox::questionYesNo(this,
1090 i18n("Do you want to import the data\n" 1103 i18n("Do you want to import the data\n"
1091 "into the current document? (If you\n" 1104 "into the current document? (If you\n"
1092 "select \"no\", a new document will be\n" 1105 "select \"no\", a new document will be\n"
1093 "opened.)"), 1106 "opened.)"),
1094 i18n("Import into This Document?")) 1107 i18n("Import into This Document?"))
1095 == KMessageBox::No) { 1108 == KMessageBox::No) {
1096 // import the data to a new window. 1109 // import the data to a new window.
1097 PwM *newInstance = init->createMainWnd(); 1110 PwM *newInstance = init->createMainWnd();
1098 bool ok = newInstance->importCsv(); 1111 bool ok = newInstance->importCsv();
1099 if (!ok) { 1112 if (!ok) {
1100 newInstance->setForceQuit(true); 1113 newInstance->setForceQuit(true);
1101 delete_and_null(newInstance); 1114 delete_and_null(newInstance);
1102 } 1115 }
1103 return ok; 1116 return ok;
1104 } 1117 }
1105 } 1118 }
1106 1119
1107 QString filename = KFileDialog::getOpenFileName("*.csv", i18n("*|CSV Text File"), this); 1120 QString filename = KFileDialog::getOpenFileName("*.csv", i18n("*|CSV Text File"), this);
1108 if (filename.isEmpty()) 1121 if (filename.isEmpty())
1109 return false; 1122 return false;
1110 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer); 1123 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer);
1111 if (!csv.importData(filename, curDoc())) { 1124 if (!csv.importData(filename, curDoc())) {
1112 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 1125 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
1113 showStatMsg(i18n("CSV file import failed.")); 1126 showStatMsg(i18n("CSV file import failed."));
1114 return false; 1127 return false;
1115 } 1128 }
1116 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 1129 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
1117 KMessageBox::information(this, 1130 KMessageBox::information(this,
1118 i18n("Successfully imported the CSV data\n" 1131 i18n("Successfully imported the CSV data\n"
1119 "into the current document."), i18n("Successfully Imported")); 1132 "into the current document."), i18n("Successfully Imported"));
1120 showStatMsg(i18n("Successfully imported")); 1133 showStatMsg(i18n("Successfully imported"));
1121 setVirgin(false); 1134 setVirgin(false);
1122 return true; 1135 return true;
1123} 1136}
1124 1137
1125 1138
1126void PwM::exportToKWallet() 1139void PwM::exportToKWallet()
1127{ 1140{
1128#ifdef CONFIG_KWALLETIF 1141#ifdef CONFIG_KWALLETIF
1129 if (!checkAndAskForKWalletEmu()) 1142 if (!checkAndAskForKWalletEmu())
1130 return; 1143 return;
1131 PWM_ASSERT(curDoc()); 1144 PWM_ASSERT(curDoc());
1132 if (curDoc()->isDocEmpty()) { 1145 if (curDoc()->isDocEmpty()) {
1133 KMessageBox::information(this, 1146 KMessageBox::information(this,
1134 i18n 1147 i18n
1135 ("Sorry, there's nothing to export.\n" 1148 ("Sorry, there's nothing to export.\n"
1136 "Please first add some passwords."), 1149 "Please first add some passwords."),
1137 i18n("nothing to do")); 1150 i18n("nothing to do"));
1138 init->initKWalletEmu(); 1151 init->initKWalletEmu();
1139 return; 1152 return;
1140 } 1153 }
1141 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer); 1154 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer);
1142 KWalletIf walletIf(this); 1155 KWalletIf walletIf(this);
1143 if (walletIf.kwalletExport(curDoc())) { 1156 if (walletIf.kwalletExport(curDoc())) {
1144 KMessageBox::information(this, 1157 KMessageBox::information(this,
1145 i18n("Successfully exported the data of the current " 1158 i18n("Successfully exported the data of the current "
1146 "document to KWallet."), 1159 "document to KWallet."),
1147 i18n("Successfully exported data.")); 1160 i18n("Successfully exported data."));
1148 showStatMsg(i18n("Successfully exported data.")); 1161 showStatMsg(i18n("Successfully exported data."));
1149 } 1162 }
1150 init->initKWalletEmu(); 1163 init->initKWalletEmu();
1151 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 1164 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
1152#endif // CONFIG_KWALLETIF 1165#endif // CONFIG_KWALLETIF
1153} 1166}
1154 1167
1155bool PwM::importFromGpasman() 1168bool PwM::importFromGpasman()
1156{ 1169{
1157 if (!isVirgin()) { 1170 if (!isVirgin()) {
1158 if (KMessageBox::questionYesNo(this, 1171 if (KMessageBox::questionYesNo(this,
1159 i18n("Do you want to import the data\n" 1172 i18n("Do you want to import the data\n"
1160 "into the current document? (If you\n" 1173 "into the current document? (If you\n"
1161 "select \"no\", a new document will be\n" 1174 "select \"no\", a new document will be\n"
1162 "opened.)"), 1175 "opened.)"),
1163 i18n("import into this document?")) 1176 i18n("import into this document?"))
1164 == KMessageBox::No) { 1177 == KMessageBox::No) {
1165 // import the data to a new window. 1178 // import the data to a new window.
1166 PwM *newInstance = init->createMainWnd(); 1179 PwM *newInstance = init->createMainWnd();
1167 bool ok = newInstance->importFromGpasman(); 1180 bool ok = newInstance->importFromGpasman();
1168 if (!ok) { 1181 if (!ok) {
1169 newInstance->setForceQuit(true); 1182 newInstance->setForceQuit(true);
1170 delete_and_null(newInstance); 1183 delete_and_null(newInstance);
1171 } 1184 }
1172 return ok; 1185 return ok;
1173 } 1186 }
1174 } 1187 }
1175 1188
1176 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer); 1189 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer);
1177 PwMerror ret; 1190 PwMerror ret;
1178 QString path(KFileDialog::getOpenFileName(QString::null, 1191 QString path(KFileDialog::getOpenFileName(QString::null,
1179 i18n("*|Gpasman or Kpasman file"), this)); 1192 i18n("*|Gpasman or Kpasman file"), this));
1180 if (path == "") 1193 if (path == "")
1181 goto cancelImport; 1194 goto cancelImport;
1182 ret = curDoc()->importFromGpasman(&path); 1195 ret = curDoc()->importFromGpasman(&path);
1183 if (ret == e_wrongPw) { 1196 if (ret == e_wrongPw) {
1184 if (KMessageBox::questionYesNo(this, 1197 if (KMessageBox::questionYesNo(this,
1185 i18n 1198 i18n
1186 ("This is probably the wrong master-password\n" 1199 ("This is probably the wrong master-password\n"
1187 "you have typed in.\n" 1200 "you have typed in.\n"
1188 "There is no real way to determine the\n" 1201 "There is no real way to determine the\n"
1189 "correctness of the password in the Gpasman\n" 1202 "correctness of the password in the Gpasman\n"
1190 "file-format. But I think this\n" 1203 "file-format. But I think this\n"
1191 "password ist wrong.\n" 1204 "password ist wrong.\n"
1192 "Do you want to continue nevertheless?"), 1205 "Do you want to continue nevertheless?"),
1193 i18n("password error")) 1206 i18n("password error"))
1194 == KMessageBox::No) { 1207 == KMessageBox::No) {
1195 goto cancelImport; 1208 goto cancelImport;
1196 } 1209 }
1197 } else if (ret != e_success) { 1210 } else if (ret != e_success) {
1198 KMessageBox::error(this, 1211 KMessageBox::error(this,
1199 i18n("Could not import file!\n" 1212 i18n("Could not import file!\n"
1200 "Do you have permission to read this file?"), 1213 "Do you have permission to read this file?"),
1201 i18n("import failed")); 1214 i18n("import failed"));
1202 goto cancelImport; 1215 goto cancelImport;
1203 } 1216 }
1204 setVirgin(false); 1217 setVirgin(false);
1205 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 1218 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
1206 return true; 1219 return true;
1207 1220
1208cancelImport: 1221cancelImport:
1209 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 1222 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
1210 return false; 1223 return false;
1211} 1224}
1212 1225
1213#ifdef CONFIG_KWALLETIF 1226#ifdef CONFIG_KWALLETIF
1214bool PwM::checkAndAskForKWalletEmu() 1227bool PwM::checkAndAskForKWalletEmu()
1215{ 1228{
1216 if (init->kwalletEmu()) { 1229 if (init->kwalletEmu()) {
1217 /* KWallet emulation is enabled. We can't import/export 1230 /* KWallet emulation is enabled. We can't import/export
1218 * data from/to it, while emulation is active. 1231 * data from/to it, while emulation is active.
1219 */ 1232 */
1220 if (KMessageBox::questionYesNo(this, 1233 if (KMessageBox::questionYesNo(this,
1221 i18n("KWallet emulation is enabled.\n" 1234 i18n("KWallet emulation is enabled.\n"
1222 "You can't import or export data from/to " 1235 "You can't import or export data from/to "
1223 "the original KWallet, while the emulation " 1236 "the original KWallet, while the emulation "
1224 "is active.\n" 1237 "is active.\n"
1225 "Do you want to tempoarly disable the KWallet emulation?"), 1238 "Do you want to tempoarly disable the KWallet emulation?"),
1226 i18n("Tempoarly disable KWallet emulation?")) 1239 i18n("Tempoarly disable KWallet emulation?"))
1227 == KMessageBox::Yes) { 1240 == KMessageBox::Yes) {
1228 init->initKWalletEmu(true); 1241 init->initKWalletEmu(true);
1229 PWM_ASSERT(!init->kwalletEmu()); 1242 PWM_ASSERT(!init->kwalletEmu());
1230 return true; 1243 return true;
1231 } 1244 }
1232 return false; 1245 return false;
1233 } 1246 }
1234 return true; 1247 return true;
1235} 1248}
1236#endif // CONFIG_KWALLETIF 1249#endif // CONFIG_KWALLETIF
1237 1250
1238bool PwM::importKWallet() 1251bool PwM::importKWallet()
1239{ 1252{
1240#ifdef CONFIG_KWALLETIF 1253#ifdef CONFIG_KWALLETIF
1241 if (!checkAndAskForKWalletEmu()) 1254 if (!checkAndAskForKWalletEmu())
1242 return false; 1255 return false;
1243 KWalletIf walletIf(this); 1256 KWalletIf walletIf(this);
1244 if (!isVirgin()) { 1257 if (!isVirgin()) {
1245 if (KMessageBox::questionYesNo(this, 1258 if (KMessageBox::questionYesNo(this,
1246 i18n("Do you want to import the data " 1259 i18n("Do you want to import the data "
1247 "into the current document? (If you " 1260 "into the current document? (If you "
1248 "select \"no\", a new document will be " 1261 "select \"no\", a new document will be "
1249 "opened.)"), 1262 "opened.)"),
1250 i18n("import into this document?")) 1263 i18n("import into this document?"))
1251 == KMessageBox::No) { 1264 == KMessageBox::No) {
1252 // import the data to a new window. 1265 // import the data to a new window.
1253 PwM *newInstance = init->createMainWnd(); 1266 PwM *newInstance = init->createMainWnd();
1254 bool ok = newInstance->importKWallet(); 1267 bool ok = newInstance->importKWallet();
1255 if (!ok) { 1268 if (!ok) {
1256 newInstance->setForceQuit(true); 1269 newInstance->setForceQuit(true);
1257 delete_and_null(newInstance); 1270 delete_and_null(newInstance);
1258 goto exit_fail; 1271 goto exit_fail;
1259 } else { 1272 } else {
1260 goto exit_ok; 1273 goto exit_ok;
1261 } 1274 }
1262 } 1275 }
1263 } 1276 }
1264 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer); 1277 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer);
1265 if (!walletIf.kwalletImport(curDoc())) { 1278 if (!walletIf.kwalletImport(curDoc())) {
1266 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 1279 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
1267 showStatMsg(i18n("KWallet import failed")); 1280 showStatMsg(i18n("KWallet import failed"));
1268 goto exit_fail; 1281 goto exit_fail;
1269 } 1282 }
1270 KMessageBox::information(this, 1283 KMessageBox::information(this,
1271 i18n("Successfully imported the KWallet data " 1284 i18n("Successfully imported the KWallet data "
1272 "into the current document."), 1285 "into the current document."),
1273 i18n("successfully imported")); 1286 i18n("successfully imported"));
1274 showStatMsg(i18n("successfully imported")); 1287 showStatMsg(i18n("successfully imported"));
1275 setVirgin(false); 1288 setVirgin(false);
1276 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 1289 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
1277 1290
1278exit_ok: 1291exit_ok:
1279 init->initKWalletEmu(); 1292 init->initKWalletEmu();
1280 return true; 1293 return true;
1281 1294
1282exit_fail: 1295exit_fail:
1283 init->initKWalletEmu(); 1296 init->initKWalletEmu();
1284#endif // CONFIG_KWALLETIF 1297#endif // CONFIG_KWALLETIF
1285 return false; 1298 return false;
1286} 1299}
1287 1300
1288void PwM::print_slot() 1301void PwM::print_slot()
1289{ 1302{
1290 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer); 1303 curDoc()->timer()->getLock(DocTimer::id_autoLockTimer);
1291#ifndef PWM_EMBEDDED 1304#ifndef PWM_EMBEDDED
1292 PwMPrint p(curDoc(), this); 1305 PwMPrint p(curDoc(), this);
1293 p.printNow(); 1306 p.printNow();
1294#else 1307#else
1295 qDebug("PwM::print_slot , PRINTING IS NOT IMPLEMENTED"); 1308 qDebug("PwM::print_slot , PRINTING IS NOT IMPLEMENTED");
1296#endif 1309#endif
1297 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer); 1310 curDoc()->timer()->putLock(DocTimer::id_autoLockTimer);
1298} 1311}
1299 1312
1300void PwM::genNewCard_slot() 1313void PwM::genNewCard_slot()
1301{ 1314{
1302#ifdef CONFIG_KEYCARD 1315#ifdef CONFIG_KEYCARD
1303 init->keycard()->genNewCard(); 1316 init->keycard()->genNewCard();
1304#endif 1317#endif
1305} 1318}
1306 1319
1307void PwM::eraseCard_slot() 1320void PwM::eraseCard_slot()
1308{ 1321{
1309#ifdef CONFIG_KEYCARD 1322#ifdef CONFIG_KEYCARD
1310 init->keycard()->eraseCard(); 1323 init->keycard()->eraseCard();
1311#endif 1324#endif
1312} 1325}
1313 1326
1314void PwM::readCardId_slot() 1327void PwM::readCardId_slot()
1315{ 1328{
1316#ifdef CONFIG_KEYCARD 1329#ifdef CONFIG_KEYCARD
1317 init->keycard()->displayKey(); 1330 init->keycard()->displayKey();
1318#endif 1331#endif
1319} 1332}
1320 1333
1321void PwM::makeCardBackup_slot() 1334void PwM::makeCardBackup_slot()
1322{ 1335{
1323#ifdef CONFIG_KEYCARD 1336#ifdef CONFIG_KEYCARD
1324 init->keycard()->makeBackupImage(); 1337 init->keycard()->makeBackupImage();
1325#endif 1338#endif
1326} 1339}
1327 1340
1328void PwM::replayCardBackup_slot() 1341void PwM::replayCardBackup_slot()
1329{ 1342{
1330#ifdef CONFIG_KEYCARD 1343#ifdef CONFIG_KEYCARD
1331 init->keycard()->replayBackupImage(); 1344 init->keycard()->replayBackupImage();
1332#endif 1345#endif
1333} 1346}
1334 1347
1335void PwM::execLauncher_slot() 1348void PwM::execLauncher_slot()
1336{ 1349{
1337 PWM_ASSERT(curDoc()); 1350 PWM_ASSERT(curDoc());
1338 if (curDoc()->isDeepLocked()) 1351 if (curDoc()->isDeepLocked())
1339 return; 1352 return;
1340 unsigned int curEntryIndex; 1353 unsigned int curEntryIndex;
1341 if (!view->getCurEntryIndex(&curEntryIndex)) 1354 if (!view->getCurEntryIndex(&curEntryIndex))
1342 return; 1355 return;
1343 bool ret = curDoc()->execLauncher(view->getCurrentCategory(), 1356 bool ret = curDoc()->execLauncher(view->getCurrentCategory(),
1344 curEntryIndex); 1357 curEntryIndex);
1345 if (ret) 1358 if (ret)
1346 showStatMsg(i18n("Executed the \"Launcher\".")); 1359 showStatMsg(i18n("Executed the \"Launcher\"."));
1347 else 1360 else
1348 showStatMsg(i18n("ERROR: Couldn't execute the \"Launcher\"!")); 1361 showStatMsg(i18n("ERROR: Couldn't execute the \"Launcher\"!"));
1349} 1362}
1350 1363
1351void PwM::goToURL_slot() 1364void PwM::goToURL_slot()
1352{ 1365{
1353 PWM_ASSERT(curDoc()); 1366 PWM_ASSERT(curDoc());
1354 if (curDoc()->isDeepLocked()) 1367 if (curDoc()->isDeepLocked())
1355 return; 1368 return;
1356 unsigned int curEntryIndex; 1369 unsigned int curEntryIndex;
1357 if (!view->getCurEntryIndex(&curEntryIndex)) 1370 if (!view->getCurEntryIndex(&curEntryIndex))
1358 return; 1371 return;
1359 bool ret = curDoc()->goToURL(view->getCurrentCategory(), 1372 bool ret = curDoc()->goToURL(view->getCurrentCategory(),
1360 curEntryIndex); 1373 curEntryIndex);
1361 if (ret) 1374 if (ret)
1362 showStatMsg(i18n("started browser with current URL.")); 1375 showStatMsg(i18n("started browser with current URL."));
1363 else 1376 else
1364 showStatMsg(i18n("ERROR: Couldn't start browser! Maybe invalid URL?")); 1377 showStatMsg(i18n("ERROR: Couldn't start browser! Maybe invalid URL?"));
1365} 1378}
1366 1379
1367void PwM::copyToClipboard(const QString &s) 1380void PwM::copyToClipboard(const QString &s)
1368{ 1381{
1369 QClipboard *cb = QApplication::clipboard(); 1382 QClipboard *cb = QApplication::clipboard();
1370#ifndef PWM_EMBEDDED 1383#ifndef PWM_EMBEDDED
1371 if (cb->supportsSelection()) 1384 if (cb->supportsSelection())
1372 cb->setText(s, QClipboard::Selection); 1385 cb->setText(s, QClipboard::Selection);
1373 cb->setText(s, QClipboard::Clipboard); 1386 cb->setText(s, QClipboard::Clipboard);
1374#else 1387#else
1375 cb->setText(s); 1388 cb->setText(s);
1376 1389
1377#endif 1390#endif
1378 1391
1379} 1392}
1380 1393
1381 1394
1382void PwM::showStatMsg(const QString &msg) 1395void PwM::showStatMsg(const QString &msg)
1383{ 1396{
1384#ifdef DESKTOP_VERSION 1397#ifdef DESKTOP_VERSION
1385 statusBar()->message(msg, STATUSBAR_MSG_TIMEOUT * 1000); 1398 statusBar()->message(msg, STATUSBAR_MSG_TIMEOUT * 1000);
1386#else 1399#else
1387 //qDebug("Statusbar : %s",msg.latin1()); 1400 //qDebug("Statusbar : %s",msg.latin1());
1388 Global::statusMessage(msg); 1401 Global::statusMessage(msg);
1389#endif 1402#endif
1390} 1403}
1391 1404
1392void PwM::focusInEvent(QFocusEvent *e) 1405void PwM::focusInEvent(QFocusEvent *e)
1393{ 1406{
1394 if (e->gotFocus()) { 1407 if (e->gotFocus()) {
1395 emit gotFocus(this); 1408 emit gotFocus(this);
1396 } else if (e->lostFocus()) { 1409 } else if (e->lostFocus()) {
1397 emit lostFocus(this); 1410 emit lostFocus(this);
1398 } 1411 }
1399} 1412}
1400 1413
1401 1414
1402#ifdef PWM_EMBEDDED 1415#ifdef PWM_EMBEDDED
1403 1416
1404void PwM::category_slot() 1417void PwM::category_slot()
1405{ 1418{
1406 PwMDoc *doc = curDoc(); 1419 PwMDoc *doc = curDoc();
1407 PWM_ASSERT(doc); 1420 PWM_ASSERT(doc);
1408 doc->timer()->getLock(DocTimer::id_autoLockTimer); 1421 doc->timer()->getLock(DocTimer::id_autoLockTimer);
1409 1422
1410 editCategoryWnd w(doc, this, "editcategory"); 1423 editCategoryWnd w(doc, this, "editcategory");
1411/* 1424/*
1412 vector<string> catList; 1425 vector<string> catList;
1413 doc->getCategoryList(&catList); 1426 doc->getCategoryList(&catList);
1414 unsigned i, size = catList.size(); 1427 unsigned i, size = catList.size();
1415 for (i = 0; i < size; ++i) { 1428 for (i = 0; i < size; ++i) {
1416 w.addCategory(catList[i].c_str()); 1429 w.addCategory(catList[i].c_str());
1417 } 1430 }
1418 w.setCurrCategory(view->getCurrentCategory()); 1431 w.setCurrCategory(view->getCurrentCategory());
1419 if (pw) 1432 if (pw)
1420 w.pwLineEdit->setText(*pw); 1433 w.pwLineEdit->setText(*pw);
1421*/ 1434*/
1422 w.setCurrCategory(view->getCurrentCategory()); 1435 w.setCurrCategory(view->getCurrentCategory());
1423 1436
1424 tryAgain: 1437 tryAgain:
1425 if (w.exec() == 1) 1438 if (w.exec() == 1)
1426 { 1439 {
1427 PwMDataItem d; 1440 PwMDataItem d;
1428 1441
1429 //US BUG: to initialize all values of curEntr with meaningfulldata, 1442 //US BUG: to initialize all values of curEntr with meaningfulldata,
1430 // we call clear on it. Reason: Metadata will be uninitialized otherwise. 1443 // we call clear on it. Reason: Metadata will be uninitialized otherwise.
1431 // another option would be to create a constructor for PwMDataItem 1444 // another option would be to create a constructor for PwMDataItem
1432 d.clear(true); 1445 d.clear(true);
1433 /* 1446 /*
1434 d.desc = w.getDescription().latin1(); 1447 d.desc = w.getDescription().latin1();
1435 d.name = w.getUsername().latin1(); 1448 d.name = w.getUsername().latin1();
1436 d.pw = w.getPassword().latin1(); 1449 d.pw = w.getPassword().latin1();
1437 d.comment = w.getComment().latin1(); 1450 d.comment = w.getComment().latin1();
1438 d.url = w.getUrl().latin1(); 1451 d.url = w.getUrl().latin1();
1439 d.launcher = w.getLauncher().latin1(); 1452 d.launcher = w.getLauncher().latin1();
1440 PwMerror ret = doc->addEntry(w.getCategory(), &d); 1453 PwMerror ret = doc->addEntry(w.getCategory(), &d);
1441 if (ret == e_entryExists) { 1454 if (ret == e_entryExists) {
1442 KMessageBox::error(this, 1455 KMessageBox::error(this,
1443 i18n 1456 i18n
1444 ("An entry with this \"Description\",\n" 1457 ("An entry with this \"Description\",\n"
1445 "does already exist.\n" 1458 "does already exist.\n"
1446 "Please select another description."), 1459 "Please select another description."),
1447 i18n("entry already exists.")); 1460 i18n("entry already exists."));
1448 goto tryAgain; 1461 goto tryAgain;
1449 } else if (ret == e_maxAllowedEntr) { 1462 } else if (ret == e_maxAllowedEntr) {
1450 KMessageBox::error(this, i18n("The maximum possible number of\nentries" 1463 KMessageBox::error(this, i18n("The maximum possible number of\nentries"
1451 "has been reached.\nYou can't add more entries."), 1464 "has been reached.\nYou can't add more entries."),
1452 i18n("maximum number of entries")); 1465 i18n("maximum number of entries"));
1453 doc->timer()->putLock(DocTimer::id_autoLockTimer); 1466 doc->timer()->putLock(DocTimer::id_autoLockTimer);
1454 return; 1467 return;
1455 } 1468 }
1456 */ 1469 */
1457 } 1470 }
1458 setVirgin(false); 1471 setVirgin(false);
1459 doc->timer()->putLock(DocTimer::id_autoLockTimer); 1472 doc->timer()->putLock(DocTimer::id_autoLockTimer);
1460} 1473}
1461 1474
1462 1475
1463void PwM::whatsnew_slot() 1476void PwM::whatsnew_slot()
1464{ 1477{
1465 KApplication::showFile( "KDE-Pim/Pi Version Info", "kdepim/WhatsNew.txt" ); 1478 KApplication::showFile( "KDE-Pim/Pi Version Info", "kdepim/WhatsNew.txt" );
1466} 1479}
1467 1480
1468void PwM::showLicense_slot() 1481void PwM::showLicense_slot()
1469{ 1482{
1470 KApplication::showLicence(); 1483 KApplication::showLicence();
1471} 1484}
1472 1485
1473void PwM::faq_slot() 1486void PwM::faq_slot()
1474{ 1487{
1475 KApplication::showFile( "PWM/Pi FAQ", "kdepim/pwmanager/pwmanagerFAQ.txt" ); 1488 KApplication::showFile( "PWM/Pi FAQ", "kdepim/pwmanager/pwmanagerFAQ.txt" );
1476} 1489}
1477 1490
1478void PwM::syncHowTo_slot() 1491void PwM::syncHowTo_slot()
1479{ 1492{
1480 KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/SyncHowto.txt" ); 1493 KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/SyncHowto.txt" );
1481} 1494}
1482 1495
1483 1496
1484void PwM::createAboutData_slot() 1497void PwM::createAboutData_slot()
1485{ 1498{
1486 QString version; 1499 QString version;
1487#include <../version> 1500#include <../version>
1488; 1501;
1489 QMessageBox::about( this, "About PwManager/Pi", 1502 QMessageBox::about( this, "About PwManager/Pi",
1490 "PwManager/Platform-independent\n" 1503 "PwManager/Platform-independent\n"
1491 "(PWM/Pi) " +version + " - " + 1504 "(PWM/Pi) " +version + " - " +
1492#ifdef DESKTOP_VERSION 1505#ifdef DESKTOP_VERSION
1493 "Desktop Edition\n" 1506 "Desktop Edition\n"
1494#else 1507#else
1495 "PDA-Edition\n" 1508 "PDA-Edition\n"
1496 "for: Zaurus 5500 / 7x0 / 8x0\n" 1509 "for: Zaurus 5500 / 7x0 / 8x0\n"
1497#endif 1510#endif
1498 1511
1499 "(c) 2004 Ulf Schenk\n" 1512 "(c) 2004 Ulf Schenk\n"
1500 "(c) 2004 Lutz Rogowski\n" 1513 "(c) 2004 Lutz Rogowski\n"
1501 "(c) 1997-2004, The KDE PIM Team\n" 1514 "(c) 1997-2004, The KDE PIM Team\n"
1502 1515
1503 "(c) Michael Buesch - main programming\nand current maintainer\nmbuesch@freenet.de\n" 1516 "(c) Michael Buesch - main programming\nand current maintainer\nmbuesch@freenet.de\n"