-rw-r--r-- | korganizer/koagendaview.cpp | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/korganizer/koagendaview.cpp b/korganizer/koagendaview.cpp index 6428757..b5596d9 100644 --- a/korganizer/koagendaview.cpp +++ b/korganizer/koagendaview.cpp | |||
@@ -109,192 +109,227 @@ void TimeLabels::drawContents(QPainter *p,int cx, int cy, int cw, int ch) | |||
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) | ||
206 | { | ||
207 | mMouseDownY = e->pos().y(); | ||
208 | } | ||
209 | |||
210 | void TimeLabels::contentsMouseMoveEvent ( QMouseEvent * e ) | ||
211 | { | ||
212 | int diff = mMouseDownY - e->pos().y(); | ||
213 | if ( diff < 10 && diff > -10 ) | ||
214 | return; | ||
215 | int tSize = KOPrefs::instance()->mHourSize + (diff/10) ; | ||
216 | if ( tSize < 4 ) | ||
217 | tSize = 4; | ||
218 | if ( tSize > 18 ) | ||
219 | tSize = 18; | ||
220 | tSize = (tSize-2)/2; | ||
221 | topLevelWidget()->setCaption(i18n("New Agendasize: %1").arg(tSize)); | ||
222 | |||
223 | } | ||
224 | void TimeLabels::contentsMouseReleaseEvent ( QMouseEvent * e ) | ||
225 | { | ||
226 | int diff = mMouseDownY - e->pos().y(); | ||
227 | if ( diff < 10 && diff > -10 ) | ||
228 | return; | ||
229 | int tSize = KOPrefs::instance()->mHourSize + (diff/10); | ||
230 | if ( tSize < 4 ) | ||
231 | tSize = 4; | ||
232 | if ( tSize > 18 ) | ||
233 | tSize = 18; | ||
234 | tSize = (tSize/2)*2; | ||
235 | if ( tSize == KOPrefs::instance()->mHourSize ) | ||
236 | return; | ||
237 | KOPrefs::instance()->mHourSize = tSize; | ||
238 | emit scaleChanged(); | ||
239 | } | ||
205 | 240 | ||
206 | /** This is called in response to repaint() */ | 241 | /** This is called in response to repaint() */ |
207 | void TimeLabels::paintEvent(QPaintEvent*) | 242 | void TimeLabels::paintEvent(QPaintEvent*) |
208 | { | 243 | { |
209 | 244 | ||
210 | // kdDebug() << "paintevent..." << endl; | 245 | // kdDebug() << "paintevent..." << endl; |
211 | // this is another hack! | 246 | // this is another hack! |
212 | // QPainter painter(this); | 247 | // QPainter painter(this); |
213 | //QString c | 248 | //QString c |
214 | repaintContents(contentsX(), contentsY(), visibleWidth(), visibleHeight()); | 249 | repaintContents(contentsX(), contentsY(), visibleWidth(), visibleHeight()); |
215 | } | 250 | } |
216 | 251 | ||
217 | //////////////////////////////////////////////////////////////////////////// | 252 | //////////////////////////////////////////////////////////////////////////// |
218 | 253 | ||
219 | EventIndicator::EventIndicator(Location loc,QWidget *parent,const char *name) | 254 | EventIndicator::EventIndicator(Location loc,QWidget *parent,const char *name) |
220 | : QFrame(parent,name) | 255 | : QFrame(parent,name) |
221 | { | 256 | { |
222 | mColumns = 1; | 257 | mColumns = 1; |
223 | mTopBox = 0; | 258 | mTopBox = 0; |
224 | mLocation = loc; | 259 | mLocation = loc; |
225 | mTopLayout = 0; | 260 | mTopLayout = 0; |
226 | mPaintWidget = 0; | 261 | mPaintWidget = 0; |
227 | mXOffset = 0; | 262 | mXOffset = 0; |
228 | if (mLocation == Top) mPixmap = SmallIcon("1uparrow"); | 263 | if (mLocation == Top) mPixmap = SmallIcon("1uparrow"); |
229 | else mPixmap = SmallIcon("1downarrow"); | 264 | else mPixmap = SmallIcon("1downarrow"); |
230 | mEnabled.resize(mColumns); | 265 | mEnabled.resize(mColumns); |
231 | if (mLocation == Top) | 266 | if (mLocation == Top) |
232 | setMaximumHeight(0); | 267 | setMaximumHeight(0); |
233 | else | 268 | else |
234 | setMinimumHeight(mPixmap.height()); | 269 | setMinimumHeight(mPixmap.height()); |
235 | } | 270 | } |
236 | 271 | ||
237 | EventIndicator::~EventIndicator() | 272 | EventIndicator::~EventIndicator() |
238 | { | 273 | { |
239 | } | 274 | } |
240 | 275 | ||
241 | void EventIndicator::drawContents(QPainter *p) | 276 | void EventIndicator::drawContents(QPainter *p) |
242 | { | 277 | { |
243 | 278 | ||
244 | // kdDebug() << "======== top: " << contentsRect().top() << " bottom " << // contentsRect().bottom() << " left " << contentsRect().left() << " right " << contentsRect().right() << endl; | 279 | // kdDebug() << "======== top: " << contentsRect().top() << " bottom " << // contentsRect().bottom() << " left " << contentsRect().left() << " right " << contentsRect().right() << endl; |
245 | KDGanttSplitterHandle* han = 0; | 280 | KDGanttSplitterHandle* han = 0; |
246 | if ( mPaintWidget ) | 281 | if ( mPaintWidget ) |
247 | han = mPaintWidget->firstHandle(); | 282 | han = mPaintWidget->firstHandle(); |
248 | if ( ! han ) { | 283 | if ( ! han ) { |
249 | int i; | 284 | int i; |
250 | for(i=0;i<mColumns;++i) { | 285 | for(i=0;i<mColumns;++i) { |
251 | if (mEnabled[i]) { | 286 | if (mEnabled[i]) { |
252 | int cellWidth = contentsRect().right()/mColumns; | 287 | int cellWidth = contentsRect().right()/mColumns; |
253 | int xOffset = KOGlobals::self()->reverseLayout() ? | 288 | int xOffset = KOGlobals::self()->reverseLayout() ? |
254 | (mColumns - 1 - i)*cellWidth + cellWidth/2 -mPixmap.width()/2 : | 289 | (mColumns - 1 - i)*cellWidth + cellWidth/2 -mPixmap.width()/2 : |
255 | i*cellWidth + cellWidth/2 -mPixmap.width()/2; | 290 | i*cellWidth + cellWidth/2 -mPixmap.width()/2; |
256 | p->drawPixmap(QPoint(xOffset,0),mPixmap); | 291 | p->drawPixmap(QPoint(xOffset,0),mPixmap); |
257 | } | 292 | } |
258 | } | 293 | } |
259 | } else { | 294 | } else { |
260 | han->repaint(); | 295 | han->repaint(); |
261 | //mPaintWidget->setBackgroundColor( red ); | 296 | //mPaintWidget->setBackgroundColor( red ); |
262 | 297 | ||
263 | QPainter pa( han ); | 298 | QPainter pa( han ); |
264 | int i; | 299 | int i; |
265 | bool setColor = false; | 300 | bool setColor = false; |
266 | for(i=0;i<mColumns;++i) { | 301 | for(i=0;i<mColumns;++i) { |
267 | if (mEnabled[i]) { | 302 | if (mEnabled[i]) { |
268 | setColor = true; | 303 | setColor = true; |
269 | 304 | ||
270 | int cellWidth = contentsRect().right()/mColumns; | 305 | int cellWidth = contentsRect().right()/mColumns; |
271 | int xOffset = KOGlobals::self()->reverseLayout() ? | 306 | int xOffset = KOGlobals::self()->reverseLayout() ? |
272 | (mColumns - 1 - i)*cellWidth + cellWidth/2 -mPixmap.width()/2 : | 307 | (mColumns - 1 - i)*cellWidth + cellWidth/2 -mPixmap.width()/2 : |
273 | i*cellWidth + cellWidth/2 -mPixmap.width()/2; | 308 | i*cellWidth + cellWidth/2 -mPixmap.width()/2; |
274 | pa.drawPixmap(QPoint(mXOffset + xOffset,0),mPixmap); | 309 | pa.drawPixmap(QPoint(mXOffset + xOffset,0),mPixmap); |
275 | //qDebug("222draw pix %d ",xOffset ); | 310 | //qDebug("222draw pix %d ",xOffset ); |
276 | 311 | ||
277 | } | 312 | } |
278 | 313 | ||
279 | } | 314 | } |
280 | pa.end(); | 315 | pa.end(); |
281 | 316 | ||
282 | } | 317 | } |
283 | } | 318 | } |
284 | 319 | ||
285 | void EventIndicator::setXOffset( int x ) | 320 | void EventIndicator::setXOffset( int x ) |
286 | { | 321 | { |
287 | mXOffset = x; | 322 | mXOffset = x; |
288 | } | 323 | } |
289 | void EventIndicator::setPaintWidget( KDGanttMinimizeSplitter * w ) | 324 | void EventIndicator::setPaintWidget( KDGanttMinimizeSplitter * w ) |
290 | { | 325 | { |
291 | mPaintWidget = w; | 326 | mPaintWidget = w; |
292 | } | 327 | } |
293 | void EventIndicator::changeColumns(int columns) | 328 | void EventIndicator::changeColumns(int columns) |
294 | { | 329 | { |
295 | mColumns = columns; | 330 | mColumns = columns; |
296 | mEnabled.resize(mColumns); | 331 | mEnabled.resize(mColumns); |
297 | 332 | ||
298 | update(); | 333 | update(); |
299 | } | 334 | } |
300 | 335 | ||
@@ -317,192 +352,194 @@ KOAgendaView::KOAgendaView(Calendar *cal,QWidget *parent,const char *name) : | |||
317 | 352 | ||
318 | mLayoutDayLabels = 0; | 353 | mLayoutDayLabels = 0; |
319 | mDayLabelsFrame = 0; | 354 | mDayLabelsFrame = 0; |
320 | mDayLabels = 0; | 355 | mDayLabels = 0; |
321 | bool isRTL = KOGlobals::self()->reverseLayout(); | 356 | bool isRTL = KOGlobals::self()->reverseLayout(); |
322 | 357 | ||
323 | if ( KOPrefs::instance()->mVerticalScreen ) { | 358 | if ( KOPrefs::instance()->mVerticalScreen ) { |
324 | mExpandedPixmap = SmallIcon( "1downarrow" ); | 359 | mExpandedPixmap = SmallIcon( "1downarrow" ); |
325 | mNotExpandedPixmap = SmallIcon( "1uparrow" ); | 360 | mNotExpandedPixmap = SmallIcon( "1uparrow" ); |
326 | } else { | 361 | } else { |
327 | mExpandedPixmap = SmallIcon( isRTL ? "1leftarrow" : "1rightarrow" ); | 362 | mExpandedPixmap = SmallIcon( isRTL ? "1leftarrow" : "1rightarrow" ); |
328 | mNotExpandedPixmap = SmallIcon( isRTL ? "1rightarrow" : "1leftarrow" ); | 363 | mNotExpandedPixmap = SmallIcon( isRTL ? "1rightarrow" : "1leftarrow" ); |
329 | } | 364 | } |
330 | 365 | ||
331 | QBoxLayout *topLayout = new QVBoxLayout(this); | 366 | QBoxLayout *topLayout = new QVBoxLayout(this); |
332 | 367 | ||
333 | // Create day name labels for agenda columns | 368 | // Create day name labels for agenda columns |
334 | mDayLabelsFrame = new QHBox(this); | 369 | mDayLabelsFrame = new QHBox(this); |
335 | topLayout->addWidget(mDayLabelsFrame); | 370 | topLayout->addWidget(mDayLabelsFrame); |
336 | mDayLabels = new QFrame (mDayLabelsFrame); | 371 | mDayLabels = new QFrame (mDayLabelsFrame); |
337 | mLayoutDayLabels = new QHBoxLayout(mDayLabels); | 372 | mLayoutDayLabels = new QHBoxLayout(mDayLabels); |
338 | // Create agenda splitter | 373 | // Create agenda splitter |
339 | #ifndef KORG_NOSPLITTER | 374 | #ifndef KORG_NOSPLITTER |
340 | mSplitterAgenda = new QSplitter(Vertical,this); | 375 | mSplitterAgenda = new QSplitter(Vertical,this); |
341 | topLayout->addWidget(mSplitterAgenda); | 376 | topLayout->addWidget(mSplitterAgenda); |
342 | mSplitterAgenda->setOpaqueResize(); | 377 | mSplitterAgenda->setOpaqueResize(); |
343 | 378 | ||
344 | mAllDayFrame = new QHBox(mSplitterAgenda); | 379 | mAllDayFrame = new QHBox(mSplitterAgenda); |
345 | 380 | ||
346 | QWidget *agendaFrame = new QWidget(mSplitterAgenda); | 381 | QWidget *agendaFrame = new QWidget(mSplitterAgenda); |
347 | #else | 382 | #else |
348 | #if 0 | 383 | #if 0 |
349 | QWidget *mainBox = new QWidget( this ); | 384 | QWidget *mainBox = new QWidget( this ); |
350 | topLayout->addWidget( mainBox ); | 385 | topLayout->addWidget( mainBox ); |
351 | QBoxLayout *mainLayout = new QVBoxLayout(mainBox); | 386 | QBoxLayout *mainLayout = new QVBoxLayout(mainBox); |
352 | mAllDayFrame = new QHBox(mainBox); | 387 | mAllDayFrame = new QHBox(mainBox); |
353 | mainLayout->addWidget(mAllDayFrame); | 388 | mainLayout->addWidget(mAllDayFrame); |
354 | mainLayout->setStretchFactor( mAllDayFrame, 0 ); | 389 | mainLayout->setStretchFactor( mAllDayFrame, 0 ); |
355 | mAllDayFrame->setFocusPolicy(NoFocus); | 390 | mAllDayFrame->setFocusPolicy(NoFocus); |
356 | QWidget *agendaFrame = new QWidget(mainBox); | 391 | QWidget *agendaFrame = new QWidget(mainBox); |
357 | mainLayout->addWidget(agendaFrame); | 392 | mainLayout->addWidget(agendaFrame); |
358 | mainLayout->setStretchFactor( agendaFrame, 10 ); | 393 | mainLayout->setStretchFactor( agendaFrame, 10 ); |
359 | 394 | ||
360 | agendaFrame->setFocusPolicy(NoFocus); | 395 | agendaFrame->setFocusPolicy(NoFocus); |
361 | #endif | 396 | #endif |
362 | mSplitterAgenda = new KDGanttMinimizeSplitter( Qt::Vertical, this); | 397 | mSplitterAgenda = new KDGanttMinimizeSplitter( Qt::Vertical, this); |
363 | mSplitterAgenda->setMinimizeDirection ( KDGanttMinimizeSplitter::Up ); | 398 | mSplitterAgenda->setMinimizeDirection ( KDGanttMinimizeSplitter::Up ); |
364 | topLayout->addWidget( mSplitterAgenda ); | 399 | topLayout->addWidget( mSplitterAgenda ); |
365 | mAllDayFrame = new QHBox(mSplitterAgenda); | 400 | mAllDayFrame = new QHBox(mSplitterAgenda); |
366 | mAllDayFrame->setFocusPolicy(NoFocus); | 401 | mAllDayFrame->setFocusPolicy(NoFocus); |
367 | QWidget *agendaFrame = new QWidget(mSplitterAgenda); | 402 | QWidget *agendaFrame = new QWidget(mSplitterAgenda); |
368 | agendaFrame->setFocusPolicy(NoFocus); | 403 | agendaFrame->setFocusPolicy(NoFocus); |
369 | 404 | ||
370 | #endif | 405 | #endif |
371 | 406 | ||
372 | // Create all-day agenda widget | 407 | // Create all-day agenda widget |
373 | mDummyAllDayLeft = new QVBox( mAllDayFrame ); | 408 | mDummyAllDayLeft = new QVBox( mAllDayFrame ); |
374 | 409 | ||
375 | mExpandButton = new QPushButton(mDummyAllDayLeft); | 410 | mExpandButton = new QPushButton(mDummyAllDayLeft); |
376 | mExpandButton->setPixmap( mNotExpandedPixmap ); | 411 | mExpandButton->setPixmap( mNotExpandedPixmap ); |
377 | int widebut = mExpandButton->sizeHint().width(); | 412 | int widebut = mExpandButton->sizeHint().width(); |
378 | if ( QApplication::desktop()->width() < 480 ) | 413 | if ( QApplication::desktop()->width() < 480 ) |
379 | widebut = widebut*2; | 414 | widebut = widebut*2; |
380 | else | 415 | else |
381 | widebut = (widebut*3) / 2; | 416 | widebut = (widebut*3) / 2; |
382 | //mExpandButton->setSizePolicy( QSizePolicy( QSizePolicy::Fixed, | 417 | //mExpandButton->setSizePolicy( QSizePolicy( QSizePolicy::Fixed, |
383 | // QSizePolicy::Fixed ) ); | 418 | // QSizePolicy::Fixed ) ); |
384 | mExpandButton->setFixedSize( widebut, widebut); | 419 | mExpandButton->setFixedSize( widebut, widebut); |
385 | connect( mExpandButton, SIGNAL( clicked() ), SIGNAL( toggleExpand() ) ); | 420 | connect( mExpandButton, SIGNAL( clicked() ), SIGNAL( toggleExpand() ) ); |
386 | mExpandButton->setFocusPolicy(NoFocus); | 421 | mExpandButton->setFocusPolicy(NoFocus); |
387 | mAllDayAgenda = new KOAgenda(1,mAllDayFrame); | 422 | mAllDayAgenda = new KOAgenda(1,mAllDayFrame); |
388 | mAllDayAgenda->setFocusPolicy(NoFocus); | 423 | mAllDayAgenda->setFocusPolicy(NoFocus); |
389 | QWidget *dummyAllDayRight = new QWidget(mAllDayFrame); | 424 | QWidget *dummyAllDayRight = new QWidget(mAllDayFrame); |
390 | 425 | ||
391 | // Create event context menu for all day agenda | 426 | // Create event context menu for all day agenda |
392 | mAllDayAgendaPopup = eventPopup(); | 427 | mAllDayAgendaPopup = eventPopup(); |
393 | connect(mAllDayAgenda,SIGNAL(showIncidencePopupSignal(Incidence *)), | 428 | connect(mAllDayAgenda,SIGNAL(showIncidencePopupSignal(Incidence *)), |
394 | mAllDayAgendaPopup,SLOT(showIncidencePopup(Incidence *))); | 429 | mAllDayAgendaPopup,SLOT(showIncidencePopup(Incidence *))); |
395 | 430 | ||
396 | // Create agenda frame | 431 | // Create agenda frame |
397 | QGridLayout *agendaLayout = new QGridLayout(agendaFrame,3,3); | 432 | QGridLayout *agendaLayout = new QGridLayout(agendaFrame,3,3); |
398 | // QHBox *agendaFrame = new QHBox(splitterAgenda); | 433 | // QHBox *agendaFrame = new QHBox(splitterAgenda); |
399 | 434 | ||
400 | // create event indicator bars | 435 | // create event indicator bars |
401 | mEventIndicatorTop = new EventIndicator(EventIndicator::Top,agendaFrame); | 436 | mEventIndicatorTop = new EventIndicator(EventIndicator::Top,agendaFrame); |
402 | agendaLayout->addWidget(mEventIndicatorTop,0,1); | 437 | agendaLayout->addWidget(mEventIndicatorTop,0,1); |
403 | mEventIndicatorTop->setPaintWidget( mSplitterAgenda ); | 438 | mEventIndicatorTop->setPaintWidget( mSplitterAgenda ); |
404 | mEventIndicatorBottom = new EventIndicator(EventIndicator::Bottom, | 439 | mEventIndicatorBottom = new EventIndicator(EventIndicator::Bottom, |
405 | agendaFrame); | 440 | agendaFrame); |
406 | agendaLayout->addWidget(mEventIndicatorBottom,2,1); | 441 | agendaLayout->addWidget(mEventIndicatorBottom,2,1); |
407 | QWidget *dummyAgendaRight = new QWidget(agendaFrame); | 442 | QWidget *dummyAgendaRight = new QWidget(agendaFrame); |
408 | agendaLayout->addWidget(dummyAgendaRight,0,2); | 443 | agendaLayout->addWidget(dummyAgendaRight,0,2); |
409 | 444 | ||
410 | // Create time labels | 445 | // Create time labels |
411 | mTimeLabels = new TimeLabels(24,agendaFrame); | 446 | mTimeLabels = new TimeLabels(24,agendaFrame); |
412 | agendaLayout->addWidget(mTimeLabels,1,0); | 447 | agendaLayout->addWidget(mTimeLabels,1,0); |
448 | connect(mTimeLabels,SIGNAL( scaleChanged()), | ||
449 | this,SLOT(updateConfig())); | ||
413 | 450 | ||
414 | // Create agenda | 451 | // Create agenda |
415 | mAgenda = new KOAgenda(1,96,KOPrefs::instance()->mHourSize,agendaFrame); | 452 | mAgenda = new KOAgenda(1,96,KOPrefs::instance()->mHourSize,agendaFrame); |
416 | agendaLayout->addMultiCellWidget(mAgenda,1,1,1,2); | 453 | agendaLayout->addMultiCellWidget(mAgenda,1,1,1,2); |
417 | agendaLayout->setColStretch(1,1); | 454 | agendaLayout->setColStretch(1,1); |
418 | mAgenda->setFocusPolicy(NoFocus); | 455 | mAgenda->setFocusPolicy(NoFocus); |
419 | // Create event context menu for agenda | 456 | // Create event context menu for agenda |
420 | mAgendaPopup = eventPopup(); | 457 | mAgendaPopup = eventPopup(); |
421 | 458 | ||
422 | mAgendaPopup->addAdditionalItem(QIconSet(SmallIcon("bell")), | 459 | mAgendaPopup->addAdditionalItem(QIconSet(SmallIcon("bell")), |
423 | i18n("Toggle Alarm"),mAgenda, | 460 | i18n("Toggle Alarm"),mAgenda, |
424 | SLOT(popupAlarm()),true); | 461 | SLOT(popupAlarm()),true); |
425 | 462 | ||
426 | 463 | ||
427 | connect(mAgenda,SIGNAL(showIncidencePopupSignal(Incidence *)), | 464 | connect(mAgenda,SIGNAL(showIncidencePopupSignal(Incidence *)), |
428 | mAgendaPopup,SLOT(showIncidencePopup(Incidence *))); | 465 | mAgendaPopup,SLOT(showIncidencePopup(Incidence *))); |
429 | 466 | ||
430 | // make connections between dependent widgets | 467 | // make connections between dependent widgets |
431 | mTimeLabels->setAgenda(mAgenda); | 468 | mTimeLabels->setAgenda(mAgenda); |
432 | 469 | ||
433 | // Update widgets to reflect user preferences | 470 | // Update widgets to reflect user preferences |
434 | // updateConfig(); | 471 | // updateConfig(); |
435 | 472 | ||
436 | // createDayLabels(); | 473 | // createDayLabels(); |
437 | 474 | ||
438 | // these blank widgets make the All Day Event box line up with the agenda | 475 | // these blank widgets make the All Day Event box line up with the agenda |
439 | dummyAllDayRight->setFixedWidth(mAgenda->verticalScrollBar()->width()); | 476 | dummyAllDayRight->setFixedWidth(mAgenda->verticalScrollBar()->width()); |
440 | dummyAgendaRight->setFixedWidth(mAgenda->verticalScrollBar()->width()); | 477 | dummyAgendaRight->setFixedWidth(mAgenda->verticalScrollBar()->width()); |
441 | mDummyAllDayLeft->setFixedWidth(mTimeLabels->width()); | 478 | mDummyAllDayLeft->setFixedWidth(mTimeLabels->width()); |
442 | 479 | ||
443 | // Scrolling | 480 | // Scrolling |
444 | connect(mAgenda->verticalScrollBar(),SIGNAL(valueChanged(int)), | 481 | connect(mAgenda->verticalScrollBar(),SIGNAL(valueChanged(int)), |
445 | mTimeLabels, SLOT(positionChanged())); | 482 | mTimeLabels, SLOT(positionChanged())); |
446 | connect(mTimeLabels->verticalScrollBar(),SIGNAL(valueChanged(int)), | 483 | connect(mTimeLabels->verticalScrollBar(),SIGNAL(valueChanged(int)), |
447 | SLOT(setContentsPos(int))); | 484 | SLOT(setContentsPos(int))); |
448 | 485 | ||
449 | // Create/Show/Edit/Delete Event | 486 | // Create/Show/Edit/Delete Event |
450 | connect(mAgenda,SIGNAL(newEventSignal(int,int)), | 487 | connect(mAgenda,SIGNAL(newEventSignal(int,int)), |
451 | SLOT(newEvent(int,int))); | 488 | SLOT(newEvent(int,int))); |
452 | connect(mAgenda,SIGNAL(newEventSignal(int,int,int,int)), | 489 | connect(mAgenda,SIGNAL(newEventSignal(int,int,int,int)), |
453 | SLOT(newEvent(int,int,int,int))); | 490 | SLOT(newEvent(int,int,int,int))); |
454 | connect(mAllDayAgenda,SIGNAL(newEventSignal(int,int)), | 491 | connect(mAllDayAgenda,SIGNAL(newEventSignal(int,int)), |
455 | SLOT(newEventAllDay(int,int))); | 492 | SLOT(newEventAllDay(int,int))); |
456 | connect(mAllDayAgenda,SIGNAL(newEventSignal(int,int,int,int)), | 493 | connect(mAllDayAgenda,SIGNAL(newEventSignal(int,int,int,int)), |
457 | SLOT(newEventAllDay(int,int))); | 494 | SLOT(newEventAllDay(int,int))); |
458 | connect(mAgenda,SIGNAL(newTimeSpanSignal(int,int,int,int)), | 495 | connect(mAgenda,SIGNAL(newTimeSpanSignal(int,int,int,int)), |
459 | SLOT(newTimeSpanSelected(int,int,int,int))); | 496 | SLOT(newTimeSpanSelected(int,int,int,int))); |
460 | connect(mAllDayAgenda,SIGNAL(newTimeSpanSignal(int,int,int,int)), | 497 | connect(mAllDayAgenda,SIGNAL(newTimeSpanSignal(int,int,int,int)), |
461 | SLOT(newTimeSpanSelectedAllDay(int,int,int,int))); | 498 | SLOT(newTimeSpanSelectedAllDay(int,int,int,int))); |
462 | connect(mAgenda,SIGNAL(newStartSelectSignal()),SLOT(updateView())); | 499 | connect(mAgenda,SIGNAL(newStartSelectSignal()),SLOT(updateView())); |
463 | connect(mAllDayAgenda,SIGNAL(newStartSelectSignal()),SLOT(updateView())); | 500 | connect(mAllDayAgenda,SIGNAL(newStartSelectSignal()),SLOT(updateView())); |
464 | 501 | ||
465 | connect(mAgenda,SIGNAL(editIncidenceSignal(Incidence *)), | 502 | connect(mAgenda,SIGNAL(editIncidenceSignal(Incidence *)), |
466 | SIGNAL(editIncidenceSignal(Incidence *))); | 503 | SIGNAL(editIncidenceSignal(Incidence *))); |
467 | connect(mAllDayAgenda,SIGNAL(editIncidenceSignal(Incidence *)), | 504 | connect(mAllDayAgenda,SIGNAL(editIncidenceSignal(Incidence *)), |
468 | SIGNAL(editIncidenceSignal(Incidence *))); | 505 | SIGNAL(editIncidenceSignal(Incidence *))); |
469 | connect(mAgenda,SIGNAL(showIncidenceSignal(Incidence *)), | 506 | connect(mAgenda,SIGNAL(showIncidenceSignal(Incidence *)), |
470 | SIGNAL(showIncidenceSignal(Incidence *))); | 507 | SIGNAL(showIncidenceSignal(Incidence *))); |
471 | connect(mAllDayAgenda,SIGNAL(showIncidenceSignal(Incidence *)), | 508 | connect(mAllDayAgenda,SIGNAL(showIncidenceSignal(Incidence *)), |
472 | SIGNAL(showIncidenceSignal(Incidence *))); | 509 | SIGNAL(showIncidenceSignal(Incidence *))); |
473 | connect(mAgenda,SIGNAL(deleteIncidenceSignal(Incidence *)), | 510 | connect(mAgenda,SIGNAL(deleteIncidenceSignal(Incidence *)), |
474 | SIGNAL(deleteIncidenceSignal(Incidence *))); | 511 | SIGNAL(deleteIncidenceSignal(Incidence *))); |
475 | connect(mAllDayAgenda,SIGNAL(deleteIncidenceSignal(Incidence *)), | 512 | connect(mAllDayAgenda,SIGNAL(deleteIncidenceSignal(Incidence *)), |
476 | SIGNAL(deleteIncidenceSignal(Incidence *))); | 513 | SIGNAL(deleteIncidenceSignal(Incidence *))); |
477 | 514 | ||
478 | connect(mAgenda,SIGNAL(itemModified(KOAgendaItem *, int )), | 515 | connect(mAgenda,SIGNAL(itemModified(KOAgendaItem *, int )), |
479 | SLOT(updateEventDates(KOAgendaItem *, int ))); | 516 | SLOT(updateEventDates(KOAgendaItem *, int ))); |
480 | connect(mAllDayAgenda,SIGNAL(itemModified(KOAgendaItem *, int )), | 517 | connect(mAllDayAgenda,SIGNAL(itemModified(KOAgendaItem *, int )), |
481 | SLOT(updateEventDates(KOAgendaItem *, int))); | 518 | SLOT(updateEventDates(KOAgendaItem *, int))); |
482 | 519 | ||
483 | // event indicator update | 520 | // event indicator update |
484 | connect(mAgenda,SIGNAL(lowerYChanged(int)), | 521 | connect(mAgenda,SIGNAL(lowerYChanged(int)), |
485 | SLOT(updateEventIndicatorTop(int))); | 522 | SLOT(updateEventIndicatorTop(int))); |
486 | connect(mAgenda,SIGNAL(upperYChanged(int)), | 523 | connect(mAgenda,SIGNAL(upperYChanged(int)), |
487 | SLOT(updateEventIndicatorBottom(int))); | 524 | SLOT(updateEventIndicatorBottom(int))); |
488 | // drag signals | 525 | // drag signals |
489 | /* | 526 | /* |
490 | connect(mAgenda,SIGNAL(startDragSignal(Event *)), | 527 | connect(mAgenda,SIGNAL(startDragSignal(Event *)), |
491 | SLOT(startDrag(Event *))); | 528 | SLOT(startDrag(Event *))); |
492 | connect(mAllDayAgenda,SIGNAL(startDragSignal(Event *)), | 529 | connect(mAllDayAgenda,SIGNAL(startDragSignal(Event *)), |
493 | SLOT(startDrag(Event *))); | 530 | SLOT(startDrag(Event *))); |
494 | */ | 531 | */ |
495 | // synchronize selections | 532 | // synchronize selections |
496 | connect( mAgenda, SIGNAL( incidenceSelected( Incidence * ) ), | 533 | connect( mAgenda, SIGNAL( incidenceSelected( Incidence * ) ), |
497 | mAllDayAgenda, SLOT( deselectItem() ) ); | 534 | mAllDayAgenda, SLOT( deselectItem() ) ); |
498 | connect( mAllDayAgenda, SIGNAL( incidenceSelected( Incidence * ) ), | 535 | connect( mAllDayAgenda, SIGNAL( incidenceSelected( Incidence * ) ), |
499 | mAgenda, SLOT( deselectItem() ) ); | 536 | mAgenda, SLOT( deselectItem() ) ); |
500 | connect( mAgenda, SIGNAL( incidenceSelected( Incidence * ) ), | 537 | connect( mAgenda, SIGNAL( incidenceSelected( Incidence * ) ), |
501 | SIGNAL( incidenceSelected( Incidence * ) ) ); | 538 | SIGNAL( incidenceSelected( Incidence * ) ) ); |
502 | connect( mAllDayAgenda, SIGNAL( incidenceSelected( Incidence * ) ), | 539 | connect( mAllDayAgenda, SIGNAL( incidenceSelected( Incidence * ) ), |
503 | SIGNAL( incidenceSelected( Incidence * ) ) ); | 540 | SIGNAL( incidenceSelected( Incidence * ) ) ); |
504 | connect( mAgenda, SIGNAL( resizedSignal() ), | 541 | connect( mAgenda, SIGNAL( resizedSignal() ), |
505 | SLOT( updateConfig( ) ) ); | 542 | SLOT( updateConfig( ) ) ); |
506 | connect( mAgenda, SIGNAL( addToCalSignal(Incidence *, Incidence *) ), | 543 | connect( mAgenda, SIGNAL( addToCalSignal(Incidence *, Incidence *) ), |
507 | SLOT( addToCalSlot(Incidence *, Incidence * ) ) ); | 544 | SLOT( addToCalSlot(Incidence *, Incidence * ) ) ); |
508 | connect( mAllDayAgenda, SIGNAL( addToCalSignal(Incidence * ,Incidence *) ), | 545 | connect( mAllDayAgenda, SIGNAL( addToCalSignal(Incidence * ,Incidence *) ), |