author | zautrix <zautrix> | 2005-03-26 15:39:48 (UTC) |
---|---|---|
committer | zautrix <zautrix> | 2005-03-26 15:39:48 (UTC) |
commit | 5079ed1883f8e53bc12be971c3c9495f45abf341 (patch) (unidiff) | |
tree | b145c9c6f086ce96e75363d70c06563b5f54fa81 | |
parent | 98444f8937b151a3deb71b7ae0da495872c52855 (diff) | |
download | kdepimpi-5079ed1883f8e53bc12be971c3c9495f45abf341.zip kdepimpi-5079ed1883f8e53bc12be971c3c9495f45abf341.tar.gz kdepimpi-5079ed1883f8e53bc12be971c3c9495f45abf341.tar.bz2 |
layout fix
-rw-r--r-- | korganizer/koagenda.cpp | 172 |
1 files changed, 80 insertions, 92 deletions
diff --git a/korganizer/koagenda.cpp b/korganizer/koagenda.cpp index 14f52b8..ed7a443 100644 --- a/korganizer/koagenda.cpp +++ b/korganizer/koagenda.cpp | |||
@@ -92,552 +92,543 @@ int MarcusBains::todayColumn() | |||
92 | QDate currentDate = QDate::currentDate(); | 92 | QDate currentDate = QDate::currentDate(); |
93 | 93 | ||
94 | DateList dateList = agenda->dateList(); | 94 | DateList dateList = agenda->dateList(); |
95 | DateList::ConstIterator it; | 95 | DateList::ConstIterator it; |
96 | int col = 0; | 96 | int col = 0; |
97 | for(it = dateList.begin(); it != dateList.end(); ++it) { | 97 | for(it = dateList.begin(); it != dateList.end(); ++it) { |
98 | if((*it) == currentDate) | 98 | if((*it) == currentDate) |
99 | return KOGlobals::self()->reverseLayout() ? | 99 | return KOGlobals::self()->reverseLayout() ? |
100 | agenda->columns() - 1 - col : col; | 100 | agenda->columns() - 1 - col : col; |
101 | ++col; | 101 | ++col; |
102 | } | 102 | } |
103 | 103 | ||
104 | return -1; | 104 | return -1; |
105 | } | 105 | } |
106 | void MarcusBains::updateLoc() | 106 | void MarcusBains::updateLoc() |
107 | { | 107 | { |
108 | updateLocation(); | 108 | updateLocation(); |
109 | } | 109 | } |
110 | void MarcusBains::updateLocation(bool recalculate) | 110 | void MarcusBains::updateLocation(bool recalculate) |
111 | { | 111 | { |
112 | 112 | ||
113 | QTime tim = QTime::currentTime(); | 113 | QTime tim = QTime::currentTime(); |
114 | //qDebug(" MarcusBains::updateLocation %s ", tim.toString().latin1()); | 114 | //qDebug(" MarcusBains::updateLocation %s ", tim.toString().latin1()); |
115 | if((tim.hour() == 0) && (oldTime.hour()==23)) | 115 | if((tim.hour() == 0) && (oldTime.hour()==23)) |
116 | recalculate = true; | 116 | recalculate = true; |
117 | 117 | ||
118 | int mins = tim.hour()*60 + tim.minute(); | 118 | int mins = tim.hour()*60 + tim.minute(); |
119 | int minutesPerCell = 24 * 60 / agenda->rows(); | 119 | int minutesPerCell = 24 * 60 / agenda->rows(); |
120 | int y = mins*agenda->gridSpacingY()/minutesPerCell; | 120 | int y = mins*agenda->gridSpacingY()/minutesPerCell; |
121 | int today = recalculate ? todayColumn() : oldToday; | 121 | int today = recalculate ? todayColumn() : oldToday; |
122 | int x = agenda->gridSpacingX()*today; | 122 | int x = agenda->gridSpacingX()*today; |
123 | bool disabled = !(KOPrefs::instance()->mMarcusBainsEnabled); | 123 | bool disabled = !(KOPrefs::instance()->mMarcusBainsEnabled); |
124 | 124 | ||
125 | oldTime = tim; | 125 | oldTime = tim; |
126 | oldToday = today; | 126 | oldToday = today; |
127 | 127 | ||
128 | if(disabled || (today<0)) { | 128 | if(disabled || (today<0)) { |
129 | hide(); mTimeBox->hide(); | 129 | hide(); mTimeBox->hide(); |
130 | return; | 130 | return; |
131 | } else { | 131 | } else { |
132 | show(); mTimeBox->show(); | 132 | show(); mTimeBox->show(); |
133 | } | 133 | } |
134 | 134 | ||
135 | if(recalculate) | 135 | if(recalculate) |
136 | setFixedSize(agenda->gridSpacingX(),1); | 136 | setFixedSize(agenda->gridSpacingX(),1); |
137 | agenda->moveChild(this, x, y); | 137 | agenda->moveChild(this, x, y); |
138 | raise(); | 138 | raise(); |
139 | 139 | ||
140 | if(recalculate) | 140 | if(recalculate) |
141 | //mTimeBox->setFont(QFont("helvetica",10)); | 141 | //mTimeBox->setFont(QFont("helvetica",10)); |
142 | mTimeBox->setFont(KOPrefs::instance()->mMarcusBainsFont); | 142 | mTimeBox->setFont(KOPrefs::instance()->mMarcusBainsFont); |
143 | 143 | ||
144 | mTimeBox->setText(KGlobal::locale()->formatTime(tim, KOPrefs::instance()->mMarcusBainsShowSeconds)); | 144 | mTimeBox->setText(KGlobal::locale()->formatTime(tim, KOPrefs::instance()->mMarcusBainsShowSeconds)); |
145 | mTimeBox->adjustSize(); | 145 | mTimeBox->adjustSize(); |
146 | // the -2 below is there because there is a bug in this program | 146 | // the -2 below is there because there is a bug in this program |
147 | // somewhere, where the last column of this widget is a few pixels | 147 | // somewhere, where the last column of this widget is a few pixels |
148 | // narrower than the other columns. | 148 | // narrower than the other columns. |
149 | int offs = (today==agenda->columns()-1) ? -4 : 0; | 149 | int offs = (today==agenda->columns()-1) ? -4 : 0; |
150 | agenda->moveChild(mTimeBox, | 150 | agenda->moveChild(mTimeBox, |
151 | x+agenda->gridSpacingX()-mTimeBox->width()+offs-1, | 151 | x+agenda->gridSpacingX()-mTimeBox->width()+offs-1, |
152 | y-mTimeBox->height()); | 152 | y-mTimeBox->height()); |
153 | 153 | ||
154 | mTimeBox->raise(); | 154 | mTimeBox->raise(); |
155 | //mTimeBox->setAutoMask(true); | 155 | //mTimeBox->setAutoMask(true); |
156 | minutes->start(5000,true); | 156 | minutes->start(5000,true); |
157 | } | 157 | } |
158 | 158 | ||
159 | 159 | ||
160 | //////////////////////////////////////////////////////////////////////////// | 160 | //////////////////////////////////////////////////////////////////////////// |
161 | 161 | ||
162 | 162 | ||
163 | /* | 163 | /* |
164 | Create an agenda widget with rows rows and columns columns. | 164 | Create an agenda widget with rows rows and columns columns. |
165 | */ | 165 | */ |
166 | KOAgenda::KOAgenda(int columns,int rows,int rowSize,QWidget *parent, | 166 | KOAgenda::KOAgenda(int columns,int rows,int rowSize,QWidget *parent, |
167 | const char *name,WFlags f) : | 167 | const char *name,WFlags f) : |
168 | QScrollView(parent,name,f) | 168 | QScrollView(parent,name,f) |
169 | { | 169 | { |
170 | 170 | ||
171 | 171 | ||
172 | mColumns = columns; | 172 | mColumns = columns; |
173 | mRows = rows; | 173 | mRows = rows; |
174 | mGridSpacingY = rowSize; | 174 | mGridSpacingY = rowSize; |
175 | mAllDayMode = false; | 175 | mAllDayMode = false; |
176 | #ifndef DESKTOP_VERSION | 176 | #ifndef DESKTOP_VERSION |
177 | //QPEApplication::setStylusOperation( viewport(), QPEApplication::RightOnHold ); | 177 | //QPEApplication::setStylusOperation( viewport(), QPEApplication::RightOnHold ); |
178 | #endif | 178 | #endif |
179 | mHolidayMask = 0; | 179 | mHolidayMask = 0; |
180 | init(); | 180 | init(); |
181 | } | 181 | } |
182 | 182 | ||
183 | /* | 183 | /* |
184 | Create an agenda widget with columns columns and one row. This is used for | 184 | Create an agenda widget with columns columns and one row. This is used for |
185 | all-day events. | 185 | all-day events. |
186 | */ | 186 | */ |
187 | KOAgenda::KOAgenda(int columns,QWidget *parent,const char *name,WFlags f) : | 187 | KOAgenda::KOAgenda(int columns,QWidget *parent,const char *name,WFlags f) : |
188 | QScrollView(parent,name,f) | 188 | QScrollView(parent,name,f) |
189 | { | 189 | { |
190 | blockResize = false; | 190 | blockResize = false; |
191 | mColumns = columns; | 191 | mColumns = columns; |
192 | mRows = 1; | 192 | mRows = 1; |
193 | //qDebug("aaaaaaaaaaaaaaaaaaldays %d ", KOPrefs::instance()->mAllDaySize); | 193 | //qDebug("aaaaaaaaaaaaaaaaaaldays %d ", KOPrefs::instance()->mAllDaySize); |
194 | mGridSpacingY = KOPrefs::instance()->mAllDaySize; | 194 | mGridSpacingY = KOPrefs::instance()->mAllDaySize; |
195 | mAllDayMode = true; | 195 | mAllDayMode = true; |
196 | #ifndef DESKTOP_VERSION | 196 | #ifndef DESKTOP_VERSION |
197 | //QPEApplication::setStylusOperation( viewport(), QPEApplication::RightOnHold ); | 197 | //QPEApplication::setStylusOperation( viewport(), QPEApplication::RightOnHold ); |
198 | #endif | 198 | #endif |
199 | mHolidayMask = 0; | 199 | mHolidayMask = 0; |
200 | init(); | 200 | init(); |
201 | } | 201 | } |
202 | 202 | ||
203 | 203 | ||
204 | KOAgenda::~KOAgenda() | 204 | KOAgenda::~KOAgenda() |
205 | { | 205 | { |
206 | if(mMarcusBains) delete mMarcusBains; | 206 | if(mMarcusBains) delete mMarcusBains; |
207 | 207 | ||
208 | } | 208 | } |
209 | 209 | ||
210 | Incidence *KOAgenda::selectedIncidence() const | 210 | Incidence *KOAgenda::selectedIncidence() const |
211 | { | 211 | { |
212 | return (mSelectedItem ? mSelectedItem->incidence() : 0); | 212 | return (mSelectedItem ? mSelectedItem->incidence() : 0); |
213 | } | 213 | } |
214 | 214 | ||
215 | 215 | ||
216 | QDate KOAgenda::selectedIncidenceDate() const | 216 | QDate KOAgenda::selectedIncidenceDate() const |
217 | { | 217 | { |
218 | return (mSelectedItem ? mSelectedItem->itemDate() : QDate()); | 218 | return (mSelectedItem ? mSelectedItem->itemDate() : QDate()); |
219 | } | 219 | } |
220 | 220 | ||
221 | 221 | ||
222 | void KOAgenda::init() | 222 | void KOAgenda::init() |
223 | { | 223 | { |
224 | mPopupTimer = new QTimer(this); | 224 | mPopupTimer = new QTimer(this); |
225 | connect(mPopupTimer , SIGNAL(timeout()), this, SLOT(popupMenu())); | 225 | connect(mPopupTimer , SIGNAL(timeout()), this, SLOT(popupMenu())); |
226 | 226 | ||
227 | mNewItemPopup = new QPopupMenu( this ); | 227 | mNewItemPopup = new QPopupMenu( this ); |
228 | connect ( mNewItemPopup, SIGNAL (activated ( int ) ), this, SLOT ( newItem(int)) ); | 228 | connect ( mNewItemPopup, SIGNAL (activated ( int ) ), this, SLOT ( newItem(int)) ); |
229 | QString pathString = ""; | 229 | QString pathString = ""; |
230 | if ( !KOPrefs::instance()->mToolBarMiniIcons ) { | 230 | if ( !KOPrefs::instance()->mToolBarMiniIcons ) { |
231 | if ( QApplication::desktop()->width() < 480 ) | 231 | if ( QApplication::desktop()->width() < 480 ) |
232 | pathString += "icons16/"; | 232 | pathString += "icons16/"; |
233 | } else | 233 | } else |
234 | pathString += "iconsmini/"; | 234 | pathString += "iconsmini/"; |
235 | 235 | ||
236 | mNewItemPopup->insertItem ( SmallIcon( pathString +"newevent" ), i18n("New Event..."), 1 ); | 236 | mNewItemPopup->insertItem ( SmallIcon( pathString +"newevent" ), i18n("New Event..."), 1 ); |
237 | mNewItemPopup->insertItem ( SmallIcon( pathString +"newtodo" ), i18n("New Todo..."),2 ); | 237 | mNewItemPopup->insertItem ( SmallIcon( pathString +"newtodo" ), i18n("New Todo..."),2 ); |
238 | mNewItemPopup->insertSeparator ( ); | 238 | mNewItemPopup->insertSeparator ( ); |
239 | mNewItemPopup->insertItem ( SmallIcon( pathString +"day" ), i18n("Day view"),3 ); | 239 | mNewItemPopup->insertItem ( SmallIcon( pathString +"day" ), i18n("Day view"),3 ); |
240 | mNewItemPopup->insertItem ( SmallIcon( pathString +"xdays" ), i18n("Next days"),8 ); | 240 | mNewItemPopup->insertItem ( SmallIcon( pathString +"xdays" ), i18n("Next days"),8 ); |
241 | mNewItemPopup->insertItem ( SmallIcon( pathString +"week" ), i18n("Next week"),4 ); | 241 | mNewItemPopup->insertItem ( SmallIcon( pathString +"week" ), i18n("Next week"),4 ); |
242 | mNewItemPopup->insertItem ( SmallIcon( pathString +"week" ), i18n("Next two weeks"),5 ); | 242 | mNewItemPopup->insertItem ( SmallIcon( pathString +"week" ), i18n("Next two weeks"),5 ); |
243 | mNewItemPopup->insertItem ( SmallIcon( pathString +"month" ), i18n("Next month"),6 ); | 243 | mNewItemPopup->insertItem ( SmallIcon( pathString +"month" ), i18n("Next month"),6 ); |
244 | mNewItemPopup->insertItem ( SmallIcon( pathString +"journal" ), i18n("Journal view"),7 ); | 244 | mNewItemPopup->insertItem ( SmallIcon( pathString +"journal" ), i18n("Journal view"),7 ); |
245 | #ifndef _WIN32_ | 245 | #ifndef _WIN32_ |
246 | int wflags = viewport()-> getWFlags() |WRepaintNoErase;//WResizeNoErase | 246 | int wflags = viewport()-> getWFlags() |WRepaintNoErase;//WResizeNoErase |
247 | viewport()->setWFlags ( wflags); | 247 | viewport()->setWFlags ( wflags); |
248 | #endif | 248 | #endif |
249 | mGridSpacingX = 80; | 249 | mGridSpacingX = 80; |
250 | mResizeBorderWidth = 8; | 250 | mResizeBorderWidth = 8; |
251 | mScrollBorderWidth = 8; | 251 | mScrollBorderWidth = 8; |
252 | mScrollDelay = 30; | 252 | mScrollDelay = 30; |
253 | mScrollOffset = 10; | 253 | mScrollOffset = 10; |
254 | mPaintPixmap.resize( 20,20); | 254 | mPaintPixmap.resize( 20,20); |
255 | //enableClipper(true); | 255 | //enableClipper(true); |
256 | 256 | ||
257 | // Grab key strokes for keyboard navigation of agenda. Seems to have no | 257 | // Grab key strokes for keyboard navigation of agenda. Seems to have no |
258 | // effect. Has to be fixed. | 258 | // effect. Has to be fixed. |
259 | setFocusPolicy(WheelFocus); | 259 | setFocusPolicy(WheelFocus); |
260 | 260 | ||
261 | connect(&mScrollUpTimer,SIGNAL(timeout()),SLOT(scrollUp())); | 261 | connect(&mScrollUpTimer,SIGNAL(timeout()),SLOT(scrollUp())); |
262 | connect(&mScrollDownTimer,SIGNAL(timeout()),SLOT(scrollDown())); | 262 | connect(&mScrollDownTimer,SIGNAL(timeout()),SLOT(scrollDown())); |
263 | connect(&mResizeTimer,SIGNAL(timeout()),SLOT(finishResize())); | 263 | connect(&mResizeTimer,SIGNAL(timeout()),SLOT(finishResize())); |
264 | 264 | ||
265 | mStartCellX = 0; | 265 | mStartCellX = 0; |
266 | mStartCellY = 0; | 266 | mStartCellY = 0; |
267 | mCurrentCellX = 0; | 267 | mCurrentCellX = 0; |
268 | mCurrentCellY = 0; | 268 | mCurrentCellY = 0; |
269 | 269 | ||
270 | mSelectionCellX = 0; | 270 | mSelectionCellX = 0; |
271 | mSelectionYTop = 0; | 271 | mSelectionYTop = 0; |
272 | mSelectionHeight = 0; | 272 | mSelectionHeight = 0; |
273 | 273 | ||
274 | mOldLowerScrollValue = -1; | 274 | mOldLowerScrollValue = -1; |
275 | mOldUpperScrollValue = -1; | 275 | mOldUpperScrollValue = -1; |
276 | 276 | ||
277 | mClickedItem = 0; | 277 | mClickedItem = 0; |
278 | 278 | ||
279 | mActionItem = 0; | 279 | mActionItem = 0; |
280 | mActionType = NOP; | 280 | mActionType = NOP; |
281 | mItemMoved = false; | 281 | mItemMoved = false; |
282 | 282 | ||
283 | mSelectedItem = 0; | 283 | mSelectedItem = 0; |
284 | 284 | ||
285 | // mItems.setAutoDelete(true); | 285 | // mItems.setAutoDelete(true); |
286 | 286 | ||
287 | resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 ); | 287 | resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 ); |
288 | 288 | ||
289 | viewport()->update(); | 289 | viewport()->update(); |
290 | 290 | ||
291 | setMinimumSize(30, 1); | 291 | setMinimumSize(30, 1); |
292 | // setMaximumHeight(mGridSpacingY * mRows + 5); | 292 | // setMaximumHeight(mGridSpacingY * mRows + 5); |
293 | 293 | ||
294 | // Disable horizontal scrollbar. This is a hack. The geometry should be | 294 | // Disable horizontal scrollbar. This is a hack. The geometry should be |
295 | // controlled in a way that the contents horizontally always fits. Then it is | 295 | // controlled in a way that the contents horizontally always fits. Then it is |
296 | // not necessary to turn off the scrollbar. | 296 | // not necessary to turn off the scrollbar. |
297 | setHScrollBarMode(AlwaysOff); | 297 | setHScrollBarMode(AlwaysOff); |
298 | if ( ! mAllDayMode ) | 298 | if ( ! mAllDayMode ) |
299 | setVScrollBarMode(AlwaysOn); | 299 | setVScrollBarMode(AlwaysOn); |
300 | else | 300 | else |
301 | setVScrollBarMode(AlwaysOff); | 301 | setVScrollBarMode(AlwaysOff); |
302 | 302 | ||
303 | setStartHour(KOPrefs::instance()->mDayBegins); | 303 | setStartHour(KOPrefs::instance()->mDayBegins); |
304 | 304 | ||
305 | calculateWorkingHours(); | 305 | calculateWorkingHours(); |
306 | 306 | ||
307 | connect(verticalScrollBar(),SIGNAL(valueChanged(int)), | 307 | connect(verticalScrollBar(),SIGNAL(valueChanged(int)), |
308 | SLOT(checkScrollBoundaries(int))); | 308 | SLOT(checkScrollBoundaries(int))); |
309 | 309 | ||
310 | // Create the Marcus Bains line. | 310 | // Create the Marcus Bains line. |
311 | if(mAllDayMode) | 311 | if(mAllDayMode) |
312 | mMarcusBains = 0; | 312 | mMarcusBains = 0; |
313 | else { | 313 | else { |
314 | mMarcusBains = new MarcusBains(this); | 314 | mMarcusBains = new MarcusBains(this); |
315 | addChild(mMarcusBains); | 315 | addChild(mMarcusBains); |
316 | } | 316 | } |
317 | mPopupKind = 0; | 317 | mPopupKind = 0; |
318 | mPopupItem = 0; | 318 | mPopupItem = 0; |
319 | } | 319 | } |
320 | 320 | ||
321 | void KOAgenda::clear() | 321 | void KOAgenda::clear() |
322 | { | 322 | { |
323 | KOAgendaItem *item; | 323 | KOAgendaItem *item; |
324 | for ( item=mItems.first(); item != 0; item=mItems.next() ) { | 324 | for ( item=mItems.first(); item != 0; item=mItems.next() ) { |
325 | mUnusedItems.append( item ); | 325 | mUnusedItems.append( item ); |
326 | //item->hide(); | 326 | //item->hide(); |
327 | } | 327 | } |
328 | mItems.clear(); | 328 | mItems.clear(); |
329 | mSelectedItem = 0; | 329 | mSelectedItem = 0; |
330 | clearSelection(); | 330 | clearSelection(); |
331 | } | 331 | } |
332 | 332 | ||
333 | void KOAgenda::clearSelection() | 333 | void KOAgenda::clearSelection() |
334 | { | 334 | { |
335 | mSelectionCellX = 0; | 335 | mSelectionCellX = 0; |
336 | mSelectionYTop = 0; | 336 | mSelectionYTop = 0; |
337 | mSelectionHeight = 0; | 337 | mSelectionHeight = 0; |
338 | } | 338 | } |
339 | 339 | ||
340 | void KOAgenda::marcus_bains() | 340 | void KOAgenda::marcus_bains() |
341 | { | 341 | { |
342 | if(mMarcusBains) mMarcusBains->updateLocation(true); | 342 | if(mMarcusBains) mMarcusBains->updateLocation(true); |
343 | } | 343 | } |
344 | 344 | ||
345 | 345 | ||
346 | void KOAgenda::changeColumns(int columns) | 346 | void KOAgenda::changeColumns(int columns) |
347 | { | 347 | { |
348 | if (columns == 0) { | 348 | if (columns == 0) { |
349 | kdDebug() << "KOAgenda::changeColumns() called with argument 0" << endl; | 349 | qDebug("KOAgenda::changeColumns() called with argument 0 "); |
350 | return; | 350 | return; |
351 | } | 351 | } |
352 | 352 | clear(); | |
353 | clear(); | 353 | mColumns = columns; |
354 | |||
355 | mColumns = columns; | ||
356 | // setMinimumSize(mColumns * 10, mGridSpacingY + 1); | ||
357 | // init(); | ||
358 | // update(); | ||
359 | //qDebug("KOAgenda::changeColumns "); | ||
360 | computeSizes(); | 354 | computeSizes(); |
361 | // QResizeEvent event( size(), size() ); | ||
362 | |||
363 | //QApplication::sendEvent( this, &event ); | ||
364 | } | 355 | } |
365 | 356 | ||
366 | /* | 357 | /* |
367 | This is the eventFilter function, which gets all events from the KOAgendaItems | 358 | This is the eventFilter function, which gets all events from the KOAgendaItems |
368 | contained in the agenda. It has to handle moving and resizing for all items. | 359 | contained in the agenda. It has to handle moving and resizing for all items. |
369 | */ | 360 | */ |
370 | bool KOAgenda::eventFilter ( QObject *object, QEvent *event ) | 361 | bool KOAgenda::eventFilter ( QObject *object, QEvent *event ) |
371 | { | 362 | { |
372 | // kdDebug() << "KOAgenda::eventFilter" << endl; | 363 | // kdDebug() << "KOAgenda::eventFilter" << endl; |
373 | switch(event->type()) { | 364 | switch(event->type()) { |
374 | case QEvent::MouseButtonPress: | 365 | case QEvent::MouseButtonPress: |
375 | case QEvent::MouseButtonDblClick: | 366 | case QEvent::MouseButtonDblClick: |
376 | case QEvent::MouseButtonRelease: | 367 | case QEvent::MouseButtonRelease: |
377 | case QEvent::MouseMove: | 368 | case QEvent::MouseMove: |
378 | return eventFilter_mouse(object, static_cast<QMouseEvent *>(event)); | 369 | return eventFilter_mouse(object, static_cast<QMouseEvent *>(event)); |
379 | 370 | ||
380 | case (QEvent::Leave): | 371 | case (QEvent::Leave): |
381 | if (!mActionItem) | 372 | if (!mActionItem) |
382 | setCursor(arrowCursor); | 373 | setCursor(arrowCursor); |
383 | return true; | 374 | return true; |
384 | 375 | ||
385 | default: | 376 | default: |
386 | return QScrollView::eventFilter(object,event); | 377 | return QScrollView::eventFilter(object,event); |
387 | } | 378 | } |
388 | } | 379 | } |
389 | void KOAgenda::popupMenu() | 380 | void KOAgenda::popupMenu() |
390 | { | 381 | { |
391 | mPopupTimer->stop(); | 382 | mPopupTimer->stop(); |
392 | if ( mPopupKind == 1 ) { | 383 | if ( mPopupKind == 1 ) { |
393 | if (mActionItem ) { | 384 | if (mActionItem ) { |
394 | endItemAction(); | 385 | endItemAction(); |
395 | } | 386 | } |
396 | mLeftMouseDown = false; // no more leftMouse computation | 387 | mLeftMouseDown = false; // no more leftMouse computation |
397 | if (mPopupItem) { | 388 | if (mPopupItem) { |
398 | selectItem(mPopupItem); | 389 | selectItem(mPopupItem); |
399 | emit showIncidencePopupSignal(mPopupItem->incidence()); | 390 | emit showIncidencePopupSignal(mPopupItem->incidence()); |
400 | 391 | ||
401 | } | 392 | } |
402 | } else if ( mPopupKind == 2 ) { | 393 | } else if ( mPopupKind == 2 ) { |
403 | if ( mLeftMouseDown ) { // we have a simulated right click - clear left mouse action | 394 | if ( mLeftMouseDown ) { // we have a simulated right click - clear left mouse action |
404 | endSelectAction( false ); // do not emit new event signal | 395 | endSelectAction( false ); // do not emit new event signal |
405 | mLeftMouseDown = false; // no more leftMouse computation | 396 | mLeftMouseDown = false; // no more leftMouse computation |
406 | } | 397 | } |
407 | mNewItemPopup->popup( mPopupPos); | 398 | mNewItemPopup->popup( mPopupPos); |
408 | } | 399 | } |
409 | mLeftMouseDown = false; | 400 | mLeftMouseDown = false; |
410 | mPopupItem = 0; | 401 | mPopupItem = 0; |
411 | mPopupKind = 0; | 402 | mPopupKind = 0; |
412 | } | 403 | } |
413 | 404 | ||
414 | bool KOAgenda::eventFilter_mouse(QObject *object, QMouseEvent *me) | 405 | bool KOAgenda::eventFilter_mouse(QObject *object, QMouseEvent *me) |
415 | { | 406 | { |
416 | //qDebug("KOAgenda::eventFilter_mous "); | 407 | //qDebug("KOAgenda::eventFilter_mous "); |
417 | QPoint viewportPos; | 408 | QPoint viewportPos; |
418 | if (object != viewport()) { | 409 | if (object != viewport()) { |
419 | viewportPos = ((QWidget *)object)->mapToParent(me->pos()); | 410 | viewportPos = ((QWidget *)object)->mapToParent(me->pos()); |
420 | } else { | 411 | } else { |
421 | viewportPos = me->pos(); | 412 | viewportPos = me->pos(); |
422 | } | 413 | } |
423 | static int startX = 0; | 414 | static int startX = 0; |
424 | static int startY = 0; | 415 | static int startY = 0; |
425 | static int blockmoveDist = ( QApplication::desktop()->width() < 480 ? 15 : 20 ); | 416 | static int blockmoveDist = ( QApplication::desktop()->width() < 480 ? 15 : 20 ); |
426 | static bool blockMoving = true; | 417 | static bool blockMoving = true; |
427 | switch (me->type()) { | 418 | switch (me->type()) { |
428 | case QEvent::MouseButtonPress: | 419 | case QEvent::MouseButtonPress: |
429 | if (me->button() == LeftButton) { | 420 | if (me->button() == LeftButton) { |
430 | mPopupTimer->start( 600 ); | 421 | mPopupTimer->start( 600 ); |
431 | mLeftMouseDown = true; | 422 | mLeftMouseDown = true; |
432 | } | 423 | } |
433 | blockMoving = true; | 424 | blockMoving = true; |
434 | startX = viewportPos.x(); | 425 | startX = viewportPos.x(); |
435 | startY = viewportPos.y(); | 426 | startY = viewportPos.y(); |
436 | if (object != viewport()) { | 427 | if (object != viewport()) { |
437 | mPopupItem = (KOAgendaItem *)object; | 428 | mPopupItem = (KOAgendaItem *)object; |
438 | mPopupKind = 1; | 429 | mPopupKind = 1; |
439 | if (me->button() == RightButton) { | 430 | if (me->button() == RightButton) { |
440 | popupMenu(); | 431 | popupMenu(); |
441 | } else if (me->button() == LeftButton) { | 432 | } else if (me->button() == LeftButton) { |
442 | mActionItem = (KOAgendaItem *)object; | 433 | mActionItem = (KOAgendaItem *)object; |
443 | if (mActionItem) { | 434 | if (mActionItem) { |
444 | if ( mSelectionHeight > 0 ) { | 435 | if ( mSelectionHeight > 0 ) { |
445 | int selectionCellX = mSelectionCellX * mGridSpacingX; | 436 | int selectionCellX = mSelectionCellX * mGridSpacingX; |
446 | int selectionYTop = mSelectionYTop; | 437 | int selectionYTop = mSelectionYTop; |
447 | int gridSpacingX = mGridSpacingX; | 438 | int gridSpacingX = mGridSpacingX; |
448 | int selectionHeight = mSelectionHeight; | 439 | int selectionHeight = mSelectionHeight; |
449 | clearSelection(); | 440 | clearSelection(); |
450 | repaintContents( selectionCellX, selectionYTop, | 441 | repaintContents( selectionCellX, selectionYTop, |
451 | gridSpacingX, selectionHeight,false ); | 442 | gridSpacingX, selectionHeight,false ); |
452 | } | 443 | } |
453 | selectItem(mActionItem); | 444 | selectItem(mActionItem); |
454 | Incidence *incidence = mActionItem->incidence(); | 445 | Incidence *incidence = mActionItem->incidence(); |
455 | if ( incidence->isReadOnly() /*|| incidence->recurrence()->doesRecur() */) { | 446 | if ( incidence->isReadOnly() /*|| incidence->recurrence()->doesRecur() */) { |
456 | mActionItem = 0; | 447 | mActionItem = 0; |
457 | } else { | 448 | } else { |
458 | startItemAction(viewportPos); | 449 | startItemAction(viewportPos); |
459 | } | 450 | } |
460 | } | 451 | } |
461 | } | 452 | } |
462 | } else { // ---------- viewport() | 453 | } else { // ---------- viewport() |
463 | mPopupItem = 0; | 454 | mPopupItem = 0; |
464 | mPopupKind = 2; | 455 | mPopupKind = 2; |
465 | selectItem(0); | 456 | selectItem(0); |
466 | mActionItem = 0; | 457 | mActionItem = 0; |
467 | mPopupPos = viewport()->mapToGlobal( me->pos() ); | 458 | mPopupPos = viewport()->mapToGlobal( me->pos() ); |
468 | if (me->button() == RightButton) { | 459 | if (me->button() == RightButton) { |
469 | popupMenu(); | 460 | popupMenu(); |
470 | } else if (me->button() == LeftButton) { | 461 | } else if (me->button() == LeftButton) { |
471 | setCursor(arrowCursor); | 462 | setCursor(arrowCursor); |
472 | startSelectAction(viewportPos); | 463 | startSelectAction(viewportPos); |
473 | } | 464 | } |
474 | } | 465 | } |
475 | break; | 466 | break; |
476 | 467 | ||
477 | case QEvent::MouseButtonRelease: | 468 | case QEvent::MouseButtonRelease: |
478 | if (me->button() == LeftButton ) { | 469 | if (me->button() == LeftButton ) { |
479 | mPopupTimer->stop(); | 470 | mPopupTimer->stop(); |
480 | } | 471 | } |
481 | if (object != viewport()) { | 472 | if (object != viewport()) { |
482 | if (me->button() == LeftButton && mLeftMouseDown) { | 473 | if (me->button() == LeftButton && mLeftMouseDown) { |
483 | if (mActionItem) { | 474 | if (mActionItem) { |
484 | QPoint clipperPos = clipper()->mapFromGlobal(viewport()->mapToGlobal(viewportPos)); | 475 | QPoint clipperPos = clipper()->mapFromGlobal(viewport()->mapToGlobal(viewportPos)); |
485 | //qDebug(" %d %d %d ",clipperPos.y(),visibleHeight() , 9 ); | 476 | //qDebug(" %d %d %d ",clipperPos.y(),visibleHeight() , 9 ); |
486 | if ( mActionType == MOVE && (clipperPos.y() > visibleHeight()-2 ||clipperPos.y() < 0 ) ) { | 477 | if ( mActionType == MOVE && (clipperPos.y() > visibleHeight()-2 ||clipperPos.y() < 0 ) ) { |
487 | mScrollUpTimer.stop(); | 478 | mScrollUpTimer.stop(); |
488 | mScrollDownTimer.stop(); | 479 | mScrollDownTimer.stop(); |
489 | mActionItem->resetMove(); | 480 | mActionItem->resetMove(); |
490 | placeSubCells( mActionItem ); | 481 | placeSubCells( mActionItem ); |
491 | // emit startDragSignal( mActionItem->incidence() ); | 482 | // emit startDragSignal( mActionItem->incidence() ); |
492 | setCursor( arrowCursor ); | 483 | setCursor( arrowCursor ); |
493 | mActionItem = 0; | 484 | mActionItem = 0; |
494 | mActionType = NOP; | 485 | mActionType = NOP; |
495 | mItemMoved = 0; | 486 | mItemMoved = 0; |
496 | mLeftMouseDown = false; | 487 | mLeftMouseDown = false; |
497 | return true; | 488 | return true; |
498 | } | 489 | } |
499 | endItemAction(); | 490 | endItemAction(); |
500 | } | 491 | } |
501 | } | 492 | } |
502 | 493 | ||
503 | } else { // ---------- viewport() | 494 | } else { // ---------- viewport() |
504 | if (me->button() == LeftButton && mLeftMouseDown ) { //left click | 495 | if (me->button() == LeftButton && mLeftMouseDown ) { //left click |
505 | endSelectAction( true ); // emit new event signal | 496 | endSelectAction( true ); // emit new event signal |
506 | } | 497 | } |
507 | } | 498 | } |
508 | if (me->button() == LeftButton) | 499 | if (me->button() == LeftButton) |
509 | mLeftMouseDown = false; | 500 | mLeftMouseDown = false; |
510 | 501 | ||
511 | break; | 502 | break; |
512 | 503 | ||
513 | case QEvent::MouseMove: | 504 | case QEvent::MouseMove: |
514 | if ( !mLeftMouseDown ) | 505 | if ( !mLeftMouseDown ) |
515 | return true; | 506 | return true; |
516 | if ( blockMoving ) { | 507 | if ( blockMoving ) { |
517 | int dX, dY; | 508 | int dX, dY; |
518 | dX = startX - viewportPos.x(); | 509 | dX = startX - viewportPos.x(); |
519 | if ( dX < 0 ) | 510 | if ( dX < 0 ) |
520 | dX = -dX; | 511 | dX = -dX; |
521 | dY = viewportPos.y() - startY; | 512 | dY = viewportPos.y() - startY; |
522 | if ( dY < 0 ) | 513 | if ( dY < 0 ) |
523 | dY = -dY; | 514 | dY = -dY; |
524 | //qDebug("%d %d %d ", dX, dY , blockmoveDist ); | 515 | //qDebug("%d %d %d ", dX, dY , blockmoveDist ); |
525 | if ( dX > blockmoveDist || dY > blockmoveDist ) { | 516 | if ( dX > blockmoveDist || dY > blockmoveDist ) { |
526 | blockMoving = false; | 517 | blockMoving = false; |
527 | } | 518 | } |
528 | } | 519 | } |
529 | if ( ! blockMoving ) | 520 | if ( ! blockMoving ) |
530 | mPopupTimer->stop(); | 521 | mPopupTimer->stop(); |
531 | if (object != viewport()) { | 522 | if (object != viewport()) { |
532 | KOAgendaItem *moveItem = (KOAgendaItem *)object; | 523 | KOAgendaItem *moveItem = (KOAgendaItem *)object; |
533 | if (!moveItem->incidence()->isReadOnly() ) { | 524 | if (!moveItem->incidence()->isReadOnly() ) { |
534 | if (!mActionItem) | 525 | if (!mActionItem) |
535 | setNoActionCursor(moveItem,viewportPos); | 526 | setNoActionCursor(moveItem,viewportPos); |
536 | else { | 527 | else { |
537 | if ( !blockMoving ) | 528 | if ( !blockMoving ) |
538 | performItemAction(viewportPos); | 529 | performItemAction(viewportPos); |
539 | } | 530 | } |
540 | } | 531 | } |
541 | } else { // ---------- viewport() | 532 | } else { // ---------- viewport() |
542 | mPopupPos = viewport()->mapToGlobal( me->pos() ); | 533 | mPopupPos = viewport()->mapToGlobal( me->pos() ); |
543 | if ( mActionType == SELECT ) { | 534 | if ( mActionType == SELECT ) { |
544 | performSelectAction( viewportPos ); | 535 | performSelectAction( viewportPos ); |
545 | } | 536 | } |
546 | } | 537 | } |
547 | break; | 538 | break; |
548 | 539 | ||
549 | case QEvent::MouseButtonDblClick: | 540 | case QEvent::MouseButtonDblClick: |
550 | mPopupTimer->stop(); | 541 | mPopupTimer->stop(); |
551 | if (object == viewport()) { | 542 | if (object == viewport()) { |
552 | selectItem(0); | 543 | selectItem(0); |
553 | int x,y; | 544 | int x,y; |
554 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 545 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
555 | int gx,gy; | 546 | int gx,gy; |
556 | contentsToGrid(x,y,gx,gy); | 547 | contentsToGrid(x,y,gx,gy); |
557 | emit newEventSignal(gx,gy); | 548 | emit newEventSignal(gx,gy); |
558 | } else { | 549 | } else { |
559 | KOAgendaItem *doubleClickedItem = (KOAgendaItem *)object; | 550 | KOAgendaItem *doubleClickedItem = (KOAgendaItem *)object; |
560 | selectItem(doubleClickedItem); | 551 | selectItem(doubleClickedItem); |
561 | if ( KOPrefs::instance()->mEditOnDoubleClick ) | 552 | if ( KOPrefs::instance()->mEditOnDoubleClick ) |
562 | emit editIncidenceSignal(doubleClickedItem->incidence()); | 553 | emit editIncidenceSignal(doubleClickedItem->incidence()); |
563 | else | 554 | else |
564 | emit showIncidenceSignal(doubleClickedItem->incidence()); | 555 | emit showIncidenceSignal(doubleClickedItem->incidence()); |
565 | } | 556 | } |
566 | break; | 557 | break; |
567 | 558 | ||
568 | default: | 559 | default: |
569 | break; | 560 | break; |
570 | } | 561 | } |
571 | return true; | 562 | return true; |
572 | #if 0 | 563 | #if 0 |
573 | //qDebug("KOAgenda::eventFilter_mous "); | 564 | //qDebug("KOAgenda::eventFilter_mous "); |
574 | QPoint viewportPos; | 565 | QPoint viewportPos; |
575 | if (object != viewport()) { | 566 | if (object != viewport()) { |
576 | viewportPos = ((QWidget *)object)->mapToParent(me->pos()); | 567 | viewportPos = ((QWidget *)object)->mapToParent(me->pos()); |
577 | } else { | 568 | } else { |
578 | viewportPos = me->pos(); | 569 | viewportPos = me->pos(); |
579 | } | 570 | } |
580 | static int startX = 0; | 571 | static int startX = 0; |
581 | static int startY = 0; | 572 | static int startY = 0; |
582 | static int blockmoveDist = ( QApplication::desktop()->width() < 480 ? 15 : 20 ); | 573 | static int blockmoveDist = ( QApplication::desktop()->width() < 480 ? 15 : 20 ); |
583 | static bool blockMoving = true; | 574 | static bool blockMoving = true; |
584 | static bool leftMouseDown = false; | 575 | static bool leftMouseDown = false; |
585 | bool rightButtonPressed = false; | 576 | bool rightButtonPressed = false; |
586 | switch (me->type()) { | 577 | switch (me->type()) { |
587 | case QEvent::MouseButtonPress: | 578 | case QEvent::MouseButtonPress: |
588 | if (me->button() == LeftButton) { | 579 | if (me->button() == LeftButton) { |
589 | leftMouseDown = true; | 580 | leftMouseDown = true; |
590 | } | 581 | } |
591 | else if (me->button() == RightButton) { | 582 | else if (me->button() == RightButton) { |
592 | leftMouseDown = false; | 583 | leftMouseDown = false; |
593 | } | 584 | } |
594 | blockMoving = true; | 585 | blockMoving = true; |
595 | startX = viewportPos.x(); | 586 | startX = viewportPos.x(); |
596 | startY = viewportPos.y(); | 587 | startY = viewportPos.y(); |
597 | if (object != viewport()) { // item clicked ************** | 588 | if (object != viewport()) { // item clicked ************** |
598 | if (me->button() == RightButton) { | 589 | if (me->button() == RightButton) { |
599 | leftMouseDown = false; | 590 | leftMouseDown = false; |
600 | mClickedItem = (KOAgendaItem *)object; | 591 | mClickedItem = (KOAgendaItem *)object; |
601 | if (mActionItem ) { | 592 | if (mActionItem ) { |
602 | endItemAction(); | 593 | endItemAction(); |
603 | } | 594 | } |
604 | if (mClickedItem) { | 595 | if (mClickedItem) { |
605 | selectItem(mClickedItem); | 596 | selectItem(mClickedItem); |
606 | emit showIncidencePopupSignal(mClickedItem->incidence()); | 597 | emit showIncidencePopupSignal(mClickedItem->incidence()); |
607 | } | 598 | } |
608 | return true; | 599 | return true; |
609 | } else if (me->button() == LeftButton) { | 600 | } else if (me->button() == LeftButton) { |
610 | mActionItem = (KOAgendaItem *)object; | 601 | mActionItem = (KOAgendaItem *)object; |
611 | if (mActionItem) { | 602 | if (mActionItem) { |
612 | if ( mSelectionHeight > 0 ) { | 603 | if ( mSelectionHeight > 0 ) { |
613 | int selectionCellX = mSelectionCellX * mGridSpacingX; | 604 | int selectionCellX = mSelectionCellX * mGridSpacingX; |
614 | int selectionYTop = mSelectionYTop; | 605 | int selectionYTop = mSelectionYTop; |
615 | int gridSpacingX = mGridSpacingX; | 606 | int gridSpacingX = mGridSpacingX; |
616 | int selectionHeight = mSelectionHeight; | 607 | int selectionHeight = mSelectionHeight; |
617 | clearSelection(); | 608 | clearSelection(); |
618 | repaintContents( selectionCellX, selectionYTop, | 609 | repaintContents( selectionCellX, selectionYTop, |
619 | gridSpacingX, selectionHeight,false ); | 610 | gridSpacingX, selectionHeight,false ); |
620 | } | 611 | } |
621 | selectItem(mActionItem); | 612 | selectItem(mActionItem); |
622 | Incidence *incidence = mActionItem->incidence(); | 613 | Incidence *incidence = mActionItem->incidence(); |
623 | if ( incidence->isReadOnly() /*|| incidence->recurrence()->doesRecur() */) { | 614 | if ( incidence->isReadOnly() /*|| incidence->recurrence()->doesRecur() */) { |
624 | mActionItem = 0; | 615 | mActionItem = 0; |
625 | } else { | 616 | } else { |
626 | startItemAction(viewportPos); | 617 | startItemAction(viewportPos); |
627 | } | 618 | } |
628 | } | 619 | } |
629 | } | 620 | } |
630 | } else { // ---------- viewport() | 621 | } else { // ---------- viewport() |
631 | selectItem(0); | 622 | selectItem(0); |
632 | mActionItem = 0; | 623 | mActionItem = 0; |
633 | if (me->button() == LeftButton ) { | 624 | if (me->button() == LeftButton ) { |
634 | setCursor(arrowCursor); | 625 | setCursor(arrowCursor); |
635 | startSelectAction(viewportPos); | 626 | startSelectAction(viewportPos); |
636 | } else if (me->button() == RightButton ) { | 627 | } else if (me->button() == RightButton ) { |
637 | setCursor(arrowCursor); | 628 | setCursor(arrowCursor); |
638 | if ( leftMouseDown ) { // we have a simulated right click - clear left mouse action | 629 | if ( leftMouseDown ) { // we have a simulated right click - clear left mouse action |
639 | endSelectAction( false ); // do not emit new event signal | 630 | endSelectAction( false ); // do not emit new event signal |
640 | leftMouseDown = false; // no more leftMouse computation | 631 | leftMouseDown = false; // no more leftMouse computation |
641 | } | 632 | } |
642 | int x,y; | 633 | int x,y; |
643 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 634 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
@@ -1495,738 +1486,735 @@ void KOAgenda::drawContentsToPainter( QPainter* paint, bool backgroundOnly )// i | |||
1495 | (gxStart+1)*mGridSpacingX-1; | 1486 | (gxStart+1)*mGridSpacingX-1; |
1496 | if (xEnd > x2) xEnd = x2; | 1487 | if (xEnd > x2) xEnd = x2; |
1497 | if ( mSelectedDates[gxStart] == QDateTime::currentDateTime ().date()&& KOPrefs::instance()->mHighlightCurrentDay ) { | 1488 | if ( mSelectedDates[gxStart] == QDateTime::currentDateTime ().date()&& KOPrefs::instance()->mHighlightCurrentDay ) { |
1498 | if ( KOPrefs::instance()->mUseHighlightLightColor ) | 1489 | if ( KOPrefs::instance()->mUseHighlightLightColor ) |
1499 | p->fillRect(xStart,y1,xEnd-xStart+1,y2-y1+1, | 1490 | p->fillRect(xStart,y1,xEnd-xStart+1,y2-y1+1, |
1500 | KOPrefs::instance()->mWorkingHoursColor.light()); | 1491 | KOPrefs::instance()->mWorkingHoursColor.light()); |
1501 | else | 1492 | else |
1502 | p->fillRect(xStart,y1,xEnd-xStart+1,y2-y1+1, | 1493 | p->fillRect(xStart,y1,xEnd-xStart+1,y2-y1+1, |
1503 | KOPrefs::instance()->mWorkingHoursColor.dark()); | 1494 | KOPrefs::instance()->mWorkingHoursColor.dark()); |
1504 | } else { | 1495 | } else { |
1505 | p->fillRect(xStart,y1,xEnd-xStart+1,y2-y1+1, | 1496 | p->fillRect(xStart,y1,xEnd-xStart+1,y2-y1+1, |
1506 | KOPrefs::instance()->mWorkingHoursColor); | 1497 | KOPrefs::instance()->mWorkingHoursColor); |
1507 | } | 1498 | } |
1508 | } | 1499 | } |
1509 | ++gxStart; | 1500 | ++gxStart; |
1510 | } | 1501 | } |
1511 | } | 1502 | } |
1512 | } | 1503 | } |
1513 | /* | 1504 | /* |
1514 | int selectionX = KOGlobals::self()->reverseLayout() ? | 1505 | int selectionX = KOGlobals::self()->reverseLayout() ? |
1515 | (mColumns - 1 - mSelectionCellX) * mGridSpacingX : | 1506 | (mColumns - 1 - mSelectionCellX) * mGridSpacingX : |
1516 | mSelectionCellX * mGridSpacingX; | 1507 | mSelectionCellX * mGridSpacingX; |
1517 | 1508 | ||
1518 | // Draw selection | 1509 | // Draw selection |
1519 | if ( ( cx + cw ) >= selectionX && cx <= ( selectionX + mGridSpacingX ) && | 1510 | if ( ( cx + cw ) >= selectionX && cx <= ( selectionX + mGridSpacingX ) && |
1520 | ( cy + ch ) >= mSelectionYTop && cy <= ( mSelectionYTop + mSelectionHeight ) ) { | 1511 | ( cy + ch ) >= mSelectionYTop && cy <= ( mSelectionYTop + mSelectionHeight ) ) { |
1521 | // TODO: paint only part within cx,cy,cw,ch | 1512 | // TODO: paint only part within cx,cy,cw,ch |
1522 | p->fillRect( selectionX, mSelectionYTop, mGridSpacingX, | 1513 | p->fillRect( selectionX, mSelectionYTop, mGridSpacingX, |
1523 | mSelectionHeight, KOPrefs::instance()->mHighlightColor ); | 1514 | mSelectionHeight, KOPrefs::instance()->mHighlightColor ); |
1524 | } | 1515 | } |
1525 | */ | 1516 | */ |
1526 | // Draw vertical lines of grid | 1517 | // Draw vertical lines of grid |
1527 | 1518 | ||
1528 | int x = ((int)(cx/mGridSpacingX))*mGridSpacingX; | 1519 | int x = ((int)(cx/mGridSpacingX))*mGridSpacingX; |
1529 | if ( mGridSpacingX > 0 ) { | 1520 | if ( mGridSpacingX > 0 ) { |
1530 | while (x < cx + cw) { | 1521 | while (x < cx + cw) { |
1531 | p->drawLine(x,cy,x,cy+ch); | 1522 | p->drawLine(x,cy,x,cy+ch); |
1532 | x+=mGridSpacingX; | 1523 | x+=mGridSpacingX; |
1533 | } | 1524 | } |
1534 | } | 1525 | } |
1535 | // Draw horizontal lines of grid | 1526 | // Draw horizontal lines of grid |
1536 | int y = ((int)(cy/lGridSpacingY))*lGridSpacingY; | 1527 | int y = ((int)(cy/lGridSpacingY))*lGridSpacingY; |
1537 | if ( lGridSpacingY > 0 ) { | 1528 | if ( lGridSpacingY > 0 ) { |
1538 | while (y < cy + ch) { | 1529 | while (y < cy + ch) { |
1539 | p->setPen( SolidLine ); | 1530 | p->setPen( SolidLine ); |
1540 | p->drawLine(cx,y,cx+cw,y); | 1531 | p->drawLine(cx,y,cx+cw,y); |
1541 | y+=lGridSpacingY; | 1532 | y+=lGridSpacingY; |
1542 | p->setPen( DotLine ); | 1533 | p->setPen( DotLine ); |
1543 | p->drawLine(cx,y,cx+cw,y); | 1534 | p->drawLine(cx,y,cx+cw,y); |
1544 | y+=lGridSpacingY; | 1535 | y+=lGridSpacingY; |
1545 | } | 1536 | } |
1546 | p->setPen( SolidLine ); | 1537 | p->setPen( SolidLine ); |
1547 | } | 1538 | } |
1548 | mPixPainter.end() ; | 1539 | mPixPainter.end() ; |
1549 | } | 1540 | } |
1550 | 1541 | ||
1551 | /* | 1542 | /* |
1552 | Convert srcollview contents coordinates to agenda grid coordinates. | 1543 | Convert srcollview contents coordinates to agenda grid coordinates. |
1553 | */ | 1544 | */ |
1554 | void KOAgenda::contentsToGrid (int x, int y, int& gx, int& gy) | 1545 | void KOAgenda::contentsToGrid (int x, int y, int& gx, int& gy) |
1555 | { | 1546 | { |
1556 | gx = KOGlobals::self()->reverseLayout() ? mColumns - 1 - x/mGridSpacingX : | 1547 | gx = KOGlobals::self()->reverseLayout() ? mColumns - 1 - x/mGridSpacingX : |
1557 | x/mGridSpacingX; | 1548 | x/mGridSpacingX; |
1558 | gy = y/mGridSpacingY; | 1549 | gy = y/mGridSpacingY; |
1559 | } | 1550 | } |
1560 | 1551 | ||
1561 | /* | 1552 | /* |
1562 | Convert agenda grid coordinates to scrollview contents coordinates. | 1553 | Convert agenda grid coordinates to scrollview contents coordinates. |
1563 | */ | 1554 | */ |
1564 | void KOAgenda::gridToContents (int gx, int gy, int& x, int& y) | 1555 | void KOAgenda::gridToContents (int gx, int gy, int& x, int& y) |
1565 | { | 1556 | { |
1566 | x = KOGlobals::self()->reverseLayout() ? (mColumns - 1 - gx)*mGridSpacingX: | 1557 | x = KOGlobals::self()->reverseLayout() ? (mColumns - 1 - gx)*mGridSpacingX: |
1567 | gx*mGridSpacingX; | 1558 | gx*mGridSpacingX; |
1568 | y = gy*mGridSpacingY; | 1559 | y = gy*mGridSpacingY; |
1569 | } | 1560 | } |
1570 | 1561 | ||
1571 | 1562 | ||
1572 | /* | 1563 | /* |
1573 | Return Y coordinate corresponding to time. Coordinates are rounded to fit into | 1564 | Return Y coordinate corresponding to time. Coordinates are rounded to fit into |
1574 | the grid. | 1565 | the grid. |
1575 | */ | 1566 | */ |
1576 | int KOAgenda::timeToY(const QTime &time) | 1567 | int KOAgenda::timeToY(const QTime &time) |
1577 | { | 1568 | { |
1578 | int minutesPerCell = 24 * 60 / mRows; | 1569 | int minutesPerCell = 24 * 60 / mRows; |
1579 | int timeMinutes = time.hour() * 60 + time.minute(); | 1570 | int timeMinutes = time.hour() * 60 + time.minute(); |
1580 | int Y = (timeMinutes + (minutesPerCell / 2)) / minutesPerCell; | 1571 | int Y = (timeMinutes + (minutesPerCell / 2)) / minutesPerCell; |
1581 | return Y; | 1572 | return Y; |
1582 | } | 1573 | } |
1583 | 1574 | ||
1584 | 1575 | ||
1585 | /* | 1576 | /* |
1586 | Return time corresponding to cell y coordinate. Coordinates are rounded to | 1577 | Return time corresponding to cell y coordinate. Coordinates are rounded to |
1587 | fit into the grid. | 1578 | fit into the grid. |
1588 | */ | 1579 | */ |
1589 | QTime KOAgenda::gyToTime(int gy) | 1580 | QTime KOAgenda::gyToTime(int gy) |
1590 | { | 1581 | { |
1591 | 1582 | ||
1592 | int secondsPerCell = 24 * 60 * 60/ mRows; | 1583 | int secondsPerCell = 24 * 60 * 60/ mRows; |
1593 | 1584 | ||
1594 | int timeSeconds = secondsPerCell * gy; | 1585 | int timeSeconds = secondsPerCell * gy; |
1595 | 1586 | ||
1596 | QTime time( 0, 0, 0 ); | 1587 | QTime time( 0, 0, 0 ); |
1597 | if ( timeSeconds < 24 * 60 * 60 ) { | 1588 | if ( timeSeconds < 24 * 60 * 60 ) { |
1598 | time = time.addSecs(timeSeconds); | 1589 | time = time.addSecs(timeSeconds); |
1599 | } else { | 1590 | } else { |
1600 | time.setHMS( 23, 59, 59 ); | 1591 | time.setHMS( 23, 59, 59 ); |
1601 | } | 1592 | } |
1602 | 1593 | ||
1603 | return time; | 1594 | return time; |
1604 | } | 1595 | } |
1605 | 1596 | ||
1606 | void KOAgenda::setStartHour(int startHour) | 1597 | void KOAgenda::setStartHour(int startHour) |
1607 | { | 1598 | { |
1608 | int startCell = startHour * mRows / 24; | 1599 | int startCell = startHour * mRows / 24; |
1609 | setContentsPos(0,startCell * gridSpacingY()); | 1600 | setContentsPos(0,startCell * gridSpacingY()); |
1610 | } | 1601 | } |
1611 | void KOAgenda::hideUnused() | 1602 | void KOAgenda::hideUnused() |
1612 | { | 1603 | { |
1613 | // experimental only | 1604 | // experimental only |
1614 | // return; | 1605 | // return; |
1615 | KOAgendaItem *item; | 1606 | KOAgendaItem *item; |
1616 | for ( item=mUnusedItems.first(); item != 0; item=mUnusedItems.next() ) { | 1607 | for ( item=mUnusedItems.first(); item != 0; item=mUnusedItems.next() ) { |
1617 | item->hide(); | 1608 | item->hide(); |
1618 | } | 1609 | } |
1619 | } | 1610 | } |
1620 | 1611 | ||
1621 | 1612 | ||
1622 | KOAgendaItem *KOAgenda::getNewItem(Incidence * event,QDate qd, QWidget* view) | 1613 | KOAgendaItem *KOAgenda::getNewItem(Incidence * event,QDate qd, QWidget* view) |
1623 | { | 1614 | { |
1624 | 1615 | ||
1625 | KOAgendaItem *fi; | 1616 | KOAgendaItem *fi; |
1626 | for ( fi=mUnusedItems.first(); fi != 0; fi=mUnusedItems.next() ) { | 1617 | for ( fi=mUnusedItems.first(); fi != 0; fi=mUnusedItems.next() ) { |
1627 | if ( fi->incidence() == event ) { | 1618 | if ( fi->incidence() == event ) { |
1628 | mUnusedItems.remove(); | 1619 | mUnusedItems.remove(); |
1629 | fi->init( event, qd ); | 1620 | fi->init( event, qd ); |
1630 | return fi; | 1621 | return fi; |
1631 | } | 1622 | } |
1632 | } | 1623 | } |
1633 | fi=mUnusedItems.first(); | 1624 | fi=mUnusedItems.first(); |
1634 | if ( fi ) { | 1625 | if ( fi ) { |
1635 | mUnusedItems.remove(); | 1626 | mUnusedItems.remove(); |
1636 | fi->init( event, qd ); | 1627 | fi->init( event, qd ); |
1637 | return fi; | 1628 | return fi; |
1638 | } | 1629 | } |
1639 | // qDebug("new KOAgendaItem "); | 1630 | // qDebug("new KOAgendaItem "); |
1640 | 1631 | ||
1641 | KOAgendaItem* agendaItem = new KOAgendaItem( event, qd, view, mAllDayMode ); | 1632 | KOAgendaItem* agendaItem = new KOAgendaItem( event, qd, view, mAllDayMode ); |
1642 | agendaItem->installEventFilter(this); | 1633 | agendaItem->installEventFilter(this); |
1643 | addChild(agendaItem,0,0); | 1634 | addChild(agendaItem,0,0); |
1644 | return agendaItem; | 1635 | return agendaItem; |
1645 | } | 1636 | } |
1646 | KOAgendaItem * KOAgenda::getItemForTodo ( Todo * todo ) | 1637 | KOAgendaItem * KOAgenda::getItemForTodo ( Todo * todo ) |
1647 | { | 1638 | { |
1648 | KOAgendaItem *item; | 1639 | KOAgendaItem *item; |
1649 | for ( item=mItems.first(); item != 0; item=mItems.next() ) { | 1640 | for ( item=mItems.first(); item != 0; item=mItems.next() ) { |
1650 | if ( item->incidence() == todo ) { | 1641 | if ( item->incidence() == todo ) { |
1651 | mItems.remove(); | 1642 | mItems.remove(); |
1652 | return item; | 1643 | return item; |
1653 | } | 1644 | } |
1654 | } | 1645 | } |
1655 | return 0; | 1646 | return 0; |
1656 | } | 1647 | } |
1657 | 1648 | ||
1658 | 1649 | ||
1659 | void KOAgenda::updateTodo( Todo * todo, int days, bool remove) | 1650 | void KOAgenda::updateTodo( Todo * todo, int days, bool remove) |
1660 | { | 1651 | { |
1661 | // ( todo->hasCompletedDate() && todo->completed().date() == currentDate )|| | 1652 | // ( todo->hasCompletedDate() && todo->completed().date() == currentDate )|| |
1662 | KOAgendaItem *item; | 1653 | KOAgendaItem *item; |
1663 | item = getItemForTodo ( todo ); | 1654 | item = getItemForTodo ( todo ); |
1664 | //qDebug("KOAgenda::updateTodo %d %d %d %d", this, todo, days, remove); | 1655 | //qDebug("KOAgenda::updateTodo %d %d %d %d", this, todo, days, remove); |
1665 | if ( item ) { | 1656 | if ( item ) { |
1666 | blockSignals( true ); | 1657 | blockSignals( true ); |
1667 | //qDebug("item found "); | 1658 | //qDebug("item found "); |
1668 | item->hide(); | 1659 | item->hide(); |
1669 | item->setCellX(-2, -1 ); | 1660 | item->setCellX(-2, -1 ); |
1670 | item->select(false); | 1661 | item->select(false); |
1671 | mUnusedItems.append( item ); | 1662 | mUnusedItems.append( item ); |
1672 | mItems.remove( item ); | 1663 | mItems.remove( item ); |
1673 | QPtrList<KOAgendaItem> oldconflictItems = item->conflictItems(); | 1664 | QPtrList<KOAgendaItem> oldconflictItems = item->conflictItems(); |
1674 | KOAgendaItem *itemit; | 1665 | KOAgendaItem *itemit; |
1675 | //globalFlagBlockAgendaItemPaint = 1; | 1666 | //globalFlagBlockAgendaItemPaint = 1; |
1676 | for ( itemit=oldconflictItems.first(); itemit != 0; | 1667 | for ( itemit=oldconflictItems.first(); itemit != 0; |
1677 | itemit=oldconflictItems.next() ) { | 1668 | itemit=oldconflictItems.next() ) { |
1678 | if ( itemit != item ) | 1669 | if ( itemit != item ) |
1679 | placeSubCells(itemit); | 1670 | placeSubCells(itemit); |
1680 | } | 1671 | } |
1681 | qApp->processEvents(); | 1672 | qApp->processEvents(); |
1682 | //globalFlagBlockAgendaItemPaint = 0; | 1673 | //globalFlagBlockAgendaItemPaint = 0; |
1683 | for ( itemit=oldconflictItems.first(); itemit != 0; | 1674 | for ( itemit=oldconflictItems.first(); itemit != 0; |
1684 | itemit=oldconflictItems.next() ) { | 1675 | itemit=oldconflictItems.next() ) { |
1685 | globalFlagBlockAgendaItemUpdate = 0; | 1676 | globalFlagBlockAgendaItemUpdate = 0; |
1686 | if ( itemit != item ) | 1677 | if ( itemit != item ) |
1687 | itemit->repaintMe(); | 1678 | itemit->repaintMe(); |
1688 | globalFlagBlockAgendaItemUpdate = 1; | 1679 | globalFlagBlockAgendaItemUpdate = 1; |
1689 | itemit->repaint(); | 1680 | itemit->repaint(); |
1690 | } | 1681 | } |
1691 | blockSignals( false ); | 1682 | blockSignals( false ); |
1692 | } | 1683 | } |
1693 | if ( remove ) { | 1684 | if ( remove ) { |
1694 | //qDebug("remove****************************************** "); | 1685 | //qDebug("remove****************************************** "); |
1695 | return; | 1686 | return; |
1696 | } | 1687 | } |
1697 | //qDebug("updateTodo+++++++++++++++++++++++++++++++++++++ "); | 1688 | //qDebug("updateTodo+++++++++++++++++++++++++++++++++++++ "); |
1698 | bool overdue = (!todo->isCompleted()) && (todo->dtDue() < QDate::currentDate())&& ( KOPrefs::instance()->mShowTodoInAgenda ); | 1689 | bool overdue = (!todo->isCompleted()) && (todo->dtDue() < QDate::currentDate())&& ( KOPrefs::instance()->mShowTodoInAgenda ); |
1699 | QDate currentDate; | 1690 | QDate currentDate; |
1700 | QDateTime dt; | 1691 | QDateTime dt; |
1701 | if ( todo->hasCompletedDate() ) | 1692 | if ( todo->hasCompletedDate() ) |
1702 | dt = todo->completed(); | 1693 | dt = todo->completed(); |
1703 | else | 1694 | else |
1704 | dt = todo->dtDue(); | 1695 | dt = todo->dtDue(); |
1705 | if ( overdue ) { | 1696 | if ( overdue ) { |
1706 | currentDate = QDate::currentDate(); | 1697 | currentDate = QDate::currentDate(); |
1707 | days += todo->dtDue().date().daysTo( currentDate ); | 1698 | days += todo->dtDue().date().daysTo( currentDate ); |
1708 | } | 1699 | } |
1709 | else | 1700 | else |
1710 | currentDate = dt.date(); | 1701 | currentDate = dt.date(); |
1711 | 1702 | ||
1712 | if (( todo->doesFloat() || overdue) && !todo->hasCompletedDate() ) { | 1703 | if (( todo->doesFloat() || overdue) && !todo->hasCompletedDate() ) { |
1713 | if ( ! mAllDayMode ) return; | 1704 | if ( ! mAllDayMode ) return; |
1714 | // aldayagenda | 1705 | // aldayagenda |
1715 | globalFlagBlockAgendaItemPaint = 1; | 1706 | globalFlagBlockAgendaItemPaint = 1; |
1716 | item = insertAllDayItem(todo, currentDate,days, days); | 1707 | item = insertAllDayItem(todo, currentDate,days, days); |
1717 | item->show(); | 1708 | item->show(); |
1718 | 1709 | ||
1719 | } | 1710 | } |
1720 | else { | 1711 | else { |
1721 | if ( mAllDayMode ) return; | 1712 | if ( mAllDayMode ) return; |
1722 | // mAgenda | 1713 | // mAgenda |
1723 | globalFlagBlockAgendaItemPaint = 1; | 1714 | globalFlagBlockAgendaItemPaint = 1; |
1724 | int endY = timeToY(dt.time()) - 1; | 1715 | int endY = timeToY(dt.time()) - 1; |
1725 | int hi = 12/KOPrefs::instance()->mHourSize; | 1716 | int hi = 12/KOPrefs::instance()->mHourSize; |
1726 | int startY = endY - 1-hi; | 1717 | int startY = endY - 1-hi; |
1727 | item = insertItem(todo,currentDate,days,startY,endY); | 1718 | item = insertItem(todo,currentDate,days,startY,endY); |
1728 | item->show(); | 1719 | item->show(); |
1729 | } | 1720 | } |
1730 | qApp->processEvents(); | 1721 | qApp->processEvents(); |
1731 | globalFlagBlockAgendaItemPaint = 0; | 1722 | globalFlagBlockAgendaItemPaint = 0; |
1732 | QPtrList<KOAgendaItem> oldconflictItems = item->conflictItems(); | 1723 | QPtrList<KOAgendaItem> oldconflictItems = item->conflictItems(); |
1733 | KOAgendaItem *itemit; | 1724 | KOAgendaItem *itemit; |
1734 | for ( itemit=oldconflictItems.first(); itemit != 0; | 1725 | for ( itemit=oldconflictItems.first(); itemit != 0; |
1735 | itemit=oldconflictItems.next() ) { | 1726 | itemit=oldconflictItems.next() ) { |
1736 | globalFlagBlockAgendaItemUpdate = 0; | 1727 | globalFlagBlockAgendaItemUpdate = 0; |
1737 | itemit->repaintMe(); | 1728 | itemit->repaintMe(); |
1738 | globalFlagBlockAgendaItemUpdate = 1; | 1729 | globalFlagBlockAgendaItemUpdate = 1; |
1739 | itemit->repaint(); | 1730 | itemit->repaint(); |
1740 | } | 1731 | } |
1741 | globalFlagBlockAgendaItemUpdate = 0; | 1732 | globalFlagBlockAgendaItemUpdate = 0; |
1742 | item->repaintMe(); | 1733 | item->repaintMe(); |
1743 | globalFlagBlockAgendaItemUpdate = 1; | 1734 | globalFlagBlockAgendaItemUpdate = 1; |
1744 | item->repaint(); | 1735 | item->repaint(); |
1745 | } | 1736 | } |
1746 | /* | 1737 | /* |
1747 | Insert KOAgendaItem into agenda. | 1738 | Insert KOAgendaItem into agenda. |
1748 | */ | 1739 | */ |
1749 | KOAgendaItem *KOAgenda::insertItem (Incidence *event,QDate qd,int X,int YTop,int YBottom) | 1740 | KOAgendaItem *KOAgenda::insertItem (Incidence *event,QDate qd,int X,int YTop,int YBottom) |
1750 | { | 1741 | { |
1751 | //kdDebug() << "KOAgenda::insertItem:" << event->summary() << "-" << qd.toString() << " ;top, bottom:" << YTop << "," << YBottom << endl; | ||
1752 | |||
1753 | if (mAllDayMode) { | 1742 | if (mAllDayMode) { |
1754 | kdDebug() << "KOAgenda: calling insertItem in all-day mode is illegal." << endl; | 1743 | qDebug("KOAgenda: calling insertItem in all-day mode is illegal. "); |
1755 | return 0; | 1744 | return 0; |
1756 | } | 1745 | } |
1757 | 1746 | ||
1758 | KOAgendaItem *agendaItem = getNewItem(event,qd,viewport()); | 1747 | KOAgendaItem *agendaItem = getNewItem(event,qd,viewport()); |
1759 | //agendaItem->setFrameStyle(WinPanel|Raised); | 1748 | //agendaItem->setFrameStyle(WinPanel|Raised); |
1760 | 1749 | ||
1761 | int YSize = YBottom - YTop + 1; | 1750 | int YSize = YBottom - YTop + 1; |
1762 | if (YSize < 0) { | 1751 | if (YSize < 0) { |
1763 | kdDebug() << "KOAgenda::insertItem(): Text: " << agendaItem->text() << " YSize<0" << endl; | ||
1764 | YSize = 1; | 1752 | YSize = 1; |
1765 | } | 1753 | } |
1766 | int iheight = mGridSpacingY * YSize; | 1754 | int iheight = mGridSpacingY * YSize; |
1767 | 1755 | ||
1768 | agendaItem->resize(mGridSpacingX,iheight ); | 1756 | agendaItem->resize(mGridSpacingX,iheight ); |
1769 | agendaItem->setCellXY(X,YTop,YBottom); | 1757 | agendaItem->setCellXY(X,YTop,YBottom); |
1770 | agendaItem->setCellXWidth(X); | 1758 | agendaItem->setCellXWidth(X); |
1771 | 1759 | ||
1772 | //addChild(agendaItem,X*mGridSpacingX,YTop*mGridSpacingY); | 1760 | //addChild(agendaItem,X*mGridSpacingX,YTop*mGridSpacingY); |
1773 | mItems.append(agendaItem); | 1761 | mItems.append(agendaItem); |
1774 | 1762 | ||
1775 | placeSubCells(agendaItem); | 1763 | placeSubCells(agendaItem); |
1776 | 1764 | ||
1777 | //agendaItem->show(); | 1765 | //agendaItem->show(); |
1778 | 1766 | ||
1779 | marcus_bains(); | 1767 | marcus_bains(); |
1780 | 1768 | ||
1781 | return agendaItem; | 1769 | return agendaItem; |
1782 | } | 1770 | } |
1783 | 1771 | ||
1784 | 1772 | ||
1785 | /* | 1773 | /* |
1786 | Insert all-day KOAgendaItem into agenda. | 1774 | Insert all-day KOAgendaItem into agenda. |
1787 | */ | 1775 | */ |
1788 | KOAgendaItem *KOAgenda::insertAllDayItem (Incidence *event,QDate qd,int XBegin,int XEnd) | 1776 | KOAgendaItem *KOAgenda::insertAllDayItem (Incidence *event,QDate qd,int XBegin,int XEnd) |
1789 | { | 1777 | { |
1790 | if (!mAllDayMode) { | 1778 | if (!mAllDayMode) { |
1791 | return 0; | 1779 | return 0; |
1792 | } | 1780 | } |
1793 | 1781 | ||
1794 | KOAgendaItem *agendaItem = getNewItem(event,qd,viewport()); | 1782 | KOAgendaItem *agendaItem = getNewItem(event,qd,viewport()); |
1795 | 1783 | ||
1796 | agendaItem->setCellXY(XBegin,0,0); | 1784 | agendaItem->setCellXY(XBegin,0,0); |
1797 | agendaItem->setCellXWidth(XEnd); | 1785 | agendaItem->setCellXWidth(XEnd); |
1798 | agendaItem->resize(mGridSpacingX * agendaItem->cellWidth(),mGridSpacingY); | 1786 | agendaItem->resize(mGridSpacingX * agendaItem->cellWidth(),mGridSpacingY); |
1799 | 1787 | ||
1800 | //addChild(agendaItem,XBegin*mGridSpacingX,0); | 1788 | //addChild(agendaItem,XBegin*mGridSpacingX,0); |
1801 | mItems.append(agendaItem); | 1789 | mItems.append(agendaItem); |
1802 | 1790 | ||
1803 | placeSubCells(agendaItem); | 1791 | placeSubCells(agendaItem); |
1804 | 1792 | ||
1805 | //agendaItem->show(); | 1793 | //agendaItem->show(); |
1806 | 1794 | ||
1807 | return agendaItem; | 1795 | return agendaItem; |
1808 | } | 1796 | } |
1809 | 1797 | ||
1810 | 1798 | ||
1811 | void KOAgenda::insertMultiItem (Event *event,QDate qd,int XBegin,int XEnd, | 1799 | void KOAgenda::insertMultiItem (Event *event,QDate qd,int XBegin,int XEnd, |
1812 | int YTop,int YBottom) | 1800 | int YTop,int YBottom) |
1813 | { | 1801 | { |
1814 | if (mAllDayMode) { | 1802 | if (mAllDayMode) { |
1815 | ; | 1803 | ; |
1816 | return; | 1804 | return; |
1817 | } | 1805 | } |
1818 | 1806 | ||
1819 | int cellX,cellYTop,cellYBottom; | 1807 | int cellX,cellYTop,cellYBottom; |
1820 | QString newtext; | 1808 | QString newtext; |
1821 | int width = XEnd - XBegin + 1; | 1809 | int width = XEnd - XBegin + 1; |
1822 | int count = 0; | 1810 | int count = 0; |
1823 | KOAgendaItem *current = 0; | 1811 | KOAgendaItem *current = 0; |
1824 | QPtrList<KOAgendaItem> multiItems; | 1812 | QPtrList<KOAgendaItem> multiItems; |
1825 | for (cellX = XBegin;cellX <= XEnd;++cellX) { | 1813 | for (cellX = XBegin;cellX <= XEnd;++cellX) { |
1826 | if (cellX == XBegin) cellYTop = YTop; | 1814 | if (cellX == XBegin) cellYTop = YTop; |
1827 | else cellYTop = 0; | 1815 | else cellYTop = 0; |
1828 | if (cellX == XEnd) cellYBottom = YBottom; | 1816 | if (cellX == XEnd) cellYBottom = YBottom; |
1829 | else cellYBottom = rows() - 1; | 1817 | else cellYBottom = rows() - 1; |
1830 | newtext = QString("(%1/%2): ").arg(++count).arg(width); | 1818 | newtext = QString("(%1/%2): ").arg(++count).arg(width); |
1831 | newtext.append(event->summary()); | 1819 | newtext.append(event->summary()); |
1832 | current = insertItem(event,qd,cellX,cellYTop,cellYBottom); | 1820 | current = insertItem(event,qd,cellX,cellYTop,cellYBottom); |
1833 | current->setText(newtext); | 1821 | current->setText(newtext); |
1834 | multiItems.append(current); | 1822 | multiItems.append(current); |
1835 | } | 1823 | } |
1836 | 1824 | ||
1837 | KOAgendaItem *next = 0; | 1825 | KOAgendaItem *next = 0; |
1838 | KOAgendaItem *last = multiItems.last(); | 1826 | KOAgendaItem *last = multiItems.last(); |
1839 | KOAgendaItem *first = multiItems.first(); | 1827 | KOAgendaItem *first = multiItems.first(); |
1840 | KOAgendaItem *setFirst,*setLast; | 1828 | KOAgendaItem *setFirst,*setLast; |
1841 | current = first; | 1829 | current = first; |
1842 | while (current) { | 1830 | while (current) { |
1843 | next = multiItems.next(); | 1831 | next = multiItems.next(); |
1844 | if (current == first) setFirst = 0; | 1832 | if (current == first) setFirst = 0; |
1845 | else setFirst = first; | 1833 | else setFirst = first; |
1846 | if (current == last) setLast = 0; | 1834 | if (current == last) setLast = 0; |
1847 | else setLast = last; | 1835 | else setLast = last; |
1848 | 1836 | ||
1849 | current->setMultiItem(setFirst,next,setLast); | 1837 | current->setMultiItem(setFirst,next,setLast); |
1850 | current = next; | 1838 | current = next; |
1851 | } | 1839 | } |
1852 | 1840 | ||
1853 | marcus_bains(); | 1841 | marcus_bains(); |
1854 | } | 1842 | } |
1855 | 1843 | ||
1856 | 1844 | ||
1857 | //QSizePolicy KOAgenda::sizePolicy() const | 1845 | //QSizePolicy KOAgenda::sizePolicy() const |
1858 | //{ | 1846 | //{ |
1859 | // Thought this would make the all-day event agenda minimum size and the | 1847 | // Thought this would make the all-day event agenda minimum size and the |
1860 | // normal agenda take the remaining space. But it doesn´t work. The QSplitter | 1848 | // normal agenda take the remaining space. But it doesn´t work. The QSplitter |
1861 | // don´t seem to think that an Expanding widget needs more space than a | 1849 | // don´t seem to think that an Expanding widget needs more space than a |
1862 | // Preferred one. | 1850 | // Preferred one. |
1863 | // But it doesn´t hurt, so it stays. | 1851 | // But it doesn´t hurt, so it stays. |
1864 | // if (mAllDayMode) { | 1852 | // if (mAllDayMode) { |
1865 | // return QSizePolicy(QSizePolicy::Expanding,QSizePolicy::Preferred); | 1853 | // return QSizePolicy(QSizePolicy::Expanding,QSizePolicy::Preferred); |
1866 | // } else { | 1854 | // } else { |
1867 | // return QSizePolicy(QSizePolicy::Expanding,QSizePolicy::Expanding); | 1855 | // return QSizePolicy(QSizePolicy::Expanding,QSizePolicy::Expanding); |
1868 | // } | 1856 | // } |
1869 | //} | 1857 | //} |
1870 | void KOAgenda::finishResize ( ) | 1858 | void KOAgenda::finishResize ( ) |
1871 | { | 1859 | { |
1872 | //qDebug("finishResize+++++++++++++++++++++++++++++++ ( ) "); | 1860 | //qDebug("finishResize+++++++++++++++++++++++++++++++ ( ) "); |
1873 | if ( globalFlagBlockAgenda == 0 ) { | 1861 | if ( globalFlagBlockAgenda == 0 ) { |
1874 | finishUpdate(); | 1862 | finishUpdate(); |
1875 | //qDebug("finishUpdate() called "); | 1863 | //qDebug("finishUpdate() called "); |
1876 | } | 1864 | } |
1877 | } | 1865 | } |
1878 | /* | 1866 | /* |
1879 | Overridden from QScrollView to provide proper resizing of KOAgendaItems. | 1867 | Overridden from QScrollView to provide proper resizing of KOAgendaItems. |
1880 | */ | 1868 | */ |
1881 | void KOAgenda::resizeEvent ( QResizeEvent *ev ) | 1869 | void KOAgenda::resizeEvent ( QResizeEvent *ev ) |
1882 | { | 1870 | { |
1883 | 1871 | ||
1884 | mResizeTimer.start( 150 , true ); | 1872 | mResizeTimer.start( 150 , true ); |
1885 | computeSizes(); | 1873 | computeSizes(); |
1886 | return; | 1874 | return; |
1887 | 1875 | ||
1888 | } | 1876 | } |
1889 | void KOAgenda::computeSizes() | 1877 | void KOAgenda::computeSizes() |
1890 | { | 1878 | { |
1891 | if ( globalFlagBlockStartup ) | 1879 | if ( globalFlagBlockStartup ) |
1892 | return; | 1880 | return; |
1881 | int frameOffset = frameWidth() * 2 +1; | ||
1882 | if (mAllDayMode) { | ||
1883 | mGridSpacingX = (width()-frameOffset) / mColumns; | ||
1884 | mGridSpacingY = height() - 2 * frameWidth() - 1; | ||
1885 | resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY + 1); | ||
1886 | // mGridSpacingY = height(); | ||
1887 | // resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 ); | ||
1893 | 1888 | ||
1894 | if (mAllDayMode) { | 1889 | KOAgendaItem *item; |
1895 | mGridSpacingX = (width()-3) / mColumns; | 1890 | int subCellWidth; |
1896 | mGridSpacingY = height() - 2 * frameWidth() - 1; | 1891 | for ( item=mItems.first(); item != 0; item=mItems.next() ) { |
1897 | resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY + 1); | 1892 | subCellWidth = mGridSpacingY / item->subCells(); |
1898 | // mGridSpacingY = height(); | 1893 | item->resize(mGridSpacingX * item->cellWidth(),subCellWidth); |
1899 | // resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 ); | 1894 | moveChild(item,KOGlobals::self()->reverseLayout() ? |
1900 | 1895 | (mColumns - 1 - item->cellX()) * mGridSpacingX : | |
1901 | KOAgendaItem *item; | ||
1902 | int subCellWidth; | ||
1903 | for ( item=mItems.first(); item != 0; item=mItems.next() ) { | ||
1904 | subCellWidth = mGridSpacingY / item->subCells(); | ||
1905 | item->resize(mGridSpacingX * item->cellWidth(),subCellWidth); | ||
1906 | moveChild(item,KOGlobals::self()->reverseLayout() ? | ||
1907 | (mColumns - 1 - item->cellX()) * mGridSpacingX : | ||
1908 | item->cellX() * mGridSpacingX, | 1896 | item->cellX() * mGridSpacingX, |
1909 | item->subCell() * subCellWidth); | 1897 | item->subCell() * subCellWidth); |
1910 | } | 1898 | } |
1911 | KOPrefs::instance()->mAllDaySize = mGridSpacingY; | 1899 | KOPrefs::instance()->mAllDaySize = mGridSpacingY; |
1912 | } else { | 1900 | } else { |
1913 | mGridSpacingX = (width() - verticalScrollBar()->width()-3)/mColumns; | 1901 | mGridSpacingX = (width() - verticalScrollBar()->width()-frameOffset)/mColumns; |
1914 | if (height() > mGridSpacingY * mRows + 1 ) { | 1902 | if (height() > mGridSpacingY * mRows + 1 ) { |
1915 | KOPrefs::instance()->mHourSize = ((height())/mRows)+1; | 1903 | KOPrefs::instance()->mHourSize = ((height())/mRows)+1; |
1916 | mGridSpacingY = KOPrefs::instance()->mHourSize ; | 1904 | mGridSpacingY = KOPrefs::instance()->mHourSize ; |
1917 | resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 ); | 1905 | resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 ); |
1918 | emit resizedSignal(); | 1906 | emit resizedSignal(); |
1919 | } else | 1907 | } else |
1920 | resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 ); | 1908 | resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 ); |
1921 | KOAgendaItem *item; | 1909 | KOAgendaItem *item; |
1922 | int subCellWidth; | 1910 | int subCellWidth; |
1923 | 1911 | ||
1924 | for ( item=mItems.first(); item != 0; item=mItems.next() ) { | 1912 | for ( item=mItems.first(); item != 0; item=mItems.next() ) { |
1925 | subCellWidth = mGridSpacingX / item->subCells(); | 1913 | subCellWidth = mGridSpacingX / item->subCells(); |
1926 | item->resize(subCellWidth,item->height()); | 1914 | item->resize(subCellWidth,item->height()); |
1927 | moveChild(item,(KOGlobals::self()->reverseLayout() ? | 1915 | moveChild(item,(KOGlobals::self()->reverseLayout() ? |
1928 | (mColumns - 1 - item->cellX()) * mGridSpacingX : | 1916 | (mColumns - 1 - item->cellX()) * mGridSpacingX : |
1929 | item->cellX() * mGridSpacingX) + | 1917 | item->cellX() * mGridSpacingX) + |
1930 | item->subCell() * subCellWidth,childY(item)); | 1918 | item->subCell() * subCellWidth,childY(item)); |
1919 | } | ||
1920 | } | ||
1921 | int cw = contentsWidth(); | ||
1922 | int ch = contentsHeight(); | ||
1923 | if ( mAllDayMode ) { | ||
1924 | QPixmap* paintPixAll = KOAgendaItem::paintPixAllday(); | ||
1925 | if ( (paintPixAll->width() < cw || paintPixAll->height() < ch) && cw > 0 && ch > 0 ) | ||
1926 | paintPixAll->resize( cw, ch ); | ||
1927 | } else { | ||
1928 | QPixmap* paintPix = KOAgendaItem::paintPix(); | ||
1929 | if ( paintPix->width() < cw || paintPix->height() < ch ) | ||
1930 | KOAgendaItem::resizePixmap( cw , ch ); | ||
1931 | } | 1931 | } |
1932 | } | ||
1933 | int cw = contentsWidth(); | ||
1934 | int ch = contentsHeight(); | ||
1935 | if ( mAllDayMode ) { | ||
1936 | QPixmap* paintPixAll = KOAgendaItem::paintPixAllday(); | ||
1937 | if ( (paintPixAll->width() < cw || paintPixAll->height() < ch) && cw > 0 && ch > 0 ) | ||
1938 | paintPixAll->resize( cw, ch ); | ||
1939 | } else { | ||
1940 | QPixmap* paintPix = KOAgendaItem::paintPix(); | ||
1941 | if ( paintPix->width() < cw || paintPix->height() < ch ) | ||
1942 | KOAgendaItem::resizePixmap( cw , ch ); | ||
1943 | } | ||
1944 | 1932 | ||
1945 | checkScrollBoundaries(); | 1933 | checkScrollBoundaries(); |
1946 | marcus_bains(); | 1934 | marcus_bains(); |
1947 | drawContentsToPainter(); | 1935 | drawContentsToPainter(); |
1948 | viewport()->repaint(false); | 1936 | viewport()->repaint(false); |
1949 | } | 1937 | } |
1950 | 1938 | ||
1951 | void KOAgenda::scrollUp() | 1939 | void KOAgenda::scrollUp() |
1952 | { | 1940 | { |
1953 | scrollBy(0,-mScrollOffset); | 1941 | scrollBy(0,-mScrollOffset); |
1954 | } | 1942 | } |
1955 | 1943 | ||
1956 | 1944 | ||
1957 | void KOAgenda::scrollDown() | 1945 | void KOAgenda::scrollDown() |
1958 | { | 1946 | { |
1959 | scrollBy(0,mScrollOffset); | 1947 | scrollBy(0,mScrollOffset); |
1960 | } | 1948 | } |
1961 | 1949 | ||
1962 | void KOAgenda::popupAlarm() | 1950 | void KOAgenda::popupAlarm() |
1963 | { | 1951 | { |
1964 | if (!mClickedItem) { | 1952 | if (!mClickedItem) { |
1965 | qDebug("KOAgenda::popupAlarm() called without having a clicked item "); | 1953 | qDebug("KOAgenda::popupAlarm() called without having a clicked item "); |
1966 | return; | 1954 | return; |
1967 | } | 1955 | } |
1968 | // TODO: deal correctly with multiple alarms | 1956 | // TODO: deal correctly with multiple alarms |
1969 | Alarm* alarm; | 1957 | Alarm* alarm; |
1970 | QPtrList<Alarm> list(mClickedItem->incidence()->alarms()); | 1958 | QPtrList<Alarm> list(mClickedItem->incidence()->alarms()); |
1971 | for(alarm=list.first();alarm;alarm=list.next()) { | 1959 | for(alarm=list.first();alarm;alarm=list.next()) { |
1972 | alarm->toggleAlarm(); | 1960 | alarm->toggleAlarm(); |
1973 | } | 1961 | } |
1974 | emit itemModified( mClickedItem , KOGlobals::EVENTEDITED ); | 1962 | emit itemModified( mClickedItem , KOGlobals::EVENTEDITED ); |
1975 | mClickedItem->paintMe( true ); | 1963 | mClickedItem->paintMe( true ); |
1976 | mClickedItem->repaint( false ); | 1964 | mClickedItem->repaint( false ); |
1977 | } | 1965 | } |
1978 | 1966 | ||
1979 | /* | 1967 | /* |
1980 | Calculates the minimum width | 1968 | Calculates the minimum width |
1981 | */ | 1969 | */ |
1982 | int KOAgenda::minimumWidth() const | 1970 | int KOAgenda::minimumWidth() const |
1983 | { | 1971 | { |
1984 | // TODO:: develop a way to dynamically determine the minimum width | 1972 | // TODO:: develop a way to dynamically determine the minimum width |
1985 | int min = 100; | 1973 | int min = 100; |
1986 | 1974 | ||
1987 | return min; | 1975 | return min; |
1988 | } | 1976 | } |
1989 | 1977 | ||
1990 | void KOAgenda::updateConfig() | 1978 | void KOAgenda::updateConfig() |
1991 | { | 1979 | { |
1992 | if ( viewport()->backgroundColor() != KOPrefs::instance()->mAgendaBgColor) | 1980 | if ( viewport()->backgroundColor() != KOPrefs::instance()->mAgendaBgColor) |
1993 | viewport()->setBackgroundColor(KOPrefs::instance()->mAgendaBgColor); | 1981 | viewport()->setBackgroundColor(KOPrefs::instance()->mAgendaBgColor); |
1994 | if ( mAllDayMode ) { | 1982 | if ( mAllDayMode ) { |
1995 | mGridSpacingY = height() - 1 ;// KOPrefs::instance()->mAllDaySize; | 1983 | mGridSpacingY = height() - 1 ;// KOPrefs::instance()->mAllDaySize; |
1996 | //mGridSpacingY = KOPrefs::instance()->mAllDaySize; | 1984 | //mGridSpacingY = KOPrefs::instance()->mAllDaySize; |
1997 | resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY+1 ); | 1985 | resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY+1 ); |
1998 | // setMaximumHeight( mGridSpacingY+1 ); | 1986 | // setMaximumHeight( mGridSpacingY+1 ); |
1999 | viewport()->repaint( false ); | 1987 | viewport()->repaint( false ); |
2000 | //setFixedHeight( mGridSpacingY+1 ); | 1988 | //setFixedHeight( mGridSpacingY+1 ); |
2001 | //qDebug("KOPrefs:aaaaa:instance()->mAllDaySize %d ", KOPrefs::instance()->mAllDaySize); | 1989 | //qDebug("KOPrefs:aaaaa:instance()->mAllDaySize %d ", KOPrefs::instance()->mAllDaySize); |
2002 | } | 1990 | } |
2003 | else { | 1991 | else { |
2004 | mGridSpacingY = KOPrefs::instance()->mHourSize; | 1992 | mGridSpacingY = KOPrefs::instance()->mHourSize; |
2005 | calculateWorkingHours(); | 1993 | calculateWorkingHours(); |
2006 | marcus_bains(); | 1994 | marcus_bains(); |
2007 | } | 1995 | } |
2008 | } | 1996 | } |
2009 | 1997 | ||
2010 | void KOAgenda::checkScrollBoundaries() | 1998 | void KOAgenda::checkScrollBoundaries() |
2011 | { | 1999 | { |
2012 | // Invalidate old values to force update | 2000 | // Invalidate old values to force update |
2013 | mOldLowerScrollValue = -1; | 2001 | mOldLowerScrollValue = -1; |
2014 | mOldUpperScrollValue = -1; | 2002 | mOldUpperScrollValue = -1; |
2015 | 2003 | ||
2016 | checkScrollBoundaries(verticalScrollBar()->value()); | 2004 | checkScrollBoundaries(verticalScrollBar()->value()); |
2017 | } | 2005 | } |
2018 | 2006 | ||
2019 | void KOAgenda::checkScrollBoundaries(int v) | 2007 | void KOAgenda::checkScrollBoundaries(int v) |
2020 | { | 2008 | { |
2021 | if ( mGridSpacingY == 0 ) | 2009 | if ( mGridSpacingY == 0 ) |
2022 | return; | 2010 | return; |
2023 | int yMin = v/mGridSpacingY; | 2011 | int yMin = v/mGridSpacingY; |
2024 | int yMax = (v+visibleHeight())/mGridSpacingY; | 2012 | int yMax = (v+visibleHeight())/mGridSpacingY; |
2025 | 2013 | ||
2026 | // kdDebug() << "--- yMin: " << yMin << " yMax: " << yMax << endl; | 2014 | // kdDebug() << "--- yMin: " << yMin << " yMax: " << yMax << endl; |
2027 | 2015 | ||
2028 | if (yMin != mOldLowerScrollValue) { | 2016 | if (yMin != mOldLowerScrollValue) { |
2029 | mOldLowerScrollValue = yMin; | 2017 | mOldLowerScrollValue = yMin; |
2030 | emit lowerYChanged(yMin); | 2018 | emit lowerYChanged(yMin); |
2031 | } | 2019 | } |
2032 | if (yMax != mOldUpperScrollValue) { | 2020 | if (yMax != mOldUpperScrollValue) { |
2033 | mOldUpperScrollValue = yMax; | 2021 | mOldUpperScrollValue = yMax; |
2034 | emit upperYChanged(yMax); | 2022 | emit upperYChanged(yMax); |
2035 | } | 2023 | } |
2036 | } | 2024 | } |
2037 | 2025 | ||
2038 | void KOAgenda::deselectItem() | 2026 | void KOAgenda::deselectItem() |
2039 | { | 2027 | { |
2040 | if (mSelectedItem.isNull()) return; | 2028 | if (mSelectedItem.isNull()) return; |
2041 | mSelectedItem->select(false); | 2029 | mSelectedItem->select(false); |
2042 | mSelectedItem = 0; | 2030 | mSelectedItem = 0; |
2043 | } | 2031 | } |
2044 | 2032 | ||
2045 | void KOAgenda::selectItem(KOAgendaItem *item) | 2033 | void KOAgenda::selectItem(KOAgendaItem *item) |
2046 | { | 2034 | { |
2047 | if ((KOAgendaItem *)mSelectedItem == item) return; | 2035 | if ((KOAgendaItem *)mSelectedItem == item) return; |
2048 | deselectItem(); | 2036 | deselectItem(); |
2049 | if (item == 0) { | 2037 | if (item == 0) { |
2050 | emit incidenceSelected( 0 ); | 2038 | emit incidenceSelected( 0 ); |
2051 | return; | 2039 | return; |
2052 | } | 2040 | } |
2053 | mSelectedItem = item; | 2041 | mSelectedItem = item; |
2054 | mSelectedItem->select(); | 2042 | mSelectedItem->select(); |
2055 | emit incidenceSelected( mSelectedItem->incidence() ); | 2043 | emit incidenceSelected( mSelectedItem->incidence() ); |
2056 | } | 2044 | } |
2057 | 2045 | ||
2058 | // This function seems never be called. | 2046 | // This function seems never be called. |
2059 | void KOAgenda::keyPressEvent( QKeyEvent *kev ) | 2047 | void KOAgenda::keyPressEvent( QKeyEvent *kev ) |
2060 | { | 2048 | { |
2061 | switch(kev->key()) { | 2049 | switch(kev->key()) { |
2062 | case Key_PageDown: | 2050 | case Key_PageDown: |
2063 | verticalScrollBar()->addPage(); | 2051 | verticalScrollBar()->addPage(); |
2064 | break; | 2052 | break; |
2065 | case Key_PageUp: | 2053 | case Key_PageUp: |
2066 | verticalScrollBar()->subtractPage(); | 2054 | verticalScrollBar()->subtractPage(); |
2067 | break; | 2055 | break; |
2068 | case Key_Down: | 2056 | case Key_Down: |
2069 | verticalScrollBar()->addLine(); | 2057 | verticalScrollBar()->addLine(); |
2070 | break; | 2058 | break; |
2071 | case Key_Up: | 2059 | case Key_Up: |
2072 | verticalScrollBar()->subtractLine(); | 2060 | verticalScrollBar()->subtractLine(); |
2073 | break; | 2061 | break; |
2074 | default: | 2062 | default: |
2075 | ; | 2063 | ; |
2076 | } | 2064 | } |
2077 | } | 2065 | } |
2078 | 2066 | ||
2079 | void KOAgenda::calculateWorkingHours() | 2067 | void KOAgenda::calculateWorkingHours() |
2080 | { | 2068 | { |
2081 | // mWorkingHoursEnable = KOPrefs::instance()->mEnableWorkingHours; | 2069 | // mWorkingHoursEnable = KOPrefs::instance()->mEnableWorkingHours; |
2082 | mWorkingHoursEnable = !mAllDayMode; | 2070 | mWorkingHoursEnable = !mAllDayMode; |
2083 | 2071 | ||
2084 | mWorkingHoursYTop = mGridSpacingY * | 2072 | mWorkingHoursYTop = mGridSpacingY * |
2085 | KOPrefs::instance()->mWorkingHoursStart * 4; | 2073 | KOPrefs::instance()->mWorkingHoursStart * 4; |
2086 | mWorkingHoursYBottom = mGridSpacingY * | 2074 | mWorkingHoursYBottom = mGridSpacingY * |
2087 | KOPrefs::instance()->mWorkingHoursEnd * 4 - 1; | 2075 | KOPrefs::instance()->mWorkingHoursEnd * 4 - 1; |
2088 | } | 2076 | } |
2089 | 2077 | ||
2090 | 2078 | ||
2091 | DateList KOAgenda::dateList() const | 2079 | DateList KOAgenda::dateList() const |
2092 | { | 2080 | { |
2093 | return mSelectedDates; | 2081 | return mSelectedDates; |
2094 | } | 2082 | } |
2095 | 2083 | ||
2096 | void KOAgenda::setDateList(const DateList &selectedDates) | 2084 | void KOAgenda::setDateList(const DateList &selectedDates) |
2097 | { | 2085 | { |
2098 | mSelectedDates = selectedDates; | 2086 | mSelectedDates = selectedDates; |
2099 | marcus_bains(); | 2087 | marcus_bains(); |
2100 | } | 2088 | } |
2101 | 2089 | ||
2102 | void KOAgenda::setHolidayMask(QMemArray<bool> *mask) | 2090 | void KOAgenda::setHolidayMask(QMemArray<bool> *mask) |
2103 | { | 2091 | { |
2104 | mHolidayMask = mask; | 2092 | mHolidayMask = mask; |
2105 | 2093 | ||
2106 | /* | 2094 | /* |
2107 | kdDebug() << "HolidayMask: "; | 2095 | kdDebug() << "HolidayMask: "; |
2108 | for(uint i=0;i<mask->count();++i) { | 2096 | for(uint i=0;i<mask->count();++i) { |
2109 | kdDebug() << (mask->at(i) ? "*" : "o"); | 2097 | kdDebug() << (mask->at(i) ? "*" : "o"); |
2110 | } | 2098 | } |
2111 | kdDebug() << endl; | 2099 | kdDebug() << endl; |
2112 | */ | 2100 | */ |
2113 | } | 2101 | } |
2114 | 2102 | ||
2115 | void KOAgenda::contentsMousePressEvent ( QMouseEvent *event ) | 2103 | void KOAgenda::contentsMousePressEvent ( QMouseEvent *event ) |
2116 | { | 2104 | { |
2117 | 2105 | ||
2118 | QScrollView::contentsMousePressEvent(event); | 2106 | QScrollView::contentsMousePressEvent(event); |
2119 | } | 2107 | } |
2120 | 2108 | ||
2121 | void KOAgenda::storePosition() | 2109 | void KOAgenda::storePosition() |
2122 | { | 2110 | { |
2123 | //mContentPosition | 2111 | //mContentPosition |
2124 | int max = mGridSpacingY*4*24; | 2112 | int max = mGridSpacingY*4*24; |
2125 | if ( contentsY() < 5 && max > viewport()->height()*3/2 ) | 2113 | if ( contentsY() < 5 && max > viewport()->height()*3/2 ) |
2126 | mContentPosition = 0; | 2114 | mContentPosition = 0; |
2127 | else if ( contentsY() + viewport()->height() > max - 5 && max > viewport()->height()*3/2) | 2115 | else if ( contentsY() + viewport()->height() > max - 5 && max > viewport()->height()*3/2) |
2128 | mContentPosition = -1.0; | 2116 | mContentPosition = -1.0; |
2129 | else | 2117 | else |
2130 | mContentPosition = ((float) max)/ ((float)(contentsY()+ ( viewport()->height()/2))); | 2118 | mContentPosition = ((float) max)/ ((float)(contentsY()+ ( viewport()->height()/2))); |
2131 | //qDebug("mContentPosition %f %d %d %d",mContentPosition , max, contentsY() ,viewport()->height()); | 2119 | //qDebug("mContentPosition %f %d %d %d",mContentPosition , max, contentsY() ,viewport()->height()); |
2132 | 2120 | ||
2133 | } | 2121 | } |
2134 | void KOAgenda::restorePosition() | 2122 | void KOAgenda::restorePosition() |
2135 | { | 2123 | { |
2136 | int posY; | 2124 | int posY; |
2137 | int max = mGridSpacingY*4*24; | 2125 | int max = mGridSpacingY*4*24; |
2138 | if ( mContentPosition < 0 ) | 2126 | if ( mContentPosition < 0 ) |
2139 | posY = max-viewport()->height(); | 2127 | posY = max-viewport()->height(); |
2140 | else | 2128 | else |
2141 | if ( mContentPosition == 0 ) | 2129 | if ( mContentPosition == 0 ) |
2142 | posY = 0; | 2130 | posY = 0; |
2143 | else | 2131 | else |
2144 | posY = (max/mContentPosition)-(viewport()->height()/2); | 2132 | posY = (max/mContentPosition)-(viewport()->height()/2); |
2145 | setContentsPos (0, posY ); | 2133 | setContentsPos (0, posY ); |
2146 | //qDebug("posY %d hei %d", posY, max); | 2134 | //qDebug("posY %d hei %d", posY, max); |
2147 | 2135 | ||
2148 | } | 2136 | } |
2149 | void KOAgenda::moveChild( QWidget *w, int x , int y ) | 2137 | void KOAgenda::moveChild( QWidget *w, int x , int y ) |
2150 | { | 2138 | { |
2151 | ++x; | 2139 | ++x; |
2152 | QScrollView::moveChild( w, x , y ); | 2140 | QScrollView::moveChild( w, x , y ); |
2153 | } | 2141 | } |
2154 | #include <qmessagebox.h> | 2142 | #include <qmessagebox.h> |
2155 | #ifdef DESKTOP_VERSION | 2143 | #ifdef DESKTOP_VERSION |
2156 | #include <qprinter.h> | 2144 | #include <qprinter.h> |
2157 | #include <qpainter.h> | 2145 | #include <qpainter.h> |
2158 | #include <qpaintdevicemetrics.h> | 2146 | #include <qpaintdevicemetrics.h> |
2159 | 2147 | ||
2160 | #endif | 2148 | #endif |
2161 | void KOAgenda::printSelection() | 2149 | void KOAgenda::printSelection() |
2162 | { | 2150 | { |
2163 | #ifdef DESKTOP_VERSION | 2151 | #ifdef DESKTOP_VERSION |
2164 | if ( mStartCellY == mCurrentCellY ) { | 2152 | if ( mStartCellY == mCurrentCellY ) { |
2165 | int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"), | 2153 | int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"), |
2166 | i18n("Nothing selected!\n\nThis prints the full width of the Agenda view as you see it!\n\nTo determine the vertical range of the printing, please select\na vertical range (with the left mouse button down) in one column. "), | 2154 | i18n("Nothing selected!\n\nThis prints the full width of the Agenda view as you see it!\n\nTo determine the vertical range of the printing, please select\na vertical range (with the left mouse button down) in one column. "), |
2167 | i18n("OK"), 0, 0, | 2155 | i18n("OK"), 0, 0, |
2168 | 0, 1 ); | 2156 | 0, 1 ); |
2169 | return; | 2157 | return; |
2170 | } | 2158 | } |
2171 | 2159 | ||
2172 | float dx, dy; | 2160 | float dx, dy; |
2173 | int x,y,w,h; | 2161 | int x,y,w,h; |
2174 | x= 0; | 2162 | x= 0; |
2175 | w= contentsWidth()+2; | 2163 | w= contentsWidth()+2; |
2176 | // h= contentsHeight(); | 2164 | // h= contentsHeight(); |
2177 | y = mGridSpacingY*mStartCellY; | 2165 | y = mGridSpacingY*mStartCellY; |
2178 | h = mGridSpacingY*(mCurrentCellY+1)-y+2; | 2166 | h = mGridSpacingY*(mCurrentCellY+1)-y+2; |
2179 | 2167 | ||
2180 | //return; | 2168 | //return; |
2181 | QPrinter* printer = new QPrinter(); | 2169 | QPrinter* printer = new QPrinter(); |
2182 | if ( !printer->setup()) { | 2170 | if ( !printer->setup()) { |
2183 | delete printer; | 2171 | delete printer; |
2184 | return; | 2172 | return; |
2185 | } | 2173 | } |
2186 | QPainter p( printer ); | 2174 | QPainter p( printer ); |
2187 | QPaintDeviceMetrics m = QPaintDeviceMetrics ( printer ); | 2175 | QPaintDeviceMetrics m = QPaintDeviceMetrics ( printer ); |
2188 | QString date = i18n("Date range: ")+KGlobal::locale()->formatDate( mSelectedDates.first() )+" - "+KGlobal::locale()->formatDate( mSelectedDates.last() ); | 2176 | QString date = i18n("Date range: ")+KGlobal::locale()->formatDate( mSelectedDates.first() )+" - "+KGlobal::locale()->formatDate( mSelectedDates.last() ); |
2189 | //date += " --- printing time: " + KGlobal::locale()->formatDateTime(QDateTime::currentDateTime(), true ); | 2177 | //date += " --- printing time: " + KGlobal::locale()->formatDateTime(QDateTime::currentDateTime(), true ); |
2190 | int hei = p.boundingRect(0,0, 5, 5, Qt::AlignLeft, date ).height(); | 2178 | int hei = p.boundingRect(0,0, 5, 5, Qt::AlignLeft, date ).height(); |
2191 | // p.drawText( 0, 0, date ); | 2179 | // p.drawText( 0, 0, date ); |
2192 | int offset = m.width()/8; | 2180 | int offset = m.width()/8; |
2193 | // compute the scale | 2181 | // compute the scale |
2194 | dx = ((float) m.width()-offset) / (float)w; | 2182 | dx = ((float) m.width()-offset) / (float)w; |
2195 | dy = (float)(m.height() - ( 2 * hei )-offset ) / (float)h; | 2183 | dy = (float)(m.height() - ( 2 * hei )-offset ) / (float)h; |
2196 | float scale; | 2184 | float scale; |
2197 | // scale to fit the width or height of the paper | 2185 | // scale to fit the width or height of the paper |
2198 | if ( dx < dy ) | 2186 | if ( dx < dy ) |
2199 | scale = dx; | 2187 | scale = dx; |
2200 | else | 2188 | else |
2201 | scale = dy; | 2189 | scale = dy; |
2202 | // set the scale | 2190 | // set the scale |
2203 | p.drawText( offset* scale, offset* scale*3/4, date ); | 2191 | p.drawText( offset* scale, offset* scale*3/4, date ); |
2204 | 2192 | ||
2205 | int selDay; | 2193 | int selDay; |
2206 | float widOffset = ((float) m.width()-offset) / ((float)(mSelectedDates.count())); | 2194 | float widOffset = ((float) m.width()-offset) / ((float)(mSelectedDates.count())); |
2207 | float startX = 1; | 2195 | float startX = 1; |
2208 | for ( selDay = 0; selDay < mSelectedDates.count(); ++selDay) | 2196 | for ( selDay = 0; selDay < mSelectedDates.count(); ++selDay) |
2209 | { | 2197 | { |
2210 | QString text = KGlobal::locale()->formatDate( mSelectedDates[selDay],true ); | 2198 | QString text = KGlobal::locale()->formatDate( mSelectedDates[selDay],true ); |
2211 | p.setClipRect(offset* scale+startX , 0, widOffset-4, offset* scale+(2*hei* scale) ); | 2199 | p.setClipRect(offset* scale+startX , 0, widOffset-4, offset* scale+(2*hei* scale) ); |
2212 | p.drawText( offset* scale+startX, (offset+hei)* scale, text ); | 2200 | p.drawText( offset* scale+startX, (offset+hei)* scale, text ); |
2213 | startX += widOffset; | 2201 | startX += widOffset; |
2214 | 2202 | ||
2215 | } | 2203 | } |
2216 | p.translate( offset* scale,offset* scale+ (-y * scale)+(2*hei* scale)); | 2204 | p.translate( offset* scale,offset* scale+ (-y * scale)+(2*hei* scale)); |
2217 | p.scale( scale, scale ); | 2205 | p.scale( scale, scale ); |
2218 | p.setClipRect( offset* scale, offset* scale+(2*hei* scale), w*scale, h*scale ); | 2206 | p.setClipRect( offset* scale, offset* scale+(2*hei* scale), w*scale, h*scale ); |
2219 | // now printing with y offset: 2 hei | 2207 | // now printing with y offset: 2 hei |
2220 | // p.translate( 0, -y*scale); | 2208 | // p.translate( 0, -y*scale); |
2221 | 2209 | ||
2222 | drawContentsToPainter(&p, true ); | 2210 | drawContentsToPainter(&p, true ); |
2223 | globalFlagBlockAgendaItemUpdate = false; | 2211 | globalFlagBlockAgendaItemUpdate = false; |
2224 | KOAgendaItem *item; | 2212 | KOAgendaItem *item; |
2225 | for ( item=mItems.first(); item != 0; item=mItems.next() ) { | 2213 | for ( item=mItems.first(); item != 0; item=mItems.next() ) { |
2226 | item->select(false); | 2214 | item->select(false); |
2227 | item->paintMe( false, &p ); | 2215 | item->paintMe( false, &p ); |
2228 | } | 2216 | } |
2229 | globalFlagBlockAgendaItemUpdate = true; | 2217 | globalFlagBlockAgendaItemUpdate = true; |
2230 | p.end(); | 2218 | p.end(); |
2231 | delete printer; | 2219 | delete printer; |
2232 | #else | 2220 | #else |