author | zautrix <zautrix> | 2005-03-24 11:39:34 (UTC) |
---|---|---|
committer | zautrix <zautrix> | 2005-03-24 11:39:34 (UTC) |
commit | a9e8535fd6960f454ab7009cfa996973291502a2 (patch) (unidiff) | |
tree | bcef1497b415a0b1a667c896f1fe7a4d4a764425 | |
parent | b9e83e4536ee4fc34b882fb88b8e5fd00bfdf929 (diff) | |
download | kdepimpi-a9e8535fd6960f454ab7009cfa996973291502a2.zip kdepimpi-a9e8535fd6960f454ab7009cfa996973291502a2.tar.gz kdepimpi-a9e8535fd6960f454ab7009cfa996973291502a2.tar.bz2 |
layout fix
-rw-r--r-- | korganizer/kdatenavigator.cpp | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/korganizer/kdatenavigator.cpp b/korganizer/kdatenavigator.cpp index 1474e4b..d62402f 100644 --- a/korganizer/kdatenavigator.cpp +++ b/korganizer/kdatenavigator.cpp | |||
@@ -1,313 +1,314 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of KOrganizer. | 2 | This file is part of KOrganizer. |
3 | Copyright (c) 2001,2002 Cornelius Schumacher <schumacher@kde.org> | 3 | Copyright (c) 2001,2002 Cornelius Schumacher <schumacher@kde.org> |
4 | 4 | ||
5 | This program is free software; you can redistribute it and/or modify | 5 | This program is free software; you can redistribute it and/or modify |
6 | it under the terms of the GNU General Public License as published by | 6 | it under the terms of the GNU General Public License as published by |
7 | the Free Software Foundation; either version 2 of the License, or | 7 | the Free Software Foundation; either version 2 of the License, or |
8 | (at your option) any later version. | 8 | (at your option) any later version. |
9 | 9 | ||
10 | This program is distributed in the hope that it will be useful, | 10 | This program is distributed in the hope that it will be useful, |
11 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 11 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
13 | GNU General Public License for more details. | 13 | GNU General Public License for more details. |
14 | 14 | ||
15 | You should have received a copy of the GNU General Public License | 15 | You should have received a copy of the GNU General Public License |
16 | along with this program; if not, write to the Free Software | 16 | along with this program; if not, write to the Free Software |
17 | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | 17 | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
18 | 18 | ||
19 | As a special exception, permission is given to link this program | 19 | As a special exception, permission is given to link this program |
20 | with any edition of Qt, and distribute the resulting executable, | 20 | with any edition of Qt, and distribute the resulting executable, |
21 | without including the source code for Qt in the source distribution. | 21 | without including the source code for Qt in the source distribution. |
22 | */ | 22 | */ |
23 | 23 | ||
24 | #include <qstring.h> | 24 | #include <qstring.h> |
25 | #include <qkeycode.h> | 25 | #include <qkeycode.h> |
26 | #include <qlayout.h> | 26 | #include <qlayout.h> |
27 | #include <qtimer.h> | 27 | #include <qtimer.h> |
28 | #include <qframe.h> | 28 | #include <qframe.h> |
29 | #include <qlabel.h> | 29 | #include <qlabel.h> |
30 | #include <qapplication.h> | 30 | #include <qapplication.h> |
31 | 31 | ||
32 | #include <kdebug.h> | 32 | #include <kdebug.h> |
33 | #include <klocale.h> | 33 | #include <klocale.h> |
34 | #include <kglobal.h> | 34 | #include <kglobal.h> |
35 | 35 | ||
36 | #include "koglobals.h" | 36 | #include "koglobals.h" |
37 | #include "koprefs.h" | 37 | #include "koprefs.h" |
38 | #ifndef KORG_NOPLUGINS | 38 | #ifndef KORG_NOPLUGINS |
39 | #include "kocore.h" | 39 | #include "kocore.h" |
40 | #endif | 40 | #endif |
41 | 41 | ||
42 | #include <kcalendarsystem.h> | 42 | #include <kcalendarsystem.h> |
43 | 43 | ||
44 | #include "navigatorbar.h" | 44 | #include "navigatorbar.h" |
45 | 45 | ||
46 | #include "kdatenavigator.h" | 46 | #include "kdatenavigator.h" |
47 | 47 | ||
48 | KDateNavigator::KDateNavigator( QWidget *parent, const char *name ) | 48 | KDateNavigator::KDateNavigator( QWidget *parent, const char *name ) |
49 | : QFrame(parent, name), | 49 | : QFrame(parent, name), |
50 | updateTimer(0L) | 50 | updateTimer(0L) |
51 | { | 51 | { |
52 | setFrameStyle(QFrame::NoFrame); | 52 | setFrameStyle(QFrame::NoFrame); |
53 | QDate startDate = QDate::currentDate(); | 53 | QDate startDate = QDate::currentDate(); |
54 | QGridLayout *topLayout = new QGridLayout(this,8,8); | 54 | QGridLayout *topLayout = new QGridLayout(this,8,8); |
55 | 55 | ||
56 | if (! startDate.isValid()) { | 56 | if (! startDate.isValid()) { |
57 | qDebug("KDateNavigator::invalid startdate "); | 57 | qDebug("KDateNavigator::invalid startdate "); |
58 | startDate = QDate::currentDate(); | 58 | startDate = QDate::currentDate(); |
59 | } | 59 | } |
60 | mMonthSignalOffset = 0; | 60 | mMonthSignalOffset = 0; |
61 | mSelectedDates.append(startDate); | 61 | mSelectedDates.append(startDate); |
62 | m_MthYr = startDate; | 62 | m_MthYr = startDate; |
63 | m_bShowWeekNums = true; | 63 | m_bShowWeekNums = true; |
64 | 64 | ||
65 | setFont( KOPrefs::instance()->mDateNavigatorFont ); | 65 | setFont( KOPrefs::instance()->mDateNavigatorFont ); |
66 | mNavigatorBar = new NavigatorBar( startDate, this ); | 66 | mNavigatorBar = new NavigatorBar( startDate, this ); |
67 | topLayout->addMultiCellWidget( mNavigatorBar, 0, 0, 0, 7 ); | 67 | topLayout->addMultiCellWidget( mNavigatorBar, 0, 0, 0, 7 ); |
68 | //mNavigatorBar->resize( 1,1); | 68 | //mNavigatorBar->resize( 1,1); |
69 | connect( mNavigatorBar, SIGNAL( goPrevYear() ), SIGNAL( goPrevYear() ) ); | 69 | connect( mNavigatorBar, SIGNAL( goPrevYear() ), SIGNAL( goPrevYear() ) ); |
70 | connect( mNavigatorBar, SIGNAL( goPrevMonth() ), SIGNAL( goPrevMonth() ) ); | 70 | connect( mNavigatorBar, SIGNAL( goPrevMonth() ), SIGNAL( goPrevMonth() ) ); |
71 | connect( mNavigatorBar, SIGNAL( goNextMonth() ), SIGNAL( goNextMonth() ) ); | 71 | connect( mNavigatorBar, SIGNAL( goNextMonth() ), SIGNAL( goNextMonth() ) ); |
72 | connect( mNavigatorBar, SIGNAL( goNextYear() ), SIGNAL( goNextYear() ) ); | 72 | connect( mNavigatorBar, SIGNAL( goNextYear() ), SIGNAL( goNextYear() ) ); |
73 | connect( mNavigatorBar, SIGNAL( monthSelected( int ) ), SLOT( slotMonthSelected( int ) ) ); | 73 | connect( mNavigatorBar, SIGNAL( monthSelected( int ) ), SLOT( slotMonthSelected( int ) ) ); |
74 | 74 | ||
75 | // get the day of the week on the first day | 75 | // get the day of the week on the first day |
76 | QDate dayone(m_MthYr.year(), m_MthYr.month(), 1); | 76 | QDate dayone(m_MthYr.year(), m_MthYr.month(), 1); |
77 | m_fstDayOfWk = dayone.dayOfWeek(); | 77 | m_fstDayOfWk = dayone.dayOfWeek(); |
78 | 78 | ||
79 | int i; | 79 | int i; |
80 | 80 | ||
81 | // Set up the heading fields. | 81 | // Set up the heading fields. |
82 | for( i = 0; i < 7; i++ ) { | 82 | for( i = 0; i < 7; i++ ) { |
83 | headings[i] = new QLabel("",this); | 83 | headings[i] = new QLabel("",this); |
84 | //headings[i]->setFont(QFont("Arial", 10, QFont::Bold)); | 84 | //headings[i]->setFont(QFont("Arial", 10, QFont::Bold)); |
85 | headings[i]->setAlignment(AlignCenter); | 85 | headings[i]->setAlignment(AlignCenter); |
86 | headings[i]->installEventFilter(this); | 86 | headings[i]->installEventFilter(this); |
87 | 87 | ||
88 | topLayout->addWidget(headings[i],1,i+1); | 88 | topLayout->addWidget(headings[i],1,i+1); |
89 | } | 89 | } |
90 | 90 | ||
91 | // Create the weeknumber labels | 91 | // Create the weeknumber labels |
92 | for( i = 0; i < 6; i++ ) { | 92 | for( i = 0; i < 6; i++ ) { |
93 | weeknos[i] = new QLabel(this); | 93 | weeknos[i] = new QLabel(this); |
94 | weeknos[i]->setAlignment(AlignCenter); | 94 | weeknos[i]->setAlignment(AlignCenter); |
95 | //weeknos[i]->setFont(QFont("Arial", 10)); | 95 | //weeknos[i]->setFont(QFont("Arial", 10)); |
96 | if(!m_bShowWeekNums) { | 96 | if(!m_bShowWeekNums) { |
97 | weeknos[i]->hide(); | 97 | weeknos[i]->hide(); |
98 | } | 98 | } |
99 | weeknos[i]->installEventFilter(this); | 99 | weeknos[i]->installEventFilter(this); |
100 | 100 | ||
101 | topLayout->addWidget(weeknos[i],i+2,0); | 101 | topLayout->addWidget(weeknos[i],i+2,0); |
102 | } | 102 | } |
103 | 103 | ||
104 | daymatrix = new KODayMatrix( this, "KDateNavigator::DayMatrix"); | 104 | daymatrix = new KODayMatrix( this, "KDateNavigator::DayMatrix"); |
105 | daymatrix->setFrameStyle(QFrame::Panel|QFrame::Sunken); | 105 | daymatrix->setFrameStyle(QFrame::Panel|QFrame::Sunken); |
106 | daymatrix->setLineWidth(1); | 106 | daymatrix->setLineWidth(1); |
107 | 107 | ||
108 | connect( daymatrix, SIGNAL( selected( const KCal::DateList & ) ), | 108 | connect( daymatrix, SIGNAL( selected( const KCal::DateList & ) ), |
109 | SIGNAL( datesSelected( const KCal::DateList & ) ) ); | 109 | SIGNAL( datesSelected( const KCal::DateList & ) ) ); |
110 | 110 | ||
111 | connect( daymatrix, SIGNAL( eventDropped( Event * ) ), | 111 | connect( daymatrix, SIGNAL( eventDropped( Event * ) ), |
112 | SIGNAL( eventDropped( Event * ) ) ); | 112 | SIGNAL( eventDropped( Event * ) ) ); |
113 | 113 | ||
114 | topLayout->addMultiCellWidget(daymatrix,2,7,1,7); | 114 | topLayout->addMultiCellWidget(daymatrix,2,7,1,7); |
115 | 115 | ||
116 | // read settings from configuration file. | 116 | // read settings from configuration file. |
117 | updateConfig(); | 117 | updateConfig(); |
118 | enableRollover(FollowMonth); | 118 | enableRollover(FollowMonth); |
119 | mySizeHint = sizeHintTwoButtons(); | 119 | mySizeHint = sizeHintTwoButtons(); |
120 | myFullSizeHint = sizeHintTwoButtons( 4 ); | 120 | myFullSizeHint = sizeHintTwoButtons( 4 ); |
121 | mFontChanged = false; | 121 | mFontChanged = false; |
122 | resize ( mySizeHint ); | ||
122 | } | 123 | } |
123 | void KDateNavigator::changeFont ( QFont fo ) | 124 | void KDateNavigator::changeFont ( QFont fo ) |
124 | { | 125 | { |
125 | setFont( fo ); | 126 | setFont( fo ); |
126 | mNavigatorBar->resetFont( fo ); | 127 | mNavigatorBar->resetFont( fo ); |
127 | } | 128 | } |
128 | QFont KDateNavigator::yourFontHint( QSize si , bool *b) | 129 | QFont KDateNavigator::yourFontHint( QSize si , bool *b) |
129 | { | 130 | { |
130 | QFont fo = KOPrefs::instance()->mDateNavigatorFont; | 131 | QFont fo = KOPrefs::instance()->mDateNavigatorFont; |
131 | *b = false; | 132 | *b = false; |
132 | int fontPoint = fo.pointSize(); | 133 | int fontPoint = fo.pointSize(); |
133 | while ( fontPoint > 5 ) { | 134 | while ( fontPoint > 5 ) { |
134 | --fontPoint; | 135 | --fontPoint; |
135 | fo.setPointSize( fontPoint ); | 136 | fo.setPointSize( fontPoint ); |
136 | setFont( fo ); | 137 | setFont( fo ); |
137 | mFontChanged = true; | 138 | mFontChanged = true; |
138 | mNavigatorBar->resetFont( fo ); | 139 | mNavigatorBar->resetFont( fo ); |
139 | QSize sh = sizeHintTwoButtons( 2 ); | 140 | QSize sh = sizeHintTwoButtons( 2 ); |
140 | //qDebug("fp %d %d %d %d %d", fontPoint, si.width() , sh.width() , si.height() , sh.height() ); | 141 | //qDebug("fp %d %d %d %d %d", fontPoint, si.width() , sh.width() , si.height() , sh.height() ); |
141 | if ( si.width() > sh.width() && si.height() > sh.height()) { | 142 | if ( si.width() > sh.width() && si.height() > sh.height()) { |
142 | if ( si.width() / sh.width() == 1 ) { | 143 | if ( si.width() / sh.width() == 1 ) { |
143 | if ( si.width() < sizeHintTwoButtons( 4 ).width()) | 144 | if ( si.width() < sizeHintTwoButtons( 4 ).width()) |
144 | continue; | 145 | continue; |
145 | } | 146 | } |
146 | *b = true; | 147 | *b = true; |
147 | //qDebug("fooooooooooooooooooooooouuuuund "); | 148 | //qDebug("fooooooooooooooooooooooouuuuund "); |
148 | break; | 149 | break; |
149 | } | 150 | } |
150 | } | 151 | } |
151 | //qDebug("returnnnnnnnnnnnnnnnnnnn %d", fo.pointSize() ); | 152 | //qDebug("returnnnnnnnnnnnnnnnnnnn %d", fo.pointSize() ); |
152 | return fo; | 153 | return fo; |
153 | } | 154 | } |
154 | QSize KDateNavigator::sizeHint() const | 155 | QSize KDateNavigator::sizeHint() const |
155 | { | 156 | { |
156 | QFontMetrics fm ( font() ); | 157 | QFontMetrics fm ( font() ); |
157 | QSize day = daymatrix->sizeHint(); | 158 | QSize day = daymatrix->sizeHint(); |
158 | QSize nav = mNavigatorBar->sizeHint(); | 159 | QSize nav = mNavigatorBar->sizeHint(); |
159 | int wid = fm.width( "30") + day.width()+3; | 160 | int wid = fm.width( "30") + day.width()+3; |
160 | int hei = fm.height() +day.height()+nav.height()+2; | 161 | int hei = fm.height() +day.height()+nav.height()+2; |
161 | if ( wid < nav.width() ) | 162 | if ( wid < nav.width() ) |
162 | wid = nav.width() ; | 163 | wid = nav.width() ; |
163 | //qDebug("KDateNavigator+++++++++++++ %d %d", wid , hei); | 164 | //qDebug("KDateNavigator+++++++++++++ %d %d", wid , hei); |
164 | return QSize ( wid, hei ); | 165 | return QSize ( wid, hei ); |
165 | } | 166 | } |
166 | QSize KDateNavigator::sizeHintTwoButtons( int butnum ) const | 167 | QSize KDateNavigator::sizeHintTwoButtons( int butnum ) const |
167 | { | 168 | { |
168 | QFontMetrics fm ( font() ); | 169 | QFontMetrics fm ( font() ); |
169 | QSize day = daymatrix->sizeHint(); | 170 | QSize day = daymatrix->sizeHint(); |
170 | QSize nav = mNavigatorBar->sizeHintTwoButtons( butnum ); | 171 | QSize nav = mNavigatorBar->sizeHintTwoButtons( butnum ); |
171 | int wid = fm.width( "30") + day.width()+3; | 172 | int wid = fm.width( "30") + day.width()+3; |
172 | int hei = fm.height() +day.height()+nav.height()+2; | 173 | int hei = fm.height() +day.height()+nav.height()+2; |
173 | if ( wid < nav.width() ) | 174 | if ( wid < nav.width() ) |
174 | wid = nav.width() ; | 175 | wid = nav.width() ; |
175 | //qDebug("KDateNavigator+++++++++++++ %d %d", wid , hei); | 176 | //qDebug("KDateNavigator+++++++++++++ %d %d", wid , hei); |
176 | return QSize ( wid, hei ); | 177 | return QSize ( wid, hei ); |
177 | } | 178 | } |
178 | void KDateNavigator::slotMonthSelected( int m ) | 179 | void KDateNavigator::slotMonthSelected( int m ) |
179 | { | 180 | { |
180 | if ( m_MthYr.month() <= mMonthSignalOffset) | 181 | if ( m_MthYr.month() <= mMonthSignalOffset) |
181 | m += 12; | 182 | m += 12; |
182 | //qDebug("%d mMonthSignalOffset %d emit %d", m, mMonthSignalOffset, m - mMonthSignalOffset); | 183 | //qDebug("%d mMonthSignalOffset %d emit %d", m, mMonthSignalOffset, m - mMonthSignalOffset); |
183 | emit monthSelected( m - mMonthSignalOffset ); | 184 | emit monthSelected( m - mMonthSignalOffset ); |
184 | 185 | ||
185 | } | 186 | } |
186 | void KDateNavigator::setCalendar( Calendar *cal ) | 187 | void KDateNavigator::setCalendar( Calendar *cal ) |
187 | { | 188 | { |
188 | daymatrix->setCalendar( cal ); | 189 | daymatrix->setCalendar( cal ); |
189 | } | 190 | } |
190 | 191 | ||
191 | void KDateNavigator::setBaseDate( const QDate &date , bool doRepaint ) // = true | 192 | void KDateNavigator::setBaseDate( const QDate &date , bool doRepaint ) // = true |
192 | { | 193 | { |
193 | m_MthYr = date; | 194 | m_MthYr = date; |
194 | //qDebug("KDateNavigator::setBaseDate %s ", date.toString().latin1()); | 195 | //qDebug("KDateNavigator::setBaseDate %s ", date.toString().latin1()); |
195 | 196 | ||
196 | updateDates(); | 197 | updateDates(); |
197 | updateView(); | 198 | updateView(); |
198 | 199 | ||
199 | KCal::DateList dates; | 200 | KCal::DateList dates; |
200 | dates.append( date ); | 201 | dates.append( date ); |
201 | mNavigatorBar->selectDates( dates ); | 202 | mNavigatorBar->selectDates( dates ); |
202 | 203 | ||
203 | daymatrix->clearSelection(); | 204 | daymatrix->clearSelection(); |
204 | if ( doRepaint ) | 205 | if ( doRepaint ) |
205 | daymatrix->repaint( false ); | 206 | daymatrix->repaint( false ); |
206 | } | 207 | } |
207 | 208 | ||
208 | void KDateNavigator::enableRollover(RolloverType r) | 209 | void KDateNavigator::enableRollover(RolloverType r) |
209 | { | 210 | { |
210 | switch(r) | 211 | switch(r) |
211 | { | 212 | { |
212 | case None : | 213 | case None : |
213 | if (updateTimer) | 214 | if (updateTimer) |
214 | { | 215 | { |
215 | updateTimer->stop(); | 216 | updateTimer->stop(); |
216 | delete updateTimer; | 217 | delete updateTimer; |
217 | updateTimer=0L; | 218 | updateTimer=0L; |
218 | } | 219 | } |
219 | break; | 220 | break; |
220 | case FollowDay : | 221 | case FollowDay : |
221 | case FollowMonth : | 222 | case FollowMonth : |
222 | if (!updateTimer) | 223 | if (!updateTimer) |
223 | { | 224 | { |
224 | updateTimer = new QTimer(this); | 225 | updateTimer = new QTimer(this); |
225 | QObject::connect(updateTimer,SIGNAL(timeout()), | 226 | QObject::connect(updateTimer,SIGNAL(timeout()), |
226 | this,SLOT(possiblyPastMidnight())); | 227 | this,SLOT(possiblyPastMidnight())); |
227 | } | 228 | } |
228 | updateTimer->start(0,true); | 229 | updateTimer->start(0,true); |
229 | lastDayChecked = QDate::currentDate(); | 230 | lastDayChecked = QDate::currentDate(); |
230 | } | 231 | } |
231 | updateRollover=r; | 232 | updateRollover=r; |
232 | } | 233 | } |
233 | 234 | ||
234 | 235 | ||
235 | KDateNavigator::~KDateNavigator() | 236 | KDateNavigator::~KDateNavigator() |
236 | { | 237 | { |
237 | } | 238 | } |
238 | 239 | ||
239 | 240 | ||
240 | void KDateNavigator::passedMidnight() | 241 | void KDateNavigator::passedMidnight() |
241 | { | 242 | { |
242 | QDate today = QDate::currentDate(); | 243 | QDate today = QDate::currentDate(); |
243 | bool emitMonth = false; | 244 | bool emitMonth = false; |
244 | 245 | ||
245 | if (today.month() != lastDayChecked.month()) | 246 | if (today.month() != lastDayChecked.month()) |
246 | { | 247 | { |
247 | if (updateRollover==FollowMonth && | 248 | if (updateRollover==FollowMonth && |
248 | daymatrix->isEndOfMonth()) { | 249 | daymatrix->isEndOfMonth()) { |
249 | goNextMonth(); | 250 | goNextMonth(); |
250 | emitMonth=true; | 251 | emitMonth=true; |
251 | } | 252 | } |
252 | } | 253 | } |
253 | daymatrix->recalculateToday(); | 254 | daymatrix->recalculateToday(); |
254 | daymatrix->repaint( false ); | 255 | daymatrix->repaint( false ); |
255 | emit dayPassed(today); | 256 | emit dayPassed(today); |
256 | if (emitMonth) { emit monthPassed(today); } | 257 | if (emitMonth) { emit monthPassed(today); } |
257 | } | 258 | } |
258 | 259 | ||
259 | /* slot */ void KDateNavigator::possiblyPastMidnight() | 260 | /* slot */ void KDateNavigator::possiblyPastMidnight() |
260 | { | 261 | { |
261 | if (lastDayChecked!=QDate::currentDate()) | 262 | if (lastDayChecked!=QDate::currentDate()) |
262 | { | 263 | { |
263 | passedMidnight(); | 264 | passedMidnight(); |
264 | lastDayChecked=QDate::currentDate(); | 265 | lastDayChecked=QDate::currentDate(); |
265 | } | 266 | } |
266 | // Set the timer to go off 1 second after midnight | 267 | // Set the timer to go off 1 second after midnight |
267 | // or after 8 minutes, whichever comes first. | 268 | // or after 8 minutes, whichever comes first. |
268 | if (updateTimer) | 269 | if (updateTimer) |
269 | { | 270 | { |
270 | QTime now = QTime::currentTime(); | 271 | QTime now = QTime::currentTime(); |
271 | QTime midnight = QTime(23,59,59); | 272 | QTime midnight = QTime(23,59,59); |
272 | int msecsWait = QMIN(480000,now.msecsTo(midnight)+2000); | 273 | int msecsWait = QMIN(480000,now.msecsTo(midnight)+2000); |
273 | 274 | ||
274 | // qDebug(QString("Waiting %1 msec from %2 to %3.").arg(msecsWait)) | 275 | // qDebug(QString("Waiting %1 msec from %2 to %3.").arg(msecsWait)) |
275 | //.arg(now.toString()).arg(midnight.toString())); | 276 | //.arg(now.toString()).arg(midnight.toString())); |
276 | 277 | ||
277 | updateTimer->stop(); | 278 | updateTimer->stop(); |
278 | updateTimer->start(msecsWait,true); | 279 | updateTimer->start(msecsWait,true); |
279 | } | 280 | } |
280 | } | 281 | } |
281 | 282 | ||
282 | void KDateNavigator::updateDates() | 283 | void KDateNavigator::updateDates() |
283 | { | 284 | { |
284 | // Find the first day of the week of the current month. | 285 | // Find the first day of the week of the current month. |
285 | //int d1 = KOGlobals::self()->calendarSystem()->day( m_MthYr ); | 286 | //int d1 = KOGlobals::self()->calendarSystem()->day( m_MthYr ); |
286 | QDate dayone( m_MthYr.year(), m_MthYr.month(), m_MthYr.day() ); | 287 | QDate dayone( m_MthYr.year(), m_MthYr.month(), m_MthYr.day() ); |
287 | int d2 = KOGlobals::self()->calendarSystem()->day( dayone ); | 288 | int d2 = KOGlobals::self()->calendarSystem()->day( dayone ); |
288 | //int di = d1 - d2 + 1; | 289 | //int di = d1 - d2 + 1; |
289 | dayone = dayone.addDays( -d2 + 1 ); | 290 | dayone = dayone.addDays( -d2 + 1 ); |
290 | 291 | ||
291 | int m_fstDayOfWkCalsys = KOGlobals::self()->calendarSystem()->dayOfWeek( dayone ); | 292 | int m_fstDayOfWkCalsys = KOGlobals::self()->calendarSystem()->dayOfWeek( dayone ); |
292 | 293 | ||
293 | // If month begins on Monday and Monday is first day of week, | 294 | // If month begins on Monday and Monday is first day of week, |
294 | // month should begin on second line. Sunday doesn't have this problem. | 295 | // month should begin on second line. Sunday doesn't have this problem. |
295 | int nextLine = ( ( m_fstDayOfWkCalsys == 1) && | 296 | int nextLine = ( ( m_fstDayOfWkCalsys == 1) && |
296 | ( KGlobal::locale()->weekStartsMonday() == 1 ) ) ? 7 : 0; | 297 | ( KGlobal::locale()->weekStartsMonday() == 1 ) ) ? 7 : 0; |
297 | 298 | ||
298 | // update the matrix dates | 299 | // update the matrix dates |
299 | int index = (KGlobal::locale()->weekStartsMonday() ? 1 : 0) - m_fstDayOfWkCalsys - nextLine; | 300 | int index = (KGlobal::locale()->weekStartsMonday() ? 1 : 0) - m_fstDayOfWkCalsys - nextLine; |
300 | 301 | ||
301 | 302 | ||
302 | daymatrix->updateView(dayone.addDays(index)); | 303 | daymatrix->updateView(dayone.addDays(index)); |
303 | //each updateDates is followed by an updateView -> repaint is issued there ! | 304 | //each updateDates is followed by an updateView -> repaint is issued there ! |
304 | // daymatrix->repaint(); | 305 | // daymatrix->repaint(); |
305 | } | 306 | } |
306 | 307 | ||
307 | void KDateNavigator::updateDayMatrix() | 308 | void KDateNavigator::updateDayMatrix() |
308 | { | 309 | { |
309 | daymatrix->updateView(); | 310 | daymatrix->updateView(); |
310 | //daymatrix->repaint(); | 311 | //daymatrix->repaint(); |
311 | } | 312 | } |
312 | 313 | ||
313 | 314 | ||