summaryrefslogtreecommitdiffabout
authorzautrix <zautrix>2005-01-21 15:38:31 (UTC)
committer zautrix <zautrix>2005-01-21 15:38:31 (UTC)
commit4afdcfcac216b428ada79f4750cf7447e3175333 (patch) (unidiff)
tree8f70936ac23137c3f6fb00fce33edbfe3d821f59
parent234b9425bebd41b556277cdd94138fafecc32b45 (diff)
downloadkdepimpi-4afdcfcac216b428ada79f4750cf7447e3175333.zip
kdepimpi-4afdcfcac216b428ada79f4750cf7447e3175333.tar.gz
kdepimpi-4afdcfcac216b428ada79f4750cf7447e3175333.tar.bz2
some fixes
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--bin/kdepim/SyncHowto.txt2
-rw-r--r--korganizer/kotodoviewitem.cpp6
-rw-r--r--microkde/kdeui/klistview.cpp14
-rw-r--r--version2
4 files changed, 16 insertions, 8 deletions
diff --git a/bin/kdepim/SyncHowto.txt b/bin/kdepim/SyncHowto.txt
index 64f6f14..b0473a1 100644
--- a/bin/kdepim/SyncHowto.txt
+++ b/bin/kdepim/SyncHowto.txt
@@ -1,345 +1,345 @@
1WARNING: 1WARNING:
2YOU MAY GET UNEXPECTED (I.E. WRONG) SYNCHRONIZATION RESULTS, 2YOU MAY GET UNEXPECTED (I.E. WRONG) SYNCHRONIZATION RESULTS,
3IF YOU CHANGE AN EVENT ON THE FIRST DEVICE AND SYNC IMMEDIATELY FROM 3IF YOU CHANGE AN EVENT ON THE FIRST DEVICE AND SYNC IMMEDIATELY FROM
4THE OTHER DEVICE WITH THIS DEVICE, IF THE CLOCKS OF THE TWO DEVICES 4THE OTHER DEVICE WITH THIS DEVICE, IF THE CLOCKS OF THE TWO DEVICES
5HAVE TOO MUCH DIFFERENCE. 5HAVE TOO MUCH DIFFERENCE.
6 6
7In other words: Please make sure, that the clocks of the devices 7In other words: Please make sure, that the clocks of the devices
8you want to sync have only a difference of some seconds! 8you want to sync have only a difference of some seconds!
9 9
10 10
11CONTENT: 11CONTENT:
12 12
130) How syncing works 130) How syncing works
141) Qick overview of settings 141) Qick overview of settings
152) Sync settings in sync dialog 152) Sync settings in sync dialog
163) Syncing background 163) Syncing background
174) Sync preferences 174) Sync preferences
185) How a filter works 185) How a filter works
196) Details about sync profile kinds 196) Details about sync profile kinds
20 20
21************************************************************************* 21*************************************************************************
220) How syncing works 220) How syncing works
23************************************************************************* 23*************************************************************************
24 24
25Note: 25Note:
26The recommended and easiest way to syncronize two devices where 26The recommended and easiest way to syncronize two devices where
27KO/Pi, KA/Pi or PWM/Pi is installed, is the profile kind "Pi-Sync". 27KO/Pi, KA/Pi or PWM/Pi is installed, is the profile kind "Pi-Sync".
28Details about that in 6) b). 28Details about that in 6) b).
29 29
30In KDE-Pim/Pi you can synchronize ( sync ) your calendar/addressbook/ 30In KDE-Pim/Pi you can synchronize ( sync ) your calendar/addressbook/
31passwordfile with another calendar/addressbook/passwordfile, 31passwordfile with another calendar/addressbook/passwordfile,
32by syncing your (local) calendar/addressbook/passwordfile 32by syncing your (local) calendar/addressbook/passwordfile
33with a (remote) file. 33with a (remote) file.
34This remote file may on your local filesystem 34This remote file may on your local filesystem
35or on another (remote) device. 35or on another (remote) device.
36 36
37If you want to sync with another remote device, you have to create 37If you want to sync with another remote device, you have to create
38a sync profile. 38a sync profile.
39You have two choices for choosing the profil kind: 39You have two choices for choosing the profil kind:
40I) You can choose profile kind "Remote file" and specify a 40I) You can choose profile kind "Remote file" and specify a
41 command line download/upload command ( like scp, ftp, ...) to 41 command line download/upload command ( like scp, ftp, ...) to
42 a) download the remote file to your local machine to a temp file 42 a) download the remote file to your local machine to a temp file
43 b) sync with this temp file 43 b) sync with this temp file
44 c) upload the synced file to the remote device 44 c) upload the synced file to the remote device
45II) If you want to sync with a device, where KO/Pi( or KA/Pi, PWM/Pi) is 45II) If you want to sync with a device, where KO/Pi( or KA/Pi, PWM/Pi) is
46 installed, you can easily get the remote file via network 46 installed, you can easily get the remote file via network
47 with the build in file transfer feature: 47 with the build in file transfer feature:
48 Choose profile kind "Pi-Sync" and 48 Choose profile kind "Pi-Sync" and
49 a) Start KO/Pi,KA/Pi or PWM/Pi on remote device and 49 a) Start KO/Pi,KA/Pi or PWM/Pi on remote device and
50 enable "Pi-Sync" on remote device with password and port. 50 enable "Pi-Sync" on remote device with password and port.
51 b) Specify password, port and IP address in your profile. 51 b) Specify password, port and IP address in your profile.
52 52
53 53
54You can sync with your mobile phone as well. 54You can sync with your mobile phone as well.
55Everything is explained in more details below. 55Everything is explained in more details below.
56 56
57NOTE: 57NOTE:
58If you do not use profile kind "Pi-Sync", 58If you do not use profile kind "Pi-Sync",
59it is recommended to close 59it is recommended to close
60a running KO/Pi (KA/Pi, PWM/Pi) on the remote device. 60a running KO/Pi (KA/Pi, PWM/Pi) on the remote device.
61(Note: KO/Pi(KA/Pi, PWM/Pi) running on Zaurus with 61(Note: KO/Pi(KA/Pi, PWM/Pi) running on Zaurus with
62FastLoad enabled will never be closed!) 62FastLoad enabled will never be closed!)
63After syncing with a running KO/Pi on the remote device, 63After syncing with a running KO/Pi on the remote device,
64a "save" on the remote device will tell you that it needs to merge (sync). 64a "save" on the remote device will tell you that it needs to merge (sync).
65After merging (just a syncing with the changed file) 65After merging (just a syncing with the changed file)
66you will get the new data showing in remote KO/Pi. 66you will get the new data showing in remote KO/Pi.
67 67
68************************************************************************* 68*************************************************************************
691) Qick overview of settings 691) Qick overview of settings
70************************************************************************* 70*************************************************************************
71 71
72a) Open sync settings dialog (Menu Synchronize - Configure...) 72a) Open sync settings dialog (Menu Synchronize - Configure...)
73b) Give your device a unique name. 73b) Give your device a unique name.
74 (unique in the set of all devices you want to sync with). 74 (unique in the set of all devices you want to sync with).
75 If you have already configured another devive and created 75 If you have already configured another devive and created
76 there a sync profile to sync with this device, give your device 76 there a sync profile to sync with this device, give your device
77 the same name as this sync profile! The same name is important, 77 the same name as this sync profile! The same name is important,
78 because it makes it possible to sync first A->B 78 because it makes it possible to sync first A->B
79 (A local device, that performs the sync, B remote device) 79 (A local device, that performs the sync, B remote device)
80 and then B->A. Such that the B->A sync knows about the 80 and then B->A. Such that the B->A sync knows about the
81 already performed A->B sync. 81 already performed A->B sync.
82 That means: It is unimportant if you sync A->B or B->A, 82 That means: It is unimportant if you sync A->B or B->A,
83 the devices A and B will be synced properly. 83 the devices A and B will be synced properly.
84c) Create a new sync profile and give it a unique name. 84c) Create a new sync profile and give it a unique name.
85 (unique in the set of all sync profiles on this device). 85 (unique in the set of all sync profiles on this device).
86 If you want to sync with a device, where KO/Pi is already installed 86 If you want to sync with a device, where KO/Pi is already installed
87 and which has a given unique device name, use this device name as 87 and which has a given unique device name, use this device name as
88 your profile name ( refer to b) ). 88 your profile name ( refer to b) ).
89d) Coose the profile kind of your syncing method: 89d) Choose the profile kind of your syncing method:
90 (i) Local file or 90 (i) Local file or
91 (ii) Pi-Sync or 91 (ii) Pi-Sync or
92 (iii) Remote file or 92 (iii) Remote file or
93 (iiii) Mobile Phone. 93 (iiii) Mobile Phone.
94 Detailed explanation in 6) 94 Detailed explanation in 6)
95e) Choose the other profile options. 95e) Choose the other profile options.
96 Detailed explanation in 2) 96 Detailed explanation in 2)
97f) Close sync dialog with OK. 97f) Close sync dialog with OK.
98g) Sync. 98g) Sync.
99 99
100NOTE: 100NOTE:
101AFTER SYNCING THERE ARE "SYNC EVENTS" CREATED 101AFTER SYNCING THERE ARE "SYNC EVENTS" CREATED
102(OR UPDATED, IF IT ALREADY EXITS) FOR EACH SYNC PROFILE. 102(OR UPDATED, IF IT ALREADY EXITS) FOR EACH SYNC PROFILE.
103YOU MAY NOT DELETE OR CHANGE THESE EVENTS. 103YOU MAY NOT DELETE OR CHANGE THESE EVENTS.
104 104
105************************************************************************* 105*************************************************************************
1062) Sync settings in sync dialog 1062) Sync settings in sync dialog
107************************************************************************* 107*************************************************************************
108 108
109a) Local device name: 109a) Local device name:
110 -> 1) b) 110 -> 1) b)
111b) Profile: 111b) Profile:
112 -> 1) c) 112 -> 1) c)
113c) Multiple Sync options: Include in multiple sync: 113c) Multiple Sync options: Include in multiple sync:
114 In the Synchronize menu, there is a multiple sync menu entry. 114 In the Synchronize menu, there is a multiple sync menu entry.
115 If you choose this menu entry, all user defined profiles with this 115 If you choose this menu entry, all user defined profiles with this
116 'Include in multiple sync' option enabled will be synced 116 'Include in multiple sync' option enabled will be synced
117 one after another. And this twice. This will take some time. 117 one after another. And this twice. This will take some time.
118 After that sync, on all devices should be the same data. 118 After that sync, on all devices should be the same data.
119 119
120d)- j) Sync algo options: 120d)- j) Sync algo options:
121 121
122d) Ask for preferences before sync: 122d) Ask for preferences before sync:
123 Check this to be asked for "Sync preferences" settings before each sync. 123 Check this to be asked for "Sync preferences" settings before each sync.
124 If the profile kind is "Pi-Sync" you will be asked to confirm 124 If the profile kind is "Pi-Sync" you will be asked to confirm
125 the "Pi-Sync" specific settings (Password,IP address, port number) 125 the "Pi-Sync" specific settings (Password,IP address, port number)
126 as well. That makes it possible to use that profile for a 126 as well. That makes it possible to use that profile for a
127 device that is connected via DHCP to the network and gets different 127 device that is connected via DHCP to the network and gets different
128 IP addresses when connecting to the network. 128 IP addresses when connecting to the network.
129e) Sync preferences: 129e) Sync preferences:
130 Choose here your sync preferences. 130 Choose here your sync preferences.
131 Details -> 4) 131 Details -> 4)
132f) Show summary after sync: 132f) Show summary after sync:
133 Check this to get a small summary dialog after sync 133 Check this to get a small summary dialog after sync
134 about number of added/changed/deleted events on local/remote. 134 about number of added/changed/deleted events on local/remote.
135g) Apply filter when adding data to local: 135g) Apply filter when adding data to local:
136 What is a filter? You can read this in -> 5) 136 What is a filter? You can read this in -> 5)
137 With this option you can specify a filter for events/contacts, 137 With this option you can specify a filter for events/contacts,
138 which should be added to the local database, because they are 138 which should be added to the local database, because they are
139 in the remote database and not in the local database. 139 in the remote database and not in the local database.
140 (Database = calendar file or addressbook file). 140 (Database = calendar file or addressbook file).
141 Note that the filter is NOT applied to the remote 141 Note that the filter is NOT applied to the remote
142 database before syncing. It is only applied to a particular 142 database before syncing. It is only applied to a particular
143 item which should be added to the local database. 143 item which should be added to the local database.
144 Well, but what is the difference? 144 Well, but what is the difference?
145 The differnce is: If the remote database AND the local database contain 145 The differnce is: If the remote database AND the local database contain
146 an already synced item, which does not match the filter, then this item is synced. 146 an already synced item, which does not match the filter, then this item is synced.
147 If the remote database contains an item which does not match the filter 147 If the remote database contains an item which does not match the filter
148 and the local database does not contain this item, then this item is not added 148 and the local database does not contain this item, then this item is not added
149 to the local database, but it is still in the remote database after syncing. 149 to the local database, but it is still in the remote database after syncing.
150g) Write back synced data: 150g) Write back synced data:
151 Uncheck this to update the local calendar only. 151 Uncheck this to update the local calendar only.
152 I.e. your local calendar is synced with the remote calendar 152 I.e. your local calendar is synced with the remote calendar
153 but nothing on the remote calendar is changed. 153 but nothing on the remote calendar is changed.
154 If you uncheck "Write back synced data", the settings 154 If you uncheck "Write back synced data", the settings
155 under h) and i) are ignored, of course. 155 under h) and i) are ignored, of course.
156 156
157h) - j) Write back options: 157h) - j) Write back options:
158 158
159h) Write back (on remote) existing entries only: 159h) Write back (on remote) existing entries only:
160 Check this to update the remote data only. 160 Check this to update the remote data only.
161 I.e. no data from yor local calendar/addressbook is added to the 161 I.e. no data from yor local calendar/addressbook is added to the
162 remote device. You may use this option to 162 remote device. You may use this option to
163 sync against some kind of "public calendar/addressbook" without 163 sync against some kind of "public calendar/addressbook" without
164 adding anything of your personal data. 164 adding anything of your personal data.
165 But in this case, you cannot add an item to the remoet device. 165 But in this case, you cannot add an item to the remoet device.
166i) Apply filter when adding data to remote: 166i) Apply filter when adding data to remote:
167 What is a filter? You can read this in -> 5) 167 What is a filter? You can read this in -> 5)
168 With this option you can specify a filter for events/contacts, 168 With this option you can specify a filter for events/contacts,
169 which should be added to the remote database, because they are 169 which should be added to the remote database, because they are
170 in the local database and not in the remote database. 170 in the local database and not in the remote database.
171 (Database = calendar file or addressbook file). 171 (Database = calendar file or addressbook file).
172 Note that the filter is NOT applied to the local 172 Note that the filter is NOT applied to the local
173 database before syncing. It is only applied to a particular 173 database before syncing. It is only applied to a particular
174 item of the local database which should be added to the remote database. 174 item of the local database which should be added to the remote database.
175 Well, but what is the difference? 175 Well, but what is the difference?
176 The differnce is: If the local database AND the remote database contain 176 The differnce is: If the local database AND the remote database contain
177 an already synced item, which does not match the filter, then this item is synced. 177 an already synced item, which does not match the filter, then this item is synced.
178 If the local database contains an item which does not match the filter 178 If the local database contains an item which does not match the filter
179 and the remote database does not contain this item, then this item is not added 179 and the remote database does not contain this item, then this item is not added
180 to the remote database, but it is still in the local database after syncing. 180 to the remote database, but it is still in the local database after syncing.
181 Example: 181 Example:
182 You have specified a calendar filter "only public events". 182 You have specified a calendar filter "only public events".
183 You specify this filter as the outgoing filter for syncing. 183 You specify this filter as the outgoing filter for syncing.
184 If there is an event in the local database which is not "public", but "private", 184 If there is an event in the local database which is not "public", but "private",
185 this event is not added to the remote database. 185 this event is not added to the remote database.
186 If there is an event in the local database and in the remote database which is 186 If there is an event in the local database and in the remote database which is
187 "private" (maybe added by someone else) then this event is synced and 187 "private" (maybe added by someone else) then this event is synced and
188 it is in the local database and in the remote database after syncing. 188 it is in the local database and in the remote database after syncing.
189 That means in particular you cannot remove an event from the remote 189 That means in particular you cannot remove an event from the remote
190 database but setting it to "private". 190 database but setting it to "private".
191 If you want to remove the event you can clone it, set it to private and delete the 191 If you want to remove the event you can clone it, set it to private and delete the
192 original event. Then the original event is deleted in the remote database after sync and 192 original event. Then the original event is deleted in the remote database after sync and
193 the cloned event is not added to the remote database, because it is private. 193 the cloned event is not added to the remote database, because it is private.
194j) Write back (calendar) entries for time period only: 194j) Write back (calendar) entries for time period only:
195 Check this to write back only calendar entries for a given time period. 195 Check this to write back only calendar entries for a given time period.
196 (Useful when syncing with mobile phones.) 196 (Useful when syncing with mobile phones.)
197 You can specify the date range in weeks for the weeks in the past to the weeks in the future. 197 You can specify the date range in weeks for the weeks in the past to the weeks in the future.
198 198
199k) Profile kind: 199k) Profile kind:
200 Details -> 6) 200 Details -> 6)
201 201
202************************************************************************* 202*************************************************************************
2033) Syncing background 2033) Syncing background
204************************************************************************* 204*************************************************************************
205 205
206The same mentioned for calendars is valid for addressbooks as well. 206The same mentioned for calendars is valid for addressbooks as well.
207 207
208Synchronizing calendars ( i.e. files ) means, 208Synchronizing calendars ( i.e. files ) means,
209to merge two calendars in a useful way. 209to merge two calendars in a useful way.
210If the two calendars are completely different, 210If the two calendars are completely different,
211there is no problem, the resulting calendar contains 211there is no problem, the resulting calendar contains
212all data from the local and from the remote calendar. 212all data from the local and from the remote calendar.
213 213
214Problems will occur, if you have edited items 214Problems will occur, if you have edited items
215from the local calendar on the remote machine. 215from the local calendar on the remote machine.
216Then it could be, that items are in conflict. 216Then it could be, that items are in conflict.
217Two items are "in conflict", if they have the 217Two items are "in conflict", if they have the
218same unique ID (which get an item at time of 218same unique ID (which get an item at time of
219creation and owns it until it is deleted ) 219creation and owns it until it is deleted )
220and they both are modified after the last 220and they both are modified after the last
221synchronization. 221synchronization.
222 222
223At first sync of two calendars there is no item deleted. 223At first sync of two calendars there is no item deleted.
224If the calendars are synced before and there is an item, 224If the calendars are synced before and there is an item,
225which is not edited after the last sync and is only 225which is not edited after the last sync and is only
226available in one calendar, then this item is deleted 226available in one calendar, then this item is deleted
227in this calendar. 227in this calendar.
228 228
229But when was the last synchronization between two calendars? 229But when was the last synchronization between two calendars?
230 230
231To know that, KO/Pi creates at first syncing 231To know that, KO/Pi creates at first syncing
232of two files an unique event "<profile name> - sync Event" 232of two files an unique event "<profile name> - sync Event"
233on the remote and the local calendar. 233on the remote and the local calendar.
234After syncing, the start time of this event is set 234After syncing, the start time of this event is set
235to the time of syncing. 235to the time of syncing.
236The event is read only and the user may not change it. 236The event is read only and the user may not change it.
237 237
238If two such files are synced, that both have an event 238If two such files are synced, that both have an event
239"<profile name> - sync Event" and the events have 239"<profile name> - sync Event" and the events have
240the same start time, then deleted items on the one calendar 240the same start time, then deleted items on the one calendar
241are deleted on the other as well. 241are deleted on the other as well.
242 242
243 243
244************************************************************************* 244*************************************************************************
2454) Sync preferences 2454) Sync preferences
246************************************************************************* 246*************************************************************************
247 247
248Two items are "in conflict", if they have the same unique ID 248Two items are "in conflict", if they have the same unique ID
249and they both are modified after the last synchronization. 249and they both are modified after the last synchronization.
250(Details -> 3) ). 250(Details -> 3) ).
251 251
252If an item is not modified after the last sync and 252If an item is not modified after the last sync and
253it is not found in the other calendar, it is deleted. 253it is not found in the other calendar, it is deleted.
254 254
255On the first sync, there is no item deleted. 255On the first sync, there is no item deleted.
256 256
257SYNC PREFERENCES: 257SYNC PREFERENCES:
258 -Take local entry on conflict: 258 -Take local entry on conflict:
259 Takes the local entry on conflict. 259 Takes the local entry on conflict.
260 If it is the first sync, 260 If it is the first sync,
261 "Ask for every entry" 261 "Ask for every entry"
262 is chosen automatically, 262 is chosen automatically,
263 if this is selected. 263 if this is selected.
264 264
265 -Take remote entry on conflict: 265 -Take remote entry on conflict:
266 Takes the remote entry on conflict. 266 Takes the remote entry on conflict.
267 If it is the first sync, 267 If it is the first sync,
268 "Ask for every entry" 268 "Ask for every entry"
269 is chosen automatically, 269 is chosen automatically,
270 if this is selected. 270 if this is selected.
271 271
272 -Take newest entry on conflict: 272 -Take newest entry on conflict:
273 This takes the newest entry on conflict. 273 This takes the newest entry on conflict.
274 May be the most useful syncing mode. 274 May be the most useful syncing mode.
275 275
276 -Ask for every entry on conflict: 276 -Ask for every entry on conflict:
277 Pops up an event viewer dialog and 277 Pops up an event viewer dialog and
278 shows the two conflicting entries there. 278 shows the two conflicting entries there.
279 The user can chose, which entry he would like to take. 279 The user can chose, which entry he would like to take.
280 The button for the newest entry 280 The button for the newest entry
281 is automatically set as default button. 281 is automatically set as default button.
282 The color for the newest entry is green. 282 The color for the newest entry is green.
283 283
284 -Force: Take local entry always: 284 -Force: Take local entry always:
285 Even if the calendars are already synced 285 Even if the calendars are already synced
286 there is no item deleted on local. 286 there is no item deleted on local.
287 287
288 -Force: Take remote entry always: 288 -Force: Take remote entry always:
289 Analogous to 289 Analogous to
290 "Force: Take local entry always" 290 "Force: Take local entry always"
291 291
292************************************************************************* 292*************************************************************************
2935) How a filter works 2935) How a filter works
294************************************************************************* 294*************************************************************************
295 295
296A filter is a rule to decide if a particular item 296A filter is a rule to decide if a particular item
297(calendar iten item or contact item) belongs to a set of items. 297(calendar iten item or contact item) belongs to a set of items.
298For example, you can specify a set as: 298For example, you can specify a set as:
299Only items, that belongs to that category. 299Only items, that belongs to that category.
300Or: Only items, that does not belong to that category. 300Or: Only items, that does not belong to that category.
301Or: Only items, that are public. 301Or: Only items, that are public.
302 302
303If you specify a filter in a syncing profile, you can set the 303If you specify a filter in a syncing profile, you can set the
304rules of adding items to the local or remote database. 304rules of adding items to the local or remote database.
305 305
306Example: 306Example:
307You have a public calendar in your company, which contains all 307You have a public calendar in your company, which contains all
308company relevant data. 308company relevant data.
309 309
310You have different projects in the company and for project specific events 310You have different projects in the company and for project specific events
311is always set the project name as a category: 311is always set the project name as a category:
312E.g. all events of the project PRO_ABC do have set the categorie PRO_ABC. 312E.g. all events of the project PRO_ABC do have set the categorie PRO_ABC.
313But you are not interested in events of PRO_ABC, because you are not working on it. 313But you are not interested in events of PRO_ABC, because you are not working on it.
314Then you can specify a filter: All, but not with categoroy PRO_ABC. 314Then you can specify a filter: All, but not with categoroy PRO_ABC.
315When you specify this filter as an incoming filter for your sync profile, 315When you specify this filter as an incoming filter for your sync profile,
316all events of the company are synced and added to your local calendar, but not 316all events of the company are synced and added to your local calendar, but not
317the evenst of the project PRO_ABC. 317the evenst of the project PRO_ABC.
318 318
319You do not want that your private data can be seen 319You do not want that your private data can be seen
320in the public calendar of your company. 320in the public calendar of your company.
321Well, set the property to "private" for all your private data 321Well, set the property to "private" for all your private data
322and specify an outgoing filter: Only " public" and "confidential". 322and specify an outgoing filter: Only " public" and "confidential".
323Then you can sync your personal calendar with the calendar of the company, 323Then you can sync your personal calendar with the calendar of the company,
324but your private data is not added to the public calendar. 324but your private data is not added to the public calendar.
325 325
326************************************************************************* 326*************************************************************************
3276) Details about sync profile kinds 3276) Details about sync profile kinds
328************************************************************************* 328*************************************************************************
329 329
330a) Local file 330a) Local file
331 Please specify a local file you want to sync with. 331 Please specify a local file you want to sync with.
332 Note: If you are syncing a file, which is used by KA/Pi, please check the 332 Note: If you are syncing a file, which is used by KA/Pi, please check the
333 "Addressbook file (*.vcf) is used by KA/Pi". 333 "Addressbook file (*.vcf) is used by KA/Pi".
334 If you are syncing with a file from KAddressbook or another program, 334 If you are syncing with a file from KAddressbook or another program,
335 please uncheck "Addressbook file (*.vcf) is used by KA/Pi". 335 please uncheck "Addressbook file (*.vcf) is used by KA/Pi".
336 To set this properly is important! KA/Pi uses a "last modified" property, 336 To set this properly is important! KA/Pi uses a "last modified" property,
337 which is not supported by KAddressbook. 337 which is not supported by KAddressbook.
338 338
339b) Pi-Sync (direct Kx/Pi to Kx/Pi sync) 339b) Pi-Sync (direct Kx/Pi to Kx/Pi sync)
340 We mention here only KO/Pi, but the same is valid for KA/Pi. 340 We mention here only KO/Pi, but the same is valid for KA/Pi.
341 If you want to sync with a device, where KO/Pi is 341 If you want to sync with a device, where KO/Pi is
342 installed, you can easily get the remote file via network 342 installed, you can easily get the remote file via network
343 with the build in file transfer feature "Pi-Sync": 343 with the build in file transfer feature "Pi-Sync":
344 You have first to enable file transfer on the remote device: 344 You have first to enable file transfer on the remote device:
345 - Start KO/Pi on the remote device. 345 - Start KO/Pi on the remote device.
diff --git a/korganizer/kotodoviewitem.cpp b/korganizer/kotodoviewitem.cpp
index 347d982..ead8628 100644
--- a/korganizer/kotodoviewitem.cpp
+++ b/korganizer/kotodoviewitem.cpp
@@ -1,457 +1,457 @@
1/* 1/*
2 This file is part of KOrganizer. 2 This file is part of KOrganizer.
3 Copyright (c) 2000,2001 Cornelius Schumacher <schumacher@kde.org> 3 Copyright (c) 2000,2001 Cornelius Schumacher <schumacher@kde.org>
4 4
5 This program is free software; you can redistribute it and/or modify 5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by 6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or 7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version. 8 (at your option) any later version.
9 9
10 This program is distributed in the hope that it will be useful, 10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details. 13 GNU General Public License for more details.
14 14
15 You should have received a copy of the GNU General Public License 15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software 16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18*/ 18*/
19 19
20#include <klocale.h> 20#include <klocale.h>
21#include <kdebug.h> 21#include <kdebug.h>
22#include <qapp.h> 22#include <qapp.h>
23 23
24#include <kiconloader.h> 24#include <kiconloader.h>
25#include "kotodoviewitem.h" 25#include "kotodoviewitem.h"
26#include "kotodoview.h" 26#include "kotodoview.h"
27#include "koprefs.h" 27#include "koprefs.h"
28 28
29KOTodoViewItem::KOTodoViewItem( QListView *parent, Todo *todo, KOTodoView *kotodo) 29KOTodoViewItem::KOTodoViewItem( QListView *parent, Todo *todo, KOTodoView *kotodo)
30 : QCheckListItem( parent , "", CheckBox ), mTodo( todo ), mTodoView( kotodo ) 30 : QCheckListItem( parent , "", CheckBox ), mTodo( todo ), mTodoView( kotodo )
31{ 31{
32 construct(); 32 construct();
33} 33}
34 34
35KOTodoViewItem::KOTodoViewItem( KOTodoViewItem *parent, Todo *todo, KOTodoView *kotodo ) 35KOTodoViewItem::KOTodoViewItem( KOTodoViewItem *parent, Todo *todo, KOTodoView *kotodo )
36 : QCheckListItem( parent, "", CheckBox ), mTodo( todo ), mTodoView( kotodo ) 36 : QCheckListItem( parent, "", CheckBox ), mTodo( todo ), mTodoView( kotodo )
37{ 37{
38 construct(); 38 construct();
39} 39}
40 40
41QString KOTodoViewItem::key(int column,bool) const 41QString KOTodoViewItem::key(int column,bool) const
42{ 42{
43 QMap<int,QString>::ConstIterator it = mKeyMap.find(column); 43 QMap<int,QString>::ConstIterator it = mKeyMap.find(column);
44 if (it == mKeyMap.end()) { 44 if (it == mKeyMap.end()) {
45 return text(column).lower(); 45 return text(column).lower();
46 } else { 46 } else {
47 return *it; 47 return *it;
48 } 48 }
49} 49}
50 50
51void KOTodoViewItem:: setup() 51void KOTodoViewItem:: setup()
52{ 52{
53 53
54 int h = 20; 54 int h = 20;
55 if ( listView () ) { 55 if ( listView () ) {
56 QFontMetrics fm ( listView ()->font () ); 56 QFontMetrics fm ( listView ()->font () );
57 h = fm.height(); 57 h = fm.height();
58 } 58 }
59 setHeight( h ); 59 setHeight( h );
60 60
61} 61}
62void KOTodoViewItem::setSortKey(int column,const QString &key) 62void KOTodoViewItem::setSortKey(int column,const QString &key)
63{ 63{
64 mKeyMap.insert(column,key); 64 mKeyMap.insert(column,key);
65} 65}
66 66
67#if QT_VERSION >= 300 67#if QT_VERSION >= 300
68void KOTodoViewItem::paintBranches(QPainter *p,const QColorGroup & cg,int w, 68void KOTodoViewItem::paintBranches(QPainter *p,const QColorGroup & cg,int w,
69 int y,int h) 69 int y,int h)
70{ 70{
71 QListViewItem::paintBranches(p,cg,w,y,h); 71 QListViewItem::paintBranches(p,cg,w,y,h);
72} 72}
73#else 73#else
74#endif 74#endif
75 75
76void KOTodoViewItem::construct() 76void KOTodoViewItem::construct()
77{ 77{
78 // qDebug("KOTodoViewItem::construct() "); 78 // qDebug("KOTodoViewItem::construct() ");
79 m_init = true; 79 m_init = true;
80 QString keyd = "=="; 80 QString keyd = "==";
81 QString keyt = "=="; 81 QString keyt = "==";
82 QString skeyd = "=="; 82 QString skeyd = "==";
83 QString skeyt = "=="; 83 QString skeyt = "==";
84 84
85 setOn(mTodo->isCompleted()); 85 setOn(mTodo->isCompleted());
86 setText(0,mTodo->summary()); 86 setText(0,mTodo->summary());
87 setText(1,QString::number(mTodo->priority())); 87 setText(1,QString::number(mTodo->priority()));
88 setText(2,i18n("%1 %").arg(QString::number(mTodo->percentComplete()))); 88 setText(2,i18n("%1 %").arg(QString::number(mTodo->percentComplete())));
89 if (mTodo->percentComplete()<100) { 89 if (mTodo->percentComplete()<100) {
90 if (mTodo->isCompleted()) setSortKey(2,QString::number(999)); 90 if (mTodo->isCompleted()) setSortKey(2,QString::number(999));
91 else setSortKey(2,QString::number(mTodo->percentComplete())); 91 else setSortKey(2,QString::number(mTodo->percentComplete()));
92 } 92 }
93 else { 93 else {
94 if (mTodo->isCompleted()) setSortKey(2,QString::number(999)); 94 if (mTodo->isCompleted()) setSortKey(2,QString::number(999));
95 else setSortKey(2,QString::number(99)); 95 else setSortKey(2,QString::number(99));
96 } 96 }
97 if (mTodo->hasDueDate()) { 97 if (mTodo->hasDueDate()) {
98 setText(3, mTodo->dtDueDateStr()); 98 setText(3, mTodo->dtDueDateStr());
99 QDate d = mTodo->dtDue().date(); 99 QDate d = mTodo->dtDue().date();
100 keyd.sprintf("%04d%02d%02d",d.year(),d.month(),d.day()); 100 keyd.sprintf("%04d%02d%02d",d.year(),d.month(),d.day());
101 // setSortKey(3,keyd); 101 // setSortKey(3,keyd);
102 if (mTodo->doesFloat()) { 102 if (mTodo->doesFloat()) {
103 setText(4,""); 103 setText(4,"");
104 } 104 }
105 else { 105 else {
106 setText(4,mTodo->dtDueTimeStr()); 106 setText(4,mTodo->dtDueTimeStr());
107 QTime t = mTodo->dtDue().time(); 107 QTime t = mTodo->dtDue().time();
108 keyt.sprintf("%02d%02d",t.hour(),t.minute()); 108 keyt.sprintf("%02d%02d",t.hour(),t.minute());
109 //setSortKey(4,keyt); 109 //setSortKey(4,keyt);
110 } 110 }
111 } else { 111 } else {
112 setText(3,""); 112 setText(3,"");
113 setText(4,""); 113 setText(4,"");
114 } 114 }
115 setSortKey(3,keyd); 115 setSortKey(3,keyd);
116 setSortKey(4,keyt); 116 setSortKey(4,keyt);
117 117
118 if (mTodo->isCompleted()) setSortKey(1,"6" + QString::number(mTodo->priority())+keyd+keyt); 118 if (mTodo->isCompleted()) setSortKey(1,"6" + QString::number(mTodo->priority())+keyd+keyt);
119 else setSortKey(1,QString::number(mTodo->priority())+keyd+keyt); 119 else setSortKey(1,QString::number(mTodo->priority())+keyd+keyt);
120 120
121 121
122 122
123 if (mTodo->hasStartDate()) { 123 if (mTodo->hasStartDate()) {
124 setText(5, mTodo->dtStartDateStr()); 124 setText(5, mTodo->dtStartDateStr());
125 QDate d = mTodo->dtStart().date(); 125 QDate d = mTodo->dtStart().date();
126 skeyd.sprintf("%04d%02d%02d",d.year(),d.month(),d.day()); 126 skeyd.sprintf("%04d%02d%02d",d.year(),d.month(),d.day());
127 127
128 if (mTodo->doesFloat()) { 128 if (mTodo->doesFloat()) {
129 setText(6,""); 129 setText(6,"");
130 } 130 }
131 else { 131 else {
132 setText(6,mTodo->dtStartTimeStr()); 132 setText(6,mTodo->dtStartTimeStr());
133 QTime t = mTodo->dtStart().time(); 133 QTime t = mTodo->dtStart().time();
134 skeyt.sprintf("%02d%02d",t.hour(),t.minute()); 134 skeyt.sprintf("%02d%02d",t.hour(),t.minute());
135 135
136 } 136 }
137 } else { 137 } else {
138 setText(5,""); 138 setText(5,"");
139 setText(6,""); 139 setText(6,"");
140 } 140 }
141 setSortKey(5,skeyd); 141 setSortKey(5,skeyd);
142 setSortKey(6,skeyt); 142 setSortKey(6,skeyt);
143 143
144 setText(7,mTodo->cancelled() ? i18n("Yes") : i18n("No")); 144 setText(7,mTodo->cancelled() ? i18n("Yes") : i18n("No"));
145 setText(8,mTodo->categoriesStr()); 145 setText(8,mTodo->categoriesStr());
146 146
147#if 0 147#if 0
148 // Find sort id in description. It's the text behind the last '#' character 148 // Find sort id in description. It's the text behind the last '#' character
149 // found in the description. White spaces are removed from beginning and end 149 // found in the description. White spaces are removed from beginning and end
150 // of sort id. 150 // of sort id.
151 int pos = mTodo->description().findRev('#'); 151 int pos = mTodo->description().findRev('#');
152 if (pos < 0) { 152 if (pos < 0) {
153 setText(6,""); 153 setText(6,"");
154 } else { 154 } else {
155 QString str = mTodo->description().mid(pos+1); 155 QString str = mTodo->description().mid(pos+1);
156 str.stripWhiteSpace(); 156 str.stripWhiteSpace();
157 setText(6,str); 157 setText(6,str);
158 } 158 }
159#endif 159#endif
160 160
161 m_known = false; 161 m_known = false;
162 m_init = false; 162 m_init = false;
163 163
164 setMyPixmap(); 164 setMyPixmap();
165 165
166} 166}
167void KOTodoViewItem::setMyPixmap() 167void KOTodoViewItem::setMyPixmap()
168{ 168{
169 int size = 5; 169 int size = 5;
170 QPixmap pixi = QPixmap( 1, 1 ); 170 QPixmap pixi = QPixmap( 1, 1 );
171 // if ( !mTodo->isCompleted() && mTodo->hasDueDate() && mTodo->dtDue() < QDateTime::currentDateTime() ) { 171 // if ( !mTodo->isCompleted() && mTodo->hasDueDate() && mTodo->dtDue() < QDateTime::currentDateTime() ) {
172// pixi = SmallIcon("redcross16"); 172// pixi = SmallIcon("redcross16");
173// } else { 173// } else {
174 QPainter p; 174 QPainter p;
175 175
176 int pixSize = 0; 176 int pixSize = 0;
177 QPixmap pPix = QPixmap( size, size ); 177 QPixmap pPix = QPixmap( size, size );
178 if ( mTodo->description().length() > 0 ) { 178 if ( mTodo->description().length() > 0 ) {
179 pixi.resize(size, pixSize+size); 179 pixi.resize(size, pixSize+size);
180 pPix.fill( Qt::darkGreen ); 180 pPix.fill( Qt::darkGreen );
181 p.begin( &pixi ); 181 p.begin( &pixi );
182 p. drawPixmap ( 0, pixSize, pPix); 182 p. drawPixmap ( 0, pixSize, pPix);
183 p.end(); 183 p.end();
184 pixSize += size; 184 pixSize += size;
185 } 185 }
186 if ( mTodo->isAlarmEnabled() ) { 186 if ( mTodo->isAlarmEnabled() ) {
187 pixi.resize(size, pixSize+size); 187 pixi.resize(size, pixSize+size);
188 pPix.fill( Qt::red ); 188 pPix.fill( Qt::red );
189 p.begin( &pixi ); 189 p.begin( &pixi );
190 p. drawPixmap ( 0, pixSize, pPix); 190 p. drawPixmap ( 0, pixSize, pPix);
191 p.end(); 191 p.end();
192 pixSize += size; 192 pixSize += size;
193 } 193 }
194 // } 194 // }
195 if ( pixi.width() > 1 ) { 195 if ( pixi.width() > 1 ) {
196 setPixmap ( 0,pixi ) ; 196 setPixmap ( 0,pixi ) ;
197 } else {
198 setPixmap ( 0,QPixmap() ) ;
197 } 199 }
198
199
200} 200}
201void KOTodoViewItem::stateChange(bool state) 201void KOTodoViewItem::stateChange(bool state)
202{ 202{
203 // qDebug("KOTodoViewItem::stateChange "); 203 // qDebug("KOTodoViewItem::stateChange ");
204 // do not change setting on startup 204 // do not change setting on startup
205 if ( m_init ) return; 205 if ( m_init ) return;
206 206
207 kdDebug() << "State changed, modified " << state << endl; 207 kdDebug() << "State changed, modified " << state << endl;
208 QString keyd = "=="; 208 QString keyd = "==";
209 QString keyt = "=="; 209 QString keyt = "==";
210 210
211 if (state) mTodo->setCompleted(state); 211 if (state) mTodo->setCompleted(state);
212 else mTodo->setPercentComplete(0); 212 else mTodo->setPercentComplete(0);
213 if (isOn()!=state) { 213 if (isOn()!=state) {
214 setOn(state); 214 setOn(state);
215 } 215 }
216 216
217 if (mTodo->hasDueDate()) { 217 if (mTodo->hasDueDate()) {
218 setText(3, mTodo->dtDueDateStr()); 218 setText(3, mTodo->dtDueDateStr());
219 QDate d = mTodo->dtDue().date(); 219 QDate d = mTodo->dtDue().date();
220 keyd.sprintf("%04d%02d%02d",d.year(),d.month(),d.day()); 220 keyd.sprintf("%04d%02d%02d",d.year(),d.month(),d.day());
221 setSortKey(3,keyd); 221 setSortKey(3,keyd);
222 if (mTodo->doesFloat()) { 222 if (mTodo->doesFloat()) {
223 setText(4,""); 223 setText(4,"");
224 } 224 }
225 else { 225 else {
226 setText(4,mTodo->dtDueTimeStr()); 226 setText(4,mTodo->dtDueTimeStr());
227 QTime t = mTodo->dtDue().time(); 227 QTime t = mTodo->dtDue().time();
228 keyt.sprintf("%02d%02d",t.hour(),t.minute()); 228 keyt.sprintf("%02d%02d",t.hour(),t.minute());
229 setSortKey(4,keyt); 229 setSortKey(4,keyt);
230 } 230 }
231 } 231 }
232 if (mTodo->isCompleted()) setSortKey(1,QString::number(9)+keyd+keyt); 232 if (mTodo->isCompleted()) setSortKey(1,QString::number(9)+keyd+keyt);
233 else setSortKey(1,QString::number(mTodo->priority())+keyd+keyt); 233 else setSortKey(1,QString::number(mTodo->priority())+keyd+keyt);
234 234
235 setText(2,i18n("%1 %").arg(QString::number(mTodo->percentComplete()))); 235 setText(2,i18n("%1 %").arg(QString::number(mTodo->percentComplete())));
236 if (mTodo->percentComplete()<100) { 236 if (mTodo->percentComplete()<100) {
237 if (mTodo->isCompleted()) setSortKey(2,QString::number(999)); 237 if (mTodo->isCompleted()) setSortKey(2,QString::number(999));
238 else setSortKey(2,QString::number(mTodo->percentComplete())); 238 else setSortKey(2,QString::number(mTodo->percentComplete()));
239 } 239 }
240 else { 240 else {
241 if (mTodo->isCompleted()) setSortKey(2,QString::number(999)); 241 if (mTodo->isCompleted()) setSortKey(2,QString::number(999));
242 else setSortKey(2,QString::number(99)); 242 else setSortKey(2,QString::number(99));
243 } 243 }
244 QListViewItem * myChild = firstChild(); 244 QListViewItem * myChild = firstChild();
245 KOTodoViewItem *item; 245 KOTodoViewItem *item;
246 while( myChild ) { 246 while( myChild ) {
247 item = static_cast<KOTodoViewItem*>(myChild); 247 item = static_cast<KOTodoViewItem*>(myChild);
248 item->stateChange(state); 248 item->stateChange(state);
249 myChild = myChild->nextSibling(); 249 myChild = myChild->nextSibling();
250 } 250 }
251 mTodoView->modified(true); 251 mTodoView->modified(true);
252 mTodoView->setTodoModified( mTodo );
253 setMyPixmap(); 252 setMyPixmap();
253 mTodoView->setTodoModified( mTodo );
254} 254}
255 255
256bool KOTodoViewItem::isAlternate() 256bool KOTodoViewItem::isAlternate()
257{ 257{
258#ifndef KORG_NOLVALTERNATION 258#ifndef KORG_NOLVALTERNATION
259 KOTodoListView *lv = static_cast<KOTodoListView *>(listView()); 259 KOTodoListView *lv = static_cast<KOTodoListView *>(listView());
260 if (lv && lv->alternateBackground().isValid()) 260 if (lv && lv->alternateBackground().isValid())
261 { 261 {
262 KOTodoViewItem *above = 0; 262 KOTodoViewItem *above = 0;
263 above = dynamic_cast<KOTodoViewItem *>(itemAbove()); 263 above = dynamic_cast<KOTodoViewItem *>(itemAbove());
264 m_known = above ? above->m_known : true; 264 m_known = above ? above->m_known : true;
265 if (m_known) 265 if (m_known)
266 { 266 {
267 m_odd = above ? !above->m_odd : false; 267 m_odd = above ? !above->m_odd : false;
268 } 268 }
269 else 269 else
270 { 270 {
271 KOTodoViewItem *item; 271 KOTodoViewItem *item;
272 bool previous = true; 272 bool previous = true;
273 if (QListViewItem::parent()) 273 if (QListViewItem::parent())
274 { 274 {
275 item = dynamic_cast<KOTodoViewItem *>(QListViewItem::parent()); 275 item = dynamic_cast<KOTodoViewItem *>(QListViewItem::parent());
276 if (item) 276 if (item)
277 previous = item->m_odd; 277 previous = item->m_odd;
278 item = dynamic_cast<KOTodoViewItem *>(QListViewItem::parent()->firstChild()); 278 item = dynamic_cast<KOTodoViewItem *>(QListViewItem::parent()->firstChild());
279 } 279 }
280 else 280 else
281 { 281 {
282 item = dynamic_cast<KOTodoViewItem *>(lv->firstChild()); 282 item = dynamic_cast<KOTodoViewItem *>(lv->firstChild());
283 } 283 }
284 284
285 while(item) 285 while(item)
286 { 286 {
287 item->m_odd = previous = !previous; 287 item->m_odd = previous = !previous;
288 item->m_known = true; 288 item->m_known = true;
289 item = dynamic_cast<KOTodoViewItem *>(item->nextSibling()); 289 item = dynamic_cast<KOTodoViewItem *>(item->nextSibling());
290 } 290 }
291 } 291 }
292 return m_odd; 292 return m_odd;
293 } 293 }
294 return false; 294 return false;
295#else 295#else
296 return false; 296 return false;
297#endif 297#endif
298} 298}
299 299
300void KOTodoViewItem::paintCell(QPainter *p, const QColorGroup &cg, int column, int width, int alignment) 300void KOTodoViewItem::paintCell(QPainter *p, const QColorGroup &cg, int column, int width, int alignment)
301{ 301{
302 QColorGroup _cg = cg; 302 QColorGroup _cg = cg;
303 QColorGroup::ColorRole role; 303 QColorGroup::ColorRole role;
304 if ( KOPrefs::instance()->mTodoViewUsesForegroundColor ) 304 if ( KOPrefs::instance()->mTodoViewUsesForegroundColor )
305 role = QColorGroup::Text; 305 role = QColorGroup::Text;
306 else 306 else
307 role = QColorGroup::Base; 307 role = QColorGroup::Base;
308 //#ifndef KORG_NOLVALTERNATION 308 //#ifndef KORG_NOLVALTERNATION
309 // if (isAlternate()) 309 // if (isAlternate())
310 // _cg.setColor(QColorGroup::Base, static_cast< KOTodoListView* >(listView())->alternateBackground()); 310 // _cg.setColor(QColorGroup::Base, static_cast< KOTodoListView* >(listView())->alternateBackground());
311 bool setColor = KOPrefs::instance()->mTodoViewUsesCatColors; 311 bool setColor = KOPrefs::instance()->mTodoViewUsesCatColors;
312 QColor colorToSet; 312 QColor colorToSet;
313 if ( setColor ) { 313 if ( setColor ) {
314 QStringList categories = mTodo->categories(); 314 QStringList categories = mTodo->categories();
315 QString cat = categories.first(); 315 QString cat = categories.first();
316 if ( !cat.isEmpty()) { 316 if ( !cat.isEmpty()) {
317 colorToSet = *(KOPrefs::instance()->categoryColor(cat) ); 317 colorToSet = *(KOPrefs::instance()->categoryColor(cat) );
318 } else 318 } else
319 setColor = false; 319 setColor = false;
320 } 320 }
321 if (mTodo->hasDueDate()) { 321 if (mTodo->hasDueDate()) {
322 if (mTodo->dtDue().date()==QDate::currentDate() && 322 if (mTodo->dtDue().date()==QDate::currentDate() &&
323 !mTodo->isCompleted()) { 323 !mTodo->isCompleted()) {
324 //_cg.setColor( role , KOPrefs::instance()->mTodoDueTodayColor); 324 //_cg.setColor( role , KOPrefs::instance()->mTodoDueTodayColor);
325 colorToSet = KOPrefs::instance()->mTodoDueTodayColor; 325 colorToSet = KOPrefs::instance()->mTodoDueTodayColor;
326 setColor = true; 326 setColor = true;
327 } 327 }
328 if (mTodo->dtDue().date() < QDate::currentDate() && 328 if (mTodo->dtDue().date() < QDate::currentDate() &&
329 !mTodo->isCompleted()) { 329 !mTodo->isCompleted()) {
330 //_cg.setColor( role, KOPrefs::instance()->mTodoOverdueColor); 330 //_cg.setColor( role, KOPrefs::instance()->mTodoOverdueColor);
331 colorToSet = KOPrefs::instance()->mTodoOverdueColor; 331 colorToSet = KOPrefs::instance()->mTodoOverdueColor;
332 setColor = true; 332 setColor = true;
333 } 333 }
334 } 334 }
335 335
336 if ( setColor ) { 336 if ( setColor ) {
337 _cg.setColor(role,colorToSet ); 337 _cg.setColor(role,colorToSet );
338 if ( role == QColorGroup::Base) { 338 if ( role == QColorGroup::Base) {
339 int rgb = colorToSet.red(); 339 int rgb = colorToSet.red();
340 rgb += colorToSet.blue()/2; 340 rgb += colorToSet.blue()/2;
341 rgb += colorToSet.green(); 341 rgb += colorToSet.green();
342 if ( rgb < 200 ) 342 if ( rgb < 200 )
343 _cg.setColor(QColorGroup::Text,Qt::white ); 343 _cg.setColor(QColorGroup::Text,Qt::white );
344 } 344 }
345 } 345 }
346 //#endif 346 //#endif
347 if ( column > 0 ){ 347 if ( column > 0 ){
348 if ( column == 2 && !KOPrefs::instance()->mTodoViewShowsPercentage ) { 348 if ( column == 2 && !KOPrefs::instance()->mTodoViewShowsPercentage ) {
349 p->save(); 349 p->save();
350 int progress = (int)(( (width-6)*mTodo->percentComplete())/100.0 + 0.5); 350 int progress = (int)(( (width-6)*mTodo->percentComplete())/100.0 + 0.5);
351 351
352 p->fillRect( 0, 0, width, height(), _cg.base() ); // background 352 p->fillRect( 0, 0, width, height(), _cg.base() ); // background
353 // p->setPen(Qt::black ); //border 353 // p->setPen(Qt::black ); //border
354 // p->setBrush( KOPrefs::instance()->mHighlightColorKGlobalSettings::baseColor() ); //filling 354 // p->setBrush( KOPrefs::instance()->mHighlightColorKGlobalSettings::baseColor() ); //filling
355 QColor fc = KOPrefs::instance()->mHighlightColor; 355 QColor fc = KOPrefs::instance()->mHighlightColor;
356 if ( mTodo->percentComplete() == 100 ) 356 if ( mTodo->percentComplete() == 100 )
357 fc = darkGreen; 357 fc = darkGreen;
358 p->drawRect( 2, 2, width-4, height()-4); 358 p->drawRect( 2, 2, width-4, height()-4);
359 p->fillRect( 3, 3, progress, height()-6, 359 p->fillRect( 3, 3, progress, height()-6,
360 fc ); 360 fc );
361 p->restore(); 361 p->restore();
362 } else { 362 } else {
363 QCheckListItem::paintCell(p, _cg, column, width, alignment); 363 QCheckListItem::paintCell(p, _cg, column, width, alignment);
364 } 364 }
365 return; 365 return;
366 } 366 }
367 367
368 int align = alignment; 368 int align = alignment;
369 369
370 if ( !p ) 370 if ( !p )
371 return; 371 return;
372 372
373 p->fillRect( 0, 0, width, height(), _cg.brush( QColorGroup::Base ) ); 373 p->fillRect( 0, 0, width, height(), _cg.brush( QColorGroup::Base ) );
374 374
375 QListView *lv = listView(); 375 QListView *lv = listView();
376 if ( !lv ) 376 if ( !lv )
377 return; 377 return;
378 int marg = 2;//lv->itemMargin(); 378 int marg = 2;//lv->itemMargin();
379 int r = 0; 379 int r = 0;
380 QCheckListItem::Type myType = QCheckListItem::CheckBox; 380 QCheckListItem::Type myType = QCheckListItem::CheckBox;
381 int BoxSize = 20; 381 int BoxSize = 20;
382 int boxOffset = 2; 382 int boxOffset = 2;
383 int xOffset = 2; 383 int xOffset = 2;
384 if (qApp->desktop()->width() < 300 ) { 384 if (qApp->desktop()->width() < 300 ) {
385 BoxSize = 14; 385 BoxSize = 14;
386 boxOffset = -1; 386 boxOffset = -1;
387 xOffset = 1; 387 xOffset = 1;
388 // marg = 0; 388 // marg = 0;
389 } 389 }
390 if ( height() < BoxSize ) { 390 if ( height() < BoxSize ) {
391 boxOffset = boxOffset - ((BoxSize - height())/2) ; 391 boxOffset = boxOffset - ((BoxSize - height())/2) ;
392 // qDebug("boxOffset %d height %d", boxOffset, height() ); 392 // qDebug("boxOffset %d height %d", boxOffset, height() );
393 BoxSize = height(); 393 BoxSize = height();
394 394
395 } 395 }
396 //bool winStyle = lv->style() == WindowsStyle; 396 //bool winStyle = lv->style() == WindowsStyle;
397 397
398 int lineStart = 5; 398 int lineStart = 5;
399 if ( myType == Controller ) { 399 if ( myType == Controller ) {
400 if ( !pixmap( 0 ) ) 400 if ( !pixmap( 0 ) )
401 r += BoxSize + 4; 401 r += BoxSize + 4;
402 } else { 402 } else {
403 ASSERT( lv ); //### 403 ASSERT( lv ); //###
404 //QFontMetrics fm( lv->font() ); 404 //QFontMetrics fm( lv->font() );
405 //int d = fm.height(); 405 //int d = fm.height();
406 int x = 0; 406 int x = 0;
407 int y = (height() - BoxSize) / 2; 407 int y = (height() - BoxSize) / 2;
408 //p->setPen( QPen( _cg.text(), winStyle ? 2 : 1 ) ); 408 //p->setPen( QPen( _cg.text(), winStyle ? 2 : 1 ) );
409 if ( myType == CheckBox ) { 409 if ( myType == CheckBox ) {
410 if ( isEnabled() ) 410 if ( isEnabled() )
411 p->setPen( QPen( _cg.text(), 1 ) ); 411 p->setPen( QPen( _cg.text(), 1 ) );
412 else 412 else
413 p->setPen( QPen( listView()->palette().color( QPalette::Disabled, QColorGroup::Text ), 1 ) ); 413 p->setPen( QPen( listView()->palette().color( QPalette::Disabled, QColorGroup::Text ), 1 ) );
414 p->drawRect( x+marg, y+2, BoxSize-4, BoxSize-4 ); 414 p->drawRect( x+marg, y+2, BoxSize-4, BoxSize-4 );
415 lineStart = x+marg; 415 lineStart = x+marg;
416 ///////////////////// 416 /////////////////////
417 x++; 417 x++;
418 y++; 418 y++;
419 if ( isOn() ) { 419 if ( isOn() ) {
420 QPointArray a( 7*2 ); 420 QPointArray a( 7*2 );
421 int i, xx, yy; 421 int i, xx, yy;
422 xx = x+xOffset+marg+(boxOffset/2); 422 xx = x+xOffset+marg+(boxOffset/2);
423 yy = y+5+boxOffset; 423 yy = y+5+boxOffset;
424 for ( i=0; i<3; i++ ) { 424 for ( i=0; i<3; i++ ) {
425 a.setPoint( 2*i, xx, yy ); 425 a.setPoint( 2*i, xx, yy );
426 a.setPoint( 2*i+1, xx, yy+2 ); 426 a.setPoint( 2*i+1, xx, yy+2 );
427 // qDebug(" "); 427 // qDebug(" ");
428 xx++; yy++; 428 xx++; yy++;
429 } 429 }
430 yy -= 2; 430 yy -= 2;
431 for ( i=3; i<7; i++ ) { 431 for ( i=3; i<7; i++ ) {
432 a.setPoint( 2*i, xx, yy ); 432 a.setPoint( 2*i, xx, yy );
433 a.setPoint( 2*i+1, xx, yy+2 ); 433 a.setPoint( 2*i+1, xx, yy+2 );
434 xx++; yy--; 434 xx++; yy--;
435 } 435 }
436 p->setPen( darkGreen ); 436 p->setPen( darkGreen );
437 p->drawLineSegments( a ); 437 p->drawLineSegments( a );
438 } 438 }
439 //////////////////////// 439 ////////////////////////
440 } 440 }
441 r += BoxSize + 4; 441 r += BoxSize + 4;
442 } 442 }
443 443
444 p->translate( r, 0 ); 444 p->translate( r, 0 );
445 p->setPen( QPen( _cg.text() ) ); 445 p->setPen( QPen( _cg.text() ) );
446 QListViewItem::paintCell( p, _cg, column, width - r, align ); 446 QListViewItem::paintCell( p, _cg, column, width - r, align );
447 if ( mTodo->cancelled () ) { 447 if ( mTodo->cancelled () ) {
448 p->setPen( black ); 448 p->setPen( black );
449 QRect br = p->boundingRect( 1,1,1,1,0,mTodo->summary() ); 449 QRect br = p->boundingRect( 1,1,1,1,0,mTodo->summary() );
450 int wid = br.width() +lineStart; 450 int wid = br.width() +lineStart;
451 if ( wid > width-3 ) 451 if ( wid > width-3 )
452 wid = width-3; 452 wid = width-3;
453 p->drawLine( lineStart, height()/2+1, wid, height()/2+1 ); 453 p->drawLine( lineStart, height()/2+1, wid, height()/2+1 );
454 454
455 } 455 }
456 456
457} 457}
diff --git a/microkde/kdeui/klistview.cpp b/microkde/kdeui/klistview.cpp
index 6859d36..154cd02 100644
--- a/microkde/kdeui/klistview.cpp
+++ b/microkde/kdeui/klistview.cpp
@@ -1656,515 +1656,523 @@ void KListView::fileManagerKeyPressEvent (QKeyEvent* e)
1656 repaintItem2=nextItem; 1656 repaintItem2=nextItem;
1657 visItem=nextItem; 1657 visItem=nextItem;
1658 setCurrentItem(nextItem); 1658 setCurrentItem(nextItem);
1659 }; 1659 };
1660 break; 1660 break;
1661 1661
1662 case Key_End: 1662 case Key_End:
1663 //move to the last item and toggle selection of all items inbetween 1663 //move to the last item and toggle selection of all items inbetween
1664 nextItem=item; 1664 nextItem=item;
1665 if (d->selectedBySimpleMove) 1665 if (d->selectedBySimpleMove)
1666 item->setSelected(false); 1666 item->setSelected(false);
1667 if (shiftOrCtrl) 1667 if (shiftOrCtrl)
1668 d->selectedBySimpleMove=false; 1668 d->selectedBySimpleMove=false;
1669 1669
1670 while(nextItem!=0) 1670 while(nextItem!=0)
1671 { 1671 {
1672 if (shiftOrCtrl) 1672 if (shiftOrCtrl)
1673 nextItem->setSelected(!nextItem->isSelected()); 1673 nextItem->setSelected(!nextItem->isSelected());
1674 if (nextItem->itemBelow()==0) 1674 if (nextItem->itemBelow()==0)
1675 { 1675 {
1676 if (d->selectedBySimpleMove) 1676 if (d->selectedBySimpleMove)
1677 nextItem->setSelected(true); 1677 nextItem->setSelected(true);
1678 repaintItem2=nextItem; 1678 repaintItem2=nextItem;
1679 visItem=nextItem; 1679 visItem=nextItem;
1680 setCurrentItem(nextItem); 1680 setCurrentItem(nextItem);
1681 } 1681 }
1682 nextItem=nextItem->itemBelow(); 1682 nextItem=nextItem->itemBelow();
1683 } 1683 }
1684 emitSelectionChanged=TRUE; 1684 emitSelectionChanged=TRUE;
1685 break; 1685 break;
1686 1686
1687 case Key_Home: 1687 case Key_Home:
1688 // move to the first item and toggle selection of all items inbetween 1688 // move to the first item and toggle selection of all items inbetween
1689 nextItem = firstChild(); 1689 nextItem = firstChild();
1690 visItem = nextItem; 1690 visItem = nextItem;
1691 repaintItem2 = visItem; 1691 repaintItem2 = visItem;
1692 if (d->selectedBySimpleMove) 1692 if (d->selectedBySimpleMove)
1693 item->setSelected(false); 1693 item->setSelected(false);
1694 if (shiftOrCtrl) 1694 if (shiftOrCtrl)
1695 { 1695 {
1696 d->selectedBySimpleMove=false; 1696 d->selectedBySimpleMove=false;
1697 1697
1698 while ( nextItem != item ) 1698 while ( nextItem != item )
1699 { 1699 {
1700 nextItem->setSelected( !nextItem->isSelected() ); 1700 nextItem->setSelected( !nextItem->isSelected() );
1701 nextItem = nextItem->itemBelow(); 1701 nextItem = nextItem->itemBelow();
1702 } 1702 }
1703 item->setSelected( !item->isSelected() ); 1703 item->setSelected( !item->isSelected() );
1704 } 1704 }
1705 setCurrentItem( firstChild() ); 1705 setCurrentItem( firstChild() );
1706 emitSelectionChanged=TRUE; 1706 emitSelectionChanged=TRUE;
1707 break; 1707 break;
1708 1708
1709 case Key_Next: 1709 case Key_Next:
1710 items=visibleHeight()/item->height(); 1710 items=visibleHeight()/item->height();
1711 nextItem=item; 1711 nextItem=item;
1712 if (d->selectedBySimpleMove) 1712 if (d->selectedBySimpleMove)
1713 item->setSelected(false); 1713 item->setSelected(false);
1714 if (shiftOrCtrl) 1714 if (shiftOrCtrl)
1715 { 1715 {
1716 d->selectedBySimpleMove=false; 1716 d->selectedBySimpleMove=false;
1717 d->selectionDirection=1; 1717 d->selectionDirection=1;
1718 }; 1718 };
1719 1719
1720 for (int i=0; i<items; i++) 1720 for (int i=0; i<items; i++)
1721 { 1721 {
1722 if (shiftOrCtrl) 1722 if (shiftOrCtrl)
1723 nextItem->setSelected(!nextItem->isSelected()); 1723 nextItem->setSelected(!nextItem->isSelected());
1724 //the end 1724 //the end
1725 if ((i==items-1) || (nextItem->itemBelow()==0)) 1725 if ((i==items-1) || (nextItem->itemBelow()==0))
1726 1726
1727 { 1727 {
1728 if (shiftOrCtrl) 1728 if (shiftOrCtrl)
1729 nextItem->setSelected(!nextItem->isSelected()); 1729 nextItem->setSelected(!nextItem->isSelected());
1730 if (d->selectedBySimpleMove) 1730 if (d->selectedBySimpleMove)
1731 nextItem->setSelected(true); 1731 nextItem->setSelected(true);
1732 ensureItemVisible(nextItem); 1732 ensureItemVisible(nextItem);
1733 setCurrentItem(nextItem); 1733 setCurrentItem(nextItem);
1734 update(); 1734 update();
1735 if ((shiftOrCtrl) || (d->selectedBySimpleMove)) 1735 if ((shiftOrCtrl) || (d->selectedBySimpleMove))
1736 { 1736 {
1737 emit selectionChanged(); 1737 emit selectionChanged();
1738 } 1738 }
1739 return; 1739 return;
1740 } 1740 }
1741 nextItem=nextItem->itemBelow(); 1741 nextItem=nextItem->itemBelow();
1742 } 1742 }
1743 break; 1743 break;
1744 1744
1745 case Key_Prior: 1745 case Key_Prior:
1746 items=visibleHeight()/item->height(); 1746 items=visibleHeight()/item->height();
1747 nextItem=item; 1747 nextItem=item;
1748 if (d->selectedBySimpleMove) 1748 if (d->selectedBySimpleMove)
1749 item->setSelected(false); 1749 item->setSelected(false);
1750 if (shiftOrCtrl) 1750 if (shiftOrCtrl)
1751 { 1751 {
1752 d->selectionDirection=-1; 1752 d->selectionDirection=-1;
1753 d->selectedBySimpleMove=false; 1753 d->selectedBySimpleMove=false;
1754 }; 1754 };
1755 1755
1756 for (int i=0; i<items; i++) 1756 for (int i=0; i<items; i++)
1757 { 1757 {
1758 if ((nextItem!=item) &&(shiftOrCtrl)) 1758 if ((nextItem!=item) &&(shiftOrCtrl))
1759 nextItem->setSelected(!nextItem->isSelected()); 1759 nextItem->setSelected(!nextItem->isSelected());
1760 //the end 1760 //the end
1761 if ((i==items-1) || (nextItem->itemAbove()==0)) 1761 if ((i==items-1) || (nextItem->itemAbove()==0))
1762 1762
1763 { 1763 {
1764 if (d->selectedBySimpleMove) 1764 if (d->selectedBySimpleMove)
1765 nextItem->setSelected(true); 1765 nextItem->setSelected(true);
1766 ensureItemVisible(nextItem); 1766 ensureItemVisible(nextItem);
1767 setCurrentItem(nextItem); 1767 setCurrentItem(nextItem);
1768 update(); 1768 update();
1769 if ((shiftOrCtrl) || (d->selectedBySimpleMove)) 1769 if ((shiftOrCtrl) || (d->selectedBySimpleMove))
1770 { 1770 {
1771 emit selectionChanged(); 1771 emit selectionChanged();
1772 } 1772 }
1773 return; 1773 return;
1774 } 1774 }
1775 nextItem=nextItem->itemAbove(); 1775 nextItem=nextItem->itemAbove();
1776 } 1776 }
1777 break; 1777 break;
1778 1778
1779 case Key_Minus: 1779 case Key_Minus:
1780 if ( item->isOpen() ) 1780 if ( item->isOpen() )
1781 setOpen( item, FALSE ); 1781 setOpen( item, FALSE );
1782 break; 1782 break;
1783 case Key_Plus: 1783 case Key_Plus:
1784 if ( !item->isOpen() && (item->isExpandable() || item->childCount()) ) 1784 if ( !item->isOpen() && (item->isExpandable() || item->childCount()) )
1785 setOpen( item, TRUE ); 1785 setOpen( item, TRUE );
1786 break; 1786 break;
1787 default: 1787 default:
1788 bool realKey = ((e->key()!=Key_Shift) && (e->key()!=Key_Control) 1788 bool realKey = ((e->key()!=Key_Shift) && (e->key()!=Key_Control)
1789 && (e->key()!=Key_Meta) && (e->key()!=Key_Alt)); 1789 && (e->key()!=Key_Meta) && (e->key()!=Key_Alt));
1790 1790
1791 bool selectCurrentItem = (d->selectedBySimpleMove) && (item->isSelected()); 1791 bool selectCurrentItem = (d->selectedBySimpleMove) && (item->isSelected());
1792 if (realKey && selectCurrentItem) 1792 if (realKey && selectCurrentItem)
1793 item->setSelected(false); 1793 item->setSelected(false);
1794 //this is mainly for the "goto filename beginning with pressed char" feature (aleXXX) 1794 //this is mainly for the "goto filename beginning with pressed char" feature (aleXXX)
1795 QListView::SelectionMode oldSelectionMode = selectionMode(); 1795 QListView::SelectionMode oldSelectionMode = selectionMode();
1796 setSelectionMode (QListView::Multi); 1796 setSelectionMode (QListView::Multi);
1797 QListView::keyPressEvent (e); 1797 QListView::keyPressEvent (e);
1798 setSelectionMode (oldSelectionMode); 1798 setSelectionMode (oldSelectionMode);
1799 if (realKey && selectCurrentItem) 1799 if (realKey && selectCurrentItem)
1800 { 1800 {
1801 currentItem()->setSelected(true); 1801 currentItem()->setSelected(true);
1802 emitSelectionChanged=TRUE; 1802 emitSelectionChanged=TRUE;
1803 } 1803 }
1804 repaintItem2=currentItem(); 1804 repaintItem2=currentItem();
1805 if (realKey) 1805 if (realKey)
1806 visItem=currentItem(); 1806 visItem=currentItem();
1807 break; 1807 break;
1808 } 1808 }
1809 1809
1810 if (visItem) 1810 if (visItem)
1811 ensureItemVisible(visItem); 1811 ensureItemVisible(visItem);
1812 1812
1813 QRect ir; 1813 QRect ir;
1814 if (repaintItem1) 1814 if (repaintItem1)
1815 ir = ir.unite( itemRect(repaintItem1) ); 1815 ir = ir.unite( itemRect(repaintItem1) );
1816 if (repaintItem2) 1816 if (repaintItem2)
1817 ir = ir.unite( itemRect(repaintItem2) ); 1817 ir = ir.unite( itemRect(repaintItem2) );
1818 1818
1819 if ( !ir.isEmpty() ) 1819 if ( !ir.isEmpty() )
1820 { // rectangle to be repainted 1820 { // rectangle to be repainted
1821 if ( ir.x() < 0 ) 1821 if ( ir.x() < 0 )
1822 ir.moveBy( -ir.x(), 0 ); 1822 ir.moveBy( -ir.x(), 0 );
1823 viewport()->repaint( ir, FALSE ); 1823 viewport()->repaint( ir, FALSE );
1824 } 1824 }
1825 /*if (repaintItem1) 1825 /*if (repaintItem1)
1826 repaintItem1->repaint(); 1826 repaintItem1->repaint();
1827 if (repaintItem2) 1827 if (repaintItem2)
1828 repaintItem2->repaint();*/ 1828 repaintItem2->repaint();*/
1829 update(); 1829 update();
1830 if (emitSelectionChanged) 1830 if (emitSelectionChanged)
1831 emit selectionChanged(); 1831 emit selectionChanged();
1832} 1832}
1833 1833
1834void KListView::setSelectionModeExt (SelectionModeExt mode) 1834void KListView::setSelectionModeExt (SelectionModeExt mode)
1835{ 1835{
1836 d->selectionMode = mode; 1836 d->selectionMode = mode;
1837 1837
1838 switch (mode) 1838 switch (mode)
1839 { 1839 {
1840 case Single: 1840 case Single:
1841 case Multi: 1841 case Multi:
1842 case Extended: 1842 case Extended:
1843 case NoSelection: 1843 case NoSelection:
1844 setSelectionMode (static_cast<QListView::SelectionMode>(static_cast<int>(mode))); 1844 setSelectionMode (static_cast<QListView::SelectionMode>(static_cast<int>(mode)));
1845 break; 1845 break;
1846 1846
1847 case FileManager: 1847 case FileManager:
1848 setSelectionMode (QListView::Extended); 1848 setSelectionMode (QListView::Extended);
1849 break; 1849 break;
1850 1850
1851 default: 1851 default:
1852 kdWarning () << "Warning: illegal selection mode " << int(mode) << " set!" << endl; 1852 kdWarning () << "Warning: illegal selection mode " << int(mode) << " set!" << endl;
1853 break; 1853 break;
1854 } 1854 }
1855} 1855}
1856 1856
1857KListView::SelectionModeExt KListView::selectionModeExt () const 1857KListView::SelectionModeExt KListView::selectionModeExt () const
1858{ 1858{
1859 return d->selectionMode; 1859 return d->selectionMode;
1860} 1860}
1861 1861
1862int KListView::itemIndex( const QListViewItem *item ) const 1862int KListView::itemIndex( const QListViewItem *item ) const
1863{ 1863{
1864 if ( !item ) 1864 if ( !item )
1865 return -1; 1865 return -1;
1866 1866
1867 if ( item == firstChild() ) 1867 if ( item == firstChild() )
1868 return 0; 1868 return 0;
1869 else { 1869 else {
1870 QListViewItemIterator it(firstChild()); 1870 QListViewItemIterator it(firstChild());
1871 uint j = 0; 1871 uint j = 0;
1872 for (; it.current() && it.current() != item; ++it, ++j ); 1872 for (; it.current() && it.current() != item; ++it, ++j );
1873 1873
1874 if( !it.current() ) 1874 if( !it.current() )
1875 return -1; 1875 return -1;
1876 1876
1877 return j; 1877 return j;
1878 } 1878 }
1879} 1879}
1880 1880
1881QListViewItem* KListView::itemAtIndex(int index) 1881QListViewItem* KListView::itemAtIndex(int index)
1882{ 1882{
1883 if (index<0) 1883 if (index<0)
1884 return 0; 1884 return 0;
1885 1885
1886 int j(0); 1886 int j(0);
1887 for (QListViewItemIterator it=firstChild(); it.current(); it++) 1887 for (QListViewItemIterator it=firstChild(); it.current(); it++)
1888 { 1888 {
1889 if (j==index) 1889 if (j==index)
1890 return it.current(); 1890 return it.current();
1891 j++; 1891 j++;
1892 }; 1892 };
1893 return 0; 1893 return 0;
1894} 1894}
1895 1895
1896 1896
1897void KListView::emitContextMenu (KListView*, QListViewItem* i) 1897void KListView::emitContextMenu (KListView*, QListViewItem* i)
1898{ 1898{
1899 QPoint p; 1899 QPoint p;
1900 // qDebug("KListView::emitContextMenu "); 1900 // qDebug("KListView::emitContextMenu ");
1901 1901
1902 if (i) 1902 if (i)
1903 p = viewport()->mapToGlobal(itemRect(i).center()); 1903 p = viewport()->mapToGlobal(itemRect(i).center());
1904 else 1904 else
1905 p = mapToGlobal(rect().center()); 1905 p = mapToGlobal(rect().center());
1906 1906
1907 emit contextMenu (this, i, p); 1907 emit contextMenu (this, i, p);
1908} 1908}
1909 1909
1910void KListView::emitContextMenu (QListViewItem* i, const QPoint& p, int col) 1910void KListView::emitContextMenu (QListViewItem* i, const QPoint& p, int col)
1911{ 1911{
1912 // qDebug("KListView::emitContextMenu col"); 1912 QListViewItem* item = i;
1913 emit contextRequest( i, p, col ); 1913 int c = col;
1914 emit contextMenu (this, i, p); 1914 // do not trust the values for QListViewItem* i and int col;
1915 // qDebug("KListView::emitContextMenu col");
1916 if ( col == -1 ) {
1917 QPoint pp = viewport()->mapFromGlobal(p);
1918 item = itemAt( pp);
1919 c = header()->sectionAt(pp.x() );
1920 }
1921 emit contextRequest( item, p, c );
1922 emit contextMenu (this, item, p);
1915} 1923}
1916 1924
1917void KListView::setAcceptDrops (bool val) 1925void KListView::setAcceptDrops (bool val)
1918{ 1926{
1919 QListView::setAcceptDrops (val); 1927 QListView::setAcceptDrops (val);
1920 viewport()->setAcceptDrops (val); 1928 viewport()->setAcceptDrops (val);
1921} 1929}
1922 1930
1923int KListView::dropVisualizerWidth () const 1931int KListView::dropVisualizerWidth () const
1924{ 1932{
1925 return d->mDropVisualizerWidth; 1933 return d->mDropVisualizerWidth;
1926} 1934}
1927 1935
1928 1936
1929void KListView::viewportPaintEvent(QPaintEvent *e) 1937void KListView::viewportPaintEvent(QPaintEvent *e)
1930{ 1938{
1931 QListView::viewportPaintEvent(e); 1939 QListView::viewportPaintEvent(e);
1932 1940
1933 if (d->mOldDropVisualizer.isValid() && e->rect().intersects(d->mOldDropVisualizer)) 1941 if (d->mOldDropVisualizer.isValid() && e->rect().intersects(d->mOldDropVisualizer))
1934 { 1942 {
1935 QPainter painter(viewport()); 1943 QPainter painter(viewport());
1936 1944
1937 // This is where we actually draw the drop-visualizer 1945 // This is where we actually draw the drop-visualizer
1938 painter.fillRect(d->mOldDropVisualizer, Dense4Pattern); 1946 painter.fillRect(d->mOldDropVisualizer, Dense4Pattern);
1939 } 1947 }
1940 if (d->mOldDropHighlighter.isValid() && e->rect().intersects(d->mOldDropHighlighter)) 1948 if (d->mOldDropHighlighter.isValid() && e->rect().intersects(d->mOldDropHighlighter))
1941 { 1949 {
1942 QPainter painter(viewport()); 1950 QPainter painter(viewport());
1943 1951
1944qDebug("KListView::viewportPaintEvent has to be verified"); 1952qDebug("KListView::viewportPaintEvent has to be verified");
1945 1953
1946 // This is where we actually draw the drop-highlighter 1954 // This is where we actually draw the drop-highlighter
1947//US style().drawPrimitive(QStyle::PE_FocusRect, &painter, d->mOldDropHighlighter, colorGroup(), 1955//US style().drawPrimitive(QStyle::PE_FocusRect, &painter, d->mOldDropHighlighter, colorGroup(),
1948//US QStyle::Style_FocusAtBorder); 1956//US QStyle::Style_FocusAtBorder);
1949 1957
1950//LR style().drawFocusRect(&painter, d->mOldDropHighlighter, colorGroup(), (const QColor*)0, true); 1958//LR style().drawFocusRect(&painter, d->mOldDropHighlighter, colorGroup(), (const QColor*)0, true);
1951 1959
1952 1960
1953 } 1961 }
1954} 1962}
1955 1963
1956void KListView::setFullWidth() 1964void KListView::setFullWidth()
1957{ 1965{
1958 setFullWidth(true); 1966 setFullWidth(true);
1959} 1967}
1960 1968
1961void KListView::setFullWidth(bool fullWidth) 1969void KListView::setFullWidth(bool fullWidth)
1962{ 1970{
1963 d->fullWidth = fullWidth; 1971 d->fullWidth = fullWidth;
1964//US header()->setStretchEnabled(fullWidth, columns()-1); 1972//US header()->setStretchEnabled(fullWidth, columns()-1);
1965} 1973}
1966 1974
1967bool KListView::fullWidth() const 1975bool KListView::fullWidth() const
1968{ 1976{
1969 return d->fullWidth; 1977 return d->fullWidth;
1970} 1978}
1971 1979
1972int KListView::addColumn(const QString& label, int width) 1980int KListView::addColumn(const QString& label, int width)
1973{ 1981{
1974 int result = QListView::addColumn(label, width); 1982 int result = QListView::addColumn(label, width);
1975 if (d->fullWidth) { 1983 if (d->fullWidth) {
1976//US header()->setStretchEnabled(false, columns()-2); 1984//US header()->setStretchEnabled(false, columns()-2);
1977//US header()->setStretchEnabled(true, columns()-1); 1985//US header()->setStretchEnabled(true, columns()-1);
1978 } 1986 }
1979 return result; 1987 return result;
1980} 1988}
1981 1989
1982int KListView::addColumn(const QIconSet& iconset, const QString& label, int width) 1990int KListView::addColumn(const QIconSet& iconset, const QString& label, int width)
1983{ 1991{
1984 int result = QListView::addColumn(iconset, label, width); 1992 int result = QListView::addColumn(iconset, label, width);
1985 if (d->fullWidth) { 1993 if (d->fullWidth) {
1986//US header()->setStretchEnabled(false, columns()-2); 1994//US header()->setStretchEnabled(false, columns()-2);
1987//US header()->setStretchEnabled(true, columns()-1); 1995//US header()->setStretchEnabled(true, columns()-1);
1988 } 1996 }
1989 return result; 1997 return result;
1990} 1998}
1991 1999
1992void KListView::removeColumn(int index) 2000void KListView::removeColumn(int index)
1993{ 2001{
1994 QListView::removeColumn(index); 2002 QListView::removeColumn(index);
1995//US if (d->fullWidth && index == columns()) header()->setStretchEnabled(true, columns()-1); 2003//US if (d->fullWidth && index == columns()) header()->setStretchEnabled(true, columns()-1);
1996} 2004}
1997 2005
1998void KListView::viewportResizeEvent(QResizeEvent* e) 2006void KListView::viewportResizeEvent(QResizeEvent* e)
1999{ 2007{
2000 QListView::viewportResizeEvent(e); 2008 QListView::viewportResizeEvent(e);
2001} 2009}
2002 2010
2003const QColor &KListView::alternateBackground() const 2011const QColor &KListView::alternateBackground() const
2004{ 2012{
2005 return d->alternateBackground; 2013 return d->alternateBackground;
2006} 2014}
2007 2015
2008void KListView::setAlternateBackground(const QColor &c) 2016void KListView::setAlternateBackground(const QColor &c)
2009{ 2017{
2010 d->alternateBackground = c; 2018 d->alternateBackground = c;
2011 repaint(); 2019 repaint();
2012} 2020}
2013 2021
2014void KListView::saveLayout(KConfig *config, const QString &group) const 2022void KListView::saveLayout(KConfig *config, const QString &group) const
2015{ 2023{
2016 KConfigGroupSaver saver(config, group); 2024 KConfigGroupSaver saver(config, group);
2017 QStringList widths, order; 2025 QStringList widths, order;
2018 for (int i = 0; i < columns(); ++i) 2026 for (int i = 0; i < columns(); ++i)
2019 { 2027 {
2020 widths << QString::number(columnWidth(i)); 2028 widths << QString::number(columnWidth(i));
2021 order << QString::number(header()->mapToIndex(i)); 2029 order << QString::number(header()->mapToIndex(i));
2022 } 2030 }
2023 config->writeEntry("ColumnWidths", widths); 2031 config->writeEntry("ColumnWidths", widths);
2024 config->writeEntry("ColumnOrder", order); 2032 config->writeEntry("ColumnOrder", order);
2025 config->writeEntry("SortColumn", d->sortColumn); 2033 config->writeEntry("SortColumn", d->sortColumn);
2026 config->writeEntry("SortAscending", d->sortAscending); 2034 config->writeEntry("SortAscending", d->sortAscending);
2027} 2035}
2028 2036
2029void KListView::restoreLayout(KConfig *config, const QString &group) 2037void KListView::restoreLayout(KConfig *config, const QString &group)
2030{ 2038{
2031 KConfigGroupSaver saver(config, group); 2039 KConfigGroupSaver saver(config, group);
2032 QStringList cols = config->readListEntry("ColumnWidths"); 2040 QStringList cols = config->readListEntry("ColumnWidths");
2033 int i = 0; 2041 int i = 0;
2034 for (QStringList::ConstIterator it = cols.begin(); it != cols.end(); ++it) 2042 for (QStringList::ConstIterator it = cols.begin(); it != cols.end(); ++it)
2035 setColumnWidth(i++, (*it).toInt()); 2043 setColumnWidth(i++, (*it).toInt());
2036 2044
2037 cols = config->readListEntry("ColumnOrder"); 2045 cols = config->readListEntry("ColumnOrder");
2038 i = 0; 2046 i = 0;
2039 for (QStringList::ConstIterator it = cols.begin(); it != cols.end(); ++it) 2047 for (QStringList::ConstIterator it = cols.begin(); it != cols.end(); ++it)
2040 header()->moveSection(i++, (*it).toInt()); 2048 header()->moveSection(i++, (*it).toInt());
2041 2049
2042/*US I changed the following code, because hasKey is not available. 2050/*US I changed the following code, because hasKey is not available.
2043!!! check if my version is correct 2051!!! check if my version is correct
2044 if (config->hasKey("SortColumn")) 2052 if (config->hasKey("SortColumn"))
2045 setSorting(config->readNumEntry("SortColumn"), config->readBoolEntry("SortAscending", true)); 2053 setSorting(config->readNumEntry("SortColumn"), config->readBoolEntry("SortAscending", true));
2046*/ 2054*/
2047 QStringList langLst = config->readListEntry( "SortColumn" ); 2055 QStringList langLst = config->readListEntry( "SortColumn" );
2048 if (!langLst.isEmpty()) 2056 if (!langLst.isEmpty())
2049 setSorting(config->readNumEntry("SortColumn"), config->readBoolEntry("SortAscending", true)); 2057 setSorting(config->readNumEntry("SortColumn"), config->readBoolEntry("SortAscending", true));
2050} 2058}
2051 2059
2052void KListView::setSorting(int column, bool ascending) 2060void KListView::setSorting(int column, bool ascending)
2053{ 2061{
2054 d->sortColumn = column; 2062 d->sortColumn = column;
2055 d->sortAscending = ascending; 2063 d->sortAscending = ascending;
2056 QListView::setSorting(column, ascending); 2064 QListView::setSorting(column, ascending);
2057} 2065}
2058 2066
2059int KListView::columnSorted(void) const 2067int KListView::columnSorted(void) const
2060{ 2068{
2061 return d->sortColumn; 2069 return d->sortColumn;
2062} 2070}
2063 2071
2064bool KListView::ascendingSort(void) const 2072bool KListView::ascendingSort(void) const
2065{ 2073{
2066 return d->sortAscending; 2074 return d->sortAscending;
2067} 2075}
2068 2076
2069KListViewItem::KListViewItem(QListView *parent) 2077KListViewItem::KListViewItem(QListView *parent)
2070 : QListViewItem(parent) 2078 : QListViewItem(parent)
2071{ 2079{
2072 init(); 2080 init();
2073} 2081}
2074 2082
2075KListViewItem::KListViewItem(QListViewItem *parent) 2083KListViewItem::KListViewItem(QListViewItem *parent)
2076 : QListViewItem(parent) 2084 : QListViewItem(parent)
2077{ 2085{
2078 init(); 2086 init();
2079} 2087}
2080 2088
2081KListViewItem::KListViewItem(QListView *parent, QListViewItem *after) 2089KListViewItem::KListViewItem(QListView *parent, QListViewItem *after)
2082 : QListViewItem(parent, after) 2090 : QListViewItem(parent, after)
2083{ 2091{
2084 init(); 2092 init();
2085} 2093}
2086 2094
2087KListViewItem::KListViewItem(QListViewItem *parent, QListViewItem *after) 2095KListViewItem::KListViewItem(QListViewItem *parent, QListViewItem *after)
2088 : QListViewItem(parent, after) 2096 : QListViewItem(parent, after)
2089{ 2097{
2090 init(); 2098 init();
2091} 2099}
2092 2100
2093KListViewItem::KListViewItem(QListView *parent, 2101KListViewItem::KListViewItem(QListView *parent,
2094 QString label1, QString label2, QString label3, QString label4, 2102 QString label1, QString label2, QString label3, QString label4,
2095 QString label5, QString label6, QString label7, QString label8) 2103 QString label5, QString label6, QString label7, QString label8)
2096 : QListViewItem(parent, label1, label2, label3, label4, label5, label6, label7, label8) 2104 : QListViewItem(parent, label1, label2, label3, label4, label5, label6, label7, label8)
2097{ 2105{
2098 init(); 2106 init();
2099} 2107}
2100 2108
2101KListViewItem::KListViewItem(QListViewItem *parent, 2109KListViewItem::KListViewItem(QListViewItem *parent,
2102 QString label1, QString label2, QString label3, QString label4, 2110 QString label1, QString label2, QString label3, QString label4,
2103 QString label5, QString label6, QString label7, QString label8) 2111 QString label5, QString label6, QString label7, QString label8)
2104 : QListViewItem(parent, label1, label2, label3, label4, label5, label6, label7, label8) 2112 : QListViewItem(parent, label1, label2, label3, label4, label5, label6, label7, label8)
2105{ 2113{
2106 init(); 2114 init();
2107} 2115}
2108 2116
2109KListViewItem::KListViewItem(QListView *parent, QListViewItem *after, 2117KListViewItem::KListViewItem(QListView *parent, QListViewItem *after,
2110 QString label1, QString label2, QString label3, QString label4, 2118 QString label1, QString label2, QString label3, QString label4,
2111 QString label5, QString label6, QString label7, QString label8) 2119 QString label5, QString label6, QString label7, QString label8)
2112 : QListViewItem(parent, after, label1, label2, label3, label4, label5, label6, label7, label8) 2120 : QListViewItem(parent, after, label1, label2, label3, label4, label5, label6, label7, label8)
2113{ 2121{
2114 init(); 2122 init();
2115} 2123}
2116 2124
2117KListViewItem::KListViewItem(QListViewItem *parent, QListViewItem *after, 2125KListViewItem::KListViewItem(QListViewItem *parent, QListViewItem *after,
2118 QString label1, QString label2, QString label3, QString label4, 2126 QString label1, QString label2, QString label3, QString label4,
2119 QString label5, QString label6, QString label7, QString label8) 2127 QString label5, QString label6, QString label7, QString label8)
2120 : QListViewItem(parent, after, label1, label2, label3, label4, label5, label6, label7, label8) 2128 : QListViewItem(parent, after, label1, label2, label3, label4, label5, label6, label7, label8)
2121{ 2129{
2122 init(); 2130 init();
2123} 2131}
2124 2132
2125KListViewItem::~KListViewItem() 2133KListViewItem::~KListViewItem()
2126{ 2134{
2127} 2135}
2128 2136
2129void KListViewItem::init() 2137void KListViewItem::init()
2130{ 2138{
2131 m_known = false; 2139 m_known = false;
2132} 2140}
2133 2141
2134const QColor &KListViewItem::backgroundColor() 2142const QColor &KListViewItem::backgroundColor()
2135{ 2143{
2136 if (isAlternate()) 2144 if (isAlternate())
2137 return static_cast< KListView* >(listView())->alternateBackground(); 2145 return static_cast< KListView* >(listView())->alternateBackground();
2138 return listView()->viewport()->colorGroup().base(); 2146 return listView()->viewport()->colorGroup().base();
2139} 2147}
2140 2148
2141bool KListViewItem::isAlternate() 2149bool KListViewItem::isAlternate()
2142{ 2150{
2143 KListView *lv = static_cast<KListView *>(listView()); 2151 KListView *lv = static_cast<KListView *>(listView());
2144 if (lv && lv->alternateBackground().isValid()) 2152 if (lv && lv->alternateBackground().isValid())
2145 { 2153 {
2146 KListViewItem *above = 0; 2154 KListViewItem *above = 0;
2147//US above = dynamic_cast<KListViewItem *>(itemAbove()); 2155//US above = dynamic_cast<KListViewItem *>(itemAbove());
2148 above = (KListViewItem *)(itemAbove()); 2156 above = (KListViewItem *)(itemAbove());
2149 m_known = above ? above->m_known : true; 2157 m_known = above ? above->m_known : true;
2150 if (m_known) 2158 if (m_known)
2151 { 2159 {
2152 m_odd = above ? !above->m_odd : false; 2160 m_odd = above ? !above->m_odd : false;
2153 } 2161 }
2154 else 2162 else
2155 { 2163 {
2156 KListViewItem *item; 2164 KListViewItem *item;
2157 bool previous = true; 2165 bool previous = true;
2158 if (parent()) 2166 if (parent())
2159 { 2167 {
2160//US item = dynamic_cast<KListViewItem *>(parent()); 2168//US item = dynamic_cast<KListViewItem *>(parent());
2161 item = (KListViewItem *)(parent()); 2169 item = (KListViewItem *)(parent());
2162 if (item) 2170 if (item)
2163 previous = item->m_odd; 2171 previous = item->m_odd;
2164//US item = dynamic_cast<KListViewItem *>(parent()->firstChild()); 2172//US item = dynamic_cast<KListViewItem *>(parent()->firstChild());
2165 item = (KListViewItem *)(parent()->firstChild()); 2173 item = (KListViewItem *)(parent()->firstChild());
2166 } 2174 }
2167 else 2175 else
2168 { 2176 {
2169//US item = dynamic_cast<KListViewItem *>(lv->firstChild()); 2177//US item = dynamic_cast<KListViewItem *>(lv->firstChild());
2170 item = (KListViewItem *)(lv->firstChild()); 2178 item = (KListViewItem *)(lv->firstChild());
diff --git a/version b/version
index dedf950..02b0fb1 100644
--- a/version
+++ b/version
@@ -1 +1 @@
version = "1.9.19"; version = "1.9.20";