author | zautrix <zautrix> | 2005-01-26 23:12:59 (UTC) |
---|---|---|
committer | zautrix <zautrix> | 2005-01-26 23:12:59 (UTC) |
commit | f20b5e71f9ae61b18f0ced792508b40432ad50b6 (patch) (unidiff) | |
tree | 3dde48c6dcecf2e5c19d3e7a62aba57c385e92df | |
parent | 15351333eff09beadb6e691e9f0aab2aaf0a95a0 (diff) | |
download | kdepimpi-f20b5e71f9ae61b18f0ced792508b40432ad50b6.zip kdepimpi-f20b5e71f9ae61b18f0ced792508b40432ad50b6.tar.gz kdepimpi-f20b5e71f9ae61b18f0ced792508b40432ad50b6.tar.bz2 |
fixes
-rw-r--r-- | korganizer/koagendaview.cpp | 2 | ||||
-rw-r--r-- | korganizer/koagendaview.h | 1 |
2 files changed, 3 insertions, 0 deletions
diff --git a/korganizer/koagendaview.cpp b/korganizer/koagendaview.cpp index b5596d9..05216a7 100644 --- a/korganizer/koagendaview.cpp +++ b/korganizer/koagendaview.cpp | |||
@@ -80,274 +80,276 @@ TimeLabels::TimeLabels(int rows,QWidget *parent,const char *name,WFlags f) : | |||
80 | QScrollView(parent,name,f) | 80 | QScrollView(parent,name,f) |
81 | { | 81 | { |
82 | mRows = rows; | 82 | mRows = rows; |
83 | 83 | ||
84 | setMinimumHeight( 20 ); | 84 | setMinimumHeight( 20 ); |
85 | mCellHeight = KOPrefs::instance()->mHourSize*4; | 85 | mCellHeight = KOPrefs::instance()->mHourSize*4; |
86 | 86 | ||
87 | enableClipper(true); | 87 | enableClipper(true); |
88 | 88 | ||
89 | setHScrollBarMode(AlwaysOff); | 89 | setHScrollBarMode(AlwaysOff); |
90 | setVScrollBarMode(AlwaysOff); | 90 | setVScrollBarMode(AlwaysOff); |
91 | 91 | ||
92 | resizeContents(50,mRows * mCellHeight); | 92 | resizeContents(50,mRows * mCellHeight); |
93 | 93 | ||
94 | viewport()->setBackgroundMode( PaletteBackground ); | 94 | viewport()->setBackgroundMode( PaletteBackground ); |
95 | } | 95 | } |
96 | 96 | ||
97 | void TimeLabels::setCellHeight(int height) | 97 | void TimeLabels::setCellHeight(int height) |
98 | { | 98 | { |
99 | mCellHeight = height; | 99 | mCellHeight = height; |
100 | } | 100 | } |
101 | 101 | ||
102 | /* | 102 | /* |
103 | Optimization so that only the "dirty" portion of the scroll view | 103 | Optimization so that only the "dirty" portion of the scroll view |
104 | is redrawn. Unfortunately, this is not called by default paintEvent() method. | 104 | is redrawn. Unfortunately, this is not called by default paintEvent() method. |
105 | */ | 105 | */ |
106 | void TimeLabels::drawContents(QPainter *p,int cx, int cy, int cw, int ch) | 106 | void TimeLabels::drawContents(QPainter *p,int cx, int cy, int cw, int ch) |
107 | { | 107 | { |
108 | 108 | ||
109 | // if ( globalFlagBlockAgenda ) | 109 | // if ( globalFlagBlockAgenda ) |
110 | // return; | 110 | // return; |
111 | // bug: the parameters cx, cy, cw, ch are the areas that need to be | 111 | // bug: the parameters cx, cy, cw, ch are the areas that need to be |
112 | // redrawn, not the area of the widget. unfortunately, this | 112 | // redrawn, not the area of the widget. unfortunately, this |
113 | // code assumes the latter... | 113 | // code assumes the latter... |
114 | 114 | ||
115 | // now, for a workaround... | 115 | // now, for a workaround... |
116 | // these two assignments fix the weird redraw bug | 116 | // these two assignments fix the weird redraw bug |
117 | cx = contentsX() + 2; | 117 | cx = contentsX() + 2; |
118 | cw = contentsWidth() - 2; | 118 | cw = contentsWidth() - 2; |
119 | // end of workaround | 119 | // end of workaround |
120 | 120 | ||
121 | int cell = ((int)(cy/mCellHeight)); | 121 | int cell = ((int)(cy/mCellHeight)); |
122 | int y = cell * mCellHeight; | 122 | int y = cell * mCellHeight; |
123 | QFontMetrics fm = fontMetrics(); | 123 | QFontMetrics fm = fontMetrics(); |
124 | QString hour; | 124 | QString hour; |
125 | QString suffix; | 125 | QString suffix; |
126 | QString fullTime; | 126 | QString fullTime; |
127 | int tW = fm.width("24:00i"); | 127 | int tW = fm.width("24:00i"); |
128 | 128 | ||
129 | while (y < cy + ch) { | 129 | while (y < cy + ch) { |
130 | p->drawLine(cx,y,cx+tW,y); | 130 | p->drawLine(cx,y,cx+tW,y); |
131 | hour.setNum(cell); | 131 | hour.setNum(cell); |
132 | suffix = "am"; | 132 | suffix = "am"; |
133 | 133 | ||
134 | // handle 24h and am/pm time formats | 134 | // handle 24h and am/pm time formats |
135 | if (KGlobal::locale()->use12Clock()) { | 135 | if (KGlobal::locale()->use12Clock()) { |
136 | if (cell > 11) suffix = "pm"; | 136 | if (cell > 11) suffix = "pm"; |
137 | if (cell == 0) hour.setNum(12); | 137 | if (cell == 0) hour.setNum(12); |
138 | if (cell > 12) hour.setNum(cell - 12); | 138 | if (cell > 12) hour.setNum(cell - 12); |
139 | } else { | 139 | } else { |
140 | suffix = ":00"; | 140 | suffix = ":00"; |
141 | } | 141 | } |
142 | 142 | ||
143 | // create string in format of "XX:XX" or "XXpm/am" | 143 | // create string in format of "XX:XX" or "XXpm/am" |
144 | fullTime = hour + suffix; | 144 | fullTime = hour + suffix; |
145 | 145 | ||
146 | // center and draw the time label | 146 | // center and draw the time label |
147 | int timeWidth = fm.width(fullTime+"i"); | 147 | int timeWidth = fm.width(fullTime+"i"); |
148 | int offset = this->width() - timeWidth; | 148 | int offset = this->width() - timeWidth; |
149 | int borderWidth = 5; | 149 | int borderWidth = 5; |
150 | int timeHeight = fm.height(); | 150 | int timeHeight = fm.height(); |
151 | timeHeight = timeHeight + 2 - ( timeHeight / 4 ); | 151 | timeHeight = timeHeight + 2 - ( timeHeight / 4 ); |
152 | p->drawText(cx -borderWidth + offset, y+ timeHeight, fullTime); | 152 | p->drawText(cx -borderWidth + offset, y+ timeHeight, fullTime); |
153 | 153 | ||
154 | // increment indices | 154 | // increment indices |
155 | y += mCellHeight; | 155 | y += mCellHeight; |
156 | cell++; | 156 | cell++; |
157 | } | 157 | } |
158 | } | 158 | } |
159 | 159 | ||
160 | /** | 160 | /** |
161 | Calculates the minimum width. | 161 | Calculates the minimum width. |
162 | */ | 162 | */ |
163 | int TimeLabels::minimumWidth() const | 163 | int TimeLabels::minimumWidth() const |
164 | { | 164 | { |
165 | QFontMetrics fm = fontMetrics(); | 165 | QFontMetrics fm = fontMetrics(); |
166 | 166 | ||
167 | //TODO: calculate this value | 167 | //TODO: calculate this value |
168 | int borderWidth = 4; | 168 | int borderWidth = 4; |
169 | 169 | ||
170 | // the maximum width possible | 170 | // the maximum width possible |
171 | int width = fm.width("88:88x") + borderWidth; | 171 | int width = fm.width("88:88x") + borderWidth; |
172 | 172 | ||
173 | return width; | 173 | return width; |
174 | } | 174 | } |
175 | 175 | ||
176 | /** updates widget's internal state */ | 176 | /** updates widget's internal state */ |
177 | void TimeLabels::updateConfig() | 177 | void TimeLabels::updateConfig() |
178 | { | 178 | { |
179 | // set the font | 179 | // set the font |
180 | // config->setGroup("Fonts"); | 180 | // config->setGroup("Fonts"); |
181 | // QFont font = config->readFontEntry("TimeBar Font"); | 181 | // QFont font = config->readFontEntry("TimeBar Font"); |
182 | setFont(KOPrefs::instance()->mTimeBarFont); | 182 | setFont(KOPrefs::instance()->mTimeBarFont); |
183 | 183 | ||
184 | // update geometry restrictions based on new settings | 184 | // update geometry restrictions based on new settings |
185 | setFixedWidth(minimumWidth()); | 185 | setFixedWidth(minimumWidth()); |
186 | 186 | ||
187 | // update HourSize | 187 | // update HourSize |
188 | mCellHeight = KOPrefs::instance()->mHourSize*4; | 188 | mCellHeight = KOPrefs::instance()->mHourSize*4; |
189 | resizeContents(50,mRows * mCellHeight); | 189 | resizeContents(50,mRows * mCellHeight); |
190 | } | 190 | } |
191 | 191 | ||
192 | /** update time label positions */ | 192 | /** update time label positions */ |
193 | void TimeLabels::positionChanged() | 193 | void TimeLabels::positionChanged() |
194 | { | 194 | { |
195 | int adjustment = mAgenda->contentsY(); | 195 | int adjustment = mAgenda->contentsY(); |
196 | setContentsPos(0, adjustment); | 196 | setContentsPos(0, adjustment); |
197 | } | 197 | } |
198 | 198 | ||
199 | /** */ | 199 | /** */ |
200 | void TimeLabels::setAgenda(KOAgenda* agenda) | 200 | void TimeLabels::setAgenda(KOAgenda* agenda) |
201 | { | 201 | { |
202 | mAgenda = agenda; | 202 | mAgenda = agenda; |
203 | } | 203 | } |
204 | 204 | ||
205 | void TimeLabels::contentsMousePressEvent ( QMouseEvent * e) | 205 | void TimeLabels::contentsMousePressEvent ( QMouseEvent * e) |
206 | { | 206 | { |
207 | mMouseDownY = e->pos().y(); | 207 | mMouseDownY = e->pos().y(); |
208 | mOrgCap = topLevelWidget()->caption(); | ||
208 | } | 209 | } |
209 | 210 | ||
210 | void TimeLabels::contentsMouseMoveEvent ( QMouseEvent * e ) | 211 | void TimeLabels::contentsMouseMoveEvent ( QMouseEvent * e ) |
211 | { | 212 | { |
212 | int diff = mMouseDownY - e->pos().y(); | 213 | int diff = mMouseDownY - e->pos().y(); |
213 | if ( diff < 10 && diff > -10 ) | 214 | if ( diff < 10 && diff > -10 ) |
214 | return; | 215 | return; |
215 | int tSize = KOPrefs::instance()->mHourSize + (diff/10) ; | 216 | int tSize = KOPrefs::instance()->mHourSize + (diff/10) ; |
216 | if ( tSize < 4 ) | 217 | if ( tSize < 4 ) |
217 | tSize = 4; | 218 | tSize = 4; |
218 | if ( tSize > 18 ) | 219 | if ( tSize > 18 ) |
219 | tSize = 18; | 220 | tSize = 18; |
220 | tSize = (tSize-2)/2; | 221 | tSize = (tSize-2)/2; |
221 | topLevelWidget()->setCaption(i18n("New Agendasize: %1").arg(tSize)); | 222 | topLevelWidget()->setCaption(i18n("New Agendasize: %1").arg(tSize)); |
222 | 223 | ||
223 | } | 224 | } |
224 | void TimeLabels::contentsMouseReleaseEvent ( QMouseEvent * e ) | 225 | void TimeLabels::contentsMouseReleaseEvent ( QMouseEvent * e ) |
225 | { | 226 | { |
227 | topLevelWidget()->setCaption( mOrgCap ); | ||
226 | int diff = mMouseDownY - e->pos().y(); | 228 | int diff = mMouseDownY - e->pos().y(); |
227 | if ( diff < 10 && diff > -10 ) | 229 | if ( diff < 10 && diff > -10 ) |
228 | return; | 230 | return; |
229 | int tSize = KOPrefs::instance()->mHourSize + (diff/10); | 231 | int tSize = KOPrefs::instance()->mHourSize + (diff/10); |
230 | if ( tSize < 4 ) | 232 | if ( tSize < 4 ) |
231 | tSize = 4; | 233 | tSize = 4; |
232 | if ( tSize > 18 ) | 234 | if ( tSize > 18 ) |
233 | tSize = 18; | 235 | tSize = 18; |
234 | tSize = (tSize/2)*2; | 236 | tSize = (tSize/2)*2; |
235 | if ( tSize == KOPrefs::instance()->mHourSize ) | 237 | if ( tSize == KOPrefs::instance()->mHourSize ) |
236 | return; | 238 | return; |
237 | KOPrefs::instance()->mHourSize = tSize; | 239 | KOPrefs::instance()->mHourSize = tSize; |
238 | emit scaleChanged(); | 240 | emit scaleChanged(); |
239 | } | 241 | } |
240 | 242 | ||
241 | /** This is called in response to repaint() */ | 243 | /** This is called in response to repaint() */ |
242 | void TimeLabels::paintEvent(QPaintEvent*) | 244 | void TimeLabels::paintEvent(QPaintEvent*) |
243 | { | 245 | { |
244 | 246 | ||
245 | // kdDebug() << "paintevent..." << endl; | 247 | // kdDebug() << "paintevent..." << endl; |
246 | // this is another hack! | 248 | // this is another hack! |
247 | // QPainter painter(this); | 249 | // QPainter painter(this); |
248 | //QString c | 250 | //QString c |
249 | repaintContents(contentsX(), contentsY(), visibleWidth(), visibleHeight()); | 251 | repaintContents(contentsX(), contentsY(), visibleWidth(), visibleHeight()); |
250 | } | 252 | } |
251 | 253 | ||
252 | //////////////////////////////////////////////////////////////////////////// | 254 | //////////////////////////////////////////////////////////////////////////// |
253 | 255 | ||
254 | EventIndicator::EventIndicator(Location loc,QWidget *parent,const char *name) | 256 | EventIndicator::EventIndicator(Location loc,QWidget *parent,const char *name) |
255 | : QFrame(parent,name) | 257 | : QFrame(parent,name) |
256 | { | 258 | { |
257 | mColumns = 1; | 259 | mColumns = 1; |
258 | mTopBox = 0; | 260 | mTopBox = 0; |
259 | mLocation = loc; | 261 | mLocation = loc; |
260 | mTopLayout = 0; | 262 | mTopLayout = 0; |
261 | mPaintWidget = 0; | 263 | mPaintWidget = 0; |
262 | mXOffset = 0; | 264 | mXOffset = 0; |
263 | if (mLocation == Top) mPixmap = SmallIcon("1uparrow"); | 265 | if (mLocation == Top) mPixmap = SmallIcon("1uparrow"); |
264 | else mPixmap = SmallIcon("1downarrow"); | 266 | else mPixmap = SmallIcon("1downarrow"); |
265 | mEnabled.resize(mColumns); | 267 | mEnabled.resize(mColumns); |
266 | if (mLocation == Top) | 268 | if (mLocation == Top) |
267 | setMaximumHeight(0); | 269 | setMaximumHeight(0); |
268 | else | 270 | else |
269 | setMinimumHeight(mPixmap.height()); | 271 | setMinimumHeight(mPixmap.height()); |
270 | } | 272 | } |
271 | 273 | ||
272 | EventIndicator::~EventIndicator() | 274 | EventIndicator::~EventIndicator() |
273 | { | 275 | { |
274 | } | 276 | } |
275 | 277 | ||
276 | void EventIndicator::drawContents(QPainter *p) | 278 | void EventIndicator::drawContents(QPainter *p) |
277 | { | 279 | { |
278 | 280 | ||
279 | // kdDebug() << "======== top: " << contentsRect().top() << " bottom " << // contentsRect().bottom() << " left " << contentsRect().left() << " right " << contentsRect().right() << endl; | 281 | // kdDebug() << "======== top: " << contentsRect().top() << " bottom " << // contentsRect().bottom() << " left " << contentsRect().left() << " right " << contentsRect().right() << endl; |
280 | KDGanttSplitterHandle* han = 0; | 282 | KDGanttSplitterHandle* han = 0; |
281 | if ( mPaintWidget ) | 283 | if ( mPaintWidget ) |
282 | han = mPaintWidget->firstHandle(); | 284 | han = mPaintWidget->firstHandle(); |
283 | if ( ! han ) { | 285 | if ( ! han ) { |
284 | int i; | 286 | int i; |
285 | for(i=0;i<mColumns;++i) { | 287 | for(i=0;i<mColumns;++i) { |
286 | if (mEnabled[i]) { | 288 | if (mEnabled[i]) { |
287 | int cellWidth = contentsRect().right()/mColumns; | 289 | int cellWidth = contentsRect().right()/mColumns; |
288 | int xOffset = KOGlobals::self()->reverseLayout() ? | 290 | int xOffset = KOGlobals::self()->reverseLayout() ? |
289 | (mColumns - 1 - i)*cellWidth + cellWidth/2 -mPixmap.width()/2 : | 291 | (mColumns - 1 - i)*cellWidth + cellWidth/2 -mPixmap.width()/2 : |
290 | i*cellWidth + cellWidth/2 -mPixmap.width()/2; | 292 | i*cellWidth + cellWidth/2 -mPixmap.width()/2; |
291 | p->drawPixmap(QPoint(xOffset,0),mPixmap); | 293 | p->drawPixmap(QPoint(xOffset,0),mPixmap); |
292 | } | 294 | } |
293 | } | 295 | } |
294 | } else { | 296 | } else { |
295 | han->repaint(); | 297 | han->repaint(); |
296 | //mPaintWidget->setBackgroundColor( red ); | 298 | //mPaintWidget->setBackgroundColor( red ); |
297 | 299 | ||
298 | QPainter pa( han ); | 300 | QPainter pa( han ); |
299 | int i; | 301 | int i; |
300 | bool setColor = false; | 302 | bool setColor = false; |
301 | for(i=0;i<mColumns;++i) { | 303 | for(i=0;i<mColumns;++i) { |
302 | if (mEnabled[i]) { | 304 | if (mEnabled[i]) { |
303 | setColor = true; | 305 | setColor = true; |
304 | 306 | ||
305 | int cellWidth = contentsRect().right()/mColumns; | 307 | int cellWidth = contentsRect().right()/mColumns; |
306 | int xOffset = KOGlobals::self()->reverseLayout() ? | 308 | int xOffset = KOGlobals::self()->reverseLayout() ? |
307 | (mColumns - 1 - i)*cellWidth + cellWidth/2 -mPixmap.width()/2 : | 309 | (mColumns - 1 - i)*cellWidth + cellWidth/2 -mPixmap.width()/2 : |
308 | i*cellWidth + cellWidth/2 -mPixmap.width()/2; | 310 | i*cellWidth + cellWidth/2 -mPixmap.width()/2; |
309 | pa.drawPixmap(QPoint(mXOffset + xOffset,0),mPixmap); | 311 | pa.drawPixmap(QPoint(mXOffset + xOffset,0),mPixmap); |
310 | //qDebug("222draw pix %d ",xOffset ); | 312 | //qDebug("222draw pix %d ",xOffset ); |
311 | 313 | ||
312 | } | 314 | } |
313 | 315 | ||
314 | } | 316 | } |
315 | pa.end(); | 317 | pa.end(); |
316 | 318 | ||
317 | } | 319 | } |
318 | } | 320 | } |
319 | 321 | ||
320 | void EventIndicator::setXOffset( int x ) | 322 | void EventIndicator::setXOffset( int x ) |
321 | { | 323 | { |
322 | mXOffset = x; | 324 | mXOffset = x; |
323 | } | 325 | } |
324 | void EventIndicator::setPaintWidget( KDGanttMinimizeSplitter * w ) | 326 | void EventIndicator::setPaintWidget( KDGanttMinimizeSplitter * w ) |
325 | { | 327 | { |
326 | mPaintWidget = w; | 328 | mPaintWidget = w; |
327 | } | 329 | } |
328 | void EventIndicator::changeColumns(int columns) | 330 | void EventIndicator::changeColumns(int columns) |
329 | { | 331 | { |
330 | mColumns = columns; | 332 | mColumns = columns; |
331 | mEnabled.resize(mColumns); | 333 | mEnabled.resize(mColumns); |
332 | 334 | ||
333 | update(); | 335 | update(); |
334 | } | 336 | } |
335 | 337 | ||
336 | void EventIndicator::enableColumn(int column, bool enable) | 338 | void EventIndicator::enableColumn(int column, bool enable) |
337 | { | 339 | { |
338 | mEnabled[column] = enable; | 340 | mEnabled[column] = enable; |
339 | } | 341 | } |
340 | 342 | ||
341 | 343 | ||
342 | //////////////////////////////////////////////////////////////////////////// | 344 | //////////////////////////////////////////////////////////////////////////// |
343 | //////////////////////////////////////////////////////////////////////////// | 345 | //////////////////////////////////////////////////////////////////////////// |
344 | //////////////////////////////////////////////////////////////////////////// | 346 | //////////////////////////////////////////////////////////////////////////// |
345 | 347 | ||
346 | KOAgendaView::KOAgendaView(Calendar *cal,QWidget *parent,const char *name) : | 348 | KOAgendaView::KOAgendaView(Calendar *cal,QWidget *parent,const char *name) : |
347 | KOEventView (cal,parent,name) | 349 | KOEventView (cal,parent,name) |
348 | { | 350 | { |
349 | mBlockUpdating = true; | 351 | mBlockUpdating = true; |
350 | mStartHour = 8; | 352 | mStartHour = 8; |
351 | mSelectedDates.append(QDate::currentDate()); | 353 | mSelectedDates.append(QDate::currentDate()); |
352 | 354 | ||
353 | mLayoutDayLabels = 0; | 355 | mLayoutDayLabels = 0; |
diff --git a/korganizer/koagendaview.h b/korganizer/koagendaview.h index 221b0ea..3cf938f 100644 --- a/korganizer/koagendaview.h +++ b/korganizer/koagendaview.h | |||
@@ -1,207 +1,208 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of KOrganizer. | 2 | This file is part of KOrganizer. |
3 | Copyright (c) 2000,2001 Cornelius Schumacher <schumacher@kde.org> | 3 | Copyright (c) 2000,2001 Cornelius Schumacher <schumacher@kde.org> |
4 | 4 | ||
5 | This program is free software; you can redistribute it and/or modify | 5 | This program is free software; you can redistribute it and/or modify |
6 | it under the terms of the GNU General Public License as published by | 6 | it under the terms of the GNU General Public License as published by |
7 | the Free Software Foundation; either version 2 of the License, or | 7 | the Free Software Foundation; either version 2 of the License, or |
8 | (at your option) any later version. | 8 | (at your option) any later version. |
9 | 9 | ||
10 | This program is distributed in the hope that it will be useful, | 10 | This program is distributed in the hope that it will be useful, |
11 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 11 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
13 | GNU General Public License for more details. | 13 | GNU General Public License for more details. |
14 | 14 | ||
15 | You should have received a copy of the GNU General Public License | 15 | You should have received a copy of the GNU General Public License |
16 | along with this program; if not, write to the Free Software | 16 | along with this program; if not, write to the Free Software |
17 | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | 17 | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
18 | 18 | ||
19 | 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 KOAGENDAVIEW_H | 23 | #ifndef KOAGENDAVIEW_H |
24 | #define KOAGENDAVIEW_H | 24 | #define KOAGENDAVIEW_H |
25 | 25 | ||
26 | #include <qscrollview.h> | 26 | #include <qscrollview.h> |
27 | #include <qdatetime.h> | 27 | #include <qdatetime.h> |
28 | #include <qlayout.h> | 28 | #include <qlayout.h> |
29 | #ifndef DESKTOP_VERSION | 29 | #ifndef DESKTOP_VERSION |
30 | #include <qksplitter.h> | 30 | #include <qksplitter.h> |
31 | #else | 31 | #else |
32 | #include <qsplitter.h> | 32 | #include <qsplitter.h> |
33 | #endif | 33 | #endif |
34 | #include <qmemarray.h> | 34 | #include <qmemarray.h> |
35 | 35 | ||
36 | #include "koeventview.h" | 36 | #include "koeventview.h" |
37 | 37 | ||
38 | 38 | ||
39 | class QHBox; | 39 | class QHBox; |
40 | class QFrame; | 40 | class QFrame; |
41 | class QLabel; | 41 | class QLabel; |
42 | class QPushButton; | 42 | class QPushButton; |
43 | class CalendarView; | 43 | class CalendarView; |
44 | class KOAgenda; | 44 | class KOAgenda; |
45 | class KOAgendaItem; | 45 | class KOAgendaItem; |
46 | class KConfig; | 46 | class KConfig; |
47 | class KDGanttMinimizeSplitter; | 47 | class KDGanttMinimizeSplitter; |
48 | class TimeLabels : public QScrollView { | 48 | class TimeLabels : public QScrollView { |
49 | Q_OBJECT | 49 | Q_OBJECT |
50 | public: | 50 | public: |
51 | TimeLabels(int rows,QWidget *parent=0,const char *name=0,WFlags f=0); | 51 | TimeLabels(int rows,QWidget *parent=0,const char *name=0,WFlags f=0); |
52 | 52 | ||
53 | void setCellHeight(int height); | 53 | void setCellHeight(int height); |
54 | 54 | ||
55 | /** Calculates the minimum width */ | 55 | /** Calculates the minimum width */ |
56 | virtual int minimumWidth() const; | 56 | virtual int minimumWidth() const; |
57 | 57 | ||
58 | /** updates widget's internal state */ | 58 | /** updates widget's internal state */ |
59 | void updateConfig(); | 59 | void updateConfig(); |
60 | 60 | ||
61 | /** */ | 61 | /** */ |
62 | void setAgenda(KOAgenda* agenda); | 62 | void setAgenda(KOAgenda* agenda); |
63 | 63 | ||
64 | /** */ | 64 | /** */ |
65 | virtual void paintEvent(QPaintEvent* e); | 65 | virtual void paintEvent(QPaintEvent* e); |
66 | void contentsMousePressEvent ( QMouseEvent * ) ; | 66 | void contentsMousePressEvent ( QMouseEvent * ) ; |
67 | void contentsMouseReleaseEvent ( QMouseEvent * ); | 67 | void contentsMouseReleaseEvent ( QMouseEvent * ); |
68 | void contentsMouseMoveEvent ( QMouseEvent * ); | 68 | void contentsMouseMoveEvent ( QMouseEvent * ); |
69 | 69 | ||
70 | public slots: | 70 | public slots: |
71 | /** update time label positions */ | 71 | /** update time label positions */ |
72 | void positionChanged(); | 72 | void positionChanged(); |
73 | signals: | 73 | signals: |
74 | void scaleChanged(); | 74 | void scaleChanged(); |
75 | protected: | 75 | protected: |
76 | void drawContents(QPainter *p,int cx, int cy, int cw, int ch); | 76 | void drawContents(QPainter *p,int cx, int cy, int cw, int ch); |
77 | 77 | ||
78 | private: | 78 | private: |
79 | int mMouseDownY; | 79 | int mMouseDownY; |
80 | QString mOrgCap; | ||
80 | int mRows; | 81 | int mRows; |
81 | int mCellHeight; | 82 | int mCellHeight; |
82 | 83 | ||
83 | /** */ | 84 | /** */ |
84 | KOAgenda* mAgenda; | 85 | KOAgenda* mAgenda; |
85 | }; | 86 | }; |
86 | 87 | ||
87 | class EventIndicator : public QFrame { | 88 | class EventIndicator : public QFrame { |
88 | Q_OBJECT | 89 | Q_OBJECT |
89 | public: | 90 | public: |
90 | enum Location { Top, Bottom }; | 91 | enum Location { Top, Bottom }; |
91 | EventIndicator(Location loc=Top,QWidget *parent=0,const char *name=0); | 92 | EventIndicator(Location loc=Top,QWidget *parent=0,const char *name=0); |
92 | virtual ~EventIndicator(); | 93 | virtual ~EventIndicator(); |
93 | 94 | ||
94 | void changeColumns(int columns); | 95 | void changeColumns(int columns); |
95 | void setPaintWidget( KDGanttMinimizeSplitter* ); | 96 | void setPaintWidget( KDGanttMinimizeSplitter* ); |
96 | void setXOffset( int ); | 97 | void setXOffset( int ); |
97 | void enableColumn(int column, bool enable); | 98 | void enableColumn(int column, bool enable); |
98 | 99 | ||
99 | protected: | 100 | protected: |
100 | void drawContents(QPainter *); | 101 | void drawContents(QPainter *); |
101 | 102 | ||
102 | private: | 103 | private: |
103 | int mXOffset; | 104 | int mXOffset; |
104 | KDGanttMinimizeSplitter* mPaintWidget; | 105 | KDGanttMinimizeSplitter* mPaintWidget; |
105 | int mColumns; | 106 | int mColumns; |
106 | QHBox *mTopBox; | 107 | QHBox *mTopBox; |
107 | QBoxLayout *mTopLayout; | 108 | QBoxLayout *mTopLayout; |
108 | Location mLocation; | 109 | Location mLocation; |
109 | QPixmap mPixmap; | 110 | QPixmap mPixmap; |
110 | QMemArray<bool> mEnabled; | 111 | QMemArray<bool> mEnabled; |
111 | }; | 112 | }; |
112 | 113 | ||
113 | /** | 114 | /** |
114 | KOAgendaView is the agenda-like view used to display events in an one or | 115 | KOAgendaView is the agenda-like view used to display events in an one or |
115 | multi-day view. | 116 | multi-day view. |
116 | */ | 117 | */ |
117 | class KOAgendaView : public KOEventView { | 118 | class KOAgendaView : public KOEventView { |
118 | Q_OBJECT | 119 | Q_OBJECT |
119 | public: | 120 | public: |
120 | KOAgendaView(Calendar *cal,QWidget *parent = 0,const char *name = 0 ); | 121 | KOAgendaView(Calendar *cal,QWidget *parent = 0,const char *name = 0 ); |
121 | virtual ~KOAgendaView(); | 122 | virtual ~KOAgendaView(); |
122 | void setStartHour( int ); | 123 | void setStartHour( int ); |
123 | void toggleAllDay(); | 124 | void toggleAllDay(); |
124 | 125 | ||
125 | 126 | ||
126 | /** Returns maximum number of days supported by the koagendaview */ | 127 | /** Returns maximum number of days supported by the koagendaview */ |
127 | virtual int maxDatesHint(); | 128 | virtual int maxDatesHint(); |
128 | 129 | ||
129 | /** Returns number of currently shown dates. */ | 130 | /** Returns number of currently shown dates. */ |
130 | virtual int currentDateCount(); | 131 | virtual int currentDateCount(); |
131 | 132 | ||
132 | /** returns the currently selected events */ | 133 | /** returns the currently selected events */ |
133 | virtual QPtrList<Incidence> selectedIncidences(); | 134 | virtual QPtrList<Incidence> selectedIncidences(); |
134 | 135 | ||
135 | /** returns the currently selected events */ | 136 | /** returns the currently selected events */ |
136 | virtual DateList selectedDates(); | 137 | virtual DateList selectedDates(); |
137 | 138 | ||
138 | /** Remove all events from view */ | 139 | /** Remove all events from view */ |
139 | void clearView(); | 140 | void clearView(); |
140 | KOAgenda *agenda() { return mAgenda;} | 141 | KOAgenda *agenda() { return mAgenda;} |
141 | virtual void printPreview(CalPrinter *calPrinter, | 142 | virtual void printPreview(CalPrinter *calPrinter, |
142 | const QDate &, const QDate &); | 143 | const QDate &, const QDate &); |
143 | 144 | ||
144 | /** start-datetime of selection */ | 145 | /** start-datetime of selection */ |
145 | QDateTime selectionStart() {return mTimeSpanBegin;} | 146 | QDateTime selectionStart() {return mTimeSpanBegin;} |
146 | /** end-datetime of selection */ | 147 | /** end-datetime of selection */ |
147 | QDateTime selectionEnd() {return mTimeSpanEnd;} | 148 | QDateTime selectionEnd() {return mTimeSpanEnd;} |
148 | /** returns true if selection is for whole day */ | 149 | /** returns true if selection is for whole day */ |
149 | bool selectedIsAllDay() {return mTimeSpanInAllDay;} | 150 | bool selectedIsAllDay() {return mTimeSpanInAllDay;} |
150 | /** make selected start/end invalid */ | 151 | /** make selected start/end invalid */ |
151 | void deleteSelectedDateTime(); | 152 | void deleteSelectedDateTime(); |
152 | void repaintAgenda(); | 153 | void repaintAgenda(); |
153 | public slots: | 154 | public slots: |
154 | virtual void updateView(); | 155 | virtual void updateView(); |
155 | virtual void updateConfig(); | 156 | virtual void updateConfig(); |
156 | virtual void showDates(const QDate &start, const QDate &end); | 157 | virtual void showDates(const QDate &start, const QDate &end); |
157 | virtual void showEvents(QPtrList<Event> eventList); | 158 | virtual void showEvents(QPtrList<Event> eventList); |
158 | 159 | ||
159 | void updateTodo( Todo *, int ); | 160 | void updateTodo( Todo *, int ); |
160 | void changeEventDisplay(Event *, int); | 161 | void changeEventDisplay(Event *, int); |
161 | 162 | ||
162 | void clearSelection(); | 163 | void clearSelection(); |
163 | 164 | ||
164 | void newEvent(int gx,int gy); | 165 | void newEvent(int gx,int gy); |
165 | void newEvent(int gxStart, int gyStart, int gxEnd, int gyEnd); | 166 | void newEvent(int gxStart, int gyStart, int gxEnd, int gyEnd); |
166 | void newEventAllDay(int gx, int gy); | 167 | void newEventAllDay(int gx, int gy); |
167 | 168 | ||
168 | void startDrag(Event *); | 169 | void startDrag(Event *); |
169 | 170 | ||
170 | void readSettings(); | 171 | void readSettings(); |
171 | void readSettings(KConfig *); | 172 | void readSettings(KConfig *); |
172 | void writeSettings(KConfig *); | 173 | void writeSettings(KConfig *); |
173 | 174 | ||
174 | void setContentsPos(int y); | 175 | void setContentsPos(int y); |
175 | 176 | ||
176 | void setExpandedButton( bool expanded ); | 177 | void setExpandedButton( bool expanded ); |
177 | void scrollOneHourUp(); | 178 | void scrollOneHourUp(); |
178 | void scrollOneHourDown(); | 179 | void scrollOneHourDown(); |
179 | void addToCalSlot(Incidence *, Incidence *); | 180 | void addToCalSlot(Incidence *, Incidence *); |
180 | 181 | ||
181 | signals: | 182 | signals: |
182 | void toggleExpand(); | 183 | void toggleExpand(); |
183 | void todoMoved( Todo *, int ); | 184 | void todoMoved( Todo *, int ); |
184 | void incidenceChanged(Incidence * , int ); | 185 | void incidenceChanged(Incidence * , int ); |
185 | // void cloneIncidenceSignal(Incidence *); | 186 | // void cloneIncidenceSignal(Incidence *); |
186 | 187 | ||
187 | protected: | 188 | protected: |
188 | bool mBlockUpdating; | 189 | bool mBlockUpdating; |
189 | int mUpcomingWidth; | 190 | int mUpcomingWidth; |
190 | /** Fill agenda beginning with date startDate */ | 191 | /** Fill agenda beginning with date startDate */ |
191 | void fillAgenda(const QDate &startDate); | 192 | void fillAgenda(const QDate &startDate); |
192 | void resizeEvent( QResizeEvent* e ); | 193 | void resizeEvent( QResizeEvent* e ); |
193 | /** Fill agenda using the current set value for the start date */ | 194 | /** Fill agenda using the current set value for the start date */ |
194 | void fillAgenda(); | 195 | void fillAgenda(); |
195 | 196 | ||
196 | /** Create labels for the selected dates. */ | 197 | /** Create labels for the selected dates. */ |
197 | void createDayLabels(); | 198 | void createDayLabels(); |
198 | 199 | ||
199 | /** | 200 | /** |
200 | Set the masks on the agenda widgets indicating, which days are holidays. | 201 | Set the masks on the agenda widgets indicating, which days are holidays. |
201 | */ | 202 | */ |
202 | void setHolidayMasks(); | 203 | void setHolidayMasks(); |
203 | 204 | ||
204 | protected slots: | 205 | protected slots: |
205 | /** Update event belonging to agenda item */ | 206 | /** Update event belonging to agenda item */ |
206 | void updateEventDates(KOAgendaItem *item, int mode = -1); | 207 | void updateEventDates(KOAgendaItem *item, int mode = -1); |
207 | //void updateMovedTodo(); | 208 | //void updateMovedTodo(); |