author | zautrix <zautrix> | 2005-04-17 12:17:07 (UTC) |
---|---|---|
committer | zautrix <zautrix> | 2005-04-17 12:17:07 (UTC) |
commit | 2d81c75c4ffb8f144ae58e90e68496500d07a19e (patch) (unidiff) | |
tree | 1b27958fdc2948c1235579029188b1de78d7b820 | |
parent | f64384edcc1e3b3f7511480866b0900aa1ebdda6 (diff) | |
download | kdepimpi-2d81c75c4ffb8f144ae58e90e68496500d07a19e.zip kdepimpi-2d81c75c4ffb8f144ae58e90e68496500d07a19e.tar.gz kdepimpi-2d81c75c4ffb8f144ae58e90e68496500d07a19e.tar.bz2 |
fixx
-rw-r--r-- | bin/kdepim/WhatsNew.txt | 4 | ||||
-rw-r--r-- | korganizer/koagenda.cpp | 264 | ||||
-rw-r--r-- | korganizer/koagenda.h | 2 | ||||
-rw-r--r-- | korganizer/koagendaview.cpp | 22 |
4 files changed, 46 insertions, 246 deletions
diff --git a/bin/kdepim/WhatsNew.txt b/bin/kdepim/WhatsNew.txt index 44bf20b..03895fd 100644 --- a/bin/kdepim/WhatsNew.txt +++ b/bin/kdepim/WhatsNew.txt | |||
@@ -1,260 +1,264 @@ | |||
1 | Info about the changes in new versions of KDE-Pim/Pi | 1 | Info about the changes in new versions of KDE-Pim/Pi |
2 | 2 | ||
3 | ********** VERSION 2.0.28 ************ | 3 | ********** VERSION 2.0.28 ************ |
4 | 4 | ||
5 | KO/Pi: | ||
6 | Fixed two problems in KO/Pi timetracking. | ||
7 | Added context menu to month view for creating new events/todos. | ||
8 | Fixed some other small bugs. | ||
5 | 9 | ||
6 | 10 | ||
7 | ********** VERSION 2.0.27 ************ | 11 | ********** VERSION 2.0.27 ************ |
8 | 12 | ||
9 | More bugfixes. | 13 | More bugfixes. |
10 | Added possibility to clone in KO/Pi a todo with all its subtodos. | 14 | Added possibility to clone in KO/Pi a todo with all its subtodos. |
11 | Added config option for alternate background in list views. | 15 | Added config option for alternate background in list views. |
12 | 16 | ||
13 | Added a timetracker funtionality in KO/Pi for todos in the todo view. | 17 | Added a timetracker funtionality in KO/Pi for todos in the todo view. |
14 | If a todo is set to started and then to stopped it is saving information about the runtime in | 18 | If a todo is set to started and then to stopped it is saving information about the runtime in |
15 | <yourhome>/kdepim/apps/timetrackerdir. | 19 | <yourhome>/kdepim/apps/timetrackerdir. |
16 | To read, display, print this information an external program is needed which will be developed. | 20 | To read, display, print this information an external program is needed which will be developed. |
17 | It will display the data in a Gantt timetable view with one row for each todo. | 21 | It will display the data in a Gantt timetable view with one row for each todo. |
18 | It will have many possibilities sorting the data after category, parent todos, attendees, ... and for creating/printing status reports/summaries. | 22 | It will have many possibilities sorting the data after category, parent todos, attendees, ... and for creating/printing status reports/summaries. |
19 | Merging of data from different computers/users will be quite easy because every run is stored in a single file. | 23 | Merging of data from different computers/users will be quite easy because every run is stored in a single file. |
20 | 24 | ||
21 | ********** VERSION 2.0.26 ************ | 25 | ********** VERSION 2.0.26 ************ |
22 | 26 | ||
23 | Added two more fields to the KA/Pi view config: | 27 | Added two more fields to the KA/Pi view config: |
24 | A "Mobile (home)" and a "Mobile (work)" field. | 28 | A "Mobile (home)" and a "Mobile (work)" field. |
25 | Fixed utf8 import (e.g. for Japaneese text) in KA/Pi. | 29 | Fixed utf8 import (e.g. for Japaneese text) in KA/Pi. |
26 | 30 | ||
27 | Some alarm applet enhancements, e.g. sound stops automatically if value of suspend spinbox changes. | 31 | Some alarm applet enhancements, e.g. sound stops automatically if value of suspend spinbox changes. |
28 | And again fixed some more small bugs. | 32 | And again fixed some more small bugs. |
29 | 33 | ||
30 | ********** VERSION 2.0.25 ************ | 34 | ********** VERSION 2.0.25 ************ |
31 | 35 | ||
32 | And again fixed some bugs. | 36 | And again fixed some bugs. |
33 | 37 | ||
34 | ********** VERSION 2.0.24 ************ | 38 | ********** VERSION 2.0.24 ************ |
35 | 39 | ||
36 | Fixed again a lot of small bugs. | 40 | Fixed again a lot of small bugs. |
37 | Some performance optimizations in date navigator. | 41 | Some performance optimizations in date navigator. |
38 | Month view displays now multi days events on top of each cell, such that it is more likely that all multi days items of one event are in the same row. | 42 | Month view displays now multi days events on top of each cell, such that it is more likely that all multi days items of one event are in the same row. |
39 | 43 | ||
40 | ********** VERSION 2.0.23 ************ | 44 | ********** VERSION 2.0.23 ************ |
41 | 45 | ||
42 | Fixed again a lot of small and strange bugs, e.g. the missing toolbar of KA/Pi after a new installation. | 46 | Fixed again a lot of small and strange bugs, e.g. the missing toolbar of KA/Pi after a new installation. |
43 | Fixed the (agenda) layout of KO/Pi on 5500er. | 47 | Fixed the (agenda) layout of KO/Pi on 5500er. |
44 | Some usebility enhancements (e.g. reselection the current item of the todo view after some changes). | 48 | Some usebility enhancements (e.g. reselection the current item of the todo view after some changes). |
45 | 49 | ||
46 | ********** VERSION 2.0.22 ************ | 50 | ********** VERSION 2.0.22 ************ |
47 | 51 | ||
48 | KO/Pi: | 52 | KO/Pi: |
49 | Fix for creating events/todos via the abgenda context menu. | 53 | Fix for creating events/todos via the abgenda context menu. |
50 | Added option to split toolbar to 3 toolbars. | 54 | Added option to split toolbar to 3 toolbars. |
51 | (Toolbar moving s disabled for this option due to a bug in Qt somewhere). | 55 | (Toolbar moving s disabled for this option due to a bug in Qt somewhere). |
52 | Added option to show one small filter-view-toolbar. | 56 | Added option to show one small filter-view-toolbar. |
53 | Added a print option to the desktop version: | 57 | Added a print option to the desktop version: |
54 | Now you can print out the view of the "Event Viewer". | 58 | Now you can print out the view of the "Event Viewer". |
55 | That means you can print all data of one particular event/todo. | 59 | That means you can print all data of one particular event/todo. |
56 | Added scaling options to printout of Event Viewer and What'sNext View. | 60 | Added scaling options to printout of Event Viewer and What'sNext View. |
57 | Fixed some problems in the month view in "week start sunday" mode. | 61 | Fixed some problems in the month view in "week start sunday" mode. |
58 | KA/Pi: | 62 | KA/Pi: |
59 | Added two more config options. | 63 | Added two more config options. |
60 | Fixed resizing problem of address request dialog when orientation was switched. | 64 | Fixed resizing problem of address request dialog when orientation was switched. |
61 | Cleaned up the menu structure. | 65 | Cleaned up the menu structure. |
62 | Fixed some more problems. | 66 | Fixed some more problems. |
63 | 67 | ||
64 | Fixed the annoying problem that scrolling continued after the key was released in KO/Pi Monthview and the KA/Pi views. | 68 | Fixed the annoying problem that scrolling continued after the key was released in KO/Pi Monthview and the KA/Pi views. |
65 | 69 | ||
66 | And, this is a really cool option (Ben did suggest it): | 70 | And, this is a really cool option (Ben did suggest it): |
67 | Now KO/Pi and KA/Pi can be run from a USB stick: | 71 | Now KO/Pi and KA/Pi can be run from a USB stick: |
68 | All data is read from and written to the stick. | 72 | All data is read from and written to the stick. |
69 | You can enable this in the global configure option TAB with: | 73 | You can enable this in the global configure option TAB with: |
70 | Save using LOCAL storage. | 74 | Save using LOCAL storage. |
71 | Just put KDE-Pim/Pi on a memory stick and you can access all your PIM data on every computer with Windows XP. It will work with the ME and Linux versions as well. I will put a memory stick version for teh next stable release online. | 75 | Just put KDE-Pim/Pi on a memory stick and you can access all your PIM data on every computer with Windows XP. It will work with the ME and Linux versions as well. I will put a memory stick version for teh next stable release online. |
72 | 76 | ||
73 | ********** VERSION 2.0.21 ************ | 77 | ********** VERSION 2.0.21 ************ |
74 | 78 | ||
75 | Fixed another SMTP problem in OM/Pi. | 79 | Fixed another SMTP problem in OM/Pi. |
76 | Some small changed in the new datenavigator in KO/Pi. | 80 | Some small changed in the new datenavigator in KO/Pi. |
77 | Changed default setting for new filter in KA/Pi to "exclude categories". | 81 | Changed default setting for new filter in KA/Pi to "exclude categories". |
78 | Changed the default font size for 640x480 display . | 82 | Changed the default font size for 640x480 display . |
79 | Changed popup menu behaviour in agenda and list view. | 83 | Changed popup menu behaviour in agenda and list view. |
80 | Fixed some layout problems of the date label size in the month view. | 84 | Fixed some layout problems of the date label size in the month view. |
81 | Made month view update faster. | 85 | Made month view update faster. |
82 | Made first datenavigator repainting faster. | 86 | Made first datenavigator repainting faster. |
83 | Changed the title of the event/todo edit dialogs. | 87 | Changed the title of the event/todo edit dialogs. |
84 | Timelabels in agenga changed from 22:00 to 22 oo. ( the oo higher, of course). | 88 | Timelabels in agenga changed from 22:00 to 22 oo. ( the oo higher, of course). |
85 | Many small usebility fixes in KO/Pi. | 89 | Many small usebility fixes in KO/Pi. |
86 | Pressing the "Calendar" button on the Z switches now to the next view in KO/Pi. | 90 | Pressing the "Calendar" button on the Z switches now to the next view in KO/Pi. |
87 | The set of possible "next views" are the views you have toolbar buttons for. | 91 | The set of possible "next views" are the views you have toolbar buttons for. |
88 | 92 | ||
89 | Made alarm sound working on Linux. | 93 | Made alarm sound working on Linux. |
90 | 94 | ||
91 | KO/Pi alarm applet changed: | 95 | KO/Pi alarm applet changed: |
92 | Made buttons in alarm dialog much bigger. | 96 | Made buttons in alarm dialog much bigger. |
93 | Made setting of timer more user friendly by showing the actual timer fire time and making the buttons in the timer settings much bigger. | 97 | Made setting of timer more user friendly by showing the actual timer fire time and making the buttons in the timer settings much bigger. |
94 | The goal was it to make it possible to use a finger tip ( and not the stylus ) on the touchscreen to adjust the settings. | 98 | The goal was it to make it possible to use a finger tip ( and not the stylus ) on the touchscreen to adjust the settings. |
95 | 99 | ||
96 | And because this version is realeased at Easter, I added an Easter-egg: | 100 | And because this version is realeased at Easter, I added an Easter-egg: |
97 | With a new undocumented command you can get a message box about the next alarm. | 101 | With a new undocumented command you can get a message box about the next alarm. |
98 | Good luck to find it! | 102 | Good luck to find it! |
99 | 103 | ||
100 | 104 | ||
101 | 105 | ||
102 | ********** VERSION 2.0.20 ************ | 106 | ********** VERSION 2.0.20 ************ |
103 | 107 | ||
104 | Two small fixes in OM/Pi. | 108 | Two small fixes in OM/Pi. |
105 | 109 | ||
106 | Better resizing of the new datenavigator in KO/Pi. | 110 | Better resizing of the new datenavigator in KO/Pi. |
107 | 111 | ||
108 | ********** VERSION 2.0.19 ************ | 112 | ********** VERSION 2.0.19 ************ |
109 | KO/Pi: | 113 | KO/Pi: |
110 | Enhancements and bugfixes in the new datenavigator. | 114 | Enhancements and bugfixes in the new datenavigator. |
111 | Bugfix in this changelog: | 115 | Bugfix in this changelog: |
112 | The datenavigator was changed in version 2.0.18, not the datepicker. | 116 | The datenavigator was changed in version 2.0.18, not the datepicker. |
113 | 117 | ||
114 | ********** VERSION 2.0.18 ************ | 118 | ********** VERSION 2.0.18 ************ |
115 | KO/Pi: | 119 | KO/Pi: |
116 | Fixed some minor problems. | 120 | Fixed some minor problems. |
117 | Cleaned up the KO/Pi config dialog. | 121 | Cleaned up the KO/Pi config dialog. |
118 | Fixed problem moving events in aganda view. | 122 | Fixed problem moving events in aganda view. |
119 | Made datepicker scaleable, i.e. if the datenavigator shows now a | 123 | Made datepicker scaleable, i.e. if the datenavigator shows now a |
120 | datenavigator matrix depending on its size. | 124 | datenavigator matrix depending on its size. |
121 | Birthdays are now displayed green in the datenavigator. | 125 | Birthdays are now displayed green in the datenavigator. |
122 | What'sThis Help in datenavigator shows all events of the day. | 126 | What'sThis Help in datenavigator shows all events of the day. |
123 | 127 | ||
124 | OM/Pi: | 128 | OM/Pi: |
125 | Updated the backend mail library to the latest version. | 129 | Updated the backend mail library to the latest version. |
126 | Please backup your mail before using this version. | 130 | Please backup your mail before using this version. |
127 | 131 | ||
128 | ********** VERSION 2.0.17 ************ | 132 | ********** VERSION 2.0.17 ************ |
129 | 133 | ||
130 | KO/Pi: | 134 | KO/Pi: |
131 | Tooltips in month view were not sorted. Fixed. | 135 | Tooltips in month view were not sorted. Fixed. |
132 | Daylabel in agenda view ( for display of one day ) was too short. Fixed. | 136 | Daylabel in agenda view ( for display of one day ) was too short. Fixed. |
133 | Conflict display dialog for syncing was not on top of other windows. Fixed. | 137 | Conflict display dialog for syncing was not on top of other windows. Fixed. |
134 | Fixed some minor problems. | 138 | Fixed some minor problems. |
135 | 139 | ||
136 | Fixed an endless loop when importing vcs file with RESOURCES entry. | 140 | Fixed an endless loop when importing vcs file with RESOURCES entry. |
137 | 141 | ||
138 | ********** VERSION 2.0.16 ************ | 142 | ********** VERSION 2.0.16 ************ |
139 | OM/Pi: | 143 | OM/Pi: |
140 | Fixed the SMTP account setting the option. | 144 | Fixed the SMTP account setting the option. |
141 | Fixed something in mail sending. | 145 | Fixed something in mail sending. |
142 | 146 | ||
143 | KO/Pi: | 147 | KO/Pi: |
144 | Added possibility to export selected events/todos as vcal file. | 148 | Added possibility to export selected events/todos as vcal file. |
145 | 149 | ||
146 | ********** VERSION 2.0.15 ************ | 150 | ********** VERSION 2.0.15 ************ |
147 | 151 | ||
148 | PwM/Pi: | 152 | PwM/Pi: |
149 | Added keyboard shorcuts for | 153 | Added keyboard shorcuts for |
150 | - toggling summary view (space bar) | 154 | - toggling summary view (space bar) |
151 | - delete item (delete + backspace key) | 155 | - delete item (delete + backspace key) |
152 | - add new item ( i + n key) | 156 | - add new item ( i + n key) |
153 | Fixed length of info in the title. | 157 | Fixed length of info in the title. |
154 | 158 | ||
155 | KO/Pi-KA/Pi: | 159 | KO/Pi-KA/Pi: |
156 | Changed "ME" menu bar entry to an icon. | 160 | Changed "ME" menu bar entry to an icon. |
157 | 161 | ||
158 | KO/Pi: | 162 | KO/Pi: |
159 | Fixed two minor bugs in displaying todos. | 163 | Fixed two minor bugs in displaying todos. |
160 | If in month view a cell is selected, the key shortcut "d" shows now that date. | 164 | If in month view a cell is selected, the key shortcut "d" shows now that date. |
161 | Added complete info for a todo in month view as an icon left of the text. | 165 | Added complete info for a todo in month view as an icon left of the text. |
162 | Fixed problems of displaying data when "<" or ">" are used in summary/location/description. | 166 | Fixed problems of displaying data when "<" or ">" are used in summary/location/description. |
163 | Fixed problem of search dialog size when switching displays. | 167 | Fixed problem of search dialog size when switching displays. |
164 | Cancel key now closes date picker. | 168 | Cancel key now closes date picker. |
165 | Rearranged KO/Pi file menu structure. | 169 | Rearranged KO/Pi file menu structure. |
166 | 170 | ||
167 | OM/Pi: | 171 | OM/Pi: |
168 | Added to the SMTP account setting the option | 172 | Added to the SMTP account setting the option |
169 | "No secure connection". | 173 | "No secure connection". |
170 | You have to configure your SMTP accounts again, sorry. | 174 | You have to configure your SMTP accounts again, sorry. |
171 | 175 | ||
172 | KA/Pi: | 176 | KA/Pi: |
173 | Added support for importing quoted-printable. | 177 | Added support for importing quoted-printable. |
174 | Support was added by Peter P.. Thanks, Peter! | 178 | Support was added by Peter P.. Thanks, Peter! |
175 | 179 | ||
176 | 180 | ||
177 | ********** VERSION 2.0.14 ************ | 181 | ********** VERSION 2.0.14 ************ |
178 | 182 | ||
179 | Made Passwordmanager PwM/Pi more userfriendly: | 183 | Made Passwordmanager PwM/Pi more userfriendly: |
180 | Rearranged some toolbar icons, optimized setting of focus, fixed layout problems and more. | 184 | Rearranged some toolbar icons, optimized setting of focus, fixed layout problems and more. |
181 | Fixed bug in KO/Pi todo printing. | 185 | Fixed bug in KO/Pi todo printing. |
182 | Made Qtopia calendar import possible on desktop . | 186 | Made Qtopia calendar import possible on desktop . |
183 | 187 | ||
184 | ********** VERSION 2.0.13 ************ | 188 | ********** VERSION 2.0.13 ************ |
185 | 189 | ||
186 | Fixed a problem in the addressee select dialog and made it more user friendly by adding a minimize splitter. | 190 | Fixed a problem in the addressee select dialog and made it more user friendly by adding a minimize splitter. |
187 | 191 | ||
188 | In the search dialog you can switch now the focus from search line edit to the list view by pressing key "arrow down". | 192 | In the search dialog you can switch now the focus from search line edit to the list view by pressing key "arrow down". |
189 | 193 | ||
190 | OM/Pi: | 194 | OM/Pi: |
191 | Fixed a refresh problem of outgoing/sent/sendfailed folders after sending mails. | 195 | Fixed a refresh problem of outgoing/sent/sendfailed folders after sending mails. |
192 | Added missing German translation. | 196 | Added missing German translation. |
193 | Added warning if path is specified in local folder settings of account config. | 197 | Added warning if path is specified in local folder settings of account config. |
194 | 198 | ||
195 | ********** VERSION 2.0.12 ************ | 199 | ********** VERSION 2.0.12 ************ |
196 | 200 | ||
197 | KO/Pi: | 201 | KO/Pi: |
198 | Fixed a bug in todo start/due date handling for non recurring todos with a start and due date. | 202 | Fixed a bug in todo start/due date handling for non recurring todos with a start and due date. |
199 | Fixed some layout problems in the KO/Pi agenda view when there were many conflicting itmes. | 203 | Fixed some layout problems in the KO/Pi agenda view when there were many conflicting itmes. |
200 | Fixed several problems of the keyboard focus in the desktop versions when opening the search dialog/event viewer. | 204 | Fixed several problems of the keyboard focus in the desktop versions when opening the search dialog/event viewer. |
201 | 205 | ||
202 | Fixed problem in pi-sync mode when wrong password was sent. | 206 | Fixed problem in pi-sync mode when wrong password was sent. |
203 | 207 | ||
204 | OM/Pi: | 208 | OM/Pi: |
205 | Fixed a crash when displaying mails with "Show mail as html" was checked in the config. | 209 | Fixed a crash when displaying mails with "Show mail as html" was checked in the config. |
206 | Added a check before displaying the mail if the mail is in html format, if "Show mail as html" is enabled. | 210 | Added a check before displaying the mail if the mail is in html format, if "Show mail as html" is enabled. |
207 | 211 | ||
208 | ********** VERSION 2.0.11 ************ | 212 | ********** VERSION 2.0.11 ************ |
209 | 213 | ||
210 | Fixed some problems in pi-sync mode | 214 | Fixed some problems in pi-sync mode |
211 | (e.g. details of events were not synced properly) | 215 | (e.g. details of events were not synced properly) |
212 | 216 | ||
213 | ********** VERSION 2.0.10 ************ | 217 | ********** VERSION 2.0.10 ************ |
214 | 218 | ||
215 | KO/Pi: | 219 | KO/Pi: |
216 | In the desktop versions the context menu in the search dialog was broken after introducing the What'sThis info for the list view. | 220 | In the desktop versions the context menu in the search dialog was broken after introducing the What'sThis info for the list view. |
217 | This is fixed. | 221 | This is fixed. |
218 | Changed the search dialog a bit to make it more user friendly. | 222 | Changed the search dialog a bit to make it more user friendly. |
219 | (E.g.: Removed message box about "no items found" and set key focus to search line edit after search). | 223 | (E.g.: Removed message box about "no items found" and set key focus to search line edit after search). |
220 | 224 | ||
221 | Added config option to hide the week number in KO/Pi toolbar. | 225 | Added config option to hide the week number in KO/Pi toolbar. |
222 | 226 | ||
223 | ********** VERSION 2.0.9 ************ | 227 | ********** VERSION 2.0.9 ************ |
224 | 228 | ||
225 | Made month view icons for multiday events a bit nicer. | 229 | Made month view icons for multiday events a bit nicer. |
226 | Some minor fixes in KO/Pi | 230 | Some minor fixes in KO/Pi |
227 | (e.g. go to today did not work for new week view properly). | 231 | (e.g. go to today did not work for new week view properly). |
228 | 232 | ||
229 | 233 | ||
230 | ********** VERSION 2.0.8 ************ | 234 | ********** VERSION 2.0.8 ************ |
231 | 235 | ||
232 | Fixed a problem in dependency info in the ipk files for the Zaurus. | 236 | Fixed a problem in dependency info in the ipk files for the Zaurus. |
233 | 237 | ||
234 | Added icon for the stealth new week view and made navigation more user friendly in monthview by adding a prev/next week button to the navigator bar. | 238 | Added icon for the stealth new week view and made navigation more user friendly in monthview by adding a prev/next week button to the navigator bar. |
235 | 239 | ||
236 | Added a "go today" button to the datepicker. | 240 | Added a "go today" button to the datepicker. |
237 | 241 | ||
238 | Added "created" and "last modified" to event/todo viewer (and What'sThis viewer) | 242 | Added "created" and "last modified" to event/todo viewer (and What'sThis viewer) |
239 | and made it configureable to show these values. | 243 | and made it configureable to show these values. |
240 | 244 | ||
241 | Fixed a problem for events (from external iCal files) that do have a duration but no end date. | 245 | Fixed a problem for events (from external iCal files) that do have a duration but no end date. |
242 | 246 | ||
243 | 247 | ||
244 | ********** VERSION 2.0.7 ************ | 248 | ********** VERSION 2.0.7 ************ |
245 | 249 | ||
246 | Added global application font settings | 250 | Added global application font settings |
247 | (for all KDE-Pim/Pi apps) to the general settings. | 251 | (for all KDE-Pim/Pi apps) to the general settings. |
248 | 252 | ||
249 | Fixed a problem in OM/Pi when trying to login to some IMAP servers | 253 | Fixed a problem in OM/Pi when trying to login to some IMAP servers |
250 | (like the IMAP server of Apple: mail.mac.com ) | 254 | (like the IMAP server of Apple: mail.mac.com ) |
251 | 255 | ||
252 | Added recurring todos to KO/Pi. | 256 | Added recurring todos to KO/Pi. |
253 | 257 | ||
254 | 258 | ||
255 | ********** VERSION 2.0.6 ************ | 259 | ********** VERSION 2.0.6 ************ |
256 | 260 | ||
257 | Stable release 2.0.6! | 261 | Stable release 2.0.6! |
258 | 262 | ||
259 | Some bugfixes in the pi-sync mode. | 263 | Some bugfixes in the pi-sync mode. |
260 | Added German translation for pi-sync mode. | 264 | Added German translation for pi-sync mode. |
diff --git a/korganizer/koagenda.cpp b/korganizer/koagenda.cpp index 114ed75..355f4bb 100644 --- a/korganizer/koagenda.cpp +++ b/korganizer/koagenda.cpp | |||
@@ -221,1149 +221,955 @@ QDate KOAgenda::selectedIncidenceDate() const | |||
221 | 221 | ||
222 | 222 | ||
223 | void KOAgenda::init() | 223 | void KOAgenda::init() |
224 | { | 224 | { |
225 | mPopupTimer = new QTimer(this); | 225 | mPopupTimer = new QTimer(this); |
226 | connect(mPopupTimer , SIGNAL(timeout()), this, SLOT(popupMenu())); | 226 | connect(mPopupTimer , SIGNAL(timeout()), this, SLOT(popupMenu())); |
227 | 227 | ||
228 | mNewItemPopup = new QPopupMenu( this ); | 228 | mNewItemPopup = new QPopupMenu( this ); |
229 | connect ( mNewItemPopup, SIGNAL (activated ( int ) ), this, SLOT ( newItem(int)) ); | 229 | connect ( mNewItemPopup, SIGNAL (activated ( int ) ), this, SLOT ( newItem(int)) ); |
230 | QString pathString = ""; | 230 | QString pathString = ""; |
231 | if ( !KOPrefs::instance()->mToolBarMiniIcons ) { | 231 | if ( !KOPrefs::instance()->mToolBarMiniIcons ) { |
232 | if ( QApplication::desktop()->width() < 480 ) | 232 | if ( QApplication::desktop()->width() < 480 ) |
233 | pathString += "icons16/"; | 233 | pathString += "icons16/"; |
234 | } else | 234 | } else |
235 | pathString += "iconsmini/"; | 235 | pathString += "iconsmini/"; |
236 | 236 | ||
237 | mNewItemPopup->insertItem ( SmallIcon( pathString +"newevent" ), i18n("New Event..."), 1 ); | 237 | mNewItemPopup->insertItem ( SmallIcon( pathString +"newevent" ), i18n("New Event..."), 1 ); |
238 | mNewItemPopup->insertItem ( SmallIcon( pathString +"newtodo" ), i18n("New Todo..."),2 ); | 238 | mNewItemPopup->insertItem ( SmallIcon( pathString +"newtodo" ), i18n("New Todo..."),2 ); |
239 | mNewItemPopup->insertSeparator ( ); | 239 | mNewItemPopup->insertSeparator ( ); |
240 | mNewItemPopup->insertItem ( SmallIcon( pathString +"day" ), i18n("Day view"),3 ); | 240 | mNewItemPopup->insertItem ( SmallIcon( pathString +"day" ), i18n("Day view"),3 ); |
241 | mNewItemPopup->insertItem ( SmallIcon( pathString +"xdays" ), i18n("Next days"),8 ); | 241 | mNewItemPopup->insertItem ( SmallIcon( pathString +"xdays" ), i18n("Next days"),8 ); |
242 | mNewItemPopup->insertItem ( SmallIcon( pathString +"week" ), i18n("Next week"),4 ); | 242 | mNewItemPopup->insertItem ( SmallIcon( pathString +"week" ), i18n("Next week"),4 ); |
243 | mNewItemPopup->insertItem ( SmallIcon( pathString +"week" ), i18n("Next two weeks"),5 ); | 243 | mNewItemPopup->insertItem ( SmallIcon( pathString +"week" ), i18n("Next two weeks"),5 ); |
244 | mNewItemPopup->insertItem ( SmallIcon( pathString +"month" ), i18n("This month"),6 ); | 244 | mNewItemPopup->insertItem ( SmallIcon( pathString +"month" ), i18n("This month"),6 ); |
245 | mNewItemPopup->insertItem ( SmallIcon( pathString +"journal" ), i18n("Journal view"),7 ); | 245 | mNewItemPopup->insertItem ( SmallIcon( pathString +"journal" ), i18n("Journal view"),7 ); |
246 | #ifndef _WIN32_ | 246 | #ifndef _WIN32_ |
247 | int wflags = viewport()-> getWFlags() |WRepaintNoErase;//WResizeNoErase | 247 | int wflags = viewport()-> getWFlags() |WRepaintNoErase;//WResizeNoErase |
248 | viewport()->setWFlags ( wflags); | 248 | viewport()->setWFlags ( wflags); |
249 | #endif | 249 | #endif |
250 | mGridSpacingX = 80; | 250 | mGridSpacingX = 80; |
251 | mResizeBorderWidth = 8; | 251 | mResizeBorderWidth = 8; |
252 | mScrollBorderWidth = 8; | 252 | mScrollBorderWidth = 8; |
253 | mScrollDelay = 30; | 253 | mScrollDelay = 30; |
254 | mScrollOffset = 10; | 254 | mScrollOffset = 10; |
255 | mPaintPixmap.resize( 20,20); | 255 | mPaintPixmap.resize( 20,20); |
256 | //enableClipper(true); | 256 | //enableClipper(true); |
257 | 257 | ||
258 | // Grab key strokes for keyboard navigation of agenda. Seems to have no | 258 | // Grab key strokes for keyboard navigation of agenda. Seems to have no |
259 | // effect. Has to be fixed. | 259 | // effect. Has to be fixed. |
260 | setFocusPolicy(WheelFocus); | 260 | setFocusPolicy(WheelFocus); |
261 | 261 | ||
262 | connect(&mScrollUpTimer,SIGNAL(timeout()),SLOT(scrollUp())); | 262 | connect(&mScrollUpTimer,SIGNAL(timeout()),SLOT(scrollUp())); |
263 | connect(&mScrollDownTimer,SIGNAL(timeout()),SLOT(scrollDown())); | 263 | connect(&mScrollDownTimer,SIGNAL(timeout()),SLOT(scrollDown())); |
264 | connect(&mResizeTimer,SIGNAL(timeout()),SLOT(finishResize())); | 264 | connect(&mResizeTimer,SIGNAL(timeout()),SLOT(finishResize())); |
265 | 265 | ||
266 | mStartCellX = 0; | 266 | mStartCellX = 0; |
267 | mStartCellY = 0; | 267 | mStartCellY = 0; |
268 | mCurrentCellX = 0; | 268 | mCurrentCellX = 0; |
269 | mCurrentCellY = 0; | 269 | mCurrentCellY = 0; |
270 | 270 | ||
271 | mSelectionCellX = 0; | 271 | mSelectionCellX = 0; |
272 | mSelectionYTop = 0; | 272 | mSelectionYTop = 0; |
273 | mSelectionHeight = 0; | 273 | mSelectionHeight = 0; |
274 | 274 | ||
275 | mOldLowerScrollValue = -1; | 275 | mOldLowerScrollValue = -1; |
276 | mOldUpperScrollValue = -1; | 276 | mOldUpperScrollValue = -1; |
277 | 277 | ||
278 | mClickedItem = 0; | 278 | mClickedItem = 0; |
279 | 279 | ||
280 | mActionItem = 0; | 280 | mActionItem = 0; |
281 | mActionType = NOP; | 281 | mActionType = NOP; |
282 | mItemMoved = false; | 282 | mItemMoved = false; |
283 | 283 | ||
284 | mSelectedItem = 0; | 284 | mSelectedItem = 0; |
285 | 285 | ||
286 | // mItems.setAutoDelete(true); | 286 | // mItems.setAutoDelete(true); |
287 | 287 | ||
288 | resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 ); | 288 | resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 ); |
289 | 289 | ||
290 | viewport()->update(); | 290 | viewport()->update(); |
291 | 291 | ||
292 | setMinimumSize(30, 1); | 292 | setMinimumSize(30, 1); |
293 | // setMaximumHeight(mGridSpacingY * mRows + 5); | 293 | // setMaximumHeight(mGridSpacingY * mRows + 5); |
294 | 294 | ||
295 | // Disable horizontal scrollbar. This is a hack. The geometry should be | 295 | // Disable horizontal scrollbar. This is a hack. The geometry should be |
296 | // controlled in a way that the contents horizontally always fits. Then it is | 296 | // controlled in a way that the contents horizontally always fits. Then it is |
297 | // not necessary to turn off the scrollbar. | 297 | // not necessary to turn off the scrollbar. |
298 | setHScrollBarMode(AlwaysOff); | 298 | setHScrollBarMode(AlwaysOff); |
299 | if ( ! mAllDayMode ) | 299 | if ( ! mAllDayMode ) |
300 | setVScrollBarMode(AlwaysOn); | 300 | setVScrollBarMode(AlwaysOn); |
301 | else | 301 | else |
302 | setVScrollBarMode(AlwaysOff); | 302 | setVScrollBarMode(AlwaysOff); |
303 | 303 | ||
304 | setStartHour(KOPrefs::instance()->mDayBegins); | 304 | setStartHour(KOPrefs::instance()->mDayBegins); |
305 | 305 | ||
306 | calculateWorkingHours(); | 306 | calculateWorkingHours(); |
307 | 307 | ||
308 | connect(verticalScrollBar(),SIGNAL(valueChanged(int)), | 308 | connect(verticalScrollBar(),SIGNAL(valueChanged(int)), |
309 | SLOT(checkScrollBoundaries(int))); | 309 | SLOT(checkScrollBoundaries(int))); |
310 | 310 | ||
311 | // Create the Marcus Bains line. | 311 | // Create the Marcus Bains line. |
312 | if(mAllDayMode) | 312 | if(mAllDayMode) |
313 | mMarcusBains = 0; | 313 | mMarcusBains = 0; |
314 | else { | 314 | else { |
315 | mMarcusBains = new MarcusBains(this); | 315 | mMarcusBains = new MarcusBains(this); |
316 | addChild(mMarcusBains); | 316 | addChild(mMarcusBains); |
317 | } | 317 | } |
318 | mPopupKind = 0; | 318 | mPopupKind = 0; |
319 | mPopupItem = 0; | 319 | mPopupItem = 0; |
320 | } | 320 | } |
321 | 321 | ||
322 | void KOAgenda::clear() | 322 | void KOAgenda::clear() |
323 | { | 323 | { |
324 | KOAgendaItem *item; | 324 | KOAgendaItem *item; |
325 | for ( item=mItems.first(); item != 0; item=mItems.next() ) { | 325 | for ( item=mItems.first(); item != 0; item=mItems.next() ) { |
326 | mUnusedItems.append( item ); | 326 | mUnusedItems.append( item ); |
327 | //item->hide(); | 327 | //item->hide(); |
328 | } | 328 | } |
329 | mItems.clear(); | 329 | mItems.clear(); |
330 | mSelectedItem = 0; | 330 | mSelectedItem = 0; |
331 | clearSelection(); | 331 | clearSelection(); |
332 | } | 332 | } |
333 | 333 | ||
334 | void KOAgenda::clearSelection() | 334 | void KOAgenda::clearSelection() |
335 | { | 335 | { |
336 | mSelectionCellX = 0; | 336 | mSelectionCellX = 0; |
337 | mSelectionYTop = 0; | 337 | mSelectionYTop = 0; |
338 | mSelectionHeight = 0; | 338 | mSelectionHeight = 0; |
339 | } | 339 | } |
340 | 340 | ||
341 | void KOAgenda::marcus_bains() | 341 | void KOAgenda::marcus_bains() |
342 | { | 342 | { |
343 | if(mMarcusBains) mMarcusBains->updateLocation(true); | 343 | if(mMarcusBains) mMarcusBains->updateLocation(true); |
344 | } | 344 | } |
345 | 345 | ||
346 | 346 | ||
347 | void KOAgenda::changeColumns(int columns) | 347 | void KOAgenda::changeColumns(int columns) |
348 | { | 348 | { |
349 | if (columns == 0) { | 349 | if (columns == 0) { |
350 | qDebug("KOAgenda::changeColumns() called with argument 0 "); | 350 | qDebug("KOAgenda::changeColumns() called with argument 0 "); |
351 | return; | 351 | return; |
352 | } | 352 | } |
353 | clear(); | 353 | clear(); |
354 | mColumns = columns; | 354 | mColumns = columns; |
355 | computeSizes(); | 355 | computeSizes(); |
356 | } | 356 | } |
357 | 357 | ||
358 | /* | 358 | /* |
359 | This is the eventFilter function, which gets all events from the KOAgendaItems | 359 | This is the eventFilter function, which gets all events from the KOAgendaItems |
360 | contained in the agenda. It has to handle moving and resizing for all items. | 360 | contained in the agenda. It has to handle moving and resizing for all items. |
361 | */ | 361 | */ |
362 | bool KOAgenda::eventFilter ( QObject *object, QEvent *event ) | 362 | bool KOAgenda::eventFilter ( QObject *object, QEvent *event ) |
363 | { | 363 | { |
364 | // kdDebug() << "KOAgenda::eventFilter" << endl; | 364 | // kdDebug() << "KOAgenda::eventFilter" << endl; |
365 | switch(event->type()) { | 365 | switch(event->type()) { |
366 | case QEvent::MouseButtonPress: | 366 | case QEvent::MouseButtonPress: |
367 | case QEvent::MouseButtonDblClick: | 367 | case QEvent::MouseButtonDblClick: |
368 | case QEvent::MouseButtonRelease: | 368 | case QEvent::MouseButtonRelease: |
369 | case QEvent::MouseMove: | 369 | case QEvent::MouseMove: |
370 | return eventFilter_mouse(object, static_cast<QMouseEvent *>(event)); | 370 | return eventFilter_mouse(object, static_cast<QMouseEvent *>(event)); |
371 | 371 | ||
372 | case (QEvent::Leave): | 372 | case (QEvent::Leave): |
373 | if (!mActionItem) | 373 | if (!mActionItem) |
374 | setCursor(arrowCursor); | 374 | setCursor(arrowCursor); |
375 | return true; | 375 | return true; |
376 | 376 | ||
377 | default: | 377 | default: |
378 | return QScrollView::eventFilter(object,event); | 378 | return QScrollView::eventFilter(object,event); |
379 | } | 379 | } |
380 | } | 380 | } |
381 | void KOAgenda::popupMenu() | 381 | void KOAgenda::popupMenu() |
382 | { | 382 | { |
383 | mPopupTimer->stop(); | 383 | mPopupTimer->stop(); |
384 | if ( mPopupKind == 1 ) { | 384 | if ( mPopupKind == 1 ) { |
385 | if (mActionItem ) { | 385 | if (mActionItem ) { |
386 | endItemAction(); | 386 | endItemAction(); |
387 | } | 387 | } |
388 | mLeftMouseDown = false; // no more leftMouse computation | 388 | mLeftMouseDown = false; // no more leftMouse computation |
389 | if (mPopupItem) { | 389 | if (mPopupItem) { |
390 | //mClickedItem = mPopupItem; | 390 | //mClickedItem = mPopupItem; |
391 | selectItem(mPopupItem); | 391 | selectItem(mPopupItem); |
392 | if ( mAllAgendaPopup && KOPrefs::instance()->mBlockPopupMenu ) | 392 | if ( mAllAgendaPopup && KOPrefs::instance()->mBlockPopupMenu ) |
393 | mAllAgendaPopup->installEventFilter( this ); | 393 | mAllAgendaPopup->installEventFilter( this ); |
394 | emit showIncidencePopupSignal(mPopupItem->incidence()); | 394 | emit showIncidencePopupSignal(mPopupItem->incidence()); |
395 | 395 | ||
396 | } | 396 | } |
397 | } else if ( mPopupKind == 2 ) { | 397 | } else if ( mPopupKind == 2 ) { |
398 | if ( mLeftMouseDown ) { // we have a simulated right click - clear left mouse action | 398 | if ( mLeftMouseDown ) { // we have a simulated right click - clear left mouse action |
399 | endSelectAction( false ); // do not emit new event signal | 399 | endSelectAction( false ); // do not emit new event signal |
400 | mLeftMouseDown = false; // no more leftMouse computation | 400 | mLeftMouseDown = false; // no more leftMouse computation |
401 | } | 401 | } |
402 | if ( KOPrefs::instance()->mBlockPopupMenu ) | 402 | if ( KOPrefs::instance()->mBlockPopupMenu ) |
403 | mNewItemPopup->installEventFilter( this ); | 403 | mNewItemPopup->installEventFilter( this ); |
404 | mNewItemPopup->popup( mPopupPos); | 404 | mNewItemPopup->popup( mPopupPos); |
405 | 405 | ||
406 | } | 406 | } |
407 | mLeftMouseDown = false; | 407 | mLeftMouseDown = false; |
408 | mPopupItem = 0; | 408 | mPopupItem = 0; |
409 | mPopupKind = 0; | 409 | mPopupKind = 0; |
410 | } | 410 | } |
411 | 411 | ||
412 | bool KOAgenda::eventFilter_mouse(QObject *object, QMouseEvent *me) | 412 | bool KOAgenda::eventFilter_mouse(QObject *object, QMouseEvent *me) |
413 | { | 413 | { |
414 | static int startX = 0; | 414 | static int startX = 0; |
415 | static int startY = 0; | 415 | static int startY = 0; |
416 | static int blockmoveDist = ( QApplication::desktop()->width() < 480 ? 15 : 20 ); | 416 | static int blockmoveDist = ( QApplication::desktop()->width() < 480 ? 15 : 20 ); |
417 | static bool blockMoving = true; | 417 | static bool blockMoving = true; |
418 | 418 | ||
419 | //qDebug("KOAgenda::eventFilter_mous "); | 419 | //qDebug("KOAgenda::eventFilter_mous "); |
420 | if ( object == mNewItemPopup ) { | 420 | if ( object == mNewItemPopup ) { |
421 | //qDebug("mNewItemPopup "); | 421 | //qDebug("mNewItemPopup "); |
422 | if ( me->type() == QEvent::MouseButtonRelease ) { | 422 | if ( me->type() == QEvent::MouseButtonRelease ) { |
423 | mNewItemPopup->removeEventFilter( this ); | 423 | mNewItemPopup->removeEventFilter( this ); |
424 | int dX = me->globalPos().x() - mPopupPos.x();; | 424 | int dX = me->globalPos().x() - mPopupPos.x();; |
425 | if ( dX < 0 ) | 425 | if ( dX < 0 ) |
426 | dX = -dX; | 426 | dX = -dX; |
427 | int dY = me->globalPos().y() - mPopupPos.y(); | 427 | int dY = me->globalPos().y() - mPopupPos.y(); |
428 | if ( dY < 0 ) | 428 | if ( dY < 0 ) |
429 | dY = -dY; | 429 | dY = -dY; |
430 | if ( dX > blockmoveDist || dY > blockmoveDist ) { | 430 | if ( dX > blockmoveDist || dY > blockmoveDist ) { |
431 | mNewItemPopup->hide(); | 431 | mNewItemPopup->hide(); |
432 | } | 432 | } |
433 | } | 433 | } |
434 | return true; | 434 | return true; |
435 | } | 435 | } |
436 | if ( object == mAllAgendaPopup ) { | 436 | if ( object == mAllAgendaPopup ) { |
437 | //qDebug(" mAllAgendaPopup "); | 437 | //qDebug(" mAllAgendaPopup "); |
438 | if ( me->type() == QEvent::MouseButtonRelease ) { | 438 | if ( me->type() == QEvent::MouseButtonRelease ) { |
439 | mAllAgendaPopup->removeEventFilter( this ); | 439 | mAllAgendaPopup->removeEventFilter( this ); |
440 | int dX = me->globalPos().x() - mPopupPos.x();; | 440 | int dX = me->globalPos().x() - mPopupPos.x();; |
441 | if ( dX < 0 ) | 441 | if ( dX < 0 ) |
442 | dX = -dX; | 442 | dX = -dX; |
443 | int dY = me->globalPos().y() - mPopupPos.y(); | 443 | int dY = me->globalPos().y() - mPopupPos.y(); |
444 | if ( dY < 0 ) | 444 | if ( dY < 0 ) |
445 | dY = -dY; | 445 | dY = -dY; |
446 | if ( dX > blockmoveDist || dY > blockmoveDist ) { | 446 | if ( dX > blockmoveDist || dY > blockmoveDist ) { |
447 | mAllAgendaPopup->hide(); | 447 | mAllAgendaPopup->hide(); |
448 | } | 448 | } |
449 | } | 449 | } |
450 | return true; | 450 | return true; |
451 | } | 451 | } |
452 | QPoint viewportPos; | 452 | QPoint viewportPos; |
453 | if (object != viewport()) { | 453 | if (object != viewport()) { |
454 | viewportPos = ((QWidget *)object)->mapToParent(me->pos()); | 454 | viewportPos = ((QWidget *)object)->mapToParent(me->pos()); |
455 | } else { | 455 | } else { |
456 | viewportPos = me->pos(); | 456 | viewportPos = me->pos(); |
457 | } | 457 | } |
458 | 458 | ||
459 | switch (me->type()) { | 459 | switch (me->type()) { |
460 | case QEvent::MouseButtonPress: | 460 | case QEvent::MouseButtonPress: |
461 | if (me->button() == LeftButton) { | 461 | if (me->button() == LeftButton) { |
462 | mPopupTimer->start( 600 ); | 462 | mPopupTimer->start( 600 ); |
463 | mLeftMouseDown = true; | 463 | mLeftMouseDown = true; |
464 | } | 464 | } |
465 | blockMoving = true; | 465 | blockMoving = true; |
466 | startX = viewportPos.x(); | 466 | startX = viewportPos.x(); |
467 | startY = viewportPos.y(); | 467 | startY = viewportPos.y(); |
468 | mPopupPos = me->globalPos(); | 468 | mPopupPos = me->globalPos(); |
469 | if (object != viewport()) { | 469 | if (object != viewport()) { |
470 | mPopupItem = (KOAgendaItem *)object; | 470 | mPopupItem = (KOAgendaItem *)object; |
471 | mPopupKind = 1; | 471 | mPopupKind = 1; |
472 | if (me->button() == RightButton) { | 472 | if (me->button() == RightButton) { |
473 | popupMenu(); | 473 | popupMenu(); |
474 | } else if (me->button() == LeftButton) { | 474 | } else if (me->button() == LeftButton) { |
475 | mActionItem = (KOAgendaItem *)object; | 475 | mActionItem = (KOAgendaItem *)object; |
476 | if (mActionItem) { | 476 | if (mActionItem) { |
477 | if ( mSelectionHeight > 0 ) { | 477 | emit signalClearSelection(); |
478 | int selectionCellX = mSelectionCellX * mGridSpacingX; | 478 | slotClearSelection(); |
479 | int selectionYTop = mSelectionYTop; | ||
480 | int gridSpacingX = mGridSpacingX; | ||
481 | int selectionHeight = mSelectionHeight; | ||
482 | clearSelection(); | ||
483 | repaintContents( selectionCellX, selectionYTop, | ||
484 | gridSpacingX, selectionHeight,false ); | ||
485 | } | ||
486 | selectItem(mActionItem); | 479 | selectItem(mActionItem); |
487 | Incidence *incidence = mActionItem->incidence(); | 480 | Incidence *incidence = mActionItem->incidence(); |
488 | if ( incidence->isReadOnly() /*|| incidence->recurrence()->doesRecur() */) { | 481 | if ( incidence->isReadOnly() /*|| incidence->recurrence()->doesRecur() */) { |
489 | mActionItem = 0; | 482 | mActionItem = 0; |
490 | } else { | 483 | } else { |
491 | startItemAction(viewportPos); | 484 | startItemAction(viewportPos); |
492 | } | 485 | } |
493 | } | 486 | } |
494 | } | 487 | } |
495 | } else { // ---------- viewport() | 488 | } else { // ---------- viewport() |
496 | mPopupItem = 0; | 489 | mPopupItem = 0; |
497 | mPopupKind = 2; | 490 | mPopupKind = 2; |
498 | selectItem(0); | 491 | selectItem(0); |
499 | mActionItem = 0; | 492 | mActionItem = 0; |
500 | if (me->button() == RightButton) { | 493 | if (me->button() == RightButton) { |
501 | int x,y; | 494 | int x,y; |
502 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 495 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
503 | int gx,gy; | 496 | int gx,gy; |
504 | contentsToGrid(x,y,gx,gy); | 497 | contentsToGrid(x,y,gx,gy); |
505 | mCurrentCellX = gx; | 498 | mCurrentCellX = gx; |
506 | mCurrentCellY = gy; | 499 | mCurrentCellY = gy; |
507 | mStartCellX = gx; | 500 | mStartCellX = gx; |
508 | mStartCellY = gy; | 501 | mStartCellY = gy; |
509 | popupMenu(); | 502 | popupMenu(); |
510 | } else if (me->button() == LeftButton) { | 503 | } else if (me->button() == LeftButton) { |
511 | setCursor(arrowCursor); | 504 | setCursor(arrowCursor); |
512 | startSelectAction(viewportPos); | 505 | startSelectAction(viewportPos); |
513 | } | 506 | } |
514 | } | 507 | } |
515 | break; | 508 | break; |
516 | 509 | ||
517 | case QEvent::MouseButtonRelease: | 510 | case QEvent::MouseButtonRelease: |
518 | if (me->button() == LeftButton ) { | 511 | if (me->button() == LeftButton ) { |
519 | mPopupTimer->stop(); | 512 | mPopupTimer->stop(); |
520 | } | 513 | } |
521 | if (object != viewport()) { | 514 | if (object != viewport()) { |
522 | if (me->button() == LeftButton && mLeftMouseDown) { | 515 | if (me->button() == LeftButton && mLeftMouseDown) { |
523 | if (mActionItem) { | 516 | if (mActionItem) { |
524 | QPoint clipperPos = clipper()->mapFromGlobal(viewport()->mapToGlobal(viewportPos)); | 517 | QPoint clipperPos = clipper()->mapFromGlobal(viewport()->mapToGlobal(viewportPos)); |
525 | //qDebug(" %d %d %d ",clipperPos.y(),visibleHeight() , 9 ); | 518 | //qDebug(" %d %d %d ",clipperPos.y(),visibleHeight() , 9 ); |
526 | if ( mActionType == MOVE && (clipperPos.y() > visibleHeight()-2 ||clipperPos.y() < 0 ) ) { | 519 | if ( mActionType == MOVE && (clipperPos.y() > visibleHeight()-2 ||clipperPos.y() < 0 ) ) { |
527 | mScrollUpTimer.stop(); | 520 | mScrollUpTimer.stop(); |
528 | mScrollDownTimer.stop(); | 521 | mScrollDownTimer.stop(); |
529 | mActionItem->resetMove(); | 522 | mActionItem->resetMove(); |
530 | placeSubCells( mActionItem ); | 523 | placeSubCells( mActionItem ); |
531 | // emit startDragSignal( mActionItem->incidence() ); | 524 | // emit startDragSignal( mActionItem->incidence() ); |
532 | setCursor( arrowCursor ); | 525 | setCursor( arrowCursor ); |
533 | mActionItem = 0; | 526 | mActionItem = 0; |
534 | mActionType = NOP; | 527 | mActionType = NOP; |
535 | mItemMoved = 0; | 528 | mItemMoved = 0; |
536 | mLeftMouseDown = false; | 529 | mLeftMouseDown = false; |
537 | return true; | 530 | return true; |
538 | } | 531 | } |
539 | endItemAction(); | 532 | endItemAction(); |
540 | } | 533 | } |
541 | } | 534 | } |
542 | 535 | ||
543 | } else { // ---------- viewport() | 536 | } else { // ---------- viewport() |
544 | if (me->button() == LeftButton && mLeftMouseDown ) { //left click | 537 | if (me->button() == LeftButton && mLeftMouseDown ) { //left click |
545 | endSelectAction( true ); // emit new event signal | 538 | endSelectAction( true ); // emit new event signal |
546 | } | 539 | } |
547 | } | 540 | } |
548 | if (me->button() == LeftButton) | 541 | if (me->button() == LeftButton) |
549 | mLeftMouseDown = false; | 542 | mLeftMouseDown = false; |
550 | 543 | ||
551 | break; | 544 | break; |
552 | 545 | ||
553 | case QEvent::MouseMove: | 546 | case QEvent::MouseMove: |
554 | //qDebug("mm "); | 547 | //qDebug("mm "); |
555 | if ( !mLeftMouseDown ) | 548 | if ( !mLeftMouseDown ) |
556 | return false; | 549 | return false; |
557 | if ( blockMoving ) { | 550 | if ( blockMoving ) { |
558 | int dX, dY; | 551 | int dX, dY; |
559 | dX = startX - viewportPos.x(); | 552 | dX = startX - viewportPos.x(); |
560 | if ( dX < 0 ) | 553 | if ( dX < 0 ) |
561 | dX = -dX; | 554 | dX = -dX; |
562 | dY = viewportPos.y() - startY; | 555 | dY = viewportPos.y() - startY; |
563 | if ( dY < 0 ) | 556 | if ( dY < 0 ) |
564 | dY = -dY; | 557 | dY = -dY; |
565 | //qDebug("%d %d %d ", dX, dY , blockmoveDist ); | 558 | //qDebug("%d %d %d ", dX, dY , blockmoveDist ); |
566 | if ( dX > blockmoveDist || dY > blockmoveDist ) { | 559 | if ( dX > blockmoveDist || dY > blockmoveDist ) { |
567 | blockMoving = false; | 560 | blockMoving = false; |
568 | } | 561 | } |
569 | } | 562 | } |
570 | if ( ! blockMoving ) | 563 | if ( ! blockMoving ) |
571 | mPopupTimer->stop(); | 564 | mPopupTimer->stop(); |
572 | if (object != viewport()) { | 565 | if (object != viewport()) { |
573 | KOAgendaItem *moveItem = (KOAgendaItem *)object; | 566 | KOAgendaItem *moveItem = (KOAgendaItem *)object; |
574 | if (!moveItem->incidence()->isReadOnly() ) { | 567 | if (!moveItem->incidence()->isReadOnly() ) { |
575 | if (!mActionItem) | 568 | if (!mActionItem) |
576 | setNoActionCursor(moveItem,viewportPos); | 569 | setNoActionCursor(moveItem,viewportPos); |
577 | else { | 570 | else { |
578 | if ( !blockMoving ) | 571 | if ( !blockMoving ) |
579 | performItemAction(viewportPos); | 572 | performItemAction(viewportPos); |
580 | } | 573 | } |
581 | } | 574 | } |
582 | } else { // ---------- viewport() | 575 | } else { // ---------- viewport() |
583 | mPopupPos = viewport()->mapToGlobal( me->pos() ); | 576 | mPopupPos = viewport()->mapToGlobal( me->pos() ); |
584 | if ( mActionType == SELECT ) { | 577 | if ( mActionType == SELECT ) { |
585 | performSelectAction( viewportPos ); | 578 | performSelectAction( viewportPos ); |
586 | } | 579 | } |
587 | } | 580 | } |
588 | break; | 581 | break; |
589 | 582 | ||
590 | case QEvent::MouseButtonDblClick: | 583 | case QEvent::MouseButtonDblClick: |
591 | mPopupTimer->stop(); | 584 | mPopupTimer->stop(); |
592 | if (object == viewport()) { | 585 | if (object == viewport()) { |
593 | selectItem(0); | 586 | selectItem(0); |
594 | int x,y; | 587 | int x,y; |
595 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 588 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
596 | int gx,gy; | 589 | int gx,gy; |
597 | contentsToGrid(x,y,gx,gy); | 590 | contentsToGrid(x,y,gx,gy); |
598 | emit newEventSignal(gx,gy); | 591 | emit newEventSignal(gx,gy); |
599 | } else { | 592 | } else { |
600 | KOAgendaItem *doubleClickedItem = (KOAgendaItem *)object; | 593 | KOAgendaItem *doubleClickedItem = (KOAgendaItem *)object; |
601 | selectItem(doubleClickedItem); | 594 | selectItem(doubleClickedItem); |
602 | if ( KOPrefs::instance()->mEditOnDoubleClick ) | 595 | if ( KOPrefs::instance()->mEditOnDoubleClick ) |
603 | emit editIncidenceSignal(doubleClickedItem->incidence()); | 596 | emit editIncidenceSignal(doubleClickedItem->incidence()); |
604 | else | 597 | else |
605 | emit showIncidenceSignal(doubleClickedItem->incidence()); | 598 | emit showIncidenceSignal(doubleClickedItem->incidence()); |
606 | } | 599 | } |
607 | break; | 600 | break; |
608 | 601 | ||
609 | default: | 602 | default: |
610 | break; | 603 | break; |
611 | } | 604 | } |
612 | return true; | 605 | return true; |
613 | #if 0 | ||
614 | //qDebug("KOAgenda::eventFilter_mous "); | ||
615 | QPoint viewportPos; | ||
616 | if (object != viewport()) { | ||
617 | viewportPos = ((QWidget *)object)->mapToParent(me->pos()); | ||
618 | } else { | ||
619 | viewportPos = me->pos(); | ||
620 | } | ||
621 | static int startX = 0; | ||
622 | static int startY = 0; | ||
623 | static int blockmoveDist = ( QApplication::desktop()->width() < 480 ? 15 : 20 ); | ||
624 | static bool blockMoving = true; | ||
625 | static bool leftMouseDown = false; | ||
626 | bool rightButtonPressed = false; | ||
627 | switch (me->type()) { | ||
628 | case QEvent::MouseButtonPress: | ||
629 | if (me->button() == LeftButton) { | ||
630 | leftMouseDown = true; | ||
631 | } | ||
632 | else if (me->button() == RightButton) { | ||
633 | leftMouseDown = false; | ||
634 | } | ||
635 | blockMoving = true; | ||
636 | startX = viewportPos.x(); | ||
637 | startY = viewportPos.y(); | ||
638 | if (object != viewport()) { // item clicked ************** | ||
639 | if (me->button() == RightButton) { | ||
640 | leftMouseDown = false; | ||
641 | mClickedItem = (KOAgendaItem *)object; | ||
642 | if (mActionItem ) { | ||
643 | endItemAction(); | ||
644 | } | ||
645 | if (mClickedItem) { | ||
646 | selectItem(mClickedItem); | ||
647 | emit showIncidencePopupSignal(mClickedItem->incidence()); | ||
648 | } | ||
649 | return true; | ||
650 | } else if (me->button() == LeftButton) { | ||
651 | mActionItem = (KOAgendaItem *)object; | ||
652 | if (mActionItem) { | ||
653 | if ( mSelectionHeight > 0 ) { | ||
654 | int selectionCellX = mSelectionCellX * mGridSpacingX; | ||
655 | int selectionYTop = mSelectionYTop; | ||
656 | int gridSpacingX = mGridSpacingX; | ||
657 | int selectionHeight = mSelectionHeight; | ||
658 | clearSelection(); | ||
659 | repaintContents( selectionCellX, selectionYTop, | ||
660 | gridSpacingX, selectionHeight,false ); | ||
661 | } | ||
662 | selectItem(mActionItem); | ||
663 | Incidence *incidence = mActionItem->incidence(); | ||
664 | if ( incidence->isReadOnly() /*|| incidence->recurrence()->doesRecur() */) { | ||
665 | mActionItem = 0; | ||
666 | } else { | ||
667 | startItemAction(viewportPos); | ||
668 | } | ||
669 | } | ||
670 | } | ||
671 | } else { // ---------- viewport() | ||
672 | selectItem(0); | ||
673 | mActionItem = 0; | ||
674 | if (me->button() == LeftButton ) { | ||
675 | setCursor(arrowCursor); | ||
676 | startSelectAction(viewportPos); | ||
677 | } else if (me->button() == RightButton ) { | ||
678 | setCursor(arrowCursor); | ||
679 | if ( leftMouseDown ) { // we have a simulated right click - clear left mouse action | ||
680 | endSelectAction( false ); // do not emit new event signal | ||
681 | leftMouseDown = false; // no more leftMouse computation | ||
682 | } | ||
683 | int x,y; | ||
684 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | ||
685 | int gx,gy; | ||
686 | contentsToGrid(x,y,gx,gy); | ||
687 | mCurrentCellX = gx; | ||
688 | mCurrentCellY = gy; | ||
689 | mStartCellX = gx; | ||
690 | mStartCellY = gy; | ||
691 | mNewItemPopup->popup( viewport()->mapToGlobal( me->pos() ) ); | ||
692 | } | ||
693 | } | ||
694 | break; | ||
695 | |||
696 | case QEvent::MouseButtonRelease: | ||
697 | |||
698 | if (object != viewport()) { | ||
699 | if (me->button() == LeftButton && leftMouseDown) { | ||
700 | if (mActionItem) { | ||
701 | QPoint clipperPos = clipper()->mapFromGlobal(viewport()->mapToGlobal(viewportPos)); | ||
702 | //qDebug(" %d %d %d ",clipperPos.y(),visibleHeight() , 9 ); | ||
703 | if ( mActionType == MOVE && (clipperPos.y() > visibleHeight()-2 ||clipperPos.y() < 0 ) ) { | ||
704 | mScrollUpTimer.stop(); | ||
705 | mScrollDownTimer.stop(); | ||
706 | mActionItem->resetMove(); | ||
707 | placeSubCells( mActionItem ); | ||
708 | // emit startDragSignal( mActionItem->incidence() ); | ||
709 | setCursor( arrowCursor ); | ||
710 | mActionItem = 0; | ||
711 | mActionType = NOP; | ||
712 | mItemMoved = 0; | ||
713 | leftMouseDown = false; | ||
714 | return true; | ||
715 | } | ||
716 | endItemAction(); | ||
717 | } | ||
718 | } | ||
719 | |||
720 | } else { // ---------- viewport() | ||
721 | if (me->button() == LeftButton && leftMouseDown ) { //left click | ||
722 | endSelectAction( true ); // emit new event signal | ||
723 | } | ||
724 | } | ||
725 | if (me->button() == LeftButton) | ||
726 | leftMouseDown = false; | ||
727 | |||
728 | break; | ||
729 | 606 | ||
730 | case QEvent::MouseMove: | ||
731 | if ( !leftMouseDown ) | ||
732 | return true; | ||
733 | if ( blockMoving ) { | ||
734 | int dX, dY; | ||
735 | dX = startX - viewportPos.x(); | ||
736 | if ( dX < 0 ) | ||
737 | dX = -dX; | ||
738 | dY = viewportPos.y() - startY; | ||
739 | if ( dY < 0 ) | ||
740 | dY = -dY; | ||
741 | //qDebug("%d %d %d ", dX, dY , blockmoveDist ); | ||
742 | if ( dX > blockmoveDist || dY > blockmoveDist ) { | ||
743 | blockMoving = false; | ||
744 | } | ||
745 | } | ||
746 | if (object != viewport()) { | ||
747 | KOAgendaItem *moveItem = (KOAgendaItem *)object; | ||
748 | if (!moveItem->incidence()->isReadOnly() ) { | ||
749 | if (!mActionItem) | ||
750 | setNoActionCursor(moveItem,viewportPos); | ||
751 | else { | ||
752 | if ( !blockMoving ) | ||
753 | performItemAction(viewportPos); | ||
754 | } | ||
755 | } | ||
756 | } else { // ---------- viewport() | ||
757 | if ( mActionType == SELECT ) { | ||
758 | performSelectAction( viewportPos ); | ||
759 | } | ||
760 | } | ||
761 | break; | ||
762 | |||
763 | case QEvent::MouseButtonDblClick: | ||
764 | blockMoving = false; | ||
765 | leftMouseDown = false; | ||
766 | if (object == viewport()) { | ||
767 | selectItem(0); | ||
768 | int x,y; | ||
769 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | ||
770 | int gx,gy; | ||
771 | contentsToGrid(x,y,gx,gy); | ||
772 | emit newEventSignal(gx,gy); | ||
773 | } else { | ||
774 | KOAgendaItem *doubleClickedItem = (KOAgendaItem *)object; | ||
775 | selectItem(doubleClickedItem); | ||
776 | if ( KOPrefs::instance()->mEditOnDoubleClick ) | ||
777 | emit editIncidenceSignal(doubleClickedItem->incidence()); | ||
778 | else | ||
779 | emit showIncidenceSignal(doubleClickedItem->incidence()); | ||
780 | } | ||
781 | break; | ||
782 | |||
783 | default: | ||
784 | break; | ||
785 | } | ||
786 | return true; | ||
787 | #endif | ||
788 | } | 607 | } |
789 | 608 | ||
790 | void KOAgenda::newItem( int item ) | 609 | void KOAgenda::newItem( int item ) |
791 | { | 610 | { |
792 | if ( item == 1 ) { //new event | 611 | if ( item == 1 ) { //new event |
793 | newEventSignal(mStartCellX ,mStartCellY ); | 612 | newEventSignal(mStartCellX ,mStartCellY ); |
794 | } else | 613 | } else |
795 | if ( item == 2 ) { //new event | 614 | if ( item == 2 ) { //new event |
796 | newTodoSignal(mStartCellX ,mStartCellY ); | 615 | newTodoSignal(mStartCellX ,mStartCellY ); |
797 | } else | 616 | } else |
798 | { | 617 | { |
799 | emit showDateView( item, mStartCellX ); | 618 | emit showDateView( item, mStartCellX ); |
800 | // 3Day view | 619 | // 3Day view |
801 | // 4Week view | 620 | // 4Week view |
802 | // 5Month view | 621 | // 5Month view |
803 | // 6Journal view | 622 | // 6Journal view |
804 | } | 623 | } |
805 | } | 624 | } |
625 | void KOAgenda::slotClearSelection() | ||
626 | { | ||
627 | if (mSelectionHeight) { | ||
628 | int selectionX = mSelectionCellX * mGridSpacingX; | ||
629 | int top = mSelectionYTop - 2 *mGridSpacingY; | ||
630 | int hei = mSelectionHeight + 4 *mGridSpacingY; | ||
631 | clearSelection(); | ||
632 | repaintContents( selectionX, top, | ||
633 | mGridSpacingX, hei ,false ); | ||
634 | } | ||
635 | |||
636 | } | ||
806 | void KOAgenda::startSelectAction(QPoint viewportPos) | 637 | void KOAgenda::startSelectAction(QPoint viewportPos) |
807 | { | 638 | { |
808 | //emit newStartSelectSignal(); | 639 | |
640 | emit signalClearSelection(); | ||
641 | slotClearSelection(); | ||
809 | 642 | ||
810 | mActionType = SELECT; | 643 | mActionType = SELECT; |
811 | 644 | ||
812 | int x,y; | 645 | int x,y; |
813 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 646 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
814 | int gx,gy; | 647 | int gx,gy; |
815 | contentsToGrid(x,y,gx,gy); | 648 | contentsToGrid(x,y,gx,gy); |
816 | 649 | ||
817 | mStartCellX = gx; | 650 | mStartCellX = gx; |
818 | mStartCellY = gy; | 651 | mStartCellY = gy; |
819 | mCurrentCellX = gx; | 652 | mCurrentCellX = gx; |
820 | mCurrentCellY = gy; | 653 | mCurrentCellY = gy; |
821 | |||
822 | // Store coordinates of old selection | ||
823 | int selectionX = mSelectionCellX * mGridSpacingX; | ||
824 | int selectionYTop = mSelectionYTop; | ||
825 | int selectionHeight = mSelectionHeight; | ||
826 | 654 | ||
827 | // Store new selection | 655 | // Store new selection |
828 | mSelectionCellX = gx; | 656 | mSelectionCellX = gx; |
829 | mSelectionYTop = gy * mGridSpacingY; | 657 | mSelectionYTop = gy * mGridSpacingY; |
830 | mSelectionHeight = mGridSpacingY; | 658 | mSelectionHeight = mGridSpacingY; |
831 | 659 | ||
832 | // Clear old selection | 660 | // Paint new selection |
833 | repaintContents( selectionX, selectionYTop, | 661 | repaintContents( mSelectionCellX * mGridSpacingX+1, mSelectionYTop, |
834 | mGridSpacingX, selectionHeight,false ); | 662 | mGridSpacingX-1, mSelectionHeight ); |
835 | |||
836 | // Paint new selection | ||
837 | // repaintContents( mSelectionCellX * mGridSpacingX, mSelectionYTop, | ||
838 | // mGridSpacingX, mSelectionHeight ); | ||
839 | } | 663 | } |
840 | 664 | ||
841 | void KOAgenda::performSelectAction(QPoint viewportPos) | 665 | void KOAgenda::performSelectAction(QPoint viewportPos) |
842 | { | 666 | { |
843 | int x,y; | 667 | int x,y; |
844 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 668 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
845 | int gx,gy; | 669 | int gx,gy; |
846 | contentsToGrid(x,y,gx,gy); | 670 | contentsToGrid(x,y,gx,gy); |
847 | 671 | ||
848 | QPoint clipperPos = clipper()-> | 672 | QPoint clipperPos = clipper()-> |
849 | mapFromGlobal(viewport()->mapToGlobal(viewportPos)); | 673 | mapFromGlobal(viewport()->mapToGlobal(viewportPos)); |
850 | 674 | ||
851 | // Scroll if cursor was moved to upper or lower end of agenda. | 675 | // Scroll if cursor was moved to upper or lower end of agenda. |
852 | if (clipperPos.y() < mScrollBorderWidth) { | 676 | if (clipperPos.y() < mScrollBorderWidth) { |
853 | mScrollUpTimer.start(mScrollDelay); | 677 | mScrollUpTimer.start(mScrollDelay); |
854 | } else if (visibleHeight() - clipperPos.y() < | 678 | } else if (visibleHeight() - clipperPos.y() < |
855 | mScrollBorderWidth) { | 679 | mScrollBorderWidth) { |
856 | mScrollDownTimer.start(mScrollDelay); | 680 | mScrollDownTimer.start(mScrollDelay); |
857 | } else { | 681 | } else { |
858 | mScrollUpTimer.stop(); | 682 | mScrollUpTimer.stop(); |
859 | mScrollDownTimer.stop(); | 683 | mScrollDownTimer.stop(); |
860 | } | 684 | } |
861 | 685 | ||
862 | if ( gy > mCurrentCellY ) { | 686 | if ( gy > mCurrentCellY ) { |
863 | mSelectionHeight = ( gy + 1 ) * mGridSpacingY - mSelectionYTop; | 687 | mSelectionHeight = ( gy + 1 ) * mGridSpacingY - mSelectionYTop; |
864 | 688 | ||
865 | #if 0 | 689 | |
866 | // FIXME: Repaint only the newly selected region | ||
867 | repaintContents( mSelectionCellX * mGridSpacingX, | ||
868 | mCurrentCellY + mGridSpacingY, | ||
869 | mGridSpacingX, | ||
870 | mSelectionHeight - ( gy - mCurrentCellY - 1 ) * mGridSpacingY ); | ||
871 | #else | ||
872 | repaintContents( (KOGlobals::self()->reverseLayout() ? | 690 | repaintContents( (KOGlobals::self()->reverseLayout() ? |
873 | mColumns - 1 - mSelectionCellX : mSelectionCellX) * | 691 | mColumns - 1 - mSelectionCellX : mSelectionCellX) * |
874 | mGridSpacingX, mSelectionYTop, | 692 | mGridSpacingX, mSelectionYTop, |
875 | mGridSpacingX, mSelectionHeight , false); | 693 | mGridSpacingX, mSelectionHeight , false); |
876 | #endif | ||
877 | 694 | ||
878 | mCurrentCellY = gy; | 695 | mCurrentCellY = gy; |
879 | } else if ( gy < mCurrentCellY ) { | 696 | } else if ( gy < mCurrentCellY ) { |
880 | if ( gy >= mStartCellY ) { | 697 | if ( gy >= mStartCellY ) { |
881 | int selectionHeight = mSelectionHeight; | 698 | int selectionHeight = mSelectionHeight; |
882 | mSelectionHeight = ( gy + 1 ) * mGridSpacingY - mSelectionYTop; | 699 | mSelectionHeight = ( gy + 1 ) * mGridSpacingY - mSelectionYTop; |
883 | 700 | ||
884 | repaintContents( (KOGlobals::self()->reverseLayout() ? | 701 | repaintContents( (KOGlobals::self()->reverseLayout() ? |
885 | mColumns - 1 - mSelectionCellX : mSelectionCellX) * | 702 | mColumns - 1 - mSelectionCellX : mSelectionCellX) * |
886 | mGridSpacingX, mSelectionYTop, | 703 | mGridSpacingX, mSelectionYTop, |
887 | mGridSpacingX, selectionHeight,false ); | 704 | mGridSpacingX, selectionHeight,false ); |
888 | 705 | ||
889 | mCurrentCellY = gy; | 706 | mCurrentCellY = gy; |
890 | } else { | 707 | } else { |
891 | } | 708 | } |
892 | } | 709 | } |
893 | } | 710 | } |
894 | 711 | ||
895 | void KOAgenda::endSelectAction( bool emitNewEvent ) | 712 | void KOAgenda::endSelectAction( bool emitNewEvent ) |
896 | { | 713 | { |
897 | mActionType = NOP; | 714 | mActionType = NOP; |
898 | mScrollUpTimer.stop(); | 715 | mScrollUpTimer.stop(); |
899 | mScrollDownTimer.stop(); | 716 | mScrollDownTimer.stop(); |
900 | 717 | ||
901 | emit newTimeSpanSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY); | 718 | emit newTimeSpanSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY); |
902 | if ( emitNewEvent && mStartCellY < mCurrentCellY ) { | 719 | if ( emitNewEvent && mStartCellY < mCurrentCellY ) { |
903 | qDebug("ew event signal "); | ||
904 | emit newEventSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY); | 720 | emit newEventSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY); |
905 | } | 721 | } |
906 | } | 722 | } |
907 | 723 | ||
908 | void KOAgenda::startItemAction(QPoint viewportPos) | 724 | void KOAgenda::startItemAction(QPoint viewportPos) |
909 | { | 725 | { |
910 | int x,y; | 726 | int x,y; |
911 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 727 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
912 | int gx,gy; | 728 | int gx,gy; |
913 | contentsToGrid(x,y,gx,gy); | 729 | contentsToGrid(x,y,gx,gy); |
914 | 730 | ||
915 | mStartCellX = gx; | 731 | mStartCellX = gx; |
916 | mStartCellY = gy; | 732 | mStartCellY = gy; |
917 | mCurrentCellX = gx; | 733 | mCurrentCellX = gx; |
918 | mCurrentCellY = gy; | 734 | mCurrentCellY = gy; |
919 | 735 | ||
920 | if (mAllDayMode) { | 736 | if (mAllDayMode) { |
921 | int gridDistanceX = (x - gx * mGridSpacingX); | 737 | int gridDistanceX = (x - gx * mGridSpacingX); |
922 | if (gridDistanceX < mResizeBorderWidth && | 738 | if (gridDistanceX < mResizeBorderWidth && |
923 | mActionItem->cellX() == mCurrentCellX) { | 739 | mActionItem->cellX() == mCurrentCellX) { |
924 | mActionType = RESIZELEFT; | 740 | mActionType = RESIZELEFT; |
925 | setCursor(sizeHorCursor); | 741 | setCursor(sizeHorCursor); |
926 | } else if ((mGridSpacingX - gridDistanceX) < mResizeBorderWidth && | 742 | } else if ((mGridSpacingX - gridDistanceX) < mResizeBorderWidth && |
927 | mActionItem->cellXWidth() == mCurrentCellX) { | 743 | mActionItem->cellXWidth() == mCurrentCellX) { |
928 | mActionType = RESIZERIGHT; | 744 | mActionType = RESIZERIGHT; |
929 | setCursor(sizeHorCursor); | 745 | setCursor(sizeHorCursor); |
930 | } else { | 746 | } else { |
931 | mActionType = MOVE; | 747 | mActionType = MOVE; |
932 | mActionItem->startMove(); | 748 | mActionItem->startMove(); |
933 | setCursor(sizeAllCursor); | 749 | setCursor(sizeAllCursor); |
934 | } | 750 | } |
935 | } else { | 751 | } else { |
936 | int gridDistanceY = (y - gy * mGridSpacingY); | 752 | int gridDistanceY = (y - gy * mGridSpacingY); |
937 | bool allowResize = ( mActionItem->incidence()->type() != "Todo" ); | 753 | bool allowResize = ( mActionItem->incidence()->type() != "Todo" ); |
938 | if (allowResize && gridDistanceY < mResizeBorderWidth && | 754 | if (allowResize && gridDistanceY < mResizeBorderWidth && |
939 | mActionItem->cellYTop() == mCurrentCellY && | 755 | mActionItem->cellYTop() == mCurrentCellY && |
940 | !mActionItem->firstMultiItem()) { | 756 | !mActionItem->firstMultiItem()) { |
941 | mActionType = RESIZETOP; | 757 | mActionType = RESIZETOP; |
942 | setCursor(sizeVerCursor); | 758 | setCursor(sizeVerCursor); |
943 | } else if (allowResize &&(mGridSpacingY - gridDistanceY) < mResizeBorderWidth && | 759 | } else if (allowResize &&(mGridSpacingY - gridDistanceY) < mResizeBorderWidth && |
944 | mActionItem->cellYBottom() == mCurrentCellY && | 760 | mActionItem->cellYBottom() == mCurrentCellY && |
945 | !mActionItem->lastMultiItem()) { | 761 | !mActionItem->lastMultiItem()) { |
946 | mActionType = RESIZEBOTTOM; | 762 | mActionType = RESIZEBOTTOM; |
947 | setCursor(sizeVerCursor); | 763 | setCursor(sizeVerCursor); |
948 | } else { | 764 | } else { |
949 | mActionType = MOVE; | 765 | mActionType = MOVE; |
950 | mActionItem->startMove(); | 766 | mActionItem->startMove(); |
951 | setCursor(sizeAllCursor); | 767 | setCursor(sizeAllCursor); |
952 | } | 768 | } |
953 | } | 769 | } |
954 | } | 770 | } |
955 | 771 | ||
956 | void KOAgenda::performItemAction(QPoint viewportPos) | 772 | void KOAgenda::performItemAction(QPoint viewportPos) |
957 | { | 773 | { |
958 | // kdDebug() << "viewportPos: " << viewportPos.x() << "," << viewportPos.y() << endl; | 774 | // kdDebug() << "viewportPos: " << viewportPos.x() << "," << viewportPos.y() << endl; |
959 | // QPoint point = viewport()->mapToGlobal(viewportPos); | 775 | // QPoint point = viewport()->mapToGlobal(viewportPos); |
960 | // kdDebug() << "Global: " << point.x() << "," << point.y() << endl; | 776 | // kdDebug() << "Global: " << point.x() << "," << point.y() << endl; |
961 | // point = clipper()->mapFromGlobal(point); | 777 | // point = clipper()->mapFromGlobal(point); |
962 | // kdDebug() << "clipper: " << point.x() << "," << point.y() << endl; | 778 | // kdDebug() << "clipper: " << point.x() << "," << point.y() << endl; |
963 | // kdDebug() << "visible height: " << visibleHeight() << endl; | 779 | // kdDebug() << "visible height: " << visibleHeight() << endl; |
964 | int x,y; | 780 | int x,y; |
965 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 781 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
966 | // kdDebug() << "contents: " << x << "," << y << "\n" << endl; | 782 | // kdDebug() << "contents: " << x << "," << y << "\n" << endl; |
967 | int gx,gy; | 783 | int gx,gy; |
968 | contentsToGrid(x,y,gx,gy); | 784 | contentsToGrid(x,y,gx,gy); |
969 | QPoint clipperPos = clipper()-> | 785 | QPoint clipperPos = clipper()-> |
970 | mapFromGlobal(viewport()->mapToGlobal(viewportPos)); | 786 | mapFromGlobal(viewport()->mapToGlobal(viewportPos)); |
971 | 787 | ||
972 | // Cursor left active agenda area. | 788 | // Cursor left active agenda area. |
973 | // This starts a drag. | 789 | // This starts a drag. |
974 | if ( /*clipperPos.y() < 0 || clipperPos.y() > visibleHeight() ||*/ | 790 | if ( /*clipperPos.y() < 0 || clipperPos.y() > visibleHeight() ||*/ |
975 | clipperPos.x() < 0 || clipperPos.x() > visibleWidth() ) { | 791 | clipperPos.x() < 0 || clipperPos.x() > visibleWidth() ) { |
976 | if ( mActionType == MOVE ) { | 792 | if ( mActionType == MOVE ) { |
977 | mScrollUpTimer.stop(); | 793 | mScrollUpTimer.stop(); |
978 | mScrollDownTimer.stop(); | 794 | mScrollDownTimer.stop(); |
979 | mActionItem->resetMove(); | 795 | mActionItem->resetMove(); |
980 | placeSubCells( mActionItem ); | 796 | placeSubCells( mActionItem ); |
981 | // emit startDragSignal( mActionItem->incidence() ); | 797 | // emit startDragSignal( mActionItem->incidence() ); |
982 | setCursor( arrowCursor ); | 798 | setCursor( arrowCursor ); |
983 | mActionItem = 0; | 799 | mActionItem = 0; |
984 | mActionType = NOP; | 800 | mActionType = NOP; |
985 | mItemMoved = 0; | 801 | mItemMoved = 0; |
986 | return; | 802 | return; |
987 | } | 803 | } |
988 | } else { | 804 | } else { |
989 | switch ( mActionType ) { | 805 | switch ( mActionType ) { |
990 | case MOVE: | 806 | case MOVE: |
991 | setCursor( sizeAllCursor ); | 807 | setCursor( sizeAllCursor ); |
992 | break; | 808 | break; |
993 | case RESIZETOP: | 809 | case RESIZETOP: |
994 | case RESIZEBOTTOM: | 810 | case RESIZEBOTTOM: |
995 | setCursor( sizeVerCursor ); | 811 | setCursor( sizeVerCursor ); |
996 | break; | 812 | break; |
997 | case RESIZELEFT: | 813 | case RESIZELEFT: |
998 | case RESIZERIGHT: | 814 | case RESIZERIGHT: |
999 | setCursor( sizeHorCursor ); | 815 | setCursor( sizeHorCursor ); |
1000 | break; | 816 | break; |
1001 | default: | 817 | default: |
1002 | setCursor( arrowCursor ); | 818 | setCursor( arrowCursor ); |
1003 | } | 819 | } |
1004 | } | 820 | } |
1005 | 821 | ||
1006 | // Scroll if item was moved to upper or lower end of agenda. | 822 | // Scroll if item was moved to upper or lower end of agenda. |
1007 | if (clipperPos.y() < mScrollBorderWidth) { | 823 | if (clipperPos.y() < mScrollBorderWidth) { |
1008 | mScrollUpTimer.start(mScrollDelay); | 824 | mScrollUpTimer.start(mScrollDelay); |
1009 | } else if (visibleHeight() - clipperPos.y() < | 825 | } else if (visibleHeight() - clipperPos.y() < |
1010 | mScrollBorderWidth) { | 826 | mScrollBorderWidth) { |
1011 | mScrollDownTimer.start(mScrollDelay); | 827 | mScrollDownTimer.start(mScrollDelay); |
1012 | } else { | 828 | } else { |
1013 | mScrollUpTimer.stop(); | 829 | mScrollUpTimer.stop(); |
1014 | mScrollDownTimer.stop(); | 830 | mScrollDownTimer.stop(); |
1015 | } | 831 | } |
1016 | 832 | ||
1017 | // Move or resize item if necessary | 833 | // Move or resize item if necessary |
1018 | if (mCurrentCellX != gx || mCurrentCellY != gy) { | 834 | if (mCurrentCellX != gx || mCurrentCellY != gy) { |
1019 | mItemMoved = true; | 835 | mItemMoved = true; |
1020 | mActionItem->raise(); | 836 | mActionItem->raise(); |
1021 | if (mActionType == MOVE) { | 837 | if (mActionType == MOVE) { |
1022 | // Move all items belonging to a multi item | 838 | // Move all items belonging to a multi item |
1023 | KOAgendaItem *moveItem = mActionItem->firstMultiItem(); | 839 | KOAgendaItem *moveItem = mActionItem->firstMultiItem(); |
1024 | bool isMultiItem = (moveItem || mActionItem->lastMultiItem()); | 840 | bool isMultiItem = (moveItem || mActionItem->lastMultiItem()); |
1025 | if (!moveItem) moveItem = mActionItem; | 841 | if (!moveItem) moveItem = mActionItem; |
1026 | while (moveItem) { | 842 | while (moveItem) { |
1027 | int dy; | 843 | int dy; |
1028 | if (isMultiItem) dy = 0; | 844 | if (isMultiItem) dy = 0; |
1029 | else dy = gy - mCurrentCellY; | 845 | else dy = gy - mCurrentCellY; |
1030 | moveItem->moveRelative(gx - mCurrentCellX,dy); | 846 | moveItem->moveRelative(gx - mCurrentCellX,dy); |
1031 | int x,y; | 847 | int x,y; |
1032 | gridToContents(moveItem->cellX(),moveItem->cellYTop(),x,y); | 848 | gridToContents(moveItem->cellX(),moveItem->cellYTop(),x,y); |
1033 | moveItem->resize(mGridSpacingX * moveItem->cellWidth(), | 849 | moveItem->resize(mGridSpacingX * moveItem->cellWidth(), |
1034 | mGridSpacingY * moveItem->cellHeight()); | 850 | mGridSpacingY * moveItem->cellHeight()); |
1035 | moveChild(moveItem,x,y); | 851 | moveChild(moveItem,x,y); |
1036 | moveItem = moveItem->nextMultiItem(); | 852 | moveItem = moveItem->nextMultiItem(); |
1037 | } | 853 | } |
1038 | } else if (mActionType == RESIZETOP) { | 854 | } else if (mActionType == RESIZETOP) { |
1039 | if (mCurrentCellY <= mActionItem->cellYBottom()) { | 855 | if (mCurrentCellY <= mActionItem->cellYBottom()) { |
1040 | mActionItem->expandTop(gy - mCurrentCellY); | 856 | mActionItem->expandTop(gy - mCurrentCellY); |
1041 | mActionItem->resize(mActionItem->width(), | 857 | mActionItem->resize(mActionItem->width(), |
1042 | mGridSpacingY * mActionItem->cellHeight()); | 858 | mGridSpacingY * mActionItem->cellHeight()); |
1043 | int x,y; | 859 | int x,y; |
1044 | gridToContents(mCurrentCellX,mActionItem->cellYTop(),x,y); | 860 | gridToContents(mCurrentCellX,mActionItem->cellYTop(),x,y); |
1045 | //moveChild(mActionItem,childX(mActionItem),y); | 861 | //moveChild(mActionItem,childX(mActionItem),y); |
1046 | QScrollView::moveChild( mActionItem,childX(mActionItem),y ); | 862 | QScrollView::moveChild( mActionItem,childX(mActionItem),y ); |
1047 | } | 863 | } |
1048 | } else if (mActionType == RESIZEBOTTOM) { | 864 | } else if (mActionType == RESIZEBOTTOM) { |
1049 | if (mCurrentCellY >= mActionItem->cellYTop()) { | 865 | if (mCurrentCellY >= mActionItem->cellYTop()) { |
1050 | mActionItem->expandBottom(gy - mCurrentCellY); | 866 | mActionItem->expandBottom(gy - mCurrentCellY); |
1051 | mActionItem->resize(mActionItem->width(), | 867 | mActionItem->resize(mActionItem->width(), |
1052 | mGridSpacingY * mActionItem->cellHeight()); | 868 | mGridSpacingY * mActionItem->cellHeight()); |
1053 | } | 869 | } |
1054 | } else if (mActionType == RESIZELEFT) { | 870 | } else if (mActionType == RESIZELEFT) { |
1055 | if (mCurrentCellX <= mActionItem->cellXWidth()) { | 871 | if (mCurrentCellX <= mActionItem->cellXWidth()) { |
1056 | mActionItem->expandLeft(gx - mCurrentCellX); | 872 | mActionItem->expandLeft(gx - mCurrentCellX); |
1057 | mActionItem->resize(mGridSpacingX * mActionItem->cellWidth(), | 873 | mActionItem->resize(mGridSpacingX * mActionItem->cellWidth(), |
1058 | mActionItem->height()); | 874 | mActionItem->height()); |
1059 | int x,y; | 875 | int x,y; |
1060 | gridToContents(mActionItem->cellX(),mActionItem->cellYTop(),x,y); | 876 | gridToContents(mActionItem->cellX(),mActionItem->cellYTop(),x,y); |
1061 | moveChild(mActionItem,x,childY(mActionItem)); | 877 | moveChild(mActionItem,x,childY(mActionItem)); |
1062 | } | 878 | } |
1063 | } else if (mActionType == RESIZERIGHT) { | 879 | } else if (mActionType == RESIZERIGHT) { |
1064 | if (mCurrentCellX >= mActionItem->cellX()) { | 880 | if (mCurrentCellX >= mActionItem->cellX()) { |
1065 | mActionItem->expandRight(gx - mCurrentCellX); | 881 | mActionItem->expandRight(gx - mCurrentCellX); |
1066 | mActionItem->resize(mGridSpacingX * mActionItem->cellWidth(), | 882 | mActionItem->resize(mGridSpacingX * mActionItem->cellWidth(), |
1067 | mActionItem->height()); | 883 | mActionItem->height()); |
1068 | } | 884 | } |
1069 | } | 885 | } |
1070 | mCurrentCellX = gx; | 886 | mCurrentCellX = gx; |
1071 | mCurrentCellY = gy; | 887 | mCurrentCellY = gy; |
1072 | } | 888 | } |
1073 | } | 889 | } |
1074 | 890 | ||
1075 | void KOAgenda::endItemAction() | 891 | void KOAgenda::endItemAction() |
1076 | { | 892 | { |
1077 | 893 | ||
1078 | if ( mItemMoved ) { | 894 | if ( mItemMoved ) { |
1079 | KOAgendaItem *placeItem = mActionItem->firstMultiItem(); | 895 | KOAgendaItem *placeItem = mActionItem->firstMultiItem(); |
1080 | if ( !placeItem ) { | 896 | if ( !placeItem ) { |
1081 | placeItem = mActionItem; | 897 | placeItem = mActionItem; |
1082 | } | 898 | } |
1083 | if ( placeItem->incidence()->recurrence()->doesRecur() ) { | 899 | if ( placeItem->incidence()->recurrence()->doesRecur() ) { |
1084 | Incidence* oldInc = placeItem->incidence(); | 900 | Incidence* oldInc = placeItem->incidence(); |
1085 | placeItem->recreateIncidence(); | 901 | placeItem->recreateIncidence(); |
1086 | emit addToCalSignal(placeItem->incidence(), oldInc ); | 902 | emit addToCalSignal(placeItem->incidence(), oldInc ); |
1087 | } | 903 | } |
1088 | int type = mActionType; | 904 | int type = mActionType; |
1089 | if ( mAllDayMode ) | 905 | if ( mAllDayMode ) |
1090 | type = -1; | 906 | type = -1; |
1091 | KOAgendaItem *modifiedItem = placeItem; | 907 | KOAgendaItem *modifiedItem = placeItem; |
1092 | //emit itemModified( placeItem, mActionType /*KOGlobals::EVENTEDITED */); | 908 | //emit itemModified( placeItem, mActionType /*KOGlobals::EVENTEDITED */); |
1093 | QPtrList<KOAgendaItem> oldconflictItems ;//= placeItem->conflictItems(); | 909 | QPtrList<KOAgendaItem> oldconflictItems ;//= placeItem->conflictItems(); |
1094 | KOAgendaItem *item; | 910 | KOAgendaItem *item; |
1095 | 911 | ||
1096 | if ( placeItem->incidence()->type() == "Todo" ) { | 912 | if ( placeItem->incidence()->type() == "Todo" ) { |
1097 | mSelectedItem = 0; | 913 | mSelectedItem = 0; |
1098 | //qDebug("todo %d %d %d ", mCurrentCellX, modifiedItem->cellX() ,modifiedItem->cellXWidth()); | 914 | //qDebug("todo %d %d %d ", mCurrentCellX, modifiedItem->cellX() ,modifiedItem->cellXWidth()); |
1099 | modifiedItem->mLastMoveXPos = mCurrentCellX; | 915 | modifiedItem->mLastMoveXPos = mCurrentCellX; |
1100 | emit itemModified( modifiedItem, mActionType ); | 916 | emit itemModified( modifiedItem, mActionType ); |
1101 | } | 917 | } |
1102 | else { | 918 | else { |
1103 | #if 0 | 919 | |
1104 | for ( item=oldconflictItems.first(); item != 0; | ||
1105 | item=oldconflictItems.next() ) { | ||
1106 | placeSubCells(item); | ||
1107 | } | ||
1108 | while ( placeItem ) { | ||
1109 | //qDebug("placeItem %s ", placeItem->incidence()->summary().latin1()); | ||
1110 | placeSubCells( placeItem ); | ||
1111 | placeItem = placeItem->nextMultiItem(); | ||
1112 | } | ||
1113 | #endif | ||
1114 | 920 | ||
1115 | globalFlagBlockAgendaItemPaint = 1; | 921 | globalFlagBlockAgendaItemPaint = 1; |
1116 | for ( item=oldconflictItems.first(); item != 0; | 922 | for ( item=oldconflictItems.first(); item != 0; |
1117 | item=oldconflictItems.next() ) { | 923 | item=oldconflictItems.next() ) { |
1118 | placeSubCells(item); | 924 | placeSubCells(item); |
1119 | } | 925 | } |
1120 | while ( placeItem ) { | 926 | while ( placeItem ) { |
1121 | //qDebug("placeItem %s ", placeItem->incidence()->summary().latin1()); | 927 | //qDebug("placeItem %s ", placeItem->incidence()->summary().latin1()); |
1122 | oldconflictItems = placeItem->conflictItems(); | 928 | oldconflictItems = placeItem->conflictItems(); |
1123 | for ( item=oldconflictItems.first(); item != 0; | 929 | for ( item=oldconflictItems.first(); item != 0; |
1124 | item=oldconflictItems.next() ) { | 930 | item=oldconflictItems.next() ) { |
1125 | placeSubCells(item); | 931 | placeSubCells(item); |
1126 | } | 932 | } |
1127 | placeSubCells( placeItem ); | 933 | placeSubCells( placeItem ); |
1128 | placeItem = placeItem->nextMultiItem(); | 934 | placeItem = placeItem->nextMultiItem(); |
1129 | } | 935 | } |
1130 | globalFlagBlockAgendaItemPaint = 0; | 936 | globalFlagBlockAgendaItemPaint = 0; |
1131 | for ( item=oldconflictItems.first(); item != 0; | 937 | for ( item=oldconflictItems.first(); item != 0; |
1132 | item=oldconflictItems.next() ) { | 938 | item=oldconflictItems.next() ) { |
1133 | globalFlagBlockAgendaItemUpdate = 0; | 939 | globalFlagBlockAgendaItemUpdate = 0; |
1134 | item->repaintMe(); | 940 | item->repaintMe(); |
1135 | globalFlagBlockAgendaItemUpdate = 1; | 941 | globalFlagBlockAgendaItemUpdate = 1; |
1136 | item->repaint( false ); | 942 | item->repaint( false ); |
1137 | } | 943 | } |
1138 | placeItem = modifiedItem; | 944 | placeItem = modifiedItem; |
1139 | 945 | ||
1140 | while ( placeItem ) { | 946 | while ( placeItem ) { |
1141 | //qDebug("placeItem %s ", placeItem->incidence()->summary().latin1()); | 947 | //qDebug("placeItem %s ", placeItem->incidence()->summary().latin1()); |
1142 | globalFlagBlockAgendaItemUpdate = 0; | 948 | globalFlagBlockAgendaItemUpdate = 0; |
1143 | placeItem->repaintMe(); | 949 | placeItem->repaintMe(); |
1144 | globalFlagBlockAgendaItemUpdate = 1; | 950 | globalFlagBlockAgendaItemUpdate = 1; |
1145 | placeItem->repaint(false); | 951 | placeItem->repaint(false); |
1146 | placeItem = placeItem->nextMultiItem(); | 952 | placeItem = placeItem->nextMultiItem(); |
1147 | } | 953 | } |
1148 | emit itemModified( modifiedItem, mActionType ); | 954 | emit itemModified( modifiedItem, mActionType ); |
1149 | 955 | ||
1150 | 956 | ||
1151 | placeItem = modifiedItem; | 957 | placeItem = modifiedItem; |
1152 | while ( placeItem ) { | 958 | while ( placeItem ) { |
1153 | oldconflictItems = placeItem->conflictItems(); | 959 | oldconflictItems = placeItem->conflictItems(); |
1154 | for ( item=oldconflictItems.first(); item != 0; | 960 | for ( item=oldconflictItems.first(); item != 0; |
1155 | item=oldconflictItems.next() ) { | 961 | item=oldconflictItems.next() ) { |
1156 | placeSubCells(item); | 962 | placeSubCells(item); |
1157 | } | 963 | } |
1158 | placeSubCells( placeItem ); | 964 | placeSubCells( placeItem ); |
1159 | placeItem = placeItem->nextMultiItem(); | 965 | placeItem = placeItem->nextMultiItem(); |
1160 | 966 | ||
1161 | } | 967 | } |
1162 | placeItem = modifiedItem; | 968 | placeItem = modifiedItem; |
1163 | while ( placeItem ) { | 969 | while ( placeItem ) { |
1164 | oldconflictItems = placeItem->conflictItems(); | 970 | oldconflictItems = placeItem->conflictItems(); |
1165 | for ( item=oldconflictItems.first(); item != 0; | 971 | for ( item=oldconflictItems.first(); item != 0; |
1166 | item=oldconflictItems.next() ) { | 972 | item=oldconflictItems.next() ) { |
1167 | globalFlagBlockAgendaItemUpdate = 0; | 973 | globalFlagBlockAgendaItemUpdate = 0; |
1168 | item->repaintMe(); | 974 | item->repaintMe(); |
1169 | globalFlagBlockAgendaItemUpdate = 1; | 975 | globalFlagBlockAgendaItemUpdate = 1; |
1170 | item->repaint(false); | 976 | item->repaint(false); |
1171 | } | 977 | } |
1172 | placeItem = placeItem->nextMultiItem(); | 978 | placeItem = placeItem->nextMultiItem(); |
1173 | } | 979 | } |
1174 | /* | 980 | /* |
1175 | 981 | ||
1176 | oldconflictItems = modifiedItem->conflictItems(); | 982 | oldconflictItems = modifiedItem->conflictItems(); |
1177 | for ( item=oldconflictItems.first(); item != 0; | 983 | for ( item=oldconflictItems.first(); item != 0; |
1178 | item=oldconflictItems.next() ) { | 984 | item=oldconflictItems.next() ) { |
1179 | globalFlagBlockAgendaItemUpdate = 0; | 985 | globalFlagBlockAgendaItemUpdate = 0; |
1180 | item->paintMe(false); | 986 | item->paintMe(false); |
1181 | globalFlagBlockAgendaItemUpdate = 1; | 987 | globalFlagBlockAgendaItemUpdate = 1; |
1182 | item->repaint(false); | 988 | item->repaint(false); |
1183 | } | 989 | } |
1184 | */ | 990 | */ |
1185 | 991 | ||
1186 | 992 | ||
1187 | } | 993 | } |
1188 | 994 | ||
1189 | } | 995 | } |
1190 | 996 | ||
1191 | mScrollUpTimer.stop(); | 997 | mScrollUpTimer.stop(); |
1192 | mScrollDownTimer.stop(); | 998 | mScrollDownTimer.stop(); |
1193 | setCursor( arrowCursor ); | 999 | setCursor( arrowCursor ); |
1194 | mActionItem = 0; | 1000 | mActionItem = 0; |
1195 | mActionType = NOP; | 1001 | mActionType = NOP; |
1196 | mItemMoved = 0; | 1002 | mItemMoved = 0; |
1197 | 1003 | ||
1198 | } | 1004 | } |
1199 | 1005 | ||
1200 | void KOAgenda::setNoActionCursor(KOAgendaItem *moveItem,QPoint viewportPos) | 1006 | void KOAgenda::setNoActionCursor(KOAgendaItem *moveItem,QPoint viewportPos) |
1201 | { | 1007 | { |
1202 | // kdDebug() << "viewportPos: " << viewportPos.x() << "," << viewportPos.y() << endl; | 1008 | // kdDebug() << "viewportPos: " << viewportPos.x() << "," << viewportPos.y() << endl; |
1203 | // QPoint point = viewport()->mapToGlobal(viewportPos); | 1009 | // QPoint point = viewport()->mapToGlobal(viewportPos); |
1204 | // kdDebug() << "Global: " << point.x() << "," << point.y() << endl; | 1010 | // kdDebug() << "Global: " << point.x() << "," << point.y() << endl; |
1205 | // point = clipper()->mapFromGlobal(point); | 1011 | // point = clipper()->mapFromGlobal(point); |
1206 | // kdDebug() << "clipper: " << point.x() << "," << point.y() << endl; | 1012 | // kdDebug() << "clipper: " << point.x() << "," << point.y() << endl; |
1207 | 1013 | ||
1208 | int x,y; | 1014 | int x,y; |
1209 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 1015 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
1210 | // kdDebug() << "contents: " << x << "," << y << "\n" << endl; | 1016 | // kdDebug() << "contents: " << x << "," << y << "\n" << endl; |
1211 | int gx,gy; | 1017 | int gx,gy; |
1212 | contentsToGrid(x,y,gx,gy); | 1018 | contentsToGrid(x,y,gx,gy); |
1213 | 1019 | ||
1214 | // Change cursor to resize cursor if appropriate | 1020 | // Change cursor to resize cursor if appropriate |
1215 | if (mAllDayMode) { | 1021 | if (mAllDayMode) { |
1216 | int gridDistanceX = (x - gx * mGridSpacingX); | 1022 | int gridDistanceX = (x - gx * mGridSpacingX); |
1217 | if (gridDistanceX < mResizeBorderWidth && | 1023 | if (gridDistanceX < mResizeBorderWidth && |
1218 | moveItem->cellX() == gx) { | 1024 | moveItem->cellX() == gx) { |
1219 | setCursor(sizeHorCursor); | 1025 | setCursor(sizeHorCursor); |
1220 | } else if ((mGridSpacingX - gridDistanceX) < mResizeBorderWidth && | 1026 | } else if ((mGridSpacingX - gridDistanceX) < mResizeBorderWidth && |
1221 | moveItem->cellXWidth() == gx) { | 1027 | moveItem->cellXWidth() == gx) { |
1222 | setCursor(sizeHorCursor); | 1028 | setCursor(sizeHorCursor); |
1223 | } else { | 1029 | } else { |
1224 | setCursor(arrowCursor); | 1030 | setCursor(arrowCursor); |
1225 | } | 1031 | } |
1226 | } else { | 1032 | } else { |
1227 | int gridDistanceY = (y - gy * mGridSpacingY); | 1033 | int gridDistanceY = (y - gy * mGridSpacingY); |
1228 | if (gridDistanceY < mResizeBorderWidth && | 1034 | if (gridDistanceY < mResizeBorderWidth && |
1229 | moveItem->cellYTop() == gy && | 1035 | moveItem->cellYTop() == gy && |
1230 | !moveItem->firstMultiItem()) { | 1036 | !moveItem->firstMultiItem()) { |
1231 | setCursor(sizeVerCursor); | 1037 | setCursor(sizeVerCursor); |
1232 | } else if ((mGridSpacingY - gridDistanceY) < mResizeBorderWidth && | 1038 | } else if ((mGridSpacingY - gridDistanceY) < mResizeBorderWidth && |
1233 | moveItem->cellYBottom() == gy && | 1039 | moveItem->cellYBottom() == gy && |
1234 | !moveItem->lastMultiItem()) { | 1040 | !moveItem->lastMultiItem()) { |
1235 | setCursor(sizeVerCursor); | 1041 | setCursor(sizeVerCursor); |
1236 | } else { | 1042 | } else { |
1237 | setCursor(arrowCursor); | 1043 | setCursor(arrowCursor); |
1238 | } | 1044 | } |
1239 | } | 1045 | } |
1240 | } | 1046 | } |
1241 | 1047 | ||
1242 | 1048 | ||
1243 | /* | 1049 | /* |
1244 | Place item in cell and take care that multiple items using the same cell do | 1050 | Place item in cell and take care that multiple items using the same cell do |
1245 | not overlap. This method is not yet optimal. It doesn´t use the maximum space | 1051 | not overlap. This method is not yet optimal. It doesn´t use the maximum space |
1246 | it can get in all cases. | 1052 | it can get in all cases. |
1247 | At the moment the method has a bug: When an item is placed only the sub cell | 1053 | At the moment the method has a bug: When an item is placed only the sub cell |
1248 | widths of the items are changed, which are within the Y region the item to | 1054 | widths of the items are changed, which are within the Y region the item to |
1249 | place spans. When the sub cell width change of one of this items affects a | 1055 | place spans. When the sub cell width change of one of this items affects a |
1250 | cell, where other items are, which do not overlap in Y with the item to place, | 1056 | cell, where other items are, which do not overlap in Y with the item to place, |
1251 | the display gets corrupted, although the corruption looks quite nice. | 1057 | the display gets corrupted, although the corruption looks quite nice. |
1252 | */ | 1058 | */ |
1253 | void KOAgenda::placeSubCells(KOAgendaItem *placeItem) | 1059 | void KOAgenda::placeSubCells(KOAgendaItem *placeItem) |
1254 | { | 1060 | { |
1255 | 1061 | ||
1256 | QPtrList<KOAgendaItem> conflictItems; | 1062 | QPtrList<KOAgendaItem> conflictItems; |
1257 | int maxSubCells = 0; | 1063 | int maxSubCells = 0; |
1258 | QIntDict<KOAgendaItem> subCellDict(5); | 1064 | QIntDict<KOAgendaItem> subCellDict(5); |
1259 | 1065 | ||
1260 | KOAgendaItem *item; | 1066 | KOAgendaItem *item; |
1261 | for ( item=mItems.first(); item != 0; item=mItems.next() ) { | 1067 | for ( item=mItems.first(); item != 0; item=mItems.next() ) { |
1262 | if (item != placeItem) { | 1068 | if (item != placeItem) { |
1263 | if (placeItem->cellX() <= item->cellXWidth() && | 1069 | if (placeItem->cellX() <= item->cellXWidth() && |
1264 | placeItem->cellXWidth() >= item->cellX()) { | 1070 | placeItem->cellXWidth() >= item->cellX()) { |
1265 | if ((placeItem->cellYTop() <= item->cellYBottom()) && | 1071 | if ((placeItem->cellYTop() <= item->cellYBottom()) && |
1266 | (placeItem->cellYBottom() >= item->cellYTop())) { | 1072 | (placeItem->cellYBottom() >= item->cellYTop())) { |
1267 | conflictItems.append(item); | 1073 | conflictItems.append(item); |
1268 | if (item->subCells() > maxSubCells) | 1074 | if (item->subCells() > maxSubCells) |
1269 | maxSubCells = item->subCells(); | 1075 | maxSubCells = item->subCells(); |
1270 | subCellDict.insert(item->subCell(),item); | 1076 | subCellDict.insert(item->subCell(),item); |
1271 | } | 1077 | } |
1272 | } | 1078 | } |
1273 | } | 1079 | } |
1274 | } | 1080 | } |
1275 | 1081 | ||
1276 | if (conflictItems.count() > 0) { | 1082 | if (conflictItems.count() > 0) { |
1277 | // Look for unused sub cell and insert item | 1083 | // Look for unused sub cell and insert item |
1278 | int i; | 1084 | int i; |
1279 | for(i=0;i<maxSubCells;++i) { | 1085 | for(i=0;i<maxSubCells;++i) { |
1280 | if (!subCellDict.find(i)) { | 1086 | if (!subCellDict.find(i)) { |
1281 | placeItem->setSubCell(i); | 1087 | placeItem->setSubCell(i); |
1282 | break; | 1088 | break; |
1283 | } | 1089 | } |
1284 | } | 1090 | } |
1285 | if (i == maxSubCells) { | 1091 | if (i == maxSubCells) { |
1286 | placeItem->setSubCell(maxSubCells); | 1092 | placeItem->setSubCell(maxSubCells); |
1287 | maxSubCells++; // add new item to number of sub cells | 1093 | maxSubCells++; // add new item to number of sub cells |
1288 | } | 1094 | } |
1289 | 1095 | ||
1290 | // Prepare for sub cell geometry adjustment | 1096 | // Prepare for sub cell geometry adjustment |
1291 | int newSubCellWidth; | 1097 | int newSubCellWidth; |
1292 | if (mAllDayMode) newSubCellWidth = mGridSpacingY / maxSubCells; | 1098 | if (mAllDayMode) newSubCellWidth = mGridSpacingY / maxSubCells; |
1293 | else newSubCellWidth = mGridSpacingX / maxSubCells; | 1099 | else newSubCellWidth = mGridSpacingX / maxSubCells; |
1294 | conflictItems.append(placeItem); | 1100 | conflictItems.append(placeItem); |
1295 | 1101 | ||
1296 | 1102 | ||
1297 | // Adjust sub cell geometry of all direct conflict items | 1103 | // Adjust sub cell geometry of all direct conflict items |
1298 | for ( item=conflictItems.first(); item != 0; | 1104 | for ( item=conflictItems.first(); item != 0; |
1299 | item=conflictItems.next() ) { | 1105 | item=conflictItems.next() ) { |
1300 | item->setSubCells(maxSubCells); | 1106 | item->setSubCells(maxSubCells); |
1301 | if (mAllDayMode) { | 1107 | if (mAllDayMode) { |
1302 | item->resize(item->cellWidth() * mGridSpacingX, newSubCellWidth); | 1108 | item->resize(item->cellWidth() * mGridSpacingX, newSubCellWidth); |
1303 | } else { | 1109 | } else { |
1304 | item->resize(newSubCellWidth, item->cellHeight() * mGridSpacingY); | 1110 | item->resize(newSubCellWidth, item->cellHeight() * mGridSpacingY); |
1305 | } | 1111 | } |
1306 | int x,y; | 1112 | int x,y; |
1307 | gridToContents(item->cellX(),item->cellYTop(),x,y); | 1113 | gridToContents(item->cellX(),item->cellYTop(),x,y); |
1308 | if (mAllDayMode) { | 1114 | if (mAllDayMode) { |
1309 | y += item->subCell() * newSubCellWidth; | 1115 | y += item->subCell() * newSubCellWidth; |
1310 | } else { | 1116 | } else { |
1311 | x += item->subCell() * newSubCellWidth; | 1117 | x += item->subCell() * newSubCellWidth; |
1312 | } | 1118 | } |
1313 | moveChild(item,x,y); | 1119 | moveChild(item,x,y); |
1314 | // qDebug("moveChild %s %d %d ", item->incidence()->summary().latin1() ,x,y); | 1120 | // qDebug("moveChild %s %d %d ", item->incidence()->summary().latin1() ,x,y); |
1315 | //item->updateItem(); | 1121 | //item->updateItem(); |
1316 | } | 1122 | } |
1317 | // Adjust sub cell geometry of all conflict items of all conflict items | 1123 | // Adjust sub cell geometry of all conflict items of all conflict items |
1318 | for ( item=conflictItems.first(); item != 0; | 1124 | for ( item=conflictItems.first(); item != 0; |
1319 | item=conflictItems.next() ) { | 1125 | item=conflictItems.next() ) { |
1320 | if ( placeItem != item ) { | 1126 | if ( placeItem != item ) { |
1321 | KOAgendaItem *item2; | 1127 | KOAgendaItem *item2; |
1322 | QPtrList<KOAgendaItem> conflictItems2 = item->conflictItems(); | 1128 | QPtrList<KOAgendaItem> conflictItems2 = item->conflictItems(); |
1323 | for ( item2=conflictItems2.first(); item2 != 0; | 1129 | for ( item2=conflictItems2.first(); item2 != 0; |
1324 | item2=conflictItems2.next() ) { | 1130 | item2=conflictItems2.next() ) { |
1325 | if ( item2->subCells() != maxSubCells) { | 1131 | if ( item2->subCells() != maxSubCells) { |
1326 | item2->setSubCells(maxSubCells); | 1132 | item2->setSubCells(maxSubCells); |
1327 | if (mAllDayMode) { | 1133 | if (mAllDayMode) { |
1328 | item2->resize(item2->cellWidth() * mGridSpacingX, newSubCellWidth); | 1134 | item2->resize(item2->cellWidth() * mGridSpacingX, newSubCellWidth); |
1329 | } else { | 1135 | } else { |
1330 | item2->resize(newSubCellWidth, item2->cellHeight() * mGridSpacingY); | 1136 | item2->resize(newSubCellWidth, item2->cellHeight() * mGridSpacingY); |
1331 | } | 1137 | } |
1332 | int x,y; | 1138 | int x,y; |
1333 | gridToContents(item2->cellX(),item2->cellYTop(),x,y); | 1139 | gridToContents(item2->cellX(),item2->cellYTop(),x,y); |
1334 | if (mAllDayMode) { | 1140 | if (mAllDayMode) { |
1335 | y += item2->subCell() * newSubCellWidth; | 1141 | y += item2->subCell() * newSubCellWidth; |
1336 | } else { | 1142 | } else { |
1337 | x += item2->subCell() * newSubCellWidth; | 1143 | x += item2->subCell() * newSubCellWidth; |
1338 | } | 1144 | } |
1339 | moveChild(item2,x,y); | 1145 | moveChild(item2,x,y); |
1340 | //qDebug("setttttt %d %s",maxSubCells, item2->text().latin1() ); | 1146 | //qDebug("setttttt %d %s",maxSubCells, item2->text().latin1() ); |
1341 | } | 1147 | } |
1342 | } | 1148 | } |
1343 | } | 1149 | } |
1344 | } | 1150 | } |
1345 | } else { | 1151 | } else { |
1346 | placeItem->setSubCell(0); | 1152 | placeItem->setSubCell(0); |
1347 | placeItem->setSubCells(1); | 1153 | placeItem->setSubCells(1); |
1348 | if (mAllDayMode) placeItem->resize(placeItem->width(),mGridSpacingY); | 1154 | if (mAllDayMode) placeItem->resize(placeItem->width(),mGridSpacingY); |
1349 | else placeItem->resize(mGridSpacingX,placeItem->height()); | 1155 | else placeItem->resize(mGridSpacingX,placeItem->height()); |
1350 | int x,y; | 1156 | int x,y; |
1351 | gridToContents(placeItem->cellX(),placeItem->cellYTop(),x,y); | 1157 | gridToContents(placeItem->cellX(),placeItem->cellYTop(),x,y); |
1352 | moveChild(placeItem,x,y); | 1158 | moveChild(placeItem,x,y); |
1353 | } | 1159 | } |
1354 | placeItem->setConflictItems(conflictItems); | 1160 | placeItem->setConflictItems(conflictItems); |
1355 | // for ( item=conflictItems.first(); item != 0; | 1161 | // for ( item=conflictItems.first(); item != 0; |
1356 | // item=conflictItems.next() ) { | 1162 | // item=conflictItems.next() ) { |
1357 | // //item->updateItem(); | 1163 | // //item->updateItem(); |
1358 | // //qDebug("xxx item->updateItem() %s %d %d", item->incidence()->summary().latin1(),item->x(), item->y() ); | 1164 | // //qDebug("xxx item->updateItem() %s %d %d", item->incidence()->summary().latin1(),item->x(), item->y() ); |
1359 | // } | 1165 | // } |
1360 | // placeItem->updateItem(); | 1166 | // placeItem->updateItem(); |
1361 | } | 1167 | } |
1362 | 1168 | ||
1363 | void KOAgenda::drawContents(QPainter* p, int cx, int cy, int cw, int ch) | 1169 | void KOAgenda::drawContents(QPainter* p, int cx, int cy, int cw, int ch) |
1364 | { | 1170 | { |
1365 | if ( globalFlagBlockAgenda ) | 1171 | if ( globalFlagBlockAgenda ) |
1366 | return; | 1172 | return; |
1367 | if ( ! mAllDayMode ) { | 1173 | if ( ! mAllDayMode ) { |
1368 | // currently not working for | 1174 | // currently not working for |
1369 | 1175 | ||
diff --git a/korganizer/koagenda.h b/korganizer/koagenda.h index 4f1fdb9..fb9983e 100644 --- a/korganizer/koagenda.h +++ b/korganizer/koagenda.h | |||
@@ -1,298 +1,300 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of KOrganizer. | 2 | This file is part of KOrganizer. |
3 | Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org> | 3 | Copyright (c) 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 | As a special exception, permission is given to link this program | 19 | As a special exception, permission is given to link this program |
20 | with any edition of Qt, and distribute the resulting executable, | 20 | with any edition of Qt, and distribute the resulting executable, |
21 | without including the source code for Qt in the source distribution. | 21 | without including the source code for Qt in the source distribution. |
22 | */ | 22 | */ |
23 | #ifndef KOAGENDA_H | 23 | #ifndef KOAGENDA_H |
24 | #define KOAGENDA_H | 24 | #define KOAGENDA_H |
25 | 25 | ||
26 | #include <qscrollview.h> | 26 | #include <qscrollview.h> |
27 | #include <qtimer.h> | 27 | #include <qtimer.h> |
28 | #include <qmemarray.h> | 28 | #include <qmemarray.h> |
29 | #include <qpainter.h> | 29 | #include <qpainter.h> |
30 | #include <qpixmap.h> | 30 | #include <qpixmap.h> |
31 | #include <qguardedptr.h> | 31 | #include <qguardedptr.h> |
32 | 32 | ||
33 | #include "koagendaitem.h" | 33 | #include "koagendaitem.h" |
34 | #include "koeventview.h" | 34 | #include "koeventview.h" |
35 | 35 | ||
36 | class QPopupMenu; | 36 | class QPopupMenu; |
37 | class QTime; | 37 | class QTime; |
38 | class KConfig; | 38 | class KConfig; |
39 | class QFrame; | 39 | class QFrame; |
40 | class KOAgenda; | 40 | class KOAgenda; |
41 | class KCal::Event; | 41 | class KCal::Event; |
42 | class KCal::Todo; | 42 | class KCal::Todo; |
43 | 43 | ||
44 | using namespace KCal; | 44 | using namespace KCal; |
45 | 45 | ||
46 | class MarcusBains : public QFrame { | 46 | class MarcusBains : public QFrame { |
47 | Q_OBJECT | 47 | Q_OBJECT |
48 | public: | 48 | public: |
49 | MarcusBains(KOAgenda *agenda=0,const char *name=0); | 49 | MarcusBains(KOAgenda *agenda=0,const char *name=0); |
50 | virtual ~MarcusBains(); | 50 | virtual ~MarcusBains(); |
51 | 51 | ||
52 | public slots: | 52 | public slots: |
53 | void updateLocation(bool recalculate=false); | 53 | void updateLocation(bool recalculate=false); |
54 | void updateLoc(); | 54 | void updateLoc(); |
55 | 55 | ||
56 | private: | 56 | private: |
57 | int todayColumn(); | 57 | int todayColumn(); |
58 | QTimer *minutes; | 58 | QTimer *minutes; |
59 | QLabel *mTimeBox; | 59 | QLabel *mTimeBox; |
60 | KOAgenda *agenda; | 60 | KOAgenda *agenda; |
61 | QTime oldTime; | 61 | QTime oldTime; |
62 | int oldToday; | 62 | int oldToday; |
63 | }; | 63 | }; |
64 | 64 | ||
65 | 65 | ||
66 | class KOAgenda : public QScrollView | 66 | class KOAgenda : public QScrollView |
67 | { | 67 | { |
68 | Q_OBJECT | 68 | Q_OBJECT |
69 | public: | 69 | public: |
70 | enum MouseActionType { NOP, MOVE, SELECT, | 70 | enum MouseActionType { NOP, MOVE, SELECT, |
71 | RESIZETOP, RESIZEBOTTOM, RESIZELEFT, RESIZERIGHT }; | 71 | RESIZETOP, RESIZEBOTTOM, RESIZELEFT, RESIZERIGHT }; |
72 | 72 | ||
73 | KOAgenda ( int columns, int rows, int columnSize, QWidget * parent=0, | 73 | KOAgenda ( int columns, int rows, int columnSize, QWidget * parent=0, |
74 | const char * name=0, WFlags f=0 ); | 74 | const char * name=0, WFlags f=0 ); |
75 | KOAgenda ( int columns, QWidget * parent=0, | 75 | KOAgenda ( int columns, QWidget * parent=0, |
76 | const char * name=0, WFlags f=0 ); | 76 | const char * name=0, WFlags f=0 ); |
77 | virtual ~KOAgenda(); | 77 | virtual ~KOAgenda(); |
78 | 78 | ||
79 | Incidence *selectedIncidence() const; | 79 | Incidence *selectedIncidence() const; |
80 | QDate selectedIncidenceDate() const; | 80 | QDate selectedIncidenceDate() const; |
81 | 81 | ||
82 | virtual bool eventFilter ( QObject *, QEvent * ); | 82 | virtual bool eventFilter ( QObject *, QEvent * ); |
83 | 83 | ||
84 | void contentsToGrid (int x, int y, int& gx, int& gy); | 84 | void contentsToGrid (int x, int y, int& gx, int& gy); |
85 | void gridToContents (int gx, int gy, int& x, int& y); | 85 | void gridToContents (int gx, int gy, int& x, int& y); |
86 | 86 | ||
87 | int timeToY (const QTime &time); | 87 | int timeToY (const QTime &time); |
88 | QTime gyToTime (int y); | 88 | QTime gyToTime (int y); |
89 | 89 | ||
90 | void setStartHour(int startHour); | 90 | void setStartHour(int startHour); |
91 | 91 | ||
92 | KOAgendaItem *insertItem (Incidence *event,QDate qd,int X,int YTop,int YBottom); | 92 | KOAgendaItem *insertItem (Incidence *event,QDate qd,int X,int YTop,int YBottom); |
93 | KOAgendaItem *insertAllDayItem (Incidence *event,QDate qd,int XBegin,int XEnd); | 93 | KOAgendaItem *insertAllDayItem (Incidence *event,QDate qd,int XBegin,int XEnd); |
94 | void insertMultiItem (Event *event,QDate qd,int XBegin,int XEnd, | 94 | void insertMultiItem (Event *event,QDate qd,int XBegin,int XEnd, |
95 | int YTop,int YBottom); | 95 | int YTop,int YBottom); |
96 | 96 | ||
97 | void changeColumns(int columns); | 97 | void changeColumns(int columns); |
98 | 98 | ||
99 | int columns() { return mColumns; } | 99 | int columns() { return mColumns; } |
100 | int rows() { return mRows; } | 100 | int rows() { return mRows; } |
101 | 101 | ||
102 | int gridSpacingX() const { return mGridSpacingX; } | 102 | int gridSpacingX() const { return mGridSpacingX; } |
103 | int gridSpacingY() const { return mGridSpacingY; } | 103 | int gridSpacingY() const { return mGridSpacingY; } |
104 | 104 | ||
105 | // virtual QSizePolicy sizePolicy() const; | 105 | // virtual QSizePolicy sizePolicy() const; |
106 | 106 | ||
107 | void clear(); | 107 | void clear(); |
108 | 108 | ||
109 | void clearSelection(); | 109 | void clearSelection(); |
110 | void hideUnused(); | 110 | void hideUnused(); |
111 | 111 | ||
112 | /** Calculates the minimum width */ | 112 | /** Calculates the minimum width */ |
113 | virtual int minimumWidth() const; | 113 | virtual int minimumWidth() const; |
114 | /** Update configuration from preference settings */ | 114 | /** Update configuration from preference settings */ |
115 | void updateConfig(); | 115 | void updateConfig(); |
116 | 116 | ||
117 | void checkScrollBoundaries(); | 117 | void checkScrollBoundaries(); |
118 | 118 | ||
119 | void setHolidayMask(QMemArray<bool> *); | 119 | void setHolidayMask(QMemArray<bool> *); |
120 | void setDateList(const DateList &selectedDates); | 120 | void setDateList(const DateList &selectedDates); |
121 | DateList dateList() const; | 121 | DateList dateList() const; |
122 | void drawContentsToPainter( QPainter* paint = 0, bool backgroundOnly = false); | 122 | void drawContentsToPainter( QPainter* paint = 0, bool backgroundOnly = false); |
123 | void finishUpdate(); | 123 | void finishUpdate(); |
124 | void printSelection(); | 124 | void printSelection(); |
125 | void storePosition(); | 125 | void storePosition(); |
126 | void restorePosition(); | 126 | void restorePosition(); |
127 | void setPopup( KOEventPopupMenu * p ) { mAllAgendaPopup = p; } | 127 | void setPopup( KOEventPopupMenu * p ) { mAllAgendaPopup = p; } |
128 | 128 | ||
129 | public slots: | 129 | public slots: |
130 | void slotClearSelection(); | ||
130 | void popupMenu(); | 131 | void popupMenu(); |
131 | void newItem( int ); | 132 | void newItem( int ); |
132 | void moveChild( QWidget *, int, int ); | 133 | void moveChild( QWidget *, int, int ); |
133 | void scrollUp(); | 134 | void scrollUp(); |
134 | void scrollDown(); | 135 | void scrollDown(); |
135 | void updateTodo( Todo * t, int , bool ); | 136 | void updateTodo( Todo * t, int , bool ); |
136 | void popupAlarm(); | 137 | void popupAlarm(); |
137 | 138 | ||
138 | void checkScrollBoundaries(int); | 139 | void checkScrollBoundaries(int); |
139 | 140 | ||
140 | /** Deselect selected items. This function does not emit any signals. */ | 141 | /** Deselect selected items. This function does not emit any signals. */ |
141 | void deselectItem(); | 142 | void deselectItem(); |
142 | /** Select item. If the argument is 0, the currently selected item gets | 143 | /** Select item. If the argument is 0, the currently selected item gets |
143 | deselected. This function emits the itemSelected(bool) signal to inform | 144 | deselected. This function emits the itemSelected(bool) signal to inform |
144 | about selection/deseelction of events. */ | 145 | about selection/deseelction of events. */ |
145 | void selectItem(KOAgendaItem *); | 146 | void selectItem(KOAgendaItem *); |
146 | void finishResize(); | 147 | void finishResize(); |
147 | 148 | ||
148 | signals: | 149 | signals: |
150 | void signalClearSelection(); | ||
149 | void showDateView( int, int); | 151 | void showDateView( int, int); |
150 | void newEventSignal(); | 152 | void newEventSignal(); |
151 | void newEventSignal(int gx,int gy); | 153 | void newEventSignal(int gx,int gy); |
152 | void newTodoSignal(int gx,int gy); | 154 | void newTodoSignal(int gx,int gy); |
153 | void newEventSignal(int gxStart, int gyStart, int gxEnd, int gyEnd); | 155 | void newEventSignal(int gxStart, int gyStart, int gxEnd, int gyEnd); |
154 | void newTimeSpanSignal(int gxStart, int gyStart, int gxEnd, int gyEnd); | 156 | void newTimeSpanSignal(int gxStart, int gyStart, int gxEnd, int gyEnd); |
155 | void newStartSelectSignal(); | 157 | void newStartSelectSignal(); |
156 | void showIncidenceSignal(Incidence *); | 158 | void showIncidenceSignal(Incidence *); |
157 | void editIncidenceSignal(Incidence *); | 159 | void editIncidenceSignal(Incidence *); |
158 | void deleteIncidenceSignal(Incidence *); | 160 | void deleteIncidenceSignal(Incidence *); |
159 | void showIncidencePopupSignal(Incidence *); | 161 | void showIncidencePopupSignal(Incidence *); |
160 | 162 | ||
161 | void itemModified(KOAgendaItem *item, int ); | 163 | void itemModified(KOAgendaItem *item, int ); |
162 | void incidenceSelected(Incidence *); | 164 | void incidenceSelected(Incidence *); |
163 | 165 | ||
164 | void lowerYChanged(int); | 166 | void lowerYChanged(int); |
165 | void upperYChanged(int); | 167 | void upperYChanged(int); |
166 | 168 | ||
167 | void startDragSignal(Incidence *); | 169 | void startDragSignal(Incidence *); |
168 | void addToCalSignal(Incidence *, Incidence *); | 170 | void addToCalSignal(Incidence *, Incidence *); |
169 | void resizedSignal(); | 171 | void resizedSignal(); |
170 | 172 | ||
171 | protected: | 173 | protected: |
172 | KOEventPopupMenu * mAllAgendaPopup; | 174 | KOEventPopupMenu * mAllAgendaPopup; |
173 | QPainter mPixPainter; | 175 | QPainter mPixPainter; |
174 | QPixmap mPaintPixmap; | 176 | QPixmap mPaintPixmap; |
175 | QPixmap mHighlightPixmap; | 177 | QPixmap mHighlightPixmap; |
176 | void drawContents(QPainter *p,int cx, int cy, int cw, int ch); | 178 | void drawContents(QPainter *p,int cx, int cy, int cw, int ch); |
177 | virtual void resizeEvent ( QResizeEvent * ); | 179 | virtual void resizeEvent ( QResizeEvent * ); |
178 | 180 | ||
179 | /** Handles mouse events. Called from eventFilter */ | 181 | /** Handles mouse events. Called from eventFilter */ |
180 | virtual bool eventFilter_mouse ( QObject *, QMouseEvent * ); | 182 | virtual bool eventFilter_mouse ( QObject *, QMouseEvent * ); |
181 | 183 | ||
182 | /** Start selecting time span. */ | 184 | /** Start selecting time span. */ |
183 | void startSelectAction(QPoint viewportPos); | 185 | void startSelectAction(QPoint viewportPos); |
184 | 186 | ||
185 | /** Select time span. */ | 187 | /** Select time span. */ |
186 | void performSelectAction(QPoint viewportPos); | 188 | void performSelectAction(QPoint viewportPos); |
187 | 189 | ||
188 | /** Emd selecting time span. */ | 190 | /** Emd selecting time span. */ |
189 | void endSelectAction( bool emitNewEvent = false ); | 191 | void endSelectAction( bool emitNewEvent = false ); |
190 | 192 | ||
191 | /** Start moving/resizing agenda item */ | 193 | /** Start moving/resizing agenda item */ |
192 | void startItemAction(QPoint viewportPos); | 194 | void startItemAction(QPoint viewportPos); |
193 | 195 | ||
194 | /** Move/resize agenda item */ | 196 | /** Move/resize agenda item */ |
195 | void performItemAction(QPoint viewportPos); | 197 | void performItemAction(QPoint viewportPos); |
196 | 198 | ||
197 | /** End moving/resizing agenda item */ | 199 | /** End moving/resizing agenda item */ |
198 | void endItemAction(); | 200 | void endItemAction(); |
199 | 201 | ||
200 | /** Set cursor, when no item action is in progress */ | 202 | /** Set cursor, when no item action is in progress */ |
201 | void setNoActionCursor(KOAgendaItem *moveItem,QPoint viewportPos); | 203 | void setNoActionCursor(KOAgendaItem *moveItem,QPoint viewportPos); |
202 | 204 | ||
203 | /** Place agenda item in agenda and adjust other cells if necessary */ | 205 | /** Place agenda item in agenda and adjust other cells if necessary */ |
204 | void placeSubCells(KOAgendaItem *placeItem); | 206 | void placeSubCells(KOAgendaItem *placeItem); |
205 | 207 | ||
206 | /** Process the keyevent, including the ignored keyevents of eventwidgets. | 208 | /** Process the keyevent, including the ignored keyevents of eventwidgets. |
207 | * Implements pgup/pgdn and cursor key navigation in the view. | 209 | * Implements pgup/pgdn and cursor key navigation in the view. |
208 | */ | 210 | */ |
209 | void keyPressEvent( QKeyEvent * ); | 211 | void keyPressEvent( QKeyEvent * ); |
210 | 212 | ||
211 | void calculateWorkingHours(); | 213 | void calculateWorkingHours(); |
212 | 214 | ||
213 | virtual void contentsMousePressEvent ( QMouseEvent * ); | 215 | virtual void contentsMousePressEvent ( QMouseEvent * ); |
214 | 216 | ||
215 | private: | 217 | private: |
216 | void init(); | 218 | void init(); |
217 | void marcus_bains(); | 219 | void marcus_bains(); |
218 | bool mAllDayMode; | 220 | bool mAllDayMode; |
219 | bool blockResize; | 221 | bool blockResize; |
220 | bool mLeftMouseDown; | 222 | bool mLeftMouseDown; |
221 | KOAgendaItem *mPopupItem; | 223 | KOAgendaItem *mPopupItem; |
222 | QTimer* mPopupTimer; | 224 | QTimer* mPopupTimer; |
223 | int mPopupKind; | 225 | int mPopupKind; |
224 | QPoint mPopupPos; | 226 | QPoint mPopupPos; |
225 | QTimer mResizeTimer; | 227 | QTimer mResizeTimer; |
226 | double mContentPosition; | 228 | double mContentPosition; |
227 | 229 | ||
228 | // Width and height of agenda cells | 230 | // Width and height of agenda cells |
229 | int mGridSpacingX; | 231 | int mGridSpacingX; |
230 | int mGridSpacingY; | 232 | int mGridSpacingY; |
231 | 233 | ||
232 | // size of border, where mouse action will resize the KOAgendaItem | 234 | // size of border, where mouse action will resize the KOAgendaItem |
233 | int mResizeBorderWidth; | 235 | int mResizeBorderWidth; |
234 | 236 | ||
235 | // size of border, where mouse mve will cause a scroll of the agenda | 237 | // size of border, where mouse mve will cause a scroll of the agenda |
236 | int mScrollBorderWidth; | 238 | int mScrollBorderWidth; |
237 | int mScrollDelay; | 239 | int mScrollDelay; |
238 | int mScrollOffset; | 240 | int mScrollOffset; |
239 | 241 | ||
240 | QTimer mScrollUpTimer; | 242 | QTimer mScrollUpTimer; |
241 | QTimer mScrollDownTimer; | 243 | QTimer mScrollDownTimer; |
242 | 244 | ||
243 | // Number of Columns/Rows of agenda grid | 245 | // Number of Columns/Rows of agenda grid |
244 | int mColumns; | 246 | int mColumns; |
245 | int mRows; | 247 | int mRows; |
246 | 248 | ||
247 | // Cells to store Move and Resize coordiantes | 249 | // Cells to store Move and Resize coordiantes |
248 | int mStartCellX; | 250 | int mStartCellX; |
249 | int mStartCellY; | 251 | int mStartCellY; |
250 | int mCurrentCellX; | 252 | int mCurrentCellX; |
251 | int mCurrentCellY; | 253 | int mCurrentCellY; |
252 | 254 | ||
253 | // Working Hour coordiantes | 255 | // Working Hour coordiantes |
254 | bool mWorkingHoursEnable; | 256 | bool mWorkingHoursEnable; |
255 | int mWorkingHoursYTop; | 257 | int mWorkingHoursYTop; |
256 | int mWorkingHoursYBottom; | 258 | int mWorkingHoursYBottom; |
257 | 259 | ||
258 | // Selection | 260 | // Selection |
259 | int mSelectionCellX; | 261 | int mSelectionCellX; |
260 | int mSelectionYTop; | 262 | int mSelectionYTop; |
261 | int mSelectionHeight; | 263 | int mSelectionHeight; |
262 | 264 | ||
263 | // List of dates to be displayed | 265 | // List of dates to be displayed |
264 | DateList mSelectedDates; | 266 | DateList mSelectedDates; |
265 | 267 | ||
266 | // The KOAgendaItem, which has been right-clicked last | 268 | // The KOAgendaItem, which has been right-clicked last |
267 | KOAgendaItem *mClickedItem; | 269 | KOAgendaItem *mClickedItem; |
268 | 270 | ||
269 | // The KOAgendaItem, which is being moved/resized | 271 | // The KOAgendaItem, which is being moved/resized |
270 | QGuardedPtr<KOAgendaItem> mActionItem; | 272 | QGuardedPtr<KOAgendaItem> mActionItem; |
271 | 273 | ||
272 | // Currently selected item | 274 | // Currently selected item |
273 | QGuardedPtr<KOAgendaItem> mSelectedItem; | 275 | QGuardedPtr<KOAgendaItem> mSelectedItem; |
274 | 276 | ||
275 | // The Marcus Bains Line widget. | 277 | // The Marcus Bains Line widget. |
276 | MarcusBains *mMarcusBains; | 278 | MarcusBains *mMarcusBains; |
277 | void computeSizes(); | 279 | void computeSizes(); |
278 | 280 | ||
279 | MouseActionType mActionType; | 281 | MouseActionType mActionType; |
280 | 282 | ||
281 | bool mItemMoved; | 283 | bool mItemMoved; |
282 | 284 | ||
283 | // List of all Items contained in agenda | 285 | // List of all Items contained in agenda |
284 | QPtrList<KOAgendaItem> mItems; | 286 | QPtrList<KOAgendaItem> mItems; |
285 | QPtrList<KOAgendaItem> mUnusedItems; | 287 | QPtrList<KOAgendaItem> mUnusedItems; |
286 | KOAgendaItem* getNewItem(Incidence * event,QDate qd, QWidget* viewport); | 288 | KOAgendaItem* getNewItem(Incidence * event,QDate qd, QWidget* viewport); |
287 | QPopupMenu *mItemPopup; // Right mouse button popup menu for KOAgendaItems | 289 | QPopupMenu *mItemPopup; // Right mouse button popup menu for KOAgendaItems |
288 | QPopupMenu *mNewItemPopup; | 290 | QPopupMenu *mNewItemPopup; |
289 | 291 | ||
290 | int mOldLowerScrollValue; | 292 | int mOldLowerScrollValue; |
291 | int mOldUpperScrollValue; | 293 | int mOldUpperScrollValue; |
292 | KOAgendaItem * getItemForTodo ( Todo * todo ); | 294 | KOAgendaItem * getItemForTodo ( Todo * todo ); |
293 | QMemArray<bool> *mHolidayMask; | 295 | QMemArray<bool> *mHolidayMask; |
294 | int mCurPixWid; | 296 | int mCurPixWid; |
295 | int mCurPixHei; | 297 | int mCurPixHei; |
296 | }; | 298 | }; |
297 | 299 | ||
298 | #endif // KOAGENDA_H | 300 | #endif // KOAGENDA_H |
diff --git a/korganizer/koagendaview.cpp b/korganizer/koagendaview.cpp index 17f791d..b43c40e 100644 --- a/korganizer/koagendaview.cpp +++ b/korganizer/koagendaview.cpp | |||
@@ -181,1267 +181,1255 @@ void TimeLabels::drawContents(QPainter *p,int cx, int cy, int cw, int ch) | |||
181 | 181 | ||
182 | } | 182 | } |
183 | 183 | ||
184 | /** | 184 | /** |
185 | Calculates the minimum width. | 185 | Calculates the minimum width. |
186 | */ | 186 | */ |
187 | int TimeLabels::minimumWidth() const | 187 | int TimeLabels::minimumWidth() const |
188 | { | 188 | { |
189 | return mMiniWidth; | 189 | return mMiniWidth; |
190 | } | 190 | } |
191 | 191 | ||
192 | /** updates widget's internal state */ | 192 | /** updates widget's internal state */ |
193 | void TimeLabels::updateConfig() | 193 | void TimeLabels::updateConfig() |
194 | { | 194 | { |
195 | mRedrawNeeded = true; | 195 | mRedrawNeeded = true; |
196 | // set the font | 196 | // set the font |
197 | // config->setGroup("Fonts"); | 197 | // config->setGroup("Fonts"); |
198 | // QFont font = config->readFontEntry("TimeBar Font"); | 198 | // QFont font = config->readFontEntry("TimeBar Font"); |
199 | setFont(KOPrefs::instance()->mTimeBarFont); | 199 | setFont(KOPrefs::instance()->mTimeBarFont); |
200 | QString test = "20"; | 200 | QString test = "20"; |
201 | if (KGlobal::locale()->use12Clock()) | 201 | if (KGlobal::locale()->use12Clock()) |
202 | test = "12"; | 202 | test = "12"; |
203 | mMiniWidth = fontMetrics().width(test); | 203 | mMiniWidth = fontMetrics().width(test); |
204 | if (KGlobal::locale()->use12Clock()) | 204 | if (KGlobal::locale()->use12Clock()) |
205 | test = "pm"; | 205 | test = "pm"; |
206 | else { | 206 | else { |
207 | test = "00"; | 207 | test = "00"; |
208 | } | 208 | } |
209 | QFont sFont = font(); | 209 | QFont sFont = font(); |
210 | sFont.setPointSize( sFont.pointSize()/2 ); | 210 | sFont.setPointSize( sFont.pointSize()/2 ); |
211 | QFontMetrics fmS( sFont ); | 211 | QFontMetrics fmS( sFont ); |
212 | mMiniWidth += fmS.width( test ) + frameWidth()*2+4 ; | 212 | mMiniWidth += fmS.width( test ) + frameWidth()*2+4 ; |
213 | // update geometry restrictions based on new settings | 213 | // update geometry restrictions based on new settings |
214 | setFixedWidth( mMiniWidth ); | 214 | setFixedWidth( mMiniWidth ); |
215 | 215 | ||
216 | // update HourSize | 216 | // update HourSize |
217 | mCellHeight = KOPrefs::instance()->mHourSize*4; | 217 | mCellHeight = KOPrefs::instance()->mHourSize*4; |
218 | resizeContents(mMiniWidth,mRows * mCellHeight+1); | 218 | resizeContents(mMiniWidth,mRows * mCellHeight+1); |
219 | } | 219 | } |
220 | 220 | ||
221 | /** update time label positions */ | 221 | /** update time label positions */ |
222 | void TimeLabels::positionChanged() | 222 | void TimeLabels::positionChanged() |
223 | { | 223 | { |
224 | int adjustment = mAgenda->contentsY(); | 224 | int adjustment = mAgenda->contentsY(); |
225 | setContentsPos(0, adjustment); | 225 | setContentsPos(0, adjustment); |
226 | } | 226 | } |
227 | 227 | ||
228 | /** */ | 228 | /** */ |
229 | void TimeLabels::setAgenda(KOAgenda* agenda) | 229 | void TimeLabels::setAgenda(KOAgenda* agenda) |
230 | { | 230 | { |
231 | mAgenda = agenda; | 231 | mAgenda = agenda; |
232 | } | 232 | } |
233 | 233 | ||
234 | void TimeLabels::contentsMousePressEvent ( QMouseEvent * e) | 234 | void TimeLabels::contentsMousePressEvent ( QMouseEvent * e) |
235 | { | 235 | { |
236 | mMouseDownY = e->pos().y(); | 236 | mMouseDownY = e->pos().y(); |
237 | mOrgCap = topLevelWidget()->caption(); | 237 | mOrgCap = topLevelWidget()->caption(); |
238 | } | 238 | } |
239 | 239 | ||
240 | void TimeLabels::contentsMouseMoveEvent ( QMouseEvent * e ) | 240 | void TimeLabels::contentsMouseMoveEvent ( QMouseEvent * e ) |
241 | { | 241 | { |
242 | int diff = mMouseDownY - e->pos().y(); | 242 | int diff = mMouseDownY - e->pos().y(); |
243 | if ( diff < 10 && diff > -10 ) | 243 | if ( diff < 10 && diff > -10 ) |
244 | return; | 244 | return; |
245 | int tSize = KOPrefs::instance()->mHourSize + (diff/10) ; | 245 | int tSize = KOPrefs::instance()->mHourSize + (diff/10) ; |
246 | if ( tSize < 4 ) | 246 | if ( tSize < 4 ) |
247 | tSize = 4; | 247 | tSize = 4; |
248 | if ( tSize > 22 ) | 248 | if ( tSize > 22 ) |
249 | tSize = 22; | 249 | tSize = 22; |
250 | tSize = (tSize-2)/2; | 250 | tSize = (tSize-2)/2; |
251 | topLevelWidget()->setCaption(i18n("New Agendasize: %1").arg(tSize)); | 251 | topLevelWidget()->setCaption(i18n("New Agendasize: %1").arg(tSize)); |
252 | 252 | ||
253 | } | 253 | } |
254 | void TimeLabels::contentsMouseReleaseEvent ( QMouseEvent * e ) | 254 | void TimeLabels::contentsMouseReleaseEvent ( QMouseEvent * e ) |
255 | { | 255 | { |
256 | topLevelWidget()->setCaption( mOrgCap ); | 256 | topLevelWidget()->setCaption( mOrgCap ); |
257 | int diff = mMouseDownY - e->pos().y(); | 257 | int diff = mMouseDownY - e->pos().y(); |
258 | if ( diff < 10 && diff > -10 ) | 258 | if ( diff < 10 && diff > -10 ) |
259 | return; | 259 | return; |
260 | int tSize = KOPrefs::instance()->mHourSize + (diff/10); | 260 | int tSize = KOPrefs::instance()->mHourSize + (diff/10); |
261 | if ( tSize < 4 ) | 261 | if ( tSize < 4 ) |
262 | tSize = 4; | 262 | tSize = 4; |
263 | if ( tSize > 22 ) | 263 | if ( tSize > 22 ) |
264 | tSize = 22; | 264 | tSize = 22; |
265 | tSize = (tSize/2)*2; | 265 | tSize = (tSize/2)*2; |
266 | if ( tSize == KOPrefs::instance()->mHourSize ) | 266 | if ( tSize == KOPrefs::instance()->mHourSize ) |
267 | return; | 267 | return; |
268 | KOPrefs::instance()->mHourSize = tSize; | 268 | KOPrefs::instance()->mHourSize = tSize; |
269 | emit scaleChanged(); | 269 | emit scaleChanged(); |
270 | } | 270 | } |
271 | 271 | ||
272 | /** This is called in response to repaint() */ | 272 | /** This is called in response to repaint() */ |
273 | void TimeLabels::paintEvent(QPaintEvent*) | 273 | void TimeLabels::paintEvent(QPaintEvent*) |
274 | { | 274 | { |
275 | 275 | ||
276 | // kdDebug() << "paintevent..." << endl; | 276 | // kdDebug() << "paintevent..." << endl; |
277 | // this is another hack! | 277 | // this is another hack! |
278 | // QPainter painter(this); | 278 | // QPainter painter(this); |
279 | //QString c | 279 | //QString c |
280 | repaintContents(contentsX(), contentsY(), visibleWidth(), visibleHeight()); | 280 | repaintContents(contentsX(), contentsY(), visibleWidth(), visibleHeight()); |
281 | } | 281 | } |
282 | 282 | ||
283 | //////////////////////////////////////////////////////////////////////////// | 283 | //////////////////////////////////////////////////////////////////////////// |
284 | 284 | ||
285 | EventIndicator::EventIndicator(Location loc,QWidget *parent,const char *name) | 285 | EventIndicator::EventIndicator(Location loc,QWidget *parent,const char *name) |
286 | : QFrame(parent,name) | 286 | : QFrame(parent,name) |
287 | { | 287 | { |
288 | mColumns = 1; | 288 | mColumns = 1; |
289 | mTopBox = 0; | 289 | mTopBox = 0; |
290 | mLocation = loc; | 290 | mLocation = loc; |
291 | mTopLayout = 0; | 291 | mTopLayout = 0; |
292 | mPaintWidget = 0; | 292 | mPaintWidget = 0; |
293 | mXOffset = 0; | 293 | mXOffset = 0; |
294 | if (mLocation == Top) mPixmap = SmallIcon("1uparrow"); | 294 | if (mLocation == Top) mPixmap = SmallIcon("1uparrow"); |
295 | else mPixmap = SmallIcon("1downarrow"); | 295 | else mPixmap = SmallIcon("1downarrow"); |
296 | mEnabled.resize(mColumns); | 296 | mEnabled.resize(mColumns); |
297 | mEnabled.fill( false ); | 297 | mEnabled.fill( false ); |
298 | setMinimumHeight(mPixmap.height()); | 298 | setMinimumHeight(mPixmap.height()); |
299 | } | 299 | } |
300 | 300 | ||
301 | EventIndicator::~EventIndicator() | 301 | EventIndicator::~EventIndicator() |
302 | { | 302 | { |
303 | } | 303 | } |
304 | 304 | ||
305 | void EventIndicator::drawContents(QPainter *p) | 305 | void EventIndicator::drawContents(QPainter *p) |
306 | { | 306 | { |
307 | 307 | ||
308 | // kdDebug() << "======== top: " << contentsRect().top() << " bottom " << // contentsRect().bottom() << " left " << contentsRect().left() << " right " << contentsRect().right() << endl; | 308 | // kdDebug() << "======== top: " << contentsRect().top() << " bottom " << // contentsRect().bottom() << " left " << contentsRect().left() << " right " << contentsRect().right() << endl; |
309 | KDGanttSplitterHandle* han = 0; | 309 | KDGanttSplitterHandle* han = 0; |
310 | if ( mPaintWidget ) | 310 | if ( mPaintWidget ) |
311 | han = mPaintWidget->firstHandle(); | 311 | han = mPaintWidget->firstHandle(); |
312 | if ( ! han ) { | 312 | if ( ! han ) { |
313 | int i; | 313 | int i; |
314 | for(i=0;i<mColumns;++i) { | 314 | for(i=0;i<mColumns;++i) { |
315 | if (mEnabled[i]) { | 315 | if (mEnabled[i]) { |
316 | int cellWidth = contentsRect().right()/mColumns; | 316 | int cellWidth = contentsRect().right()/mColumns; |
317 | int xOffset = KOGlobals::self()->reverseLayout() ? | 317 | int xOffset = KOGlobals::self()->reverseLayout() ? |
318 | (mColumns - 1 - i)*cellWidth + (cellWidth -mPixmap.width())/2 : | 318 | (mColumns - 1 - i)*cellWidth + (cellWidth -mPixmap.width())/2 : |
319 | i*cellWidth + (cellWidth -mPixmap.width()) /2; | 319 | i*cellWidth + (cellWidth -mPixmap.width()) /2; |
320 | p->drawPixmap(QPoint(1+xOffset,0),mPixmap); | 320 | p->drawPixmap(QPoint(1+xOffset,0),mPixmap); |
321 | } | 321 | } |
322 | } | 322 | } |
323 | } else { | 323 | } else { |
324 | han->repaint(); | 324 | han->repaint(); |
325 | //mPaintWidget->setBackgroundColor( red ); | 325 | //mPaintWidget->setBackgroundColor( red ); |
326 | 326 | ||
327 | QPainter pa( han ); | 327 | QPainter pa( han ); |
328 | int i; | 328 | int i; |
329 | bool setColor = false; | 329 | bool setColor = false; |
330 | for(i=0;i<mColumns;++i) { | 330 | for(i=0;i<mColumns;++i) { |
331 | if (mEnabled[i]) { | 331 | if (mEnabled[i]) { |
332 | setColor = true; | 332 | setColor = true; |
333 | 333 | ||
334 | int cellWidth = contentsRect().right()/mColumns; | 334 | int cellWidth = contentsRect().right()/mColumns; |
335 | int xOffset = KOGlobals::self()->reverseLayout() ? | 335 | int xOffset = KOGlobals::self()->reverseLayout() ? |
336 | (mColumns - 1 - i)*cellWidth + cellWidth/2 -mPixmap.width()/2 : | 336 | (mColumns - 1 - i)*cellWidth + cellWidth/2 -mPixmap.width()/2 : |
337 | i*cellWidth + cellWidth/2 -mPixmap.width()/2; | 337 | i*cellWidth + cellWidth/2 -mPixmap.width()/2; |
338 | pa.drawPixmap(QPoint(mXOffset + xOffset,0),mPixmap); | 338 | pa.drawPixmap(QPoint(mXOffset + xOffset,0),mPixmap); |
339 | //qDebug("222draw pix %d ",xOffset ); | 339 | //qDebug("222draw pix %d ",xOffset ); |
340 | 340 | ||
341 | } | 341 | } |
342 | 342 | ||
343 | } | 343 | } |
344 | pa.end(); | 344 | pa.end(); |
345 | 345 | ||
346 | } | 346 | } |
347 | } | 347 | } |
348 | 348 | ||
349 | void EventIndicator::setXOffset( int x ) | 349 | void EventIndicator::setXOffset( int x ) |
350 | { | 350 | { |
351 | mXOffset = x; | 351 | mXOffset = x; |
352 | } | 352 | } |
353 | void EventIndicator::setPaintWidget( KDGanttMinimizeSplitter * w ) | 353 | void EventIndicator::setPaintWidget( KDGanttMinimizeSplitter * w ) |
354 | { | 354 | { |
355 | mPaintWidget = w; | 355 | mPaintWidget = w; |
356 | setMaximumHeight(0); | 356 | setMaximumHeight(0); |
357 | setMinimumHeight(0); | 357 | setMinimumHeight(0); |
358 | } | 358 | } |
359 | void EventIndicator::changeColumns(int columns) | 359 | void EventIndicator::changeColumns(int columns) |
360 | { | 360 | { |
361 | mColumns = columns; | 361 | mColumns = columns; |
362 | mEnabled.resize(mColumns); | 362 | mEnabled.resize(mColumns); |
363 | 363 | ||
364 | update(); | 364 | update(); |
365 | } | 365 | } |
366 | 366 | ||
367 | void EventIndicator::enableColumn(int column, bool enable) | 367 | void EventIndicator::enableColumn(int column, bool enable) |
368 | { | 368 | { |
369 | mEnabled[column] = enable; | 369 | mEnabled[column] = enable; |
370 | } | 370 | } |
371 | 371 | ||
372 | 372 | ||
373 | //////////////////////////////////////////////////////////////////////////// | 373 | //////////////////////////////////////////////////////////////////////////// |
374 | //////////////////////////////////////////////////////////////////////////// | 374 | //////////////////////////////////////////////////////////////////////////// |
375 | //////////////////////////////////////////////////////////////////////////// | 375 | //////////////////////////////////////////////////////////////////////////// |
376 | 376 | ||
377 | KOAgendaView::KOAgendaView(Calendar *cal,QWidget *parent,const char *name) : | 377 | KOAgendaView::KOAgendaView(Calendar *cal,QWidget *parent,const char *name) : |
378 | KOEventView (cal,parent,name) | 378 | KOEventView (cal,parent,name) |
379 | { | 379 | { |
380 | mBlockUpdating = true; | 380 | mBlockUpdating = true; |
381 | mStartHour = 8; | 381 | mStartHour = 8; |
382 | mSelectedDates.append(QDate::currentDate()); | 382 | mSelectedDates.append(QDate::currentDate()); |
383 | 383 | ||
384 | mLayoutDayLabels = 0; | 384 | mLayoutDayLabels = 0; |
385 | mDayLabelsFrame = 0; | 385 | mDayLabelsFrame = 0; |
386 | mDayLabels = 0; | 386 | mDayLabels = 0; |
387 | bool isRTL = KOGlobals::self()->reverseLayout(); | 387 | bool isRTL = KOGlobals::self()->reverseLayout(); |
388 | QPixmap expandPix; | 388 | QPixmap expandPix; |
389 | if ( KOPrefs::instance()->mVerticalScreen ) { | 389 | if ( KOPrefs::instance()->mVerticalScreen ) { |
390 | expandPix = SmallIcon( "1updownarrow" ); | 390 | expandPix = SmallIcon( "1updownarrow" ); |
391 | } else { | 391 | } else { |
392 | expandPix = SmallIcon("1leftrightarrow" ); | 392 | expandPix = SmallIcon("1leftrightarrow" ); |
393 | } | 393 | } |
394 | 394 | ||
395 | QBoxLayout *topLayout = new QVBoxLayout(this); | 395 | QBoxLayout *topLayout = new QVBoxLayout(this); |
396 | 396 | ||
397 | // Create day name labels for agenda columns | 397 | // Create day name labels for agenda columns |
398 | // Create agenda splitter | 398 | // Create agenda splitter |
399 | 399 | ||
400 | mSplitterAgenda = new KDGanttMinimizeSplitter( Qt::Vertical, this); | 400 | mSplitterAgenda = new KDGanttMinimizeSplitter( Qt::Vertical, this); |
401 | mSplitterAgenda->setMinimizeDirection ( KDGanttMinimizeSplitter::Up ); | 401 | mSplitterAgenda->setMinimizeDirection ( KDGanttMinimizeSplitter::Up ); |
402 | topLayout->addWidget( mSplitterAgenda ); | 402 | topLayout->addWidget( mSplitterAgenda ); |
403 | mAllDayFrame = new QHBox(mSplitterAgenda); | 403 | mAllDayFrame = new QHBox(mSplitterAgenda); |
404 | mAllDayFrame->setFocusPolicy(NoFocus); | 404 | mAllDayFrame->setFocusPolicy(NoFocus); |
405 | QWidget *agendaFrame = new QWidget(mSplitterAgenda); | 405 | QWidget *agendaFrame = new QWidget(mSplitterAgenda); |
406 | agendaFrame->setFocusPolicy(NoFocus); | 406 | agendaFrame->setFocusPolicy(NoFocus); |
407 | 407 | ||
408 | // Create all-day agenda widget | 408 | // Create all-day agenda widget |
409 | mDummyAllDayLeft = new QVBox( mAllDayFrame ); | 409 | mDummyAllDayLeft = new QVBox( mAllDayFrame ); |
410 | 410 | ||
411 | mExpandButton = new QPushButton(mDummyAllDayLeft); | 411 | mExpandButton = new QPushButton(mDummyAllDayLeft); |
412 | mExpandButton->setPixmap( expandPix ); | 412 | mExpandButton->setPixmap( expandPix ); |
413 | int widebut = mExpandButton->sizeHint().width()+4; | 413 | int widebut = mExpandButton->sizeHint().width()+4; |
414 | int heibut = mExpandButton->sizeHint().height()+4; | 414 | int heibut = mExpandButton->sizeHint().height()+4; |
415 | if ( heibut > widebut ) | 415 | if ( heibut > widebut ) |
416 | widebut = heibut ; | 416 | widebut = heibut ; |
417 | 417 | ||
418 | //mExpandButton->setSizePolicy( QSizePolicy( QSizePolicy::Fixed, | 418 | //mExpandButton->setSizePolicy( QSizePolicy( QSizePolicy::Fixed, |
419 | // QSizePolicy::Fixed ) ); | 419 | // QSizePolicy::Fixed ) ); |
420 | mExpandButton->setFixedSize( widebut, widebut); | 420 | mExpandButton->setFixedSize( widebut, widebut); |
421 | connect( mExpandButton, SIGNAL( clicked() ), SIGNAL( toggleExpand() ) ); | 421 | connect( mExpandButton, SIGNAL( clicked() ), SIGNAL( toggleExpand() ) ); |
422 | mExpandButton->setFocusPolicy(NoFocus); | 422 | mExpandButton->setFocusPolicy(NoFocus); |
423 | mAllDayAgenda = new KOAgenda(1,mAllDayFrame); | 423 | mAllDayAgenda = new KOAgenda(1,mAllDayFrame); |
424 | mAllDayAgenda->setFocusPolicy(NoFocus); | 424 | mAllDayAgenda->setFocusPolicy(NoFocus); |
425 | QLabel *dummyAllDayRight = new QLabel (mAllDayFrame); | 425 | QLabel *dummyAllDayRight = new QLabel (mAllDayFrame); |
426 | 426 | ||
427 | // Create event context menu for all day agenda | 427 | // Create event context menu for all day agenda |
428 | //mAllDayAgendaPopup = eventPopup(); | 428 | //mAllDayAgendaPopup = eventPopup(); |
429 | 429 | ||
430 | // Create agenda frame | 430 | // Create agenda frame |
431 | QGridLayout *agendaLayout = new QGridLayout(agendaFrame,4,3); | 431 | QGridLayout *agendaLayout = new QGridLayout(agendaFrame,4,3); |
432 | // QHBox *agendaFrame = new QHBox(splitterAgenda); | 432 | // QHBox *agendaFrame = new QHBox(splitterAgenda); |
433 | 433 | ||
434 | // create event indicator bars | 434 | // create event indicator bars |
435 | mEventIndicatorTop = new EventIndicator(EventIndicator::Top,agendaFrame); | 435 | mEventIndicatorTop = new EventIndicator(EventIndicator::Top,agendaFrame); |
436 | #ifndef DESKTOP_VERSION | 436 | #ifndef DESKTOP_VERSION |
437 | // FIX | ||
438 | mEventIndicatorTop->setPaintWidget( mSplitterAgenda ); | 437 | mEventIndicatorTop->setPaintWidget( mSplitterAgenda ); |
439 | #endif | 438 | #endif |
440 | mDayLabelsFrame = new QHBox(agendaFrame); | 439 | mDayLabelsFrame = new QHBox(agendaFrame); |
441 | //topLayout->addWidget(mDayLabelsFrame); | 440 | //topLayout->addWidget(mDayLabelsFrame); |
442 | mDayLabels = new QFrame (mDayLabelsFrame); | 441 | mDayLabels = new QFrame (mDayLabelsFrame); |
443 | mLayoutDayLabels = new QHBoxLayout(mDayLabels); | 442 | mLayoutDayLabels = new QHBoxLayout(mDayLabels); |
444 | agendaLayout->addMultiCellWidget(mDayLabelsFrame ,0,0,0,2); | 443 | agendaLayout->addMultiCellWidget(mDayLabelsFrame ,0,0,0,2); |
445 | agendaLayout->addWidget(mEventIndicatorTop,1,1); | 444 | agendaLayout->addWidget(mEventIndicatorTop,1,1); |
446 | 445 | ||
447 | mEventIndicatorBottom = new EventIndicator(EventIndicator::Bottom, | 446 | mEventIndicatorBottom = new EventIndicator(EventIndicator::Bottom, |
448 | agendaFrame); | 447 | agendaFrame); |
449 | agendaLayout->addWidget(mEventIndicatorBottom,3,1); | 448 | agendaLayout->addWidget(mEventIndicatorBottom,3,1); |
450 | QWidget *dummyAgendaRight = new QWidget(agendaFrame); | 449 | QWidget *dummyAgendaRight = new QWidget(agendaFrame); |
451 | agendaLayout->addWidget(dummyAgendaRight,1,2); | 450 | agendaLayout->addWidget(dummyAgendaRight,1,2); |
452 | 451 | ||
453 | // Create time labels | 452 | // Create time labels |
454 | mTimeLabels = new TimeLabels(24,agendaFrame); | 453 | mTimeLabels = new TimeLabels(24,agendaFrame); |
455 | agendaLayout->addWidget(mTimeLabels,2,0); | 454 | agendaLayout->addWidget(mTimeLabels,2,0); |
456 | connect(mTimeLabels,SIGNAL( scaleChanged()), | 455 | connect(mTimeLabels,SIGNAL( scaleChanged()), |
457 | this,SLOT(updateConfig())); | 456 | this,SLOT(updateConfig())); |
458 | 457 | ||
459 | // Create agenda | 458 | // Create agenda |
460 | mAgenda = new KOAgenda(1,96,KOPrefs::instance()->mHourSize,agendaFrame); | 459 | mAgenda = new KOAgenda(1,96,KOPrefs::instance()->mHourSize,agendaFrame); |
461 | agendaLayout->addMultiCellWidget(mAgenda,2,2,1,2); | 460 | agendaLayout->addMultiCellWidget(mAgenda,2,2,1,2); |
462 | agendaLayout->setColStretch(1,1); | 461 | agendaLayout->setColStretch(1,1); |
463 | mAgenda->setFocusPolicy(NoFocus); | 462 | mAgenda->setFocusPolicy(NoFocus); |
464 | // Create event context menu for agenda | 463 | // Create event context menu for agenda |
465 | mAllAgendaPopup = eventPopup(); | 464 | mAllAgendaPopup = eventPopup(); |
466 | 465 | ||
467 | #if 0 | 466 | #if 0 |
468 | mAllAgendaPopup->addAdditionalItem(QIconSet(SmallIcon("bell")), | 467 | mAllAgendaPopup->addAdditionalItem(QIconSet(SmallIcon("bell")), |
469 | i18n("Toggle Alarm"),mAgenda, | 468 | i18n("Toggle Alarm"),mAgenda, |
470 | SLOT(popupAlarm()),true); | 469 | SLOT(popupAlarm()),true); |
471 | 470 | ||
472 | #endif | 471 | #endif |
473 | connect(mAgenda,SIGNAL(showIncidencePopupSignal(Incidence *)), | 472 | connect(mAgenda,SIGNAL(showIncidencePopupSignal(Incidence *)), |
474 | mAllAgendaPopup,SLOT(showIncidencePopup(Incidence *))); | 473 | mAllAgendaPopup,SLOT(showIncidencePopup(Incidence *))); |
475 | 474 | ||
476 | connect(mAllDayAgenda,SIGNAL(showIncidencePopupSignal(Incidence *)), | 475 | connect(mAllDayAgenda,SIGNAL(showIncidencePopupSignal(Incidence *)), |
477 | mAllAgendaPopup,SLOT(showIncidencePopup(Incidence *))); | 476 | mAllAgendaPopup,SLOT(showIncidencePopup(Incidence *))); |
478 | mAgenda->setPopup( mAllAgendaPopup ); | 477 | mAgenda->setPopup( mAllAgendaPopup ); |
479 | mAllDayAgenda->setPopup( mAllAgendaPopup ); | 478 | mAllDayAgenda->setPopup( mAllAgendaPopup ); |
480 | // make connections between dependent widgets | 479 | // make connections between dependent widgets |
481 | mTimeLabels->setAgenda(mAgenda); | 480 | mTimeLabels->setAgenda(mAgenda); |
482 | 481 | ||
483 | // Update widgets to reflect user preferences | 482 | // Update widgets to reflect user preferences |
484 | // updateConfig(); | 483 | // updateConfig(); |
485 | 484 | ||
486 | // createDayLabels(); | 485 | // createDayLabels(); |
487 | 486 | ||
488 | // these blank widgets make the All Day Event box line up with the agenda | 487 | // these blank widgets make the All Day Event box line up with the agenda |
489 | dummyAllDayRight->setFixedWidth(mAgenda->verticalScrollBar()->width()); | 488 | dummyAllDayRight->setFixedWidth(mAgenda->verticalScrollBar()->width()); |
490 | dummyAgendaRight->setFixedWidth(mAgenda->verticalScrollBar()->width()); | 489 | dummyAgendaRight->setFixedWidth(mAgenda->verticalScrollBar()->width()); |
491 | mDummyAllDayLeft->setFixedWidth(mTimeLabels->width()); | 490 | mDummyAllDayLeft->setFixedWidth(mTimeLabels->width()); |
492 | 491 | ||
493 | // Scrolling | 492 | // Scrolling |
494 | connect(mAgenda->verticalScrollBar(),SIGNAL(valueChanged(int)), | 493 | connect(mAgenda->verticalScrollBar(),SIGNAL(valueChanged(int)), |
495 | mTimeLabels, SLOT(positionChanged())); | 494 | mTimeLabels, SLOT(positionChanged())); |
496 | connect(mTimeLabels->verticalScrollBar(),SIGNAL(valueChanged(int)), | 495 | connect(mTimeLabels->verticalScrollBar(),SIGNAL(valueChanged(int)), |
497 | SLOT(setContentsPos(int))); | 496 | SLOT(setContentsPos(int))); |
498 | 497 | ||
499 | connect(mAgenda,SIGNAL(showDateView( int, int)),SLOT(slotShowDateView( int, int ))); | 498 | connect(mAgenda,SIGNAL(showDateView( int, int)),SLOT(slotShowDateView( int, int ))); |
500 | connect(mAllDayAgenda,SIGNAL(showDateView( int, int )), SLOT(slotShowDateView( int, int ) )); | 499 | connect(mAllDayAgenda,SIGNAL(showDateView( int, int )), SLOT(slotShowDateView( int, int ) )); |
501 | 500 | ||
502 | // Create/Show/Edit/Delete Event | 501 | // Create/Show/Edit/Delete Event |
503 | connect(mAgenda,SIGNAL(newEventSignal(int,int)), | 502 | connect(mAgenda,SIGNAL(newEventSignal(int,int)), |
504 | SLOT(newEvent(int,int))); | 503 | SLOT(newEvent(int,int))); |
505 | connect(mAgenda,SIGNAL(newTodoSignal(int,int)), | 504 | connect(mAgenda,SIGNAL(newTodoSignal(int,int)), |
506 | SLOT(newTodo(int,int))); | 505 | SLOT(newTodo(int,int))); |
507 | connect(mAgenda,SIGNAL(newEventSignal(int,int,int,int)), | 506 | connect(mAgenda,SIGNAL(newEventSignal(int,int,int,int)), |
508 | SLOT(newEvent(int,int,int,int))); | 507 | SLOT(newEvent(int,int,int,int))); |
509 | connect(mAllDayAgenda,SIGNAL(newEventSignal(int,int)), | 508 | connect(mAllDayAgenda,SIGNAL(newEventSignal(int,int)), |
510 | SLOT(newEventAllDay(int,int))); | 509 | SLOT(newEventAllDay(int,int))); |
511 | connect(mAllDayAgenda,SIGNAL(newTodoSignal(int,int)), | 510 | connect(mAllDayAgenda,SIGNAL(newTodoSignal(int,int)), |
512 | SLOT(newTodoAllDay(int,int))); | 511 | SLOT(newTodoAllDay(int,int))); |
513 | connect(mAllDayAgenda,SIGNAL(newEventSignal(int,int,int,int)), | 512 | connect(mAllDayAgenda,SIGNAL(newEventSignal(int,int,int,int)), |
514 | SLOT(newEventAllDay(int,int))); | 513 | SLOT(newEventAllDay(int,int))); |
515 | connect(mAgenda,SIGNAL(newTimeSpanSignal(int,int,int,int)), | 514 | connect(mAgenda,SIGNAL(newTimeSpanSignal(int,int,int,int)), |
516 | SLOT(newTimeSpanSelected(int,int,int,int))); | 515 | SLOT(newTimeSpanSelected(int,int,int,int))); |
517 | connect(mAllDayAgenda,SIGNAL(newTimeSpanSignal(int,int,int,int)), | 516 | connect(mAllDayAgenda,SIGNAL(newTimeSpanSignal(int,int,int,int)), |
518 | SLOT(newTimeSpanSelectedAllDay(int,int,int,int))); | 517 | SLOT(newTimeSpanSelectedAllDay(int,int,int,int))); |
519 | connect(mAgenda,SIGNAL(newStartSelectSignal()),SLOT(updateView())); | 518 | connect(mAgenda,SIGNAL(newStartSelectSignal()),SLOT(updateView())); |
520 | connect(mAllDayAgenda,SIGNAL(newStartSelectSignal()),SLOT(updateView())); | 519 | connect(mAllDayAgenda,SIGNAL(newStartSelectSignal()),SLOT(updateView())); |
521 | 520 | ||
522 | connect(mAgenda,SIGNAL(editIncidenceSignal(Incidence *)), | 521 | connect(mAgenda,SIGNAL(editIncidenceSignal(Incidence *)), |
523 | SIGNAL(editIncidenceSignal(Incidence *))); | 522 | SIGNAL(editIncidenceSignal(Incidence *))); |
524 | connect(mAllDayAgenda,SIGNAL(editIncidenceSignal(Incidence *)), | 523 | connect(mAllDayAgenda,SIGNAL(editIncidenceSignal(Incidence *)), |
525 | SIGNAL(editIncidenceSignal(Incidence *))); | 524 | SIGNAL(editIncidenceSignal(Incidence *))); |
526 | connect(mAgenda,SIGNAL(showIncidenceSignal(Incidence *)), | 525 | connect(mAgenda,SIGNAL(showIncidenceSignal(Incidence *)), |
527 | SIGNAL(showIncidenceSignal(Incidence *))); | 526 | SIGNAL(showIncidenceSignal(Incidence *))); |
528 | connect(mAllDayAgenda,SIGNAL(showIncidenceSignal(Incidence *)), | 527 | connect(mAllDayAgenda,SIGNAL(showIncidenceSignal(Incidence *)), |
529 | SIGNAL(showIncidenceSignal(Incidence *))); | 528 | SIGNAL(showIncidenceSignal(Incidence *))); |
530 | connect(mAgenda,SIGNAL(deleteIncidenceSignal(Incidence *)), | 529 | connect(mAgenda,SIGNAL(deleteIncidenceSignal(Incidence *)), |
531 | SIGNAL(deleteIncidenceSignal(Incidence *))); | 530 | SIGNAL(deleteIncidenceSignal(Incidence *))); |
532 | connect(mAllDayAgenda,SIGNAL(deleteIncidenceSignal(Incidence *)), | 531 | connect(mAllDayAgenda,SIGNAL(deleteIncidenceSignal(Incidence *)), |
533 | SIGNAL(deleteIncidenceSignal(Incidence *))); | 532 | SIGNAL(deleteIncidenceSignal(Incidence *))); |
534 | 533 | ||
535 | connect(mAgenda,SIGNAL(itemModified(KOAgendaItem *, int )), | 534 | connect(mAgenda,SIGNAL(itemModified(KOAgendaItem *, int )), |
536 | SLOT(updateEventDates(KOAgendaItem *, int ))); | 535 | SLOT(updateEventDates(KOAgendaItem *, int ))); |
537 | connect(mAllDayAgenda,SIGNAL(itemModified(KOAgendaItem *, int )), | 536 | connect(mAllDayAgenda,SIGNAL(itemModified(KOAgendaItem *, int )), |
538 | SLOT(updateEventDates(KOAgendaItem *, int))); | 537 | SLOT(updateEventDates(KOAgendaItem *, int))); |
539 | 538 | ||
540 | // event indicator update | 539 | // event indicator update |
541 | connect(mAgenda,SIGNAL(lowerYChanged(int)), | 540 | connect(mAgenda,SIGNAL(lowerYChanged(int)), |
542 | SLOT(updateEventIndicatorTop(int))); | 541 | SLOT(updateEventIndicatorTop(int))); |
543 | connect(mAgenda,SIGNAL(upperYChanged(int)), | 542 | connect(mAgenda,SIGNAL(upperYChanged(int)), |
544 | SLOT(updateEventIndicatorBottom(int))); | 543 | SLOT(updateEventIndicatorBottom(int))); |
545 | // drag signals | 544 | // drag signals |
546 | /* | 545 | /* |
547 | connect(mAgenda,SIGNAL(startDragSignal(Event *)), | 546 | connect(mAgenda,SIGNAL(startDragSignal(Event *)), |
548 | SLOT(startDrag(Event *))); | 547 | SLOT(startDrag(Event *))); |
549 | connect(mAllDayAgenda,SIGNAL(startDragSignal(Event *)), | 548 | connect(mAllDayAgenda,SIGNAL(startDragSignal(Event *)), |
550 | SLOT(startDrag(Event *))); | 549 | SLOT(startDrag(Event *))); |
551 | */ | 550 | */ |
552 | // synchronize selections | 551 | // synchronize selections |
553 | connect( mAgenda, SIGNAL( incidenceSelected( Incidence * ) ), | 552 | connect( mAgenda, SIGNAL( incidenceSelected( Incidence * ) ), |
554 | mAllDayAgenda, SLOT( deselectItem() ) ); | 553 | mAllDayAgenda, SLOT( deselectItem() ) ); |
555 | connect( mAllDayAgenda, SIGNAL( incidenceSelected( Incidence * ) ), | 554 | connect( mAllDayAgenda, SIGNAL( incidenceSelected( Incidence * ) ), |
556 | mAgenda, SLOT( deselectItem() ) ); | 555 | mAgenda, SLOT( deselectItem() ) ); |
557 | connect( mAgenda, SIGNAL( incidenceSelected( Incidence * ) ), | 556 | connect( mAgenda, SIGNAL( incidenceSelected( Incidence * ) ), |
558 | SIGNAL( incidenceSelected( Incidence * ) ) ); | 557 | SIGNAL( incidenceSelected( Incidence * ) ) ); |
559 | connect( mAllDayAgenda, SIGNAL( incidenceSelected( Incidence * ) ), | 558 | connect( mAllDayAgenda, SIGNAL( incidenceSelected( Incidence * ) ), |
560 | SIGNAL( incidenceSelected( Incidence * ) ) ); | 559 | SIGNAL( incidenceSelected( Incidence * ) ) ); |
561 | connect( mAgenda, SIGNAL( resizedSignal() ), | 560 | connect( mAgenda, SIGNAL( resizedSignal() ), |
562 | SLOT( updateConfig( ) ) ); | 561 | SLOT( updateConfig( ) ) ); |
563 | connect( mAgenda, SIGNAL( addToCalSignal(Incidence *, Incidence *) ), | 562 | connect( mAgenda, SIGNAL( addToCalSignal(Incidence *, Incidence *) ), |
564 | SLOT( addToCalSlot(Incidence *, Incidence * ) ) ); | 563 | SLOT( addToCalSlot(Incidence *, Incidence * ) ) ); |
565 | connect( mAllDayAgenda, SIGNAL( addToCalSignal(Incidence * ,Incidence *) ), | 564 | connect( mAllDayAgenda, SIGNAL( addToCalSignal(Incidence * ,Incidence *) ), |
566 | SLOT( addToCalSlot(Incidence * , Incidence *) ) ); | 565 | SLOT( addToCalSlot(Incidence * , Incidence *) ) ); |
567 | // connect( mAgenda, SIGNAL( cloneIncidenceSignal(Incidence *) ), SIGNAL( cloneIncidenceSignal(Incidence *) ) ); | 566 | // connect( mAgenda, SIGNAL( cloneIncidenceSignal(Incidence *) ), SIGNAL( cloneIncidenceSignal(Incidence *) ) ); |
568 | //connect( mAllDayAgenda, SIGNAL( cloneIncidenceSignal(Incidence *) ), SIGNAL( cloneIncidenceSignal(Incidence *) ) ); | 567 | //connect( mAllDayAgenda, SIGNAL( cloneIncidenceSignal(Incidence *) ), SIGNAL( cloneIncidenceSignal(Incidence *) ) ); |
569 | 568 | ||
569 | connect( mAllDayAgenda, SIGNAL( signalClearSelection() ),mAgenda, SLOT( slotClearSelection()) ); | ||
570 | connect( mAgenda, SIGNAL( signalClearSelection() ),mAllDayAgenda, SLOT( slotClearSelection()) ); | ||
570 | 571 | ||
571 | } | 572 | } |
572 | 573 | ||
573 | void KOAgendaView::toggleAllDay() | 574 | void KOAgendaView::toggleAllDay() |
574 | { | 575 | { |
575 | if ( mSplitterAgenda->firstHandle() ) | 576 | if ( mSplitterAgenda->firstHandle() ) |
576 | mSplitterAgenda->firstHandle()->toggle(); | 577 | mSplitterAgenda->firstHandle()->toggle(); |
577 | } | 578 | } |
578 | void KOAgendaView::addToCalSlot(Incidence * inc, Incidence * incOld ) | 579 | void KOAgendaView::addToCalSlot(Incidence * inc, Incidence * incOld ) |
579 | { | 580 | { |
580 | calendar()->addIncidence( inc ); | 581 | calendar()->addIncidence( inc ); |
581 | 582 | ||
582 | if ( incOld ) { | 583 | if ( incOld ) { |
583 | if ( incOld->type() == "Todo" ) | 584 | if ( incOld->type() == "Todo" ) |
584 | emit todoMoved((Todo*)incOld, KOGlobals::EVENTEDITED ); | 585 | emit todoMoved((Todo*)incOld, KOGlobals::EVENTEDITED ); |
585 | else | 586 | else |
586 | emit incidenceChanged(incOld, KOGlobals::EVENTEDITED); | 587 | emit incidenceChanged(incOld, KOGlobals::EVENTEDITED); |
587 | } | 588 | } |
588 | 589 | ||
589 | } | 590 | } |
590 | 591 | ||
591 | KOAgendaView::~KOAgendaView() | 592 | KOAgendaView::~KOAgendaView() |
592 | { | 593 | { |
593 | delete mAllAgendaPopup; | 594 | delete mAllAgendaPopup; |
594 | //delete mAllDayAgendaPopup; | 595 | //delete mAllDayAgendaPopup; |
595 | delete KOAgendaItem::paintPix(); | 596 | delete KOAgendaItem::paintPix(); |
596 | delete KOAgendaItem::paintPixSel(); | 597 | delete KOAgendaItem::paintPixSel(); |
597 | } | 598 | } |
598 | void KOAgendaView::resizeEvent( QResizeEvent* e ) | 599 | void KOAgendaView::resizeEvent( QResizeEvent* e ) |
599 | { | 600 | { |
600 | //qDebug("KOAgendaView::resizeEvent( QResizeEvent* e ) %d ", e->size().width()); | 601 | //qDebug("KOAgendaView::resizeEvent( QResizeEvent* e ) %d ", e->size().width()); |
601 | bool uc = false; | 602 | bool uc = false; |
602 | int ow = e->oldSize().width(); | 603 | int ow = e->oldSize().width(); |
603 | int oh = e->oldSize().height(); | 604 | int oh = e->oldSize().height(); |
604 | int w = e->size().width(); | 605 | int w = e->size().width(); |
605 | int h = e->size().height(); | 606 | int h = e->size().height(); |
606 | if ( (ow > oh && w< h ) || (ow < oh && w > h ) ) { | 607 | if ( (ow > oh && w< h ) || (ow < oh && w > h ) ) { |
607 | if ( ! mBlockUpdating && !globalFlagBlockStartup && !globalFlagBlockAgenda ) | 608 | if ( ! mBlockUpdating && !globalFlagBlockStartup && !globalFlagBlockAgenda ) |
608 | uc = true; | 609 | uc = true; |
609 | //qDebug("view changed %d %d %d %d ", ow, oh , w , h); | 610 | //qDebug("view changed %d %d %d %d ", ow, oh , w , h); |
610 | } | 611 | } |
611 | mUpcomingWidth = e->size().width() ; | 612 | mUpcomingWidth = e->size().width() ; |
612 | if ( mBlockUpdating || uc ) { | 613 | if ( mBlockUpdating || uc ) { |
613 | mBlockUpdating = false; | 614 | mBlockUpdating = false; |
614 | //mAgenda->setMinimumSize(800 , 600 ); | 615 | //mAgenda->setMinimumSize(800 , 600 ); |
615 | //qDebug("mAgenda->resize+++++++++++++++ "); | 616 | //qDebug("mAgenda->resize+++++++++++++++ "); |
616 | updateConfig(); | 617 | updateConfig(); |
617 | //qDebug("KOAgendaView::Updating now possible "); | 618 | //qDebug("KOAgendaView::Updating now possible "); |
618 | } else | 619 | } else |
619 | createDayLabels(); | 620 | createDayLabels(); |
620 | //qDebug("resizeEvent end "); | 621 | //qDebug("resizeEvent end "); |
621 | 622 | ||
622 | } | 623 | } |
623 | void KOAgendaView::slotDaylabelClicked( int num ) | 624 | void KOAgendaView::slotDaylabelClicked( int num ) |
624 | { | 625 | { |
625 | 626 | ||
626 | QDate firstDate = mSelectedDates.first(); | 627 | QDate firstDate = mSelectedDates.first(); |
627 | if ( num == -1 ) | 628 | if ( num == -1 ) |
628 | emit showDateView( 6, firstDate ); | 629 | emit showDateView( 6, firstDate ); |
629 | else if (num >= 0 ) { | 630 | else if (num >= 0 ) { |
630 | if ( mSelectedDates.count() == 1) | 631 | if ( mSelectedDates.count() == 1) |
631 | emit showDateView( 9, firstDate.addDays( num ) ); | 632 | emit showDateView( 9, firstDate.addDays( num ) ); |
632 | else | 633 | else |
633 | emit showDateView( 3, firstDate.addDays( num ) ); | 634 | emit showDateView( 3, firstDate.addDays( num ) ); |
634 | } | 635 | } |
635 | else | 636 | else |
636 | showDateView( 10, firstDate.addDays(1) ); | 637 | showDateView( 10, firstDate.addDays(1) ); |
637 | } | 638 | } |
638 | 639 | ||
639 | KOAgendaButton* KOAgendaView::getNewDaylabel() | 640 | KOAgendaButton* KOAgendaView::getNewDaylabel() |
640 | { | 641 | { |
641 | 642 | ||
642 | KOAgendaButton * dayLabel = new KOAgendaButton(mDayLabels); | 643 | KOAgendaButton * dayLabel = new KOAgendaButton(mDayLabels); |
643 | connect( dayLabel, SIGNAL( numClicked(int) ), this, SLOT ( slotDaylabelClicked(int) ) ); | 644 | connect( dayLabel, SIGNAL( numClicked(int) ), this, SLOT ( slotDaylabelClicked(int) ) ); |
644 | mDayLabelsList.append( dayLabel ); | 645 | mDayLabelsList.append( dayLabel ); |
645 | mLayoutDayLabels->addWidget(dayLabel); | 646 | mLayoutDayLabels->addWidget(dayLabel); |
646 | return dayLabel ; | 647 | return dayLabel ; |
647 | } | 648 | } |
648 | 649 | ||
649 | void KOAgendaView::createDayLabels() | 650 | void KOAgendaView::createDayLabels() |
650 | { | 651 | { |
651 | 652 | ||
652 | if ( mBlockUpdating || globalFlagBlockLabel == 1) { | 653 | if ( mBlockUpdating || globalFlagBlockLabel == 1) { |
653 | // qDebug(" KOAgendaView::createDayLabels() blocked "); | 654 | // qDebug(" KOAgendaView::createDayLabels() blocked "); |
654 | return; | 655 | return; |
655 | 656 | ||
656 | } | 657 | } |
657 | int newHight; | 658 | int newHight; |
658 | if ( !mSelectedDates.count()) | 659 | if ( !mSelectedDates.count()) |
659 | return; | 660 | return; |
660 | 661 | ||
661 | // ### Before deleting and recreating we could check if mSelectedDates changed... | 662 | // ### Before deleting and recreating we could check if mSelectedDates changed... |
662 | // It would remove some flickering and gain speed (since this is called by | 663 | // It would remove some flickering and gain speed (since this is called by |
663 | // each updateView() call) | 664 | // each updateView() call) |
664 | 665 | ||
665 | int maxWid = mUpcomingWidth - mTimeLabels->width()- mAgenda->verticalScrollBar()->width() - mAgenda->frameWidth()*2; | 666 | int maxWid = mUpcomingWidth - mTimeLabels->width()- mAgenda->verticalScrollBar()->width() - mAgenda->frameWidth()*2; |
666 | mDayLabelsFrame->setMaximumWidth( mUpcomingWidth ); | 667 | mDayLabelsFrame->setMaximumWidth( mUpcomingWidth ); |
667 | if ( maxWid < 20 ) | 668 | if ( maxWid < 20 ) |
668 | maxWid = 20; | 669 | maxWid = 20; |
669 | 670 | ||
670 | QFont dlf = KOPrefs::instance()->mTimeLabelsFont; | 671 | QFont dlf = KOPrefs::instance()->mTimeLabelsFont; |
671 | QFontMetrics fm ( dlf ); | 672 | QFontMetrics fm ( dlf ); |
672 | int selCount = mSelectedDates.count(); | 673 | int selCount = mSelectedDates.count(); |
673 | int widModulo = maxWid - (mAgenda->gridSpacingX() * selCount)+1; | 674 | int widModulo = maxWid - (mAgenda->gridSpacingX() * selCount)+1; |
674 | QString dayTest = "Mon 20"; | 675 | QString dayTest = "Mon 20"; |
675 | //QString dayTest = "Mon 20"; | 676 | //QString dayTest = "Mon 20"; |
676 | int wid = fm.width( dayTest ); | 677 | int wid = fm.width( dayTest ); |
677 | //maxWid -= ( selCount * 3 ); //working for QLabels | 678 | //maxWid -= ( selCount * 3 ); //working for QLabels |
678 | if ( QApplication::desktop()->width() <= 320 ) | 679 | if ( QApplication::desktop()->width() <= 320 ) |
679 | maxWid -= ( selCount * 3 ); //working for QPushButton | 680 | maxWid -= ( selCount * 3 ); //working for QPushButton |
680 | else | 681 | else |
681 | maxWid -= ( selCount * 3 ); //working for QPushButton | 682 | maxWid -= ( selCount * 3 ); //working for QPushButton |
682 | if ( maxWid < 0 ) | 683 | if ( maxWid < 0 ) |
683 | maxWid = 20; | 684 | maxWid = 20; |
684 | int needWid = wid * selCount; | 685 | int needWid = wid * selCount; |
685 | //qDebug("++++++++Needed : %d MaxWidth: %d", needWid, maxWid ); | 686 | //qDebug("++++++++Needed : %d MaxWidth: %d", needWid, maxWid ); |
686 | //if ( needWid > maxWid ) | 687 | //if ( needWid > maxWid ) |
687 | // qDebug("DAYLABELS TOOOOOOO BIG "); | 688 | // qDebug("DAYLABELS TOOOOOOO BIG "); |
688 | while ( needWid > maxWid ) { | 689 | while ( needWid > maxWid ) { |
689 | dayTest = dayTest.left( dayTest.length() - 1 ); | 690 | dayTest = dayTest.left( dayTest.length() - 1 ); |
690 | wid = fm.width( dayTest ); | 691 | wid = fm.width( dayTest ); |
691 | needWid = wid * selCount; | 692 | needWid = wid * selCount; |
692 | } | 693 | } |
693 | int maxLen = dayTest.length(); | 694 | int maxLen = dayTest.length(); |
694 | int fontPoint = dlf.pointSize(); | 695 | int fontPoint = dlf.pointSize(); |
695 | if ( maxLen < 2 ) { | 696 | if ( maxLen < 2 ) { |
696 | int fontPoint = dlf.pointSize(); | 697 | int fontPoint = dlf.pointSize(); |
697 | while ( fontPoint > 4 ) { | 698 | while ( fontPoint > 4 ) { |
698 | --fontPoint; | 699 | --fontPoint; |
699 | dlf.setPointSize( fontPoint ); | 700 | dlf.setPointSize( fontPoint ); |
700 | QFontMetrics f( dlf ); | 701 | QFontMetrics f( dlf ); |
701 | wid = f.width( "30" ); | 702 | wid = f.width( "30" ); |
702 | needWid = wid * selCount; | 703 | needWid = wid * selCount; |
703 | if ( needWid < maxWid ) | 704 | if ( needWid < maxWid ) |
704 | break; | 705 | break; |
705 | } | 706 | } |
706 | maxLen = 2; | 707 | maxLen = 2; |
707 | } | 708 | } |
708 | //qDebug("Max len %d ", dayTest.length() ); | 709 | //qDebug("Max len %d ", dayTest.length() ); |
709 | 710 | ||
710 | QFontMetrics tempF( dlf ); | 711 | QFontMetrics tempF( dlf ); |
711 | newHight = tempF.height(); | 712 | newHight = tempF.height(); |
712 | mDayLabels->setFont( dlf ); | 713 | mDayLabels->setFont( dlf ); |
713 | // mLayoutDayLabels = new QHBoxLayout(mDayLabels);; | 714 | // mLayoutDayLabels = new QHBoxLayout(mDayLabels);; |
714 | // mLayoutDayLabels->addSpacing(mTimeLabels->width()); | 715 | // mLayoutDayLabels->addSpacing(mTimeLabels->width()); |
715 | //mLayoutDayLabels->addSpacing( 2 ); | 716 | //mLayoutDayLabels->addSpacing( 2 ); |
716 | // QFont lFont = dlf; | 717 | // QFont lFont = dlf; |
717 | bool appendLabels = false; | 718 | bool appendLabels = false; |
718 | KOAgendaButton *dayLabel; | 719 | KOAgendaButton *dayLabel; |
719 | dayLabel = mDayLabelsList.first(); | 720 | dayLabel = mDayLabelsList.first(); |
720 | if ( !dayLabel ) { | 721 | if ( !dayLabel ) { |
721 | appendLabels = true; | 722 | appendLabels = true; |
722 | dayLabel = getNewDaylabel(); | 723 | dayLabel = getNewDaylabel(); |
723 | } | 724 | } |
724 | dayLabel->setFixedWidth( mTimeLabels->width()+mAgenda->frameWidth() ); | 725 | dayLabel->setFixedWidth( mTimeLabels->width()+mAgenda->frameWidth() ); |
725 | dayLabel->setFont( dlf ); | 726 | dayLabel->setFont( dlf ); |
726 | dayLabel->setNum( -1 ); | 727 | dayLabel->setNum( -1 ); |
727 | //dayLabel->setAlignment(QLabel::AlignHCenter); | 728 | //dayLabel->setAlignment(QLabel::AlignHCenter); |
728 | #if 0 | 729 | |
729 | if ( QApplication::desktop()->width() <= 320 ) | 730 | dayLabel->setText( KOGlobals::self()->calendarSystem()->monthName( mSelectedDates.first(), true ) ); |
730 | dayLabel->setText( KOGlobals::self()->calendarSystem()->monthName( mSelectedDates.first(), true ).left(2) ); | ||
731 | else | ||
732 | #endif | ||
733 | dayLabel->setText( KOGlobals::self()->calendarSystem()->monthName( mSelectedDates.first(), true ) ); | ||
734 | dayLabel->show(); | 731 | dayLabel->show(); |
735 | DateList::ConstIterator dit; | 732 | DateList::ConstIterator dit; |
736 | bool oneday = (mSelectedDates.first() == mSelectedDates.last() ); | 733 | bool oneday = (mSelectedDates.first() == mSelectedDates.last() ); |
737 | int counter = -1; | 734 | int counter = -1; |
738 | for( dit = mSelectedDates.begin(); dit != mSelectedDates.end(); ++dit ) { | 735 | for( dit = mSelectedDates.begin(); dit != mSelectedDates.end(); ++dit ) { |
739 | ++counter; | 736 | ++counter; |
740 | QDate date = *dit; | 737 | QDate date = *dit; |
741 | // QBoxLayout *dayLayout = new QVBoxLayout(mLayoutDayLabels); | 738 | // QBoxLayout *dayLayout = new QVBoxLayout(mLayoutDayLabels); |
742 | if ( ! appendLabels ) { | 739 | if ( ! appendLabels ) { |
743 | dayLabel = mDayLabelsList.next(); | 740 | dayLabel = mDayLabelsList.next(); |
744 | if ( !dayLabel ) | 741 | if ( !dayLabel ) |
745 | appendLabels = true; | 742 | appendLabels = true; |
746 | } | 743 | } |
747 | if ( appendLabels ) { | 744 | if ( appendLabels ) { |
748 | dayLabel = getNewDaylabel(); | 745 | dayLabel = getNewDaylabel(); |
749 | } | 746 | } |
750 | dayLabel->setMinimumWidth( 1 ); | 747 | dayLabel->setMinimumWidth( 1 ); |
751 | dayLabel->setMaximumWidth( 10240 ); | 748 | dayLabel->setMaximumWidth( 10240 ); |
752 | dayLabel->setFont( dlf ); | 749 | dayLabel->setFont( dlf ); |
753 | dayLabel->show(); | 750 | dayLabel->show(); |
754 | dayLabel->setAutoRepeat( false ); | 751 | dayLabel->setAutoRepeat( false ); |
755 | dayLabel->setNum( counter ); | 752 | dayLabel->setNum( counter ); |
756 | QString str; | 753 | QString str; |
757 | int dW = KOGlobals::self()->calendarSystem()->dayOfWeek(date); | 754 | int dW = KOGlobals::self()->calendarSystem()->dayOfWeek(date); |
758 | QString dayName = KOGlobals::self()->calendarSystem()->weekDayName( dW, true ); | 755 | QString dayName = KOGlobals::self()->calendarSystem()->weekDayName( dW, true ); |
759 | switch ( maxLen ) { | 756 | switch ( maxLen ) { |
760 | case 2: | 757 | case 2: |
761 | str = QString::number( date.day() ); | 758 | str = QString::number( date.day() ); |
762 | break; | 759 | break; |
763 | 760 | ||
764 | case 3: | 761 | case 3: |
765 | str = dayName.left( 1 ) +QString::number( date.day()); | 762 | str = dayName.left( 1 ) +QString::number( date.day()); |
766 | 763 | ||
767 | break; | 764 | break; |
768 | case 4: | 765 | case 4: |
769 | str = dayName.left( 1 ) + " " +QString::number( date.day()); | 766 | str = dayName.left( 1 ) + " " +QString::number( date.day()); |
770 | 767 | ||
771 | break; | 768 | break; |
772 | case 5: | 769 | case 5: |
773 | str = dayName.left( 2 ) + " " +QString::number( date.day()); | 770 | str = dayName.left( 2 ) + " " +QString::number( date.day()); |
774 | 771 | ||
775 | break; | 772 | break; |
776 | case 6: | 773 | case 6: |
777 | str = dayName.left( 3 ) + " " +QString::number( date.day()); | 774 | str = dayName.left( 3 ) + " " +QString::number( date.day()); |
778 | break; | 775 | break; |
779 | 776 | ||
780 | default: | 777 | default: |
781 | break; | 778 | break; |
782 | } | 779 | } |
783 | if ( oneday ) { | 780 | if ( oneday ) { |
784 | QString addString; | 781 | QString addString; |
785 | if ( mSelectedDates.first() == QDateTime::currentDateTime().date() ) | 782 | if ( mSelectedDates.first() == QDateTime::currentDateTime().date() ) |
786 | addString = i18n("Today"); | 783 | addString = i18n("Today"); |
787 | else if ( mSelectedDates.first() == QDateTime::currentDateTime().date().addDays(1) ) | 784 | else if ( mSelectedDates.first() == QDateTime::currentDateTime().date().addDays(1) ) |
788 | addString = i18n("Tomorrow"); | 785 | addString = i18n("Tomorrow"); |
789 | else if ( mSelectedDates.first() == QDateTime::currentDateTime().date().addDays(-1) ) | 786 | else if ( mSelectedDates.first() == QDateTime::currentDateTime().date().addDays(-1) ) |
790 | addString = i18n("Yesterday"); | 787 | addString = i18n("Yesterday"); |
791 | else if ( mSelectedDates.first() == QDateTime::currentDateTime().date().addDays(-2) ) | 788 | else if ( mSelectedDates.first() == QDateTime::currentDateTime().date().addDays(-2) ) |
792 | addString = i18n("Day before yesterday"); | 789 | addString = i18n("Day before yesterday"); |
793 | else if ( mSelectedDates.first() == QDateTime::currentDateTime().date().addDays(2) ) | 790 | else if ( mSelectedDates.first() == QDateTime::currentDateTime().date().addDays(2) ) |
794 | addString = i18n("Day after tomorrow"); | 791 | addString = i18n("Day after tomorrow"); |
795 | if ( !addString.isEmpty() ) { | 792 | if ( !addString.isEmpty() ) { |
796 | str = addString+", " + str; | 793 | str = addString+", " + str; |
797 | } else { | 794 | } else { |
798 | str = KGlobal::locale()->formatDate( date, KOPrefs::instance()->mShortDateInViewer); | 795 | str = KGlobal::locale()->formatDate( date, KOPrefs::instance()->mShortDateInViewer); |
799 | } | 796 | } |
800 | } | 797 | } |
801 | dayLabel->setText(str); | 798 | dayLabel->setText(str); |
802 | //dayLabel->setAlignment(QLabel::AlignHCenter); | 799 | //dayLabel->setAlignment(QLabel::AlignHCenter); |
803 | if (date == QDate::currentDate()) { | 800 | if (date == QDate::currentDate()) { |
804 | QFont bFont = dlf; | 801 | QFont bFont = dlf; |
805 | bFont.setBold( true ); | 802 | bFont.setBold( true ); |
806 | dayLabel->setFont(bFont); | 803 | dayLabel->setFont(bFont); |
807 | } | 804 | } |
808 | //dayLayout->addWidget(dayLabel); | 805 | //dayLayout->addWidget(dayLabel); |
809 | 806 | ||
810 | #ifndef KORG_NOPLUGINS | 807 | #ifndef KORG_NOPLUGINS |
811 | CalendarDecoration::List cds = KOCore::self()->calendarDecorations(); | 808 | CalendarDecoration::List cds = KOCore::self()->calendarDecorations(); |
812 | CalendarDecoration *it; | 809 | CalendarDecoration *it; |
813 | for(it = cds.first(); it; it = cds.next()) { | 810 | for(it = cds.first(); it; it = cds.next()) { |
814 | QString text = it->shortText( date ); | 811 | QString text = it->shortText( date ); |
815 | if ( !text.isEmpty() ) { | 812 | if ( !text.isEmpty() ) { |
816 | QLabel *label = new QLabel(text,mDayLabels); | 813 | QLabel *label = new QLabel(text,mDayLabels); |
817 | label->setAlignment(AlignCenter); | 814 | label->setAlignment(AlignCenter); |
818 | dayLayout->addWidget(label); | 815 | dayLayout->addWidget(label); |
819 | } | 816 | } |
820 | } | 817 | } |
821 | 818 | ||
822 | for(it = cds.first(); it; it = cds.next()) { | 819 | for(it = cds.first(); it; it = cds.next()) { |
823 | QWidget *wid = it->smallWidget(mDayLabels,date); | 820 | QWidget *wid = it->smallWidget(mDayLabels,date); |
824 | if ( wid ) { | 821 | if ( wid ) { |
825 | // wid->setHeight(20); | 822 | // wid->setHeight(20); |
826 | dayLayout->addWidget(wid); | 823 | dayLayout->addWidget(wid); |
827 | } | 824 | } |
828 | } | 825 | } |
829 | #endif | 826 | #endif |
830 | } | 827 | } |
831 | if ( ! appendLabels ) { | 828 | if ( ! appendLabels ) { |
832 | dayLabel = mDayLabelsList.next(); | 829 | dayLabel = mDayLabelsList.next(); |
833 | if ( !dayLabel ) | 830 | if ( !dayLabel ) |
834 | appendLabels = true; | 831 | appendLabels = true; |
835 | } | 832 | } |
836 | if ( appendLabels ) { | 833 | if ( appendLabels ) { |
837 | dayLabel = getNewDaylabel(); | 834 | dayLabel = getNewDaylabel(); |
838 | } | 835 | } |
839 | //dayLabel->hide();//test only | 836 | //dayLabel->hide();//test only |
840 | 837 | ||
841 | dayLabel->setText(">"); | 838 | dayLabel->setText(">"); |
842 | dayLabel->setFont( dlf ); | 839 | dayLabel->setFont( dlf ); |
843 | dayLabel->setAutoRepeat( true ); | 840 | dayLabel->setAutoRepeat( true ); |
844 | dayLabel->show(); | 841 | dayLabel->show(); |
845 | dayLabel->setNum( -2 ); | 842 | dayLabel->setNum( -2 ); |
846 | dayLabel->setFixedWidth( mAgenda->verticalScrollBar()->width()+ widModulo ); | 843 | dayLabel->setFixedWidth( mAgenda->verticalScrollBar()->width()+ widModulo ); |
847 | 844 | ||
848 | //mLayoutDayLabels->addSpacing(mAgenda->verticalScrollBar()->width()+ offset+2); | 845 | //mLayoutDayLabels->addSpacing(mAgenda->verticalScrollBar()->width()+ offset+2); |
849 | if ( !appendLabels ) { | 846 | if ( !appendLabels ) { |
850 | dayLabel = mDayLabelsList.next(); | 847 | dayLabel = mDayLabelsList.next(); |
851 | while ( dayLabel ) { | 848 | while ( dayLabel ) { |
852 | //qDebug("!dayLabel %d",dayLabel ); | 849 | //qDebug("!dayLabel %d",dayLabel ); |
853 | dayLabel->hide(); | 850 | dayLabel->hide(); |
854 | dayLabel = mDayLabelsList.next(); | 851 | dayLabel = mDayLabelsList.next(); |
855 | } | 852 | } |
856 | } | 853 | } |
857 | 854 | ||
858 | mDayLabelsFrame->setFixedHeight( newHight + 4 ); | 855 | mDayLabelsFrame->setFixedHeight( newHight + 4 ); |
859 | } | 856 | } |
860 | 857 | ||
861 | int KOAgendaView::maxDatesHint() | 858 | int KOAgendaView::maxDatesHint() |
862 | { | 859 | { |
863 | // Not sure about the max number of events, so return 0 for now. | 860 | // Not sure about the max number of events, so return 0 for now. |
864 | return 0; | 861 | return 0; |
865 | } | 862 | } |
866 | 863 | ||
867 | int KOAgendaView::currentDateCount() | 864 | int KOAgendaView::currentDateCount() |
868 | { | 865 | { |
869 | return mSelectedDates.count(); | 866 | return mSelectedDates.count(); |
870 | } | 867 | } |
871 | 868 | ||
872 | QPtrList<Incidence> KOAgendaView::selectedIncidences() | 869 | QPtrList<Incidence> KOAgendaView::selectedIncidences() |
873 | { | 870 | { |
874 | QPtrList<Incidence> selected; | 871 | QPtrList<Incidence> selected; |
875 | Incidence *incidence; | 872 | Incidence *incidence; |
876 | 873 | ||
877 | incidence = mAgenda->selectedIncidence(); | 874 | incidence = mAgenda->selectedIncidence(); |
878 | if (incidence) selected.append(incidence); | 875 | if (incidence) selected.append(incidence); |
879 | 876 | ||
880 | incidence = mAllDayAgenda->selectedIncidence(); | 877 | incidence = mAllDayAgenda->selectedIncidence(); |
881 | if (incidence) selected.append(incidence); | 878 | if (incidence) selected.append(incidence); |
882 | 879 | ||
883 | return selected; | 880 | return selected; |
884 | } | 881 | } |
885 | 882 | ||
886 | DateList KOAgendaView::selectedDates() | 883 | DateList KOAgendaView::selectedDates() |
887 | { | 884 | { |
888 | DateList selected; | 885 | DateList selected; |
889 | QDate qd; | 886 | QDate qd; |
890 | 887 | ||
891 | qd = mAgenda->selectedIncidenceDate(); | 888 | qd = mAgenda->selectedIncidenceDate(); |
892 | if (qd.isValid()) selected.append(qd); | 889 | if (qd.isValid()) selected.append(qd); |
893 | 890 | ||
894 | qd = mAllDayAgenda->selectedIncidenceDate(); | 891 | qd = mAllDayAgenda->selectedIncidenceDate(); |
895 | if (qd.isValid()) selected.append(qd); | 892 | if (qd.isValid()) selected.append(qd); |
896 | 893 | ||
897 | return selected; | 894 | return selected; |
898 | } | 895 | } |
899 | 896 | ||
900 | 897 | ||
901 | void KOAgendaView::updateView() | 898 | void KOAgendaView::updateView() |
902 | { | 899 | { |
903 | if ( mBlockUpdating ) | 900 | if ( mBlockUpdating ) |
904 | return; | 901 | return; |
905 | // kdDebug() << "KOAgendaView::updateView()" << endl; | 902 | // kdDebug() << "KOAgendaView::updateView()" << endl; |
906 | fillAgenda(); | 903 | fillAgenda(); |
907 | 904 | ||
908 | } | 905 | } |
909 | 906 | ||
910 | 907 | ||
911 | /* | 908 | /* |
912 | Update configuration settings for the agenda view. This method is not | 909 | Update configuration settings for the agenda view. This method is not |
913 | complete. | 910 | complete. |
914 | */ | 911 | */ |
915 | void KOAgendaView::updateConfig() | 912 | void KOAgendaView::updateConfig() |
916 | { | 913 | { |
917 | if ( mBlockUpdating ) | 914 | if ( mBlockUpdating ) |
918 | return; | 915 | return; |
919 | if ( mAgenda->height() > 96 * KOPrefs::instance()->mHourSize ) { | 916 | if ( mAgenda->height() > 96 * KOPrefs::instance()->mHourSize ) { |
920 | int old = KOPrefs::instance()->mHourSize; | 917 | int old = KOPrefs::instance()->mHourSize; |
921 | KOPrefs::instance()->mHourSize = mAgenda->height()/96 +1; | 918 | KOPrefs::instance()->mHourSize = mAgenda->height()/96 +1; |
922 | qDebug("KOPrefs::instance()->mHourSize adjusted %d to %d ", old,KOPrefs::instance()->mHourSize ); | 919 | qDebug("KOPrefs::instance()->mHourSize adjusted %d to %d ", old,KOPrefs::instance()->mHourSize ); |
923 | } | 920 | } |
924 | 921 | ||
925 | 922 | ||
926 | // update config for children | 923 | // update config for children |
927 | mTimeLabels->updateConfig(); | 924 | mTimeLabels->updateConfig(); |
928 | mAgenda->storePosition(); | 925 | mAgenda->storePosition(); |
929 | mAgenda->updateConfig(); | 926 | mAgenda->updateConfig(); |
930 | mAllDayAgenda->updateConfig(); | 927 | mAllDayAgenda->updateConfig(); |
931 | // widget synchronization | 928 | // widget synchronization |
932 | //TODO: find a better way, maybe signal/slot | 929 | //TODO: find a better way, maybe signal/slot |
933 | mTimeLabels->positionChanged(); | 930 | mTimeLabels->positionChanged(); |
934 | 931 | ||
935 | // for some reason, this needs to be called explicitly | 932 | // for some reason, this needs to be called explicitly |
936 | mTimeLabels->repaint(); | 933 | mTimeLabels->repaint(); |
937 | 934 | ||
938 | mDummyAllDayLeft->setFixedWidth(mTimeLabels->width()); | 935 | mDummyAllDayLeft->setFixedWidth(mTimeLabels->width()); |
939 | 936 | ||
940 | // ToolTips displaying summary of events | 937 | // ToolTips displaying summary of events |
941 | KOAgendaItem::toolTipGroup()->setEnabled(KOPrefs::instance() | 938 | KOAgendaItem::toolTipGroup()->setEnabled(KOPrefs::instance() |
942 | ->mEnableToolTips); | 939 | ->mEnableToolTips); |
943 | 940 | ||
944 | //setHolidayMasks(); | 941 | //setHolidayMasks(); |
945 | 942 | ||
946 | //createDayLabels(); called by via updateView(); | 943 | //createDayLabels(); called by via updateView(); |
947 | mEventIndicatorTop->setXOffset(mTimeLabels->width() + mAgenda->frameWidth()); | 944 | mEventIndicatorTop->setXOffset(mTimeLabels->width() + mAgenda->frameWidth()); |
948 | updateView(); | 945 | updateView(); |
949 | mAgenda->restorePosition(); | 946 | mAgenda->restorePosition(); |
950 | } | 947 | } |
951 | 948 | ||
952 | 949 | ||
953 | void KOAgendaView::updateEventDates(KOAgendaItem *item, int type) | 950 | void KOAgendaView::updateEventDates(KOAgendaItem *item, int type) |
954 | { | 951 | { |
955 | 952 | ||
956 | 953 | ||
957 | int xxx = item->cellX(); | 954 | int xxx = item->cellX(); |
958 | //qDebug("KOAgendaView::updateEventDates %d %d %d %d %d", xxx, mMinY.at(xxx),mMaxY.at(xxx),item->cellYTop(),item->cellYBottom() ); | 955 | //qDebug("KOAgendaView::updateEventDates %d %d %d %d %d", xxx, mMinY.at(xxx),mMaxY.at(xxx),item->cellYTop(),item->cellYBottom() ); |
959 | if ( mMinY.at(xxx) > item->cellYTop() ) | 956 | if ( mMinY.at(xxx) > item->cellYTop() ) |
960 | mMinY.at(xxx) = item->cellYTop(); | 957 | mMinY.at(xxx) = item->cellYTop(); |
961 | if ( mMaxY.at(xxx) < item->cellYBottom() ) | 958 | if ( mMaxY.at(xxx) < item->cellYBottom() ) |
962 | mMaxY.at(xxx) = item->cellYBottom(); | 959 | mMaxY.at(xxx) = item->cellYBottom(); |
963 | 960 | ||
964 | QDateTime startDt,endDt; | 961 | QDateTime startDt,endDt; |
965 | QDate startDate; | 962 | QDate startDate; |
966 | int lenInSecs; | 963 | int lenInSecs; |
967 | // if ( type == KOAgenda::RESIZETOP ) | 964 | // if ( type == KOAgenda::RESIZETOP ) |
968 | // qDebug("RESIZETOP "); | 965 | // qDebug("RESIZETOP "); |
969 | // if ( type == KOAgenda::RESIZEBOTTOM ) | 966 | // if ( type == KOAgenda::RESIZEBOTTOM ) |
970 | // qDebug("RESIZEBOTTOM "); | 967 | // qDebug("RESIZEBOTTOM "); |
971 | // if ( type == KOAgenda::MOVE ) | 968 | // if ( type == KOAgenda::MOVE ) |
972 | // qDebug("MOVE "); | 969 | // qDebug("MOVE "); |
973 | if ( item->incidence()->type() == "Event" ) { | 970 | if ( item->incidence()->type() == "Event" ) { |
974 | startDt =item->incidence()->dtStart(); | 971 | startDt =item->incidence()->dtStart(); |
975 | endDt = item->incidence()->dtEnd(); | 972 | endDt = item->incidence()->dtEnd(); |
976 | lenInSecs = startDt.secsTo( endDt ); | 973 | lenInSecs = startDt.secsTo( endDt ); |
977 | } | 974 | } |
978 | 975 | ||
979 | // emit incidenceItemChanged( item->incidence(), KOGlobals::EVENTEDITED ); | 976 | // emit incidenceItemChanged( item->incidence(), KOGlobals::EVENTEDITED ); |
980 | 977 | ||
981 | if ( item->incidence()->type()=="Todo" && item->mLastMoveXPos > 0 ) { | 978 | if ( item->incidence()->type()=="Todo" && item->mLastMoveXPos > 0 ) { |
982 | startDate = mSelectedDates[item->mLastMoveXPos]; | 979 | startDate = mSelectedDates[item->mLastMoveXPos]; |
983 | } else { | 980 | } else { |
984 | if (item->cellX() < 0) { | 981 | if (item->cellX() < 0) { |
985 | startDate = (mSelectedDates.first()).addDays(item->cellX()); | 982 | startDate = (mSelectedDates.first()).addDays(item->cellX()); |
986 | } else { | 983 | } else { |
987 | startDate = mSelectedDates[item->cellX()]; | 984 | startDate = mSelectedDates[item->cellX()]; |
988 | } | 985 | } |
989 | } | 986 | } |
990 | startDt.setDate(startDate); | 987 | startDt.setDate(startDate); |
991 | 988 | ||
992 | if (item->incidence()->doesFloat()) { | 989 | if (item->incidence()->doesFloat()) { |
993 | endDt.setDate(startDate.addDays(item->cellWidth() - 1)); | 990 | endDt.setDate(startDate.addDays(item->cellWidth() - 1)); |
994 | } else { | 991 | } else { |
995 | if ( type == KOAgenda::RESIZETOP || type == KOAgenda::MOVE ) | 992 | if ( type == KOAgenda::RESIZETOP || type == KOAgenda::MOVE ) |
996 | startDt.setTime(mAgenda->gyToTime(item->cellYTop())); | 993 | startDt.setTime(mAgenda->gyToTime(item->cellYTop())); |
997 | if ( item->incidence()->type() == "Event" ) { | 994 | if ( item->incidence()->type() == "Event" ) { |
998 | if ( type == KOAgenda::MOVE ) { | 995 | if ( type == KOAgenda::MOVE ) { |
999 | endDt = startDt.addSecs(lenInSecs); | 996 | endDt = startDt.addSecs(lenInSecs); |
1000 | 997 | ||
1001 | } else if ( type == KOAgenda::RESIZEBOTTOM ) { | 998 | } else if ( type == KOAgenda::RESIZEBOTTOM ) { |
1002 | if (item->lastMultiItem()) { | 999 | if (item->lastMultiItem()) { |
1003 | endDt.setTime(mAgenda->gyToTime(item->lastMultiItem()->cellYBottom()+1)); | 1000 | endDt.setTime(mAgenda->gyToTime(item->lastMultiItem()->cellYBottom()+1)); |
1004 | endDt.setDate(startDate. | 1001 | endDt.setDate(startDate. |
1005 | addDays(item->lastMultiItem()->cellX() - item->cellX())); | 1002 | addDays(item->lastMultiItem()->cellX() - item->cellX())); |
1006 | } else { | 1003 | } else { |
1007 | endDt.setTime(mAgenda->gyToTime(item->cellYBottom()+1)); | 1004 | endDt.setTime(mAgenda->gyToTime(item->cellYBottom()+1)); |
1008 | endDt.setDate(startDate); | 1005 | endDt.setDate(startDate); |
1009 | } | 1006 | } |
1010 | } | 1007 | } |
1011 | } else { | 1008 | } else { |
1012 | // todo | 1009 | // todo |
1013 | if (item->lastMultiItem()) { | 1010 | if (item->lastMultiItem()) { |
1014 | endDt.setTime(mAgenda->gyToTime(item->lastMultiItem()->cellYBottom()+1)); | 1011 | endDt.setTime(mAgenda->gyToTime(item->lastMultiItem()->cellYBottom()+1)); |
1015 | endDt.setDate(startDate. | 1012 | endDt.setDate(startDate. |
1016 | addDays(item->lastMultiItem()->cellX() - item->cellX())); | 1013 | addDays(item->lastMultiItem()->cellX() - item->cellX())); |
1017 | } else { | 1014 | } else { |
1018 | //qDebug("tem->cellYBottom() %d",item->cellYBottom() ); | 1015 | //qDebug("tem->cellYBottom() %d",item->cellYBottom() ); |
1019 | if ( item->cellYBottom() > 0 ) | 1016 | if ( item->cellYBottom() > 0 ) |
1020 | endDt.setTime(mAgenda->gyToTime(item->cellYBottom()+1)); | 1017 | endDt.setTime(mAgenda->gyToTime(item->cellYBottom()+1)); |
1021 | else | 1018 | else |
1022 | endDt.setTime((static_cast<Todo*>(item->incidence()))->dtDue().time()); | 1019 | endDt.setTime((static_cast<Todo*>(item->incidence()))->dtDue().time()); |
1023 | endDt.setDate(startDate); | 1020 | endDt.setDate(startDate); |
1024 | } | 1021 | } |
1025 | } | 1022 | } |
1026 | } | 1023 | } |
1027 | if ( item->incidence()->type() == "Event" ) { | 1024 | if ( item->incidence()->type() == "Event" ) { |
1028 | item->incidence()->setDtStart(startDt); | 1025 | item->incidence()->setDtStart(startDt); |
1029 | (static_cast<Event*>(item->incidence()))->setDtEnd(endDt); | 1026 | (static_cast<Event*>(item->incidence()))->setDtEnd(endDt); |
1030 | } else if ( item->incidence()->type() == "Todo" ) { | 1027 | } else if ( item->incidence()->type() == "Todo" ) { |
1031 | Todo* to = static_cast<Todo*>(item->incidence()); | 1028 | Todo* to = static_cast<Todo*>(item->incidence()); |
1032 | 1029 | ||
1033 | to->setDtDue(endDt); | 1030 | to->setDtDue(endDt); |
1034 | if ( to->hasStartDate() ) { | 1031 | if ( to->hasStartDate() ) { |
1035 | if (to->dtStart() >= to->dtDue() ) | 1032 | if (to->dtStart() >= to->dtDue() ) |
1036 | to->setDtStart(to->dtDue().addDays( -2 )); | 1033 | to->setDtStart(to->dtDue().addDays( -2 )); |
1037 | } | 1034 | } |
1038 | 1035 | ||
1039 | } | 1036 | } |
1040 | //qDebug("KOAgendaView::updateEventDates stsart %s end %s ", startDt.toString().latin1(), endDt.toString().latin1() ); | 1037 | //qDebug("KOAgendaView::updateEventDates stsart %s end %s ", startDt.toString().latin1(), endDt.toString().latin1() ); |
1041 | item->incidence()->setRevision(item->incidence()->revision()+1); | 1038 | item->incidence()->setRevision(item->incidence()->revision()+1); |
1042 | item->setItemDate(startDt.date()); | 1039 | item->setItemDate(startDt.date()); |
1043 | //item->updateItem(); | 1040 | //item->updateItem(); |
1044 | if ( item->incidence()->type() == "Todo" ) { | 1041 | if ( item->incidence()->type() == "Todo" ) { |
1045 | emit todoMoved((Todo*)item->incidence(), KOGlobals::EVENTEDITED ); | 1042 | emit todoMoved((Todo*)item->incidence(), KOGlobals::EVENTEDITED ); |
1046 | 1043 | ||
1047 | } | 1044 | } |
1048 | else | 1045 | else |
1049 | emit incidenceChanged(item->incidence(), KOGlobals::EVENTEDITED); | 1046 | emit incidenceChanged(item->incidence(), KOGlobals::EVENTEDITED); |
1050 | item->updateItem(); | 1047 | item->updateItem(); |
1051 | } | 1048 | } |
1052 | 1049 | ||
1053 | void KOAgendaView::showDates( const QDate &start, const QDate &end ) | 1050 | void KOAgendaView::showDates( const QDate &start, const QDate &end ) |
1054 | { | 1051 | { |
1055 | // kdDebug() << "KOAgendaView::selectDates" << endl; | 1052 | // kdDebug() << "KOAgendaView::selectDates" << endl; |
1056 | 1053 | ||
1057 | mSelectedDates.clear(); | 1054 | mSelectedDates.clear(); |
1058 | // qDebug("KOAgendaView::showDates "); | 1055 | // qDebug("KOAgendaView::showDates "); |
1059 | QDate d = start; | 1056 | QDate d = start; |
1060 | while (d <= end) { | 1057 | while (d <= end) { |
1061 | mSelectedDates.append(d); | 1058 | mSelectedDates.append(d); |
1062 | d = d.addDays( 1 ); | 1059 | d = d.addDays( 1 ); |
1063 | } | 1060 | } |
1064 | 1061 | ||
1065 | // and update the view | 1062 | // and update the view |
1066 | fillAgenda(); | 1063 | fillAgenda(); |
1067 | } | 1064 | } |
1068 | 1065 | ||
1069 | 1066 | ||
1070 | void KOAgendaView::showEvents(QPtrList<Event>) | 1067 | void KOAgendaView::showEvents(QPtrList<Event>) |
1071 | { | 1068 | { |
1072 | kdDebug() << "KOAgendaView::showEvents() is not yet implemented" << endl; | 1069 | kdDebug() << "KOAgendaView::showEvents() is not yet implemented" << endl; |
1073 | } | 1070 | } |
1074 | 1071 | ||
1075 | void KOAgendaView::changeEventDisplay(Event *, int) | 1072 | void KOAgendaView::changeEventDisplay(Event *, int) |
1076 | { | 1073 | { |
1077 | // qDebug("KOAgendaView::changeEventDisplay "); | 1074 | // qDebug("KOAgendaView::changeEventDisplay "); |
1078 | // kdDebug() << "KOAgendaView::changeEventDisplay" << endl; | 1075 | // kdDebug() << "KOAgendaView::changeEventDisplay" << endl; |
1079 | // this should be re-written to be MUCH smarter. Right now we | 1076 | // this should be re-written to be MUCH smarter. Right now we |
1080 | // are just playing dumb. | 1077 | // are just playing dumb. |
1081 | fillAgenda(); | 1078 | fillAgenda(); |
1082 | } | 1079 | } |
1083 | 1080 | ||
1084 | void KOAgendaView::fillAgenda(const QDate &) | 1081 | void KOAgendaView::fillAgenda(const QDate &) |
1085 | { | 1082 | { |
1086 | // qDebug("KOAgendaView::fillAgenda "); | 1083 | // qDebug("KOAgendaView::fillAgenda "); |
1087 | fillAgenda(); | 1084 | fillAgenda(); |
1088 | } | 1085 | } |
1089 | 1086 | ||
1090 | void KOAgendaView::fillAgenda() | 1087 | void KOAgendaView::fillAgenda() |
1091 | { | 1088 | { |
1092 | if ( globalFlagBlockStartup ) | 1089 | if ( globalFlagBlockStartup ) |
1093 | return; | 1090 | return; |
1094 | if ( globalFlagBlockAgenda == 1 ) | 1091 | if ( globalFlagBlockAgenda == 1 ) |
1095 | return; | 1092 | return; |
1096 | static bool onlyOne = false; | 1093 | static bool onlyOne = false; |
1097 | if ( onlyOne ) | 1094 | if ( onlyOne ) |
1098 | return; | 1095 | return; |
1099 | onlyOne = true; | 1096 | onlyOne = true; |
1100 | //if ( globalFlagBlockAgenda == 2 ) | 1097 | //if ( globalFlagBlockAgenda == 2 ) |
1101 | //globalFlagBlockAgenda = 0; | 1098 | //globalFlagBlockAgenda = 0; |
1102 | // globalFlagBlockPainting = false; | 1099 | // globalFlagBlockPainting = false; |
1103 | if ( globalFlagBlockAgenda == 0 ) | 1100 | if ( globalFlagBlockAgenda == 0 ) |
1104 | globalFlagBlockAgenda = 1; | 1101 | globalFlagBlockAgenda = 1; |
1105 | // clearView(); | 1102 | // clearView(); |
1106 | //qDebug("fillAgenda()++++ "); | 1103 | //qDebug("fillAgenda()++++ "); |
1107 | globalFlagBlockAgendaItemPaint = 1; | 1104 | globalFlagBlockAgendaItemPaint = 1; |
1108 | 1105 | ||
1109 | mAllDayAgenda->changeColumns(mSelectedDates.count()); | 1106 | mAllDayAgenda->changeColumns(mSelectedDates.count()); |
1110 | mAgenda->changeColumns(mSelectedDates.count()); | 1107 | mAgenda->changeColumns(mSelectedDates.count()); |
1111 | qApp->processEvents(); | 1108 | qApp->processEvents(); |
1112 | mEventIndicatorTop->changeColumns(mSelectedDates.count()); | 1109 | mEventIndicatorTop->changeColumns(mSelectedDates.count()); |
1113 | mEventIndicatorBottom->changeColumns(mSelectedDates.count()); | 1110 | mEventIndicatorBottom->changeColumns(mSelectedDates.count()); |
1114 | setHolidayMasks(); | 1111 | setHolidayMasks(); |
1115 | 1112 | ||
1116 | //mAgenda->hideUnused(); | 1113 | //mAgenda->hideUnused(); |
1117 | //mAllDayAgenda->hideUnused(); | 1114 | //mAllDayAgenda->hideUnused(); |
1118 | 1115 | ||
1119 | // mAgenda->blockNextRepaint( false ); | 1116 | // mAgenda->blockNextRepaint( false ); |
1120 | // mAgenda->viewport()->repaint(); | 1117 | // mAgenda->viewport()->repaint(); |
1121 | // mAgenda->blockNextRepaint( true ); | 1118 | // mAgenda->blockNextRepaint( true ); |
1122 | mMinY.resize(mSelectedDates.count()); | 1119 | mMinY.resize(mSelectedDates.count()); |
1123 | mMaxY.resize(mSelectedDates.count()); | 1120 | mMaxY.resize(mSelectedDates.count()); |
1124 | 1121 | ||
1125 | QPtrList<Event> dayEvents; | 1122 | QPtrList<Event> dayEvents; |
1126 | 1123 | ||
1127 | // ToDo items shall be displayed for the day they are due, but only showed today if they are already overdue. | 1124 | // ToDo items shall be displayed for the day they are due, but only showed today if they are already overdue. |
1128 | // Therefore, gtodoset all of them. | 1125 | // Therefore, gtodoset all of them. |
1129 | QPtrList<Todo> todos = calendar()->todos(); | 1126 | QPtrList<Todo> todos = calendar()->todos(); |
1130 | 1127 | ||
1131 | mAgenda->setDateList(mSelectedDates); | 1128 | mAgenda->setDateList(mSelectedDates); |
1132 | 1129 | ||
1133 | QDate today = QDate::currentDate(); | 1130 | QDate today = QDate::currentDate(); |
1134 | 1131 | ||
1135 | DateList::ConstIterator dit; | 1132 | DateList::ConstIterator dit; |
1136 | int curCol = 0; | 1133 | int curCol = 0; |
1137 | for( dit = mSelectedDates.begin(); dit != mSelectedDates.end(); ++dit ) { | 1134 | for( dit = mSelectedDates.begin(); dit != mSelectedDates.end(); ++dit ) { |
1138 | QDate currentDate = *dit; | 1135 | QDate currentDate = *dit; |
1139 | // kdDebug() << "KOAgendaView::fillAgenda(): " << currentDate.toString() | 1136 | // kdDebug() << "KOAgendaView::fillAgenda(): " << currentDate.toString() |
1140 | // << endl; | 1137 | // << endl; |
1141 | 1138 | ||
1142 | dayEvents = calendar()->events(currentDate,true); | 1139 | dayEvents = calendar()->events(currentDate,true); |
1143 | 1140 | ||
1144 | // Default values, which can never be reached | 1141 | // Default values, which can never be reached |
1145 | mMinY[curCol] = mAgenda->timeToY(QTime(23,59)) + 1; | 1142 | mMinY[curCol] = mAgenda->timeToY(QTime(23,59)) + 1; |
1146 | mMaxY[curCol] = mAgenda->timeToY(QTime(0,0)) - 1; | 1143 | mMaxY[curCol] = mAgenda->timeToY(QTime(0,0)) - 1; |
1147 | 1144 | ||
1148 | unsigned int numEvent; | 1145 | unsigned int numEvent; |
1149 | for(numEvent=0;numEvent<dayEvents.count();++numEvent) { | 1146 | for(numEvent=0;numEvent<dayEvents.count();++numEvent) { |
1150 | Event *event = dayEvents.at(numEvent); | 1147 | Event *event = dayEvents.at(numEvent); |
1151 | if ( !KOPrefs::instance()->mShowSyncEvents && event->uid().left(2) == QString("la") ) | 1148 | if ( !KOPrefs::instance()->mShowSyncEvents && event->uid().left(2) == QString("la") ) |
1152 | if ( event->uid().left(15) == QString("last-syncEvent-") ) | 1149 | if ( event->uid().left(15) == QString("last-syncEvent-") ) |
1153 | continue; | 1150 | continue; |
1154 | // kdDebug() << " Event: " << event->summary() << endl; | 1151 | // kdDebug() << " Event: " << event->summary() << endl; |
1155 | 1152 | ||
1156 | int beginX = currentDate.daysTo(event->dtStart().date()) + curCol; | 1153 | int beginX = currentDate.daysTo(event->dtStart().date()) + curCol; |
1157 | int endX = currentDate.daysTo(event->dtEnd().date()) + curCol; | 1154 | int endX = currentDate.daysTo(event->dtEnd().date()) + curCol; |
1158 | 1155 | ||
1159 | // kdDebug() << " beginX: " << beginX << " endX: " << endX << endl; | 1156 | // kdDebug() << " beginX: " << beginX << " endX: " << endX << endl; |
1160 | 1157 | ||
1161 | if (event->doesFloat()) { | 1158 | if (event->doesFloat()) { |
1162 | if (event->recurrence()->doesRecur()) { | 1159 | if (event->recurrence()->doesRecur()) { |
1163 | if (event->isMultiDay() ) { | 1160 | if (event->isMultiDay() ) { |
1164 | endX = endX - beginX;// endX is now number of days | 1161 | endX = endX - beginX;// endX is now number of days |
1165 | if ( event->recursOn( currentDate ) ) { | 1162 | if ( event->recursOn( currentDate ) ) { |
1166 | endX += curCol; | 1163 | endX += curCol; |
1167 | beginX = curCol; | 1164 | beginX = curCol; |
1168 | mAllDayAgenda->insertAllDayItem(event,currentDate,beginX,endX); | 1165 | mAllDayAgenda->insertAllDayItem(event,currentDate,beginX,endX); |
1169 | } else { | 1166 | } else { |
1170 | qDebug("days %d %s",endX , currentDate.toString().latin1()); | 1167 | qDebug("days %d %s",endX , currentDate.toString().latin1()); |
1171 | QDate dateit = currentDate.addDays( -endX ); | 1168 | QDate dateit = currentDate.addDays( -endX ); |
1172 | if ( event->recursOn( dateit ) ) { | 1169 | if ( event->recursOn( dateit ) ) { |
1173 | qDebug("found %d %d %d %s", endX,curCol, curCol-endX ,dateit.toString().latin1() ); | 1170 | qDebug("found %d %d %d %s", endX,curCol, curCol-endX ,dateit.toString().latin1() ); |
1174 | if ( curCol-endX < 0 ) { | 1171 | if ( curCol-endX < 0 ) { |
1175 | mAllDayAgenda->insertAllDayItem(event,currentDate,0,curCol); | 1172 | mAllDayAgenda->insertAllDayItem(event,currentDate,0,curCol); |
1176 | } | 1173 | } |
1177 | } | 1174 | } |
1178 | } | 1175 | } |
1179 | } else { | 1176 | } else { |
1180 | mAllDayAgenda->insertAllDayItem(event,currentDate,curCol,curCol); | 1177 | mAllDayAgenda->insertAllDayItem(event,currentDate,curCol,curCol); |
1181 | } | 1178 | } |
1182 | #if 0 | 1179 | |
1183 | if (beginX <= 0 && curCol == 0) { | ||
1184 | mAllDayAgenda->insertAllDayItem(event,currentDate,beginX,endX); | ||
1185 | } else if (beginX == curCol) { | ||
1186 | mAllDayAgenda->insertAllDayItem(event,currentDate,beginX,endX); | ||
1187 | } else { | ||
1188 | qDebug("skipped %d %d %d ",beginX , endX, curCol); | ||
1189 | } | ||
1190 | #endif | ||
1191 | //mAllDayAgenda->insertAllDayItem(event,currentDate,curCol,curCol); | ||
1192 | } else { | 1180 | } else { |
1193 | if (beginX <= 0 && curCol == 0) { | 1181 | if (beginX <= 0 && curCol == 0) { |
1194 | mAllDayAgenda->insertAllDayItem(event,currentDate,beginX,endX); | 1182 | mAllDayAgenda->insertAllDayItem(event,currentDate,beginX,endX); |
1195 | } else if (beginX == curCol) { | 1183 | } else if (beginX == curCol) { |
1196 | mAllDayAgenda->insertAllDayItem(event,currentDate,beginX,endX); | 1184 | mAllDayAgenda->insertAllDayItem(event,currentDate,beginX,endX); |
1197 | } | 1185 | } |
1198 | } | 1186 | } |
1199 | } else if (event->isMultiDay()) { | 1187 | } else if (event->isMultiDay()) { |
1200 | if ( event->doesRecur () ) { | 1188 | if ( event->doesRecur () ) { |
1201 | QDate dateit = currentDate; | 1189 | QDate dateit = currentDate; |
1202 | int count = 0; | 1190 | int count = 0; |
1203 | int max = event->dtStart().daysTo( event->dtEnd() ) +2; | 1191 | int max = event->dtStart().daysTo( event->dtEnd() ) +2; |
1204 | while (! event->recursOn( dateit ) && count <= max ) { | 1192 | while (! event->recursOn( dateit ) && count <= max ) { |
1205 | ++count; | 1193 | ++count; |
1206 | dateit = dateit.addDays( -1 ); | 1194 | dateit = dateit.addDays( -1 ); |
1207 | } | 1195 | } |
1208 | bool ok; | 1196 | bool ok; |
1209 | QDateTime nextOcstart = event->getNextOccurence( QDateTime(dateit) ,&ok ); | 1197 | QDateTime nextOcstart = event->getNextOccurence( QDateTime(dateit) ,&ok ); |
1210 | if ( ok ) | 1198 | if ( ok ) |
1211 | { | 1199 | { |
1212 | int secs = event->dtStart().secsTo( event->dtEnd() ); | 1200 | int secs = event->dtStart().secsTo( event->dtEnd() ); |
1213 | QDateTime nextOcend =nextOcstart.addSecs( secs ); ; | 1201 | QDateTime nextOcend =nextOcstart.addSecs( secs ); ; |
1214 | beginX = currentDate.daysTo(nextOcstart.date()) + curCol; | 1202 | beginX = currentDate.daysTo(nextOcstart.date()) + curCol; |
1215 | endX = currentDate.daysTo(nextOcend.date()) + curCol; | 1203 | endX = currentDate.daysTo(nextOcend.date()) + curCol; |
1216 | 1204 | ||
1217 | } | 1205 | } |
1218 | } | 1206 | } |
1219 | int startY = mAgenda->timeToY(event->dtStart().time()); | 1207 | int startY = mAgenda->timeToY(event->dtStart().time()); |
1220 | int endY = mAgenda->timeToY(event->dtEnd().time()) - 1; | 1208 | int endY = mAgenda->timeToY(event->dtEnd().time()) - 1; |
1221 | //qDebug("insert %d %d %d %d %d ",beginX,endX,startY,endY , curCol ); | 1209 | //qDebug("insert %d %d %d %d %d ",beginX,endX,startY,endY , curCol ); |
1222 | if ((beginX <= 0 && curCol == 0) || beginX == curCol) { | 1210 | if ((beginX <= 0 && curCol == 0) || beginX == curCol) { |
1223 | //qDebug("insert!!! "); | 1211 | //qDebug("insert!!! "); |
1224 | mAgenda->insertMultiItem(event,currentDate,beginX,endX,startY,endY); | 1212 | mAgenda->insertMultiItem(event,currentDate,beginX,endX,startY,endY); |
1225 | } | 1213 | } |
1226 | if (beginX == curCol) { | 1214 | if (beginX == curCol) { |
1227 | mMaxY[curCol] = mAgenda->timeToY(QTime(23,59)); | 1215 | mMaxY[curCol] = mAgenda->timeToY(QTime(23,59)); |
1228 | if (startY < mMinY[curCol]) mMinY[curCol] = startY; | 1216 | if (startY < mMinY[curCol]) mMinY[curCol] = startY; |
1229 | } else if (endX == curCol) { | 1217 | } else if (endX == curCol) { |
1230 | mMinY[curCol] = mAgenda->timeToY(QTime(0,0)); | 1218 | mMinY[curCol] = mAgenda->timeToY(QTime(0,0)); |
1231 | if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; | 1219 | if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; |
1232 | } else { | 1220 | } else { |
1233 | mMinY[curCol] = mAgenda->timeToY(QTime(0,0)); | 1221 | mMinY[curCol] = mAgenda->timeToY(QTime(0,0)); |
1234 | mMaxY[curCol] = mAgenda->timeToY(QTime(23,59)); | 1222 | mMaxY[curCol] = mAgenda->timeToY(QTime(23,59)); |
1235 | } | 1223 | } |
1236 | } else { | 1224 | } else { |
1237 | int startY = mAgenda->timeToY(event->dtStart().time()); | 1225 | int startY = mAgenda->timeToY(event->dtStart().time()); |
1238 | int endY = mAgenda->timeToY(event->dtEnd().time()) - 1; | 1226 | int endY = mAgenda->timeToY(event->dtEnd().time()) - 1; |
1239 | if (endY < startY) endY = startY; | 1227 | if (endY < startY) endY = startY; |
1240 | mAgenda->insertItem(event,currentDate,curCol,startY,endY); | 1228 | mAgenda->insertItem(event,currentDate,curCol,startY,endY); |
1241 | if (startY < mMinY[curCol]) mMinY[curCol] = startY; | 1229 | if (startY < mMinY[curCol]) mMinY[curCol] = startY; |
1242 | if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; | 1230 | if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; |
1243 | } | 1231 | } |
1244 | } | 1232 | } |
1245 | // ---------- [display Todos -------------- | 1233 | // ---------- [display Todos -------------- |
1246 | unsigned int numTodo; | 1234 | unsigned int numTodo; |
1247 | for (numTodo = 0; numTodo < todos.count(); ++numTodo) { | 1235 | for (numTodo = 0; numTodo < todos.count(); ++numTodo) { |
1248 | Todo *todo = todos.at(numTodo); | 1236 | Todo *todo = todos.at(numTodo); |
1249 | 1237 | ||
1250 | if ( ! todo->hasDueDate() && !todo->hasCompletedDate()) continue; // todo shall not be displayed if it has no date | 1238 | if ( ! todo->hasDueDate() && !todo->hasCompletedDate()) continue; // todo shall not be displayed if it has no date |
1251 | 1239 | ||
1252 | // ToDo items shall be displayed for the day they are due, but only showed today if they are already overdue. | 1240 | // ToDo items shall be displayed for the day they are due, but only showed today if they are already overdue. |
1253 | // Already completed items can be displayed on their original due date | 1241 | // Already completed items can be displayed on their original due date |
1254 | //if not KOPrefs::instance()->mShowTodoInAgenda, show overdue in agenda | 1242 | //if not KOPrefs::instance()->mShowTodoInAgenda, show overdue in agenda |
1255 | bool overdue = (!todo->isCompleted()) && (todo->dtDue() < today) && KOPrefs::instance()->mShowTodoInAgenda; | 1243 | bool overdue = (!todo->isCompleted()) && (todo->dtDue() < today) && KOPrefs::instance()->mShowTodoInAgenda; |
1256 | bool fillIn = false; | 1244 | bool fillIn = false; |
1257 | if ( todo->hasCompletedDate() && todo->completed().date() == currentDate ) | 1245 | if ( todo->hasCompletedDate() && todo->completed().date() == currentDate ) |
1258 | fillIn = true; | 1246 | fillIn = true; |
1259 | if ( ! fillIn && !todo->hasCompletedDate() ) | 1247 | if ( ! fillIn && !todo->hasCompletedDate() ) |
1260 | fillIn = ((todo->dtDue().date() == currentDate) && !overdue) || ((currentDate == today) && overdue); | 1248 | fillIn = ((todo->dtDue().date() == currentDate) && !overdue) || ((currentDate == today) && overdue); |
1261 | if ( fillIn ) { | 1249 | if ( fillIn ) { |
1262 | if ( (todo->doesFloat() || overdue ) && !todo->hasCompletedDate() ) { // Todo has no due-time set or is already overdue | 1250 | if ( (todo->doesFloat() || overdue ) && !todo->hasCompletedDate() ) { // Todo has no due-time set or is already overdue |
1263 | if ( KOPrefs::instance()->mShowTodoInAgenda ) | 1251 | if ( KOPrefs::instance()->mShowTodoInAgenda ) |
1264 | mAllDayAgenda->insertAllDayItem(todo, currentDate, curCol, curCol); | 1252 | mAllDayAgenda->insertAllDayItem(todo, currentDate, curCol, curCol); |
1265 | } | 1253 | } |
1266 | else { | 1254 | else { |
1267 | QDateTime dt; | 1255 | QDateTime dt; |
1268 | if ( todo->hasCompletedDate() ) | 1256 | if ( todo->hasCompletedDate() ) |
1269 | dt = todo->completed(); | 1257 | dt = todo->completed(); |
1270 | else | 1258 | else |
1271 | dt = todo->dtDue();; | 1259 | dt = todo->dtDue();; |
1272 | 1260 | ||
1273 | 1261 | ||
1274 | int endY = mAgenda->timeToY(dt.time()) - 1; | 1262 | int endY = mAgenda->timeToY(dt.time()) - 1; |
1275 | int hi = (18/KOPrefs::instance()->mHourSize); | 1263 | int hi = (18/KOPrefs::instance()->mHourSize); |
1276 | //qDebug("hei %d ",KOPrefs::instance()->mHourSize); | 1264 | //qDebug("hei %d ",KOPrefs::instance()->mHourSize); |
1277 | int startY = endY -hi; | 1265 | int startY = endY -hi; |
1278 | 1266 | ||
1279 | mAgenda->insertItem(todo,currentDate,curCol,startY,endY); | 1267 | mAgenda->insertItem(todo,currentDate,curCol,startY,endY); |
1280 | 1268 | ||
1281 | if (startY < mMinY[curCol]) mMinY[curCol] = startY; | 1269 | if (startY < mMinY[curCol]) mMinY[curCol] = startY; |
1282 | if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; | 1270 | if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; |
1283 | } | 1271 | } |
1284 | } | 1272 | } |
1285 | } | 1273 | } |
1286 | // ---------- display Todos] -------------- | 1274 | // ---------- display Todos] -------------- |
1287 | 1275 | ||
1288 | ++curCol; | 1276 | ++curCol; |
1289 | } | 1277 | } |
1290 | mAgenda->hideUnused(); | 1278 | mAgenda->hideUnused(); |
1291 | mAllDayAgenda->hideUnused(); | 1279 | mAllDayAgenda->hideUnused(); |
1292 | mAgenda->checkScrollBoundaries(); | 1280 | mAgenda->checkScrollBoundaries(); |
1293 | 1281 | ||
1294 | deleteSelectedDateTime(); | 1282 | deleteSelectedDateTime(); |
1295 | 1283 | ||
1296 | createDayLabels(); | 1284 | createDayLabels(); |
1297 | emit incidenceSelected( 0 ); | 1285 | emit incidenceSelected( 0 ); |
1298 | 1286 | ||
1299 | if ( globalFlagBlockAgenda == 2 ) { | 1287 | if ( globalFlagBlockAgenda == 2 ) { |
1300 | if ( KOPrefs::instance()->mSetTimeToDayStartAt ) | 1288 | if ( KOPrefs::instance()->mSetTimeToDayStartAt ) |
1301 | setStartHour( KOPrefs::instance()->mDayBegins ); | 1289 | setStartHour( KOPrefs::instance()->mDayBegins ); |
1302 | else if ( KOPrefs::instance()->mCenterOnCurrentTime ) | 1290 | else if ( KOPrefs::instance()->mCenterOnCurrentTime ) |
1303 | setStartHour( QTime::currentTime ().hour() ); | 1291 | setStartHour( QTime::currentTime ().hour() ); |
1304 | // qApp->processEvents(); | 1292 | // qApp->processEvents(); |
1305 | } | 1293 | } |
1306 | qApp->processEvents(); | 1294 | qApp->processEvents(); |
1307 | //qDebug("qApp->processEvents(); END "); | 1295 | //qDebug("qApp->processEvents(); END "); |
1308 | globalFlagBlockAgenda = 0; | 1296 | globalFlagBlockAgenda = 0; |
1309 | 1297 | ||
1310 | // mAgenda->hideUnused(); | 1298 | // mAgenda->hideUnused(); |
1311 | //mAllDayAgenda->hideUnused(); | 1299 | //mAllDayAgenda->hideUnused(); |
1312 | mAllDayAgenda->drawContentsToPainter(); | 1300 | mAllDayAgenda->drawContentsToPainter(); |
1313 | mAgenda->drawContentsToPainter(); | 1301 | mAgenda->drawContentsToPainter(); |
1314 | repaintAgenda(); | 1302 | repaintAgenda(); |
1315 | onlyOne = false; | 1303 | onlyOne = false; |
1316 | // mAgenda->finishUpdate(); | 1304 | // mAgenda->finishUpdate(); |
1317 | //mAllDayAgenda->finishUpdate(); | 1305 | //mAllDayAgenda->finishUpdate(); |
1318 | 1306 | ||
1319 | // repaintAgenda(); | 1307 | // repaintAgenda(); |
1320 | //qApp->processEvents(); | 1308 | //qApp->processEvents(); |
1321 | // globalFlagBlockAgenda = 0; | 1309 | // globalFlagBlockAgenda = 0; |
1322 | } | 1310 | } |
1323 | void KOAgendaView::repaintAgenda() | 1311 | void KOAgendaView::repaintAgenda() |
1324 | { | 1312 | { |
1325 | // mAllDayAgenda->drawContentsToPainter(); | 1313 | // mAllDayAgenda->drawContentsToPainter(); |
1326 | // mAllDayAgenda->viewport()->repaint( false ); | 1314 | // mAllDayAgenda->viewport()->repaint( false ); |
1327 | // mAgenda->drawContentsToPainter(); | 1315 | // mAgenda->drawContentsToPainter(); |
1328 | // mAgenda->viewport()->repaint( false ); | 1316 | // mAgenda->viewport()->repaint( false ); |
1329 | // qApp->processEvents(); | 1317 | // qApp->processEvents(); |
1330 | 1318 | ||
1331 | //qDebug("KOAgendaView::repaintAgenda() "); | 1319 | //qDebug("KOAgendaView::repaintAgenda() "); |
1332 | //qApp->processEvents(); | 1320 | //qApp->processEvents(); |
1333 | mAgenda->viewport()->repaint( false ); | 1321 | mAgenda->viewport()->repaint( false ); |
1334 | mAllDayAgenda->viewport()->repaint( false ); | 1322 | mAllDayAgenda->viewport()->repaint( false ); |
1335 | mAgenda->finishUpdate(); | 1323 | mAgenda->finishUpdate(); |
1336 | mAllDayAgenda->finishUpdate(); | 1324 | mAllDayAgenda->finishUpdate(); |
1337 | } | 1325 | } |
1338 | 1326 | ||
1339 | 1327 | ||
1340 | void KOAgendaView::clearView() | 1328 | void KOAgendaView::clearView() |
1341 | { | 1329 | { |
1342 | // kdDebug() << "ClearView" << endl; | 1330 | // kdDebug() << "ClearView" << endl; |
1343 | mAllDayAgenda->clear(); | 1331 | mAllDayAgenda->clear(); |
1344 | mAgenda->clear(); | 1332 | mAgenda->clear(); |
1345 | } | 1333 | } |
1346 | 1334 | ||
1347 | void KOAgendaView::printPreview(CalPrinter *calPrinter, const QDate &fd, | 1335 | void KOAgendaView::printPreview(CalPrinter *calPrinter, const QDate &fd, |
1348 | const QDate &td) | 1336 | const QDate &td) |
1349 | { | 1337 | { |
1350 | #ifndef KORG_NOPRINTER | 1338 | #ifndef KORG_NOPRINTER |
1351 | if (fd == td) | 1339 | if (fd == td) |
1352 | calPrinter->preview(CalPrinter::Day, fd, td); | 1340 | calPrinter->preview(CalPrinter::Day, fd, td); |
1353 | else | 1341 | else |
1354 | calPrinter->preview(CalPrinter::Week, fd, td); | 1342 | calPrinter->preview(CalPrinter::Week, fd, td); |
1355 | #endif | 1343 | #endif |
1356 | } | 1344 | } |
1357 | 1345 | ||
1358 | // void KOAgendaView::updateMovedTodo() | 1346 | // void KOAgendaView::updateMovedTodo() |
1359 | // { | 1347 | // { |
1360 | // // updateConfig(); | 1348 | // // updateConfig(); |
1361 | // // emit updateTodoViews(); | 1349 | // // emit updateTodoViews(); |
1362 | // } | 1350 | // } |
1363 | 1351 | ||
1364 | void KOAgendaView::slotShowDateView( int mode , int d ) | 1352 | void KOAgendaView::slotShowDateView( int mode , int d ) |
1365 | { | 1353 | { |
1366 | if ( d >= mSelectedDates.count() ) { | 1354 | if ( d >= mSelectedDates.count() ) { |
1367 | qDebug("KOAgendaView::slotShowDateView datecounterror %d d ", d, mSelectedDates.count() ); | 1355 | qDebug("KOAgendaView::slotShowDateView datecounterror %d d ", d, mSelectedDates.count() ); |
1368 | 1356 | ||
1369 | } else { | 1357 | } else { |
1370 | QDate day = mSelectedDates[d]; | 1358 | QDate day = mSelectedDates[d]; |
1371 | emit showDateView(mode , day ); | 1359 | emit showDateView(mode , day ); |
1372 | } | 1360 | } |
1373 | 1361 | ||
1374 | } | 1362 | } |
1375 | void KOAgendaView::newEvent(int gx, int gy) | 1363 | void KOAgendaView::newEvent(int gx, int gy) |
1376 | { | 1364 | { |
1377 | if (!mSelectedDates.count()) return; | 1365 | if (!mSelectedDates.count()) return; |
1378 | 1366 | ||
1379 | QDate day = mSelectedDates[gx]; | 1367 | QDate day = mSelectedDates[gx]; |
1380 | 1368 | ||
1381 | QTime time = mAgenda->gyToTime(gy); | 1369 | QTime time = mAgenda->gyToTime(gy); |
1382 | QDateTime dt(day,time); | 1370 | QDateTime dt(day,time); |
1383 | // if ( dt < QDateTime::currentDateTime () ) | 1371 | // if ( dt < QDateTime::currentDateTime () ) |
1384 | // dt = QDateTime::currentDateTime ().addSecs( 3600 ); | 1372 | // dt = QDateTime::currentDateTime ().addSecs( 3600 ); |
1385 | emit newEventSignal(dt); | 1373 | emit newEventSignal(dt); |
1386 | } | 1374 | } |
1387 | 1375 | ||
1388 | void KOAgendaView::newEvent(int gxStart, int gyStart, int gxEnd, int gyEnd) | 1376 | void KOAgendaView::newEvent(int gxStart, int gyStart, int gxEnd, int gyEnd) |
1389 | { | 1377 | { |
1390 | if (!mSelectedDates.count()) return; | 1378 | if (!mSelectedDates.count()) return; |
1391 | 1379 | ||
1392 | QDate dayStart = mSelectedDates[gxStart]; | 1380 | QDate dayStart = mSelectedDates[gxStart]; |
1393 | QDate dayEnd = mSelectedDates[gxEnd]; | 1381 | QDate dayEnd = mSelectedDates[gxEnd]; |
1394 | 1382 | ||
1395 | QTime timeStart = mAgenda->gyToTime(gyStart); | 1383 | QTime timeStart = mAgenda->gyToTime(gyStart); |
1396 | QTime timeEnd = mAgenda->gyToTime( gyEnd + 1 ); | 1384 | QTime timeEnd = mAgenda->gyToTime( gyEnd + 1 ); |
1397 | 1385 | ||
1398 | QDateTime dtStart(dayStart,timeStart); | 1386 | QDateTime dtStart(dayStart,timeStart); |
1399 | QDateTime dtEnd(dayEnd,timeEnd); | 1387 | QDateTime dtEnd(dayEnd,timeEnd); |
1400 | 1388 | ||
1401 | emit newEventSignal(dtStart,dtEnd); | 1389 | emit newEventSignal(dtStart,dtEnd); |
1402 | } | 1390 | } |
1403 | 1391 | ||
1404 | void KOAgendaView::newEventAllDay(int gx, int ) | 1392 | void KOAgendaView::newEventAllDay(int gx, int ) |
1405 | { | 1393 | { |
1406 | if (!mSelectedDates.count()) return; | 1394 | if (!mSelectedDates.count()) return; |
1407 | 1395 | ||
1408 | QDate day = mSelectedDates[gx]; | 1396 | QDate day = mSelectedDates[gx]; |
1409 | 1397 | ||
1410 | emit newEventSignal(day); | 1398 | emit newEventSignal(day); |
1411 | } | 1399 | } |
1412 | void KOAgendaView::newTodoAllDay(int gx, int ) | 1400 | void KOAgendaView::newTodoAllDay(int gx, int ) |
1413 | { | 1401 | { |
1414 | if (!mSelectedDates.count()) return; | 1402 | if (!mSelectedDates.count()) return; |
1415 | 1403 | ||
1416 | QDateTime day (mSelectedDates[gx] ); | 1404 | QDateTime day (mSelectedDates[gx] ); |
1417 | emit newTodoSignal(day, true); | 1405 | emit newTodoSignal(day, true); |
1418 | } | 1406 | } |
1419 | void KOAgendaView::newTodo(int gx, int gy ) | 1407 | void KOAgendaView::newTodo(int gx, int gy ) |
1420 | { | 1408 | { |
1421 | if (!mSelectedDates.count()) return; | 1409 | if (!mSelectedDates.count()) return; |
1422 | QDate dayStart = mSelectedDates[gx]; | 1410 | QDate dayStart = mSelectedDates[gx]; |
1423 | QTime timeStart = mAgenda->gyToTime(gy); | 1411 | QTime timeStart = mAgenda->gyToTime(gy); |
1424 | QDateTime dt (dayStart,timeStart); | 1412 | QDateTime dt (dayStart,timeStart); |
1425 | emit newTodoSignal( dt, false ); | 1413 | emit newTodoSignal( dt, false ); |
1426 | } | 1414 | } |
1427 | 1415 | ||
1428 | void KOAgendaView::updateEventIndicatorTop(int newY) | 1416 | void KOAgendaView::updateEventIndicatorTop(int newY) |
1429 | { | 1417 | { |
1430 | uint i; | 1418 | uint i; |
1431 | for(i=0;i<mMinY.size();++i) { | 1419 | for(i=0;i<mMinY.size();++i) { |
1432 | if (newY >= mMinY.at(i)) mEventIndicatorTop->enableColumn(i,true); | 1420 | if (newY >= mMinY.at(i)) mEventIndicatorTop->enableColumn(i,true); |
1433 | else mEventIndicatorTop->enableColumn(i,false); | 1421 | else mEventIndicatorTop->enableColumn(i,false); |
1434 | } | 1422 | } |
1435 | 1423 | ||
1436 | mEventIndicatorTop->update(); | 1424 | mEventIndicatorTop->update(); |
1437 | } | 1425 | } |
1438 | 1426 | ||
1439 | void KOAgendaView::updateEventIndicatorBottom(int newY) | 1427 | void KOAgendaView::updateEventIndicatorBottom(int newY) |
1440 | { | 1428 | { |
1441 | uint i; | 1429 | uint i; |
1442 | for(i=0;i<mMaxY.size();++i) { | 1430 | for(i=0;i<mMaxY.size();++i) { |
1443 | if (newY <= mMaxY.at(i)) mEventIndicatorBottom->enableColumn(i,true); | 1431 | if (newY <= mMaxY.at(i)) mEventIndicatorBottom->enableColumn(i,true); |
1444 | else mEventIndicatorBottom->enableColumn(i,false); | 1432 | else mEventIndicatorBottom->enableColumn(i,false); |
1445 | } | 1433 | } |
1446 | 1434 | ||
1447 | mEventIndicatorBottom->update(); | 1435 | mEventIndicatorBottom->update(); |