-rw-r--r-- | korganizer/komonthview.cpp | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/korganizer/komonthview.cpp b/korganizer/komonthview.cpp index 004ff50..cb69832 100644 --- a/korganizer/komonthview.cpp +++ b/korganizer/komonthview.cpp | |||
@@ -1007,548 +1007,557 @@ KOMonthView::KOMonthView(Calendar *calendar, QWidget *parent, const char *name) | |||
1007 | mWidStack->raiseWidget( mWeekView ); | 1007 | mWidStack->raiseWidget( mWeekView ); |
1008 | else | 1008 | else |
1009 | mWidStack->raiseWidget( mMonthView ); | 1009 | mWidStack->raiseWidget( mMonthView ); |
1010 | } | 1010 | } |
1011 | 1011 | ||
1012 | KOMonthView::~KOMonthView() | 1012 | KOMonthView::~KOMonthView() |
1013 | { | 1013 | { |
1014 | delete mContextMenu; | 1014 | delete mContextMenu; |
1015 | } | 1015 | } |
1016 | 1016 | ||
1017 | void KOMonthView::selectInternalWeekNum ( int n ) | 1017 | void KOMonthView::selectInternalWeekNum ( int n ) |
1018 | { | 1018 | { |
1019 | switchView(); | 1019 | switchView(); |
1020 | if ( !KOPrefs::instance()->mMonthViewWeek ) | 1020 | if ( !KOPrefs::instance()->mMonthViewWeek ) |
1021 | emit selectMonth (); | 1021 | emit selectMonth (); |
1022 | else | 1022 | else |
1023 | emit selectWeekNum ( n ); | 1023 | emit selectWeekNum ( n ); |
1024 | } | 1024 | } |
1025 | 1025 | ||
1026 | int KOMonthView::currentWeek() | 1026 | int KOMonthView::currentWeek() |
1027 | { | 1027 | { |
1028 | if ( mShowWeekView ) | 1028 | if ( mShowWeekView ) |
1029 | return mWeekLabelsW[0]->getWeekNum(); | 1029 | return mWeekLabelsW[0]->getWeekNum(); |
1030 | return mWeekLabels[0]->getWeekNum(); | 1030 | return mWeekLabels[0]->getWeekNum(); |
1031 | } | 1031 | } |
1032 | void KOMonthView::switchView() | 1032 | void KOMonthView::switchView() |
1033 | { | 1033 | { |
1034 | if ( selectedCell( ) ) | 1034 | if ( selectedCell( ) ) |
1035 | selectedCell()->deselect(); | 1035 | selectedCell()->deselect(); |
1036 | mShowWeekView = !mShowWeekView; | 1036 | mShowWeekView = !mShowWeekView; |
1037 | KOPrefs::instance()->mMonthViewWeek = mShowWeekView; | 1037 | KOPrefs::instance()->mMonthViewWeek = mShowWeekView; |
1038 | if ( clPending ) { | 1038 | if ( clPending ) { |
1039 | computeLayout(); | 1039 | computeLayout(); |
1040 | updateConfig(); | 1040 | updateConfig(); |
1041 | } | 1041 | } |
1042 | if ( mShowWeekView ) | 1042 | if ( mShowWeekView ) |
1043 | mWidStack->raiseWidget( mWeekView ); | 1043 | mWidStack->raiseWidget( mWeekView ); |
1044 | else | 1044 | else |
1045 | mWidStack->raiseWidget( mMonthView ); | 1045 | mWidStack->raiseWidget( mMonthView ); |
1046 | clPending = false; | 1046 | clPending = false; |
1047 | } | 1047 | } |
1048 | 1048 | ||
1049 | int KOMonthView::maxDatesHint() | 1049 | int KOMonthView::maxDatesHint() |
1050 | { | 1050 | { |
1051 | return mNumCells; | 1051 | return mNumCells; |
1052 | } | 1052 | } |
1053 | 1053 | ||
1054 | int KOMonthView::currentDateCount() | 1054 | int KOMonthView::currentDateCount() |
1055 | { | 1055 | { |
1056 | return mNumCells; | 1056 | return mNumCells; |
1057 | } | 1057 | } |
1058 | 1058 | ||
1059 | QPtrList<Incidence> KOMonthView::selectedIncidences() | 1059 | QPtrList<Incidence> KOMonthView::selectedIncidences() |
1060 | { | 1060 | { |
1061 | QPtrList<Incidence> selected; | 1061 | QPtrList<Incidence> selected; |
1062 | 1062 | ||
1063 | if ( mSelectedCell ) { | 1063 | if ( mSelectedCell ) { |
1064 | Incidence *incidence = mSelectedCell->selectedIncidence(); | 1064 | Incidence *incidence = mSelectedCell->selectedIncidence(); |
1065 | if ( incidence ) selected.append( incidence ); | 1065 | if ( incidence ) selected.append( incidence ); |
1066 | } | 1066 | } |
1067 | 1067 | ||
1068 | return selected; | 1068 | return selected; |
1069 | } | 1069 | } |
1070 | 1070 | ||
1071 | DateList KOMonthView::selectedDates() | 1071 | DateList KOMonthView::selectedDates() |
1072 | { | 1072 | { |
1073 | DateList selected; | 1073 | DateList selected; |
1074 | 1074 | ||
1075 | if ( mSelectedCell ) { | 1075 | if ( mSelectedCell ) { |
1076 | QDate qd = mSelectedCell->selectedIncidenceDate(); | 1076 | QDate qd = mSelectedCell->selectedIncidenceDate(); |
1077 | if ( qd.isValid() ) selected.append( qd ); | 1077 | if ( qd.isValid() ) selected.append( qd ); |
1078 | } | 1078 | } |
1079 | 1079 | ||
1080 | return selected; | 1080 | return selected; |
1081 | } | 1081 | } |
1082 | 1082 | ||
1083 | void KOMonthView::printPreview(CalPrinter *calPrinter, const QDate &fd, | 1083 | void KOMonthView::printPreview(CalPrinter *calPrinter, const QDate &fd, |
1084 | const QDate &td) | 1084 | const QDate &td) |
1085 | { | 1085 | { |
1086 | #ifndef KORG_NOPRINTER | 1086 | #ifndef KORG_NOPRINTER |
1087 | calPrinter->preview(CalPrinter::Month, fd, td); | 1087 | calPrinter->preview(CalPrinter::Month, fd, td); |
1088 | #endif | 1088 | #endif |
1089 | } | 1089 | } |
1090 | 1090 | ||
1091 | void KOMonthView::updateConfig() | 1091 | void KOMonthView::updateConfig() |
1092 | { | 1092 | { |
1093 | 1093 | ||
1094 | mWeekStartsMonday = KGlobal::locale()->weekStartsMonday(); | 1094 | mWeekStartsMonday = KGlobal::locale()->weekStartsMonday(); |
1095 | 1095 | ||
1096 | if ( mShowWeekView ) { | 1096 | if ( mShowWeekView ) { |
1097 | mWeekStartsMonday = true; | 1097 | mWeekStartsMonday = true; |
1098 | } | 1098 | } |
1099 | QFontMetrics fontmetric(mDayLabels[0]->font()); | 1099 | QFontMetrics fontmetric(mDayLabels[0]->font()); |
1100 | mWidthLongDayLabel = 0; | 1100 | mWidthLongDayLabel = 0; |
1101 | 1101 | ||
1102 | for (int i = 0; i < 7; i++) { | 1102 | for (int i = 0; i < 7; i++) { |
1103 | int width = fontmetric.width(KOGlobals::self()->calendarSystem()->weekDayName(i+1)); | 1103 | int width = fontmetric.width(KOGlobals::self()->calendarSystem()->weekDayName(i+1)); |
1104 | if ( width > mWidthLongDayLabel ) mWidthLongDayLabel = width; | 1104 | if ( width > mWidthLongDayLabel ) mWidthLongDayLabel = width; |
1105 | } | 1105 | } |
1106 | bool temp = mShowSatSunComp ; | 1106 | bool temp = mShowSatSunComp ; |
1107 | mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ; | 1107 | mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ; |
1108 | if ( ! mShowWeekView ) { | 1108 | if ( ! mShowWeekView ) { |
1109 | if ( temp != KOPrefs::instance()->mMonthViewSatSunTog ) | 1109 | if ( temp != KOPrefs::instance()->mMonthViewSatSunTog ) |
1110 | computeLayout(); | 1110 | computeLayout(); |
1111 | } | 1111 | } |
1112 | updateDayLabels(); | 1112 | updateDayLabels(); |
1113 | //qDebug("KOMonthView::updateConfig() %d %d %d ",height(), mDayLabels[0]->sizeHint().height() ,mNumWeeks); | 1113 | //qDebug("KOMonthView::updateConfig() %d %d %d ",height(), mDayLabels[0]->sizeHint().height() ,mNumWeeks); |
1114 | //int cellHeight = (height() - mDayLabels[0]->sizeHint().height()) /mNumWeeks; | 1114 | //int cellHeight = (height() - mDayLabels[0]->sizeHint().height()) /mNumWeeks; |
1115 | //resizeEvent( 0 ); | 1115 | //resizeEvent( 0 ); |
1116 | for (uint i = 0; i < mCells.count(); ++i) { | 1116 | for (uint i = 0; i < mCells.count(); ++i) { |
1117 | mCells[i]->updateConfig(); | 1117 | mCells[i]->updateConfig(); |
1118 | } | 1118 | } |
1119 | 1119 | ||
1120 | for (uint i = 0; i < mCellsW.count(); ++i) { | 1120 | for (uint i = 0; i < mCellsW.count(); ++i) { |
1121 | mCellsW[i]->updateConfig(KOPrefs::instance()->mMonthViewUsesBigFont); | 1121 | mCellsW[i]->updateConfig(KOPrefs::instance()->mMonthViewUsesBigFont); |
1122 | } | 1122 | } |
1123 | #ifdef DESKTOP_VERSION | 1123 | #ifdef DESKTOP_VERSION |
1124 | MonthViewCell::toolTipGroup()->setEnabled(KOPrefs::instance()->mEnableToolTips); | 1124 | MonthViewCell::toolTipGroup()->setEnabled(KOPrefs::instance()->mEnableToolTips); |
1125 | #endif | 1125 | #endif |
1126 | updateView(); | 1126 | updateView(); |
1127 | } | 1127 | } |
1128 | 1128 | ||
1129 | void KOMonthView::updateDayLabels() | 1129 | void KOMonthView::updateDayLabels() |
1130 | { | 1130 | { |
1131 | 1131 | ||
1132 | QPtrVector<QLabel> *mDayLabelsT; | 1132 | QPtrVector<QLabel> *mDayLabelsT; |
1133 | 1133 | ||
1134 | mDayLabelsT = &mDayLabelsW; | 1134 | mDayLabelsT = &mDayLabelsW; |
1135 | for (int i = 0; i < 7; i++) { | 1135 | for (int i = 0; i < 7; i++) { |
1136 | if (mWeekStartsMonday) { | 1136 | if (mWeekStartsMonday) { |
1137 | bool show = mShortDayLabelsW; | 1137 | bool show = mShortDayLabelsW; |
1138 | if ( i > 4 && mShowSatSunComp && mWidthLongDayLabel > (*mDayLabelsT)[i]->width() ) | 1138 | if ( i > 4 && mShowSatSunComp && mWidthLongDayLabel > (*mDayLabelsT)[i]->width() ) |
1139 | show = true; | 1139 | show = true; |
1140 | (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i+1,show)); | 1140 | (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i+1,show)); |
1141 | } else { | 1141 | } else { |
1142 | if (i==0) (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(7,mShortDayLabelsW)); | 1142 | if (i==0) (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(7,mShortDayLabelsW)); |
1143 | else (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i,mShortDayLabelsW)); | 1143 | else (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i,mShortDayLabelsW)); |
1144 | 1144 | ||
1145 | } | 1145 | } |
1146 | } | 1146 | } |
1147 | mDayLabelsT = &mDayLabels; | 1147 | mDayLabelsT = &mDayLabels; |
1148 | for (int i = 0; i < 7; i++) { | 1148 | for (int i = 0; i < 7; i++) { |
1149 | if (mWeekStartsMonday) { | 1149 | if (mWeekStartsMonday) { |
1150 | bool show = mShortDayLabelsM; | 1150 | bool show = mShortDayLabelsM; |
1151 | if ( i > 4 && mShowSatSunComp && mWidthLongDayLabel > (*mDayLabelsT)[i]->width() ) | 1151 | if ( i > 4 && mShowSatSunComp && mWidthLongDayLabel > (*mDayLabelsT)[i]->width() ) |
1152 | show = true; | 1152 | show = true; |
1153 | (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i+1,show)); | 1153 | (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i+1,show)); |
1154 | } else { | 1154 | } else { |
1155 | if (i==0) (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(7,mShortDayLabelsM)); | 1155 | if (i==0) (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(7,mShortDayLabelsM)); |
1156 | else (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i,mShortDayLabelsM)); | 1156 | else (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i,mShortDayLabelsM)); |
1157 | 1157 | ||
1158 | } | 1158 | } |
1159 | } | 1159 | } |
1160 | 1160 | ||
1161 | } | 1161 | } |
1162 | 1162 | ||
1163 | void KOMonthView::showDates(const QDate &start, const QDate &) | 1163 | void KOMonthView::showDates(const QDate &start, const QDate &) |
1164 | { | 1164 | { |
1165 | // kdDebug() << "KOMonthView::showDates(): " << start.toString() << endl; | 1165 | // kdDebug() << "KOMonthView::showDates(): " << start.toString() << endl; |
1166 | 1166 | ||
1167 | QPtrVector<MonthViewCell> *cells; | 1167 | QPtrVector<MonthViewCell> *cells; |
1168 | QPtrVector<QLabel> *dayLabels; | 1168 | QPtrVector<QLabel> *dayLabels; |
1169 | QPtrVector<KOWeekButton> *weekLabels; | 1169 | QPtrVector<KOWeekButton> *weekLabels; |
1170 | int weekNum = 6; | 1170 | int weekNum = 6; |
1171 | if ( mShowWeekView ) { | 1171 | if ( mShowWeekView ) { |
1172 | weekNum = 1; | 1172 | weekNum = 1; |
1173 | cells = &mCellsW; | 1173 | cells = &mCellsW; |
1174 | dayLabels = &mDayLabelsW; | 1174 | dayLabels = &mDayLabelsW; |
1175 | weekLabels = &mWeekLabelsW; | 1175 | weekLabels = &mWeekLabelsW; |
1176 | } else { | 1176 | } else { |
1177 | cells = &mCells; | 1177 | cells = &mCells; |
1178 | dayLabels = &mDayLabels; | 1178 | dayLabels = &mDayLabels; |
1179 | weekLabels = &mWeekLabels; | 1179 | weekLabels = &mWeekLabels; |
1180 | } | 1180 | } |
1181 | 1181 | ||
1182 | mStartDate = start; | 1182 | mStartDate = start; |
1183 | 1183 | ||
1184 | int startWeekDay = mWeekStartsMonday ? 1 : 7; | 1184 | int startWeekDay = mWeekStartsMonday ? 1 : 7; |
1185 | 1185 | ||
1186 | while( KOGlobals::self()->calendarSystem()->dayOfWeek(mStartDate) != startWeekDay ) { | 1186 | while( KOGlobals::self()->calendarSystem()->dayOfWeek(mStartDate) != startWeekDay ) { |
1187 | mStartDate = mStartDate.addDays( -1 ); | 1187 | mStartDate = mStartDate.addDays( -1 ); |
1188 | } | 1188 | } |
1189 | 1189 | ||
1190 | bool primary = false; | 1190 | bool primary = false; |
1191 | uint i; | 1191 | uint i; |
1192 | for( i = 0; i < (*cells).size(); ++i ) { | 1192 | for( i = 0; i < (*cells).size(); ++i ) { |
1193 | QDate date = mStartDate.addDays( i ); | 1193 | QDate date = mStartDate.addDays( i ); |
1194 | (*cells)[i]->setDate( date ); | 1194 | (*cells)[i]->setDate( date ); |
1195 | 1195 | ||
1196 | #ifndef KORG_NOPLUGINS | 1196 | #ifndef KORG_NOPLUGINS |
1197 | // add holiday, if present | 1197 | // add holiday, if present |
1198 | QString hstring(KOCore::self()->holiday(date)); | 1198 | QString hstring(KOCore::self()->holiday(date)); |
1199 | (*cells)[i]->setHoliday( hstring ); | 1199 | (*cells)[i]->setHoliday( hstring ); |
1200 | #endif | 1200 | #endif |
1201 | 1201 | ||
1202 | } | 1202 | } |
1203 | QDate date = mStartDate.addDays( mWeekStartsMonday ? 3 : 4 ); | 1203 | QDate date = mStartDate.addDays( mWeekStartsMonday ? 3 : 4 ); |
1204 | for( i = 0; i < weekNum; ++i ) { | 1204 | for( i = 0; i < weekNum; ++i ) { |
1205 | int wno; | 1205 | int wno; |
1206 | // remember, according to ISO 8601, the first week of the year is the | 1206 | // remember, according to ISO 8601, the first week of the year is the |
1207 | // first week that contains a thursday. Thus we must subtract off 4, | 1207 | // first week that contains a thursday. Thus we must subtract off 4, |
1208 | // not just 1. | 1208 | // not just 1. |
1209 | int dayOfYear = date.dayOfYear(); | 1209 | int dayOfYear = date.dayOfYear(); |
1210 | if (dayOfYear % 7 != 0) | 1210 | if (dayOfYear % 7 != 0) |
1211 | wno = dayOfYear / 7 + 1; | 1211 | wno = dayOfYear / 7 + 1; |
1212 | else | 1212 | else |
1213 | wno =dayOfYear / 7; | 1213 | wno =dayOfYear / 7; |
1214 | (*weekLabels)[i]->setWeekNum( wno ); | 1214 | (*weekLabels)[i]->setWeekNum( wno ); |
1215 | date = date.addDays( 7 ); | 1215 | date = date.addDays( 7 ); |
1216 | } | 1216 | } |
1217 | updateView(); | 1217 | updateView(); |
1218 | } | 1218 | } |
1219 | 1219 | ||
1220 | void KOMonthView::showEvents(QPtrList<Event>) | 1220 | void KOMonthView::showEvents(QPtrList<Event>) |
1221 | { | 1221 | { |
1222 | qDebug("KOMonthView::selectEvents is not implemented yet. "); | 1222 | qDebug("KOMonthView::selectEvents is not implemented yet. "); |
1223 | } | 1223 | } |
1224 | 1224 | ||
1225 | void KOMonthView::changeEventDisplay(Event *, int) | 1225 | void KOMonthView::changeEventDisplay(Event *, int) |
1226 | { | 1226 | { |
1227 | // this should be re-written to be much more efficient, but this | 1227 | // this should be re-written to be much more efficient, but this |
1228 | // quick-and-dirty-hack gets the job done for right now. | 1228 | // quick-and-dirty-hack gets the job done for right now. |
1229 | updateView(); | 1229 | updateView(); |
1230 | } | 1230 | } |
1231 | 1231 | ||
1232 | void KOMonthView::updateView() | 1232 | void KOMonthView::updateView() |
1233 | { | 1233 | { |
1234 | 1234 | ||
1235 | if ( !updatePossible ) | 1235 | if ( !updatePossible ) |
1236 | return; | 1236 | return; |
1237 | //QTime ti; | 1237 | //QTime ti; |
1238 | //ti.start(); | 1238 | //ti.start(); |
1239 | clearSelection(); | 1239 | clearSelection(); |
1240 | QPtrVector<MonthViewCell> *cells; | 1240 | QPtrVector<MonthViewCell> *cells; |
1241 | if ( mShowWeekView ) { | 1241 | if ( mShowWeekView ) { |
1242 | cells = &mCellsW; | 1242 | cells = &mCellsW; |
1243 | } else { | 1243 | } else { |
1244 | cells = &mCells; | 1244 | cells = &mCells; |
1245 | } | 1245 | } |
1246 | #if 1 | 1246 | #if 1 |
1247 | int i; | 1247 | int i; |
1248 | int timeSpan = (*cells).size()-1; | 1248 | int timeSpan = (*cells).size()-1; |
1249 | if ( KOPrefs::instance()->mMonthViewWeek ) | 1249 | if ( KOPrefs::instance()->mMonthViewWeek ) |
1250 | timeSpan = 6; | 1250 | timeSpan = 6; |
1251 | for( i = 0; i < timeSpan + 1; ++i ) { | 1251 | for( i = 0; i < timeSpan + 1; ++i ) { |
1252 | (*cells)[i]->startUpdateCell(); | 1252 | (*cells)[i]->startUpdateCell(); |
1253 | } | 1253 | } |
1254 | 1254 | ||
1255 | QPtrList<Event> events = calendar()->events(); | 1255 | QPtrList<Event> events = calendar()->events(); |
1256 | Event *event; | 1256 | Event *event; |
1257 | QDateTime dt; | 1257 | QDateTime dt; |
1258 | bool ok; | 1258 | bool ok; |
1259 | QDate endDate = mStartDate.addDays( timeSpan ); | 1259 | QDate endDate = mStartDate.addDays( timeSpan ); |
1260 | for( event = events.first(); event; event = events.next() ) { // for event | 1260 | for( event = events.first(); event; event = events.next() ) { // for event |
1261 | if ( event->doesRecur() ) { | 1261 | if ( event->doesRecur() ) { |
1262 | bool last; | 1262 | bool last; |
1263 | qDebug("********************************************** "); | ||
1264 | qDebug("Event summary: %s ", event->summary().latin1()); | ||
1263 | QDateTime incidenceStart = event->recurrence()->getPreviousDateTime( QDateTime( mStartDate ) , &last ); | 1265 | QDateTime incidenceStart = event->recurrence()->getPreviousDateTime( QDateTime( mStartDate ) , &last ); |
1264 | QDateTime incidenceEnd; | 1266 | QDateTime incidenceEnd; |
1265 | int eventlen = event->dtStart().date().daysTo ( event->dtEnd().date() ); | 1267 | int eventlen = event->dtStart().date().daysTo ( event->dtEnd().date() ); |
1268 | qDebug("eventlen %d ", eventlen); | ||
1266 | bool invalid = false; | 1269 | bool invalid = false; |
1267 | while( true ) { | 1270 | while( true ) { |
1268 | if ( incidenceStart.isValid() ) { | 1271 | if ( incidenceStart.isValid() ) { |
1269 | incidenceEnd = incidenceStart.addDays( eventlen ); | 1272 | incidenceEnd = incidenceStart.addDays( eventlen ); |
1270 | int st = incidenceStart.date().daysTo( endDate ); | 1273 | int st = incidenceStart.date().daysTo( endDate ); |
1271 | if ( st >= 0 ) { // start before timeend | 1274 | if ( st >= 0 ) { // start before timeend |
1272 | int end = mStartDate.daysTo( incidenceEnd.date() ); | 1275 | int end = mStartDate.daysTo( incidenceEnd.date() ); |
1273 | if ( end >= 0 ) { // end after timestart --- got one! | 1276 | if ( end >= 0 ) { // end after timestart --- got one! |
1274 | //normalize | 1277 | //normalize |
1275 | st = timeSpan - st; | 1278 | st = timeSpan - st; |
1276 | if ( st < 0 ) st = 0; | 1279 | if ( st < 0 ) st = 0; |
1277 | if ( end > timeSpan ) end = timeSpan; | 1280 | if ( end > timeSpan ) end = timeSpan; |
1278 | int iii; | 1281 | int iii; |
1279 | //qDebug("found %s %d %d ",event->summary().latin1(), st, end ); | 1282 | //qDebug("found %s %d %d ",event->summary().latin1(), st, end ); |
1280 | for ( iii = st;iii<= end;++iii) | 1283 | for ( iii = st;iii<= end;++iii) |
1281 | (*cells)[iii]->insertEvent( event ); | 1284 | (*cells)[iii]->insertEvent( event ); |
1282 | } | 1285 | } |
1283 | } | 1286 | } |
1284 | } else { | 1287 | } else { |
1285 | if ( invalid ) | 1288 | if ( invalid ) |
1286 | break; | 1289 | break; |
1287 | invalid = true; | 1290 | invalid = true; |
1288 | //qDebug("invalid %s", event->summary().latin1()); | 1291 | qDebug("invalid %s", event->summary().latin1()); |
1289 | incidenceStart = QDateTime( mStartDate ).addSecs( -2 );; | 1292 | incidenceStart = QDateTime( mStartDate ).addSecs( -2 );; |
1290 | } | 1293 | } |
1291 | if ( last ) | 1294 | if ( last ) |
1292 | break; | 1295 | break; |
1293 | bool ok; | 1296 | bool ok; |
1297 | qDebug("TRY next occurence %s ", incidenceStart.toString().latin1()); | ||
1294 | incidenceStart = event->getNextOccurence( incidenceStart.addSecs( 1 ) ,&ok ); | 1298 | incidenceStart = event->getNextOccurence( incidenceStart.addSecs( 1 ) ,&ok ); |
1295 | if ( ! ok ) | 1299 | if ( ! ok ) { |
1300 | qDebug("NOT OK "); | ||
1296 | break; | 1301 | break; |
1297 | if ( incidenceStart.date() > endDate ) | 1302 | } |
1303 | if ( incidenceStart.date() > endDate ) { | ||
1304 | qDebug("incidenceStart.date() > endDate "); | ||
1298 | break; | 1305 | break; |
1306 | } | ||
1307 | qDebug("next occurence %s ", incidenceStart.toString().latin1()); | ||
1299 | } | 1308 | } |
1300 | } else { // no recur | 1309 | } else { // no recur |
1301 | int st = event->dtStart().date().daysTo( endDate ); | 1310 | int st = event->dtStart().date().daysTo( endDate ); |
1302 | if ( st >= 0 ) { // start before timeend | 1311 | if ( st >= 0 ) { // start before timeend |
1303 | int end = mStartDate.daysTo( event->dtEnd().date() ); | 1312 | int end = mStartDate.daysTo( event->dtEnd().date() ); |
1304 | if ( end >= 0 ) { // end after timestart --- got one! | 1313 | if ( end >= 0 ) { // end after timestart --- got one! |
1305 | //normalize | 1314 | //normalize |
1306 | st = timeSpan - st; | 1315 | st = timeSpan - st; |
1307 | if ( st < 0 ) st = 0; | 1316 | if ( st < 0 ) st = 0; |
1308 | if ( end > timeSpan ) end = timeSpan; | 1317 | if ( end > timeSpan ) end = timeSpan; |
1309 | int iii; | 1318 | int iii; |
1310 | for ( iii = st;iii<= end;++iii) | 1319 | for ( iii = st;iii<= end;++iii) |
1311 | (*cells)[iii]->insertEvent( event ); | 1320 | (*cells)[iii]->insertEvent( event ); |
1312 | } | 1321 | } |
1313 | } | 1322 | } |
1314 | } | 1323 | } |
1315 | } | 1324 | } |
1316 | // insert due todos | 1325 | // insert due todos |
1317 | QPtrList<Todo> todos = calendar()->todos( ); | 1326 | QPtrList<Todo> todos = calendar()->todos( ); |
1318 | Todo *todo; | 1327 | Todo *todo; |
1319 | for(todo = todos.first(); todo; todo = todos.next()) { | 1328 | for(todo = todos.first(); todo; todo = todos.next()) { |
1320 | //insertTodo( todo ); | 1329 | //insertTodo( todo ); |
1321 | if ( todo->hasDueDate() ) { | 1330 | if ( todo->hasDueDate() ) { |
1322 | int day = mStartDate.daysTo( todo->dtDue().date() ); | 1331 | int day = mStartDate.daysTo( todo->dtDue().date() ); |
1323 | if ( day >= 0 && day < timeSpan + 1) { | 1332 | if ( day >= 0 && day < timeSpan + 1) { |
1324 | (*cells)[day]->insertTodo( todo ); | 1333 | (*cells)[day]->insertTodo( todo ); |
1325 | } | 1334 | } |
1326 | } | 1335 | } |
1327 | } | 1336 | } |
1328 | 1337 | ||
1329 | for( i = 0; i < timeSpan+1; ++i ) { | 1338 | for( i = 0; i < timeSpan+1; ++i ) { |
1330 | (*cells)[i]->finishUpdateCell(); | 1339 | (*cells)[i]->finishUpdateCell(); |
1331 | } | 1340 | } |
1332 | processSelectionChange(); | 1341 | processSelectionChange(); |
1333 | (*cells)[0]->setFocus(); | 1342 | (*cells)[0]->setFocus(); |
1334 | 1343 | ||
1335 | 1344 | ||
1336 | #else | 1345 | #else |
1337 | // old code | 1346 | // old code |
1338 | //qDebug("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ "); | 1347 | //qDebug("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ "); |
1339 | int i; | 1348 | int i; |
1340 | for( i = 0; i < (*cells).count(); ++i ) { | 1349 | for( i = 0; i < (*cells).count(); ++i ) { |
1341 | (*cells)[i]->updateCell(); | 1350 | (*cells)[i]->updateCell(); |
1342 | } | 1351 | } |
1343 | 1352 | ||
1344 | //qDebug("KOMonthView::updateView() "); | 1353 | //qDebug("KOMonthView::updateView() "); |
1345 | processSelectionChange(); | 1354 | processSelectionChange(); |
1346 | // qDebug("---------------------------------------------------------------------+ "); | 1355 | // qDebug("---------------------------------------------------------------------+ "); |
1347 | (*cells)[0]->setFocus(); | 1356 | (*cells)[0]->setFocus(); |
1348 | #endif | 1357 | #endif |
1349 | 1358 | ||
1350 | //qDebug("update time %d ", ti.elapsed()); | 1359 | //qDebug("update time %d ", ti.elapsed()); |
1351 | } | 1360 | } |
1352 | 1361 | ||
1353 | void KOMonthView::resizeEvent(QResizeEvent * e) | 1362 | void KOMonthView::resizeEvent(QResizeEvent * e) |
1354 | { | 1363 | { |
1355 | //qDebug("KOMonthView::resizeEvent %d %d -- %d %d ", e->size().width(), e->size().height(), e->oldSize().width(), e->oldSize().height()); | 1364 | //qDebug("KOMonthView::resizeEvent %d %d -- %d %d ", e->size().width(), e->size().height(), e->oldSize().width(), e->oldSize().height()); |
1356 | computeLayout(); | 1365 | computeLayout(); |
1357 | clPending = true; | 1366 | clPending = true; |
1358 | if ( mShowWeekView ) | 1367 | if ( mShowWeekView ) |
1359 | mCellsW[0]->setFocus(); | 1368 | mCellsW[0]->setFocus(); |
1360 | else | 1369 | else |
1361 | mCells[0]->setFocus(); | 1370 | mCells[0]->setFocus(); |
1362 | } | 1371 | } |
1363 | void KOMonthView::computeLayoutWeek() | 1372 | void KOMonthView::computeLayoutWeek() |
1364 | { | 1373 | { |
1365 | static int lastWid = 0; | 1374 | static int lastWid = 0; |
1366 | static int lastHei = 0; | 1375 | static int lastHei = 0; |
1367 | int daysToShow; | 1376 | int daysToShow; |
1368 | bool combinedSatSun = false; | 1377 | bool combinedSatSun = false; |
1369 | if (mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ) { | 1378 | if (mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ) { |
1370 | daysToShow = 6; | 1379 | daysToShow = 6; |
1371 | combinedSatSun = true; | 1380 | combinedSatSun = true; |
1372 | } | 1381 | } |
1373 | int tWid = topLevelWidget()->size().width(); | 1382 | int tWid = topLevelWidget()->size().width(); |
1374 | int tHei = topLevelWidget()->size().height(); | 1383 | int tHei = topLevelWidget()->size().height(); |
1375 | 1384 | ||
1376 | int wid = width();//e | 1385 | int wid = width();//e |
1377 | int hei = height()-1-mNavigatorBar->height(); | 1386 | int hei = height()-1-mNavigatorBar->height(); |
1378 | 1387 | ||
1379 | if ( ((wid *3)/2) < tWid && (( hei *3) /2) < tHei ) | 1388 | if ( ((wid *3)/2) < tWid && (( hei *3) /2) < tHei ) |
1380 | return; | 1389 | return; |
1381 | 1390 | ||
1382 | if ( lastWid == width() && lastHei == height() ) | 1391 | if ( lastWid == width() && lastHei == height() ) |
1383 | return; | 1392 | return; |
1384 | lastWid = width(); | 1393 | lastWid = width(); |
1385 | lastHei = height(); | 1394 | lastHei = height(); |
1386 | 1395 | ||
1387 | 1396 | ||
1388 | if ( wid < hei ) | 1397 | if ( wid < hei ) |
1389 | daysToShow = 2; | 1398 | daysToShow = 2; |
1390 | else | 1399 | else |
1391 | daysToShow = 3; | 1400 | daysToShow = 3; |
1392 | mShowSatSunComp = true; | 1401 | mShowSatSunComp = true; |
1393 | combinedSatSun = true; | 1402 | combinedSatSun = true; |
1394 | 1403 | ||
1395 | //qDebug("KOMonthView::computeLayout() WWW ------------------------------------ "); | 1404 | //qDebug("KOMonthView::computeLayout() WWW ------------------------------------ "); |
1396 | QFontMetrics fm ( mWeekLabels[0]->font() ); | 1405 | QFontMetrics fm ( mWeekLabels[0]->font() ); |
1397 | int weeklabelwid = fm.width( "888" ); | 1406 | int weeklabelwid = fm.width( "888" ); |
1398 | wid -= weeklabelwid; | 1407 | wid -= weeklabelwid; |
1399 | 1408 | ||
1400 | int colWid = wid / daysToShow; | 1409 | int colWid = wid / daysToShow; |
1401 | int lastCol = wid - ( colWid*6 ); | 1410 | int lastCol = wid - ( colWid*6 ); |
1402 | int dayLabelHei = mDayLabelsW[0]->sizeHint().height(); | 1411 | int dayLabelHei = mDayLabelsW[0]->sizeHint().height(); |
1403 | int cellHei = (hei - (5- daysToShow )*dayLabelHei) /(5- daysToShow ); | 1412 | int cellHei = (hei - (5- daysToShow )*dayLabelHei) /(5- daysToShow ); |
1404 | int colModulo = wid % daysToShow; | 1413 | int colModulo = wid % daysToShow; |
1405 | int rowModulo = (hei- (5- daysToShow )*dayLabelHei) % daysToShow-1; | 1414 | int rowModulo = (hei- (5- daysToShow )*dayLabelHei) % daysToShow-1; |
1406 | //qDebug("rowmod %d ", rowModulo); | 1415 | //qDebug("rowmod %d ", rowModulo); |
1407 | int i; | 1416 | int i; |
1408 | int x,y,w,h; | 1417 | int x,y,w,h; |
1409 | x= 0; | 1418 | x= 0; |
1410 | y= 0; | 1419 | y= 0; |
1411 | w = colWid; | 1420 | w = colWid; |
1412 | h = dayLabelHei ; | 1421 | h = dayLabelHei ; |
1413 | for ( i = 0; i < 7; i++) { | 1422 | for ( i = 0; i < 7; i++) { |
1414 | if ( i && !( i % daysToShow) && i < 6) { | 1423 | if ( i && !( i % daysToShow) && i < 6) { |
1415 | y += hei/(5-daysToShow); | 1424 | y += hei/(5-daysToShow); |
1416 | x = 0; | 1425 | x = 0; |
1417 | w = colWid; | 1426 | w = colWid; |
1418 | } | 1427 | } |
1419 | if ( ((i) % daysToShow) >= daysToShow-colModulo ) { | 1428 | if ( ((i) % daysToShow) >= daysToShow-colModulo ) { |
1420 | ++w; | 1429 | ++w; |
1421 | } | 1430 | } |
1422 | if ( i >= 5 ) { | 1431 | if ( i >= 5 ) { |
1423 | mDayLabelsW[i]->setGeometry( x+weeklabelwid,y,w/2+w%2,h); | 1432 | mDayLabelsW[i]->setGeometry( x+weeklabelwid,y,w/2+w%2,h); |
1424 | x -= (w/2 ); | 1433 | x -= (w/2 ); |
1425 | } | 1434 | } |
1426 | else | 1435 | else |
1427 | mDayLabelsW[i]->setGeometry( x+weeklabelwid,y,w,h); | 1436 | mDayLabelsW[i]->setGeometry( x+weeklabelwid,y,w,h); |
1428 | x += w; | 1437 | x += w; |
1429 | } | 1438 | } |
1430 | x= 0; | 1439 | x= 0; |
1431 | y= dayLabelHei; | 1440 | y= dayLabelHei; |
1432 | w = colWid; | 1441 | w = colWid; |
1433 | h = cellHei; | 1442 | h = cellHei; |
1434 | for ( i = 0; i < mCellsW.count(); ++i) { | 1443 | for ( i = 0; i < mCellsW.count(); ++i) { |
1435 | if ( i > 6 ) { | 1444 | if ( i > 6 ) { |
1436 | mCellsW[i]->hide(); | 1445 | mCellsW[i]->hide(); |
1437 | continue; | 1446 | continue; |
1438 | } | 1447 | } |
1439 | 1448 | ||
1440 | w = colWid; | 1449 | w = colWid; |
1441 | if ( ((i) % daysToShow) >= daysToShow-colModulo ) { | 1450 | if ( ((i) % daysToShow) >= daysToShow-colModulo ) { |
1442 | ++w; | 1451 | ++w; |
1443 | } | 1452 | } |
1444 | if ( i == (daysToShow-1-rowModulo)*7) | 1453 | if ( i == (daysToShow-1-rowModulo)*7) |
1445 | ++h; | 1454 | ++h; |
1446 | 1455 | ||
1447 | if ( i >= 5 ) { | 1456 | if ( i >= 5 ) { |
1448 | if ( i ==5 ) { | 1457 | if ( i ==5 ) { |
1449 | mCellsW[i]->setGeometry ( x+weeklabelwid,y,w,h/2 ); | 1458 | mCellsW[i]->setGeometry ( x+weeklabelwid,y,w,h/2 ); |
1450 | x -= w ;y += h/2; | 1459 | x -= w ;y += h/2; |
1451 | } else { | 1460 | } else { |
1452 | if ( ((i-1) % daysToShow) >= daysToShow-colModulo ) { | 1461 | if ( ((i-1) % daysToShow) >= daysToShow-colModulo ) { |
1453 | ++w; | 1462 | ++w; |
1454 | } | 1463 | } |
1455 | mCellsW[i]->setGeometry ( x+weeklabelwid,y,w,h-h/2 ); | 1464 | mCellsW[i]->setGeometry ( x+weeklabelwid,y,w,h-h/2 ); |
1456 | y -= h/2; | 1465 | y -= h/2; |
1457 | } | 1466 | } |
1458 | } else | 1467 | } else |
1459 | mCellsW[i]->setGeometry ( x+weeklabelwid,y,w,h ); | 1468 | mCellsW[i]->setGeometry ( x+weeklabelwid,y,w,h ); |
1460 | 1469 | ||
1461 | 1470 | ||
1462 | x += w; | 1471 | x += w; |
1463 | if ( x + w/2 > wid ) { | 1472 | if ( x + w/2 > wid ) { |
1464 | x = 0; | 1473 | x = 0; |
1465 | y += h+dayLabelHei ; | 1474 | y += h+dayLabelHei ; |
1466 | } | 1475 | } |
1467 | } | 1476 | } |
1468 | y= dayLabelHei; | 1477 | y= dayLabelHei; |
1469 | h = cellHei ; | 1478 | h = cellHei ; |
1470 | mWeekLabelsW[0]->setGeometry( 0,y,weeklabelwid,hei-dayLabelHei); | 1479 | mWeekLabelsW[0]->setGeometry( 0,y,weeklabelwid,hei-dayLabelHei); |
1471 | mWeekLabelsW[1]->setGeometry( 0,0,weeklabelwid,dayLabelHei); | 1480 | mWeekLabelsW[1]->setGeometry( 0,0,weeklabelwid,dayLabelHei); |
1472 | // qDebug("RRRRRRRRRRRRR %d %d old %d %d", e->size().width(),e->size().height() , e->oldSize().width(),e->oldSize().height()); | 1481 | // qDebug("RRRRRRRRRRRRR %d %d old %d %d", e->size().width(),e->size().height() , e->oldSize().width(),e->oldSize().height()); |
1473 | //qDebug("parent %d %d ", topLevelWidget()->size().width(), topLevelWidget()->size().height()); | 1482 | //qDebug("parent %d %d ", topLevelWidget()->size().width(), topLevelWidget()->size().height()); |
1474 | mShortDayLabelsW = mDayLabelsW[0]->width()-2 < mWidthLongDayLabel ; | 1483 | mShortDayLabelsW = mDayLabelsW[0]->width()-2 < mWidthLongDayLabel ; |
1475 | updateDayLabels(); | 1484 | updateDayLabels(); |
1476 | //bool forceUpdate = !updatePossible; | 1485 | //bool forceUpdate = !updatePossible; |
1477 | updatePossible = true; | 1486 | updatePossible = true; |
1478 | //mWeekLabels[mNumWeeks]->setText( i18n("M")); | 1487 | //mWeekLabels[mNumWeeks]->setText( i18n("M")); |
1479 | //if ( forceUpdate ) | 1488 | //if ( forceUpdate ) |
1480 | // updateView(); | 1489 | // updateView(); |
1481 | } | 1490 | } |
1482 | void KOMonthView::computeLayout() | 1491 | void KOMonthView::computeLayout() |
1483 | { | 1492 | { |
1484 | 1493 | ||
1485 | 1494 | ||
1486 | static int lastWid = 0; | 1495 | static int lastWid = 0; |
1487 | static int lastHei = 0; | 1496 | static int lastHei = 0; |
1488 | 1497 | ||
1489 | if ( mShowWeekView ){ | 1498 | if ( mShowWeekView ){ |
1490 | computeLayoutWeek(); | 1499 | computeLayoutWeek(); |
1491 | return; | 1500 | return; |
1492 | } | 1501 | } |
1493 | int daysToShow = 7; | 1502 | int daysToShow = 7; |
1494 | bool combinedSatSun = false; | 1503 | bool combinedSatSun = false; |
1495 | if (mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ) { | 1504 | if (mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ) { |
1496 | daysToShow = 6; | 1505 | daysToShow = 6; |
1497 | combinedSatSun = true; | 1506 | combinedSatSun = true; |
1498 | } | 1507 | } |
1499 | int tWid = topLevelWidget()->size().width(); | 1508 | int tWid = topLevelWidget()->size().width(); |
1500 | int tHei = topLevelWidget()->size().height(); | 1509 | int tHei = topLevelWidget()->size().height(); |
1501 | 1510 | ||
1502 | int wid = width();//e | 1511 | int wid = width();//e |
1503 | int hei = height()-1-mNavigatorBar->height(); | 1512 | int hei = height()-1-mNavigatorBar->height(); |
1504 | 1513 | ||
1505 | if ( ((wid *3)/2) < tWid && (( hei *3) /2) < tHei ) { | 1514 | if ( ((wid *3)/2) < tWid && (( hei *3) /2) < tHei ) { |
1506 | return; | 1515 | return; |
1507 | } | 1516 | } |
1508 | if ( lastWid == width() && lastHei == height() ){ | 1517 | if ( lastWid == width() && lastHei == height() ){ |
1509 | return; | 1518 | return; |
1510 | } | 1519 | } |
1511 | 1520 | ||
1512 | lastWid = width(); | 1521 | lastWid = width(); |
1513 | lastHei = height(); | 1522 | lastHei = height(); |
1514 | //qDebug("KOMonthView::computeLayout() MMM ------------------------------------ "); | 1523 | //qDebug("KOMonthView::computeLayout() MMM ------------------------------------ "); |
1515 | QFontMetrics fm ( mWeekLabels[0]->font() ); | 1524 | QFontMetrics fm ( mWeekLabels[0]->font() ); |
1516 | int weeklabelwid = fm.width( "888" ); | 1525 | int weeklabelwid = fm.width( "888" ); |
1517 | wid -= weeklabelwid; | 1526 | wid -= weeklabelwid; |
1518 | 1527 | ||
1519 | int colWid = wid / daysToShow; | 1528 | int colWid = wid / daysToShow; |
1520 | int lastCol = wid - ( colWid*6 ); | 1529 | int lastCol = wid - ( colWid*6 ); |
1521 | int dayLabelHei = mDayLabels[0]->sizeHint().height(); | 1530 | int dayLabelHei = mDayLabels[0]->sizeHint().height(); |
1522 | int cellHei = (hei - dayLabelHei) /6; | 1531 | int cellHei = (hei - dayLabelHei) /6; |
1523 | int colModulo = wid % daysToShow; | 1532 | int colModulo = wid % daysToShow; |
1524 | int rowModulo = (hei- dayLabelHei) % 6; | 1533 | int rowModulo = (hei- dayLabelHei) % 6; |
1525 | //qDebug("rowmod %d ", rowModulo); | 1534 | //qDebug("rowmod %d ", rowModulo); |
1526 | int i; | 1535 | int i; |
1527 | int x,y,w,h; | 1536 | int x,y,w,h; |
1528 | x= 0; | 1537 | x= 0; |
1529 | y= 0; | 1538 | y= 0; |
1530 | w = colWid; | 1539 | w = colWid; |
1531 | h = dayLabelHei ; | 1540 | h = dayLabelHei ; |
1532 | for ( i = 0; i < 7; i++) { | 1541 | for ( i = 0; i < 7; i++) { |
1533 | if ( i == daysToShow-colModulo ) | 1542 | if ( i == daysToShow-colModulo ) |
1534 | ++w; | 1543 | ++w; |
1535 | if ( combinedSatSun ) { | 1544 | if ( combinedSatSun ) { |
1536 | if ( i >= daysToShow-1 ) { | 1545 | if ( i >= daysToShow-1 ) { |
1537 | mDayLabels[i]->setGeometry( x+weeklabelwid,y,w/2,h); | 1546 | mDayLabels[i]->setGeometry( x+weeklabelwid,y,w/2,h); |
1538 | x -= w/2 ; | 1547 | x -= w/2 ; |
1539 | } | 1548 | } |
1540 | else | 1549 | else |
1541 | mDayLabels[i]->setGeometry( x+weeklabelwid,y,w,h); | 1550 | mDayLabels[i]->setGeometry( x+weeklabelwid,y,w,h); |
1542 | } else | 1551 | } else |
1543 | mDayLabels[i]->setGeometry( x+weeklabelwid,y,w,h); | 1552 | mDayLabels[i]->setGeometry( x+weeklabelwid,y,w,h); |
1544 | x += w; | 1553 | x += w; |
1545 | } | 1554 | } |
1546 | x= 0; | 1555 | x= 0; |
1547 | y= dayLabelHei; | 1556 | y= dayLabelHei; |
1548 | w = colWid; | 1557 | w = colWid; |
1549 | h = cellHei ; | 1558 | h = cellHei ; |
1550 | for ( i = 0; i < mCells.count(); ++i) { | 1559 | for ( i = 0; i < mCells.count(); ++i) { |
1551 | //qDebug("iii %d ", i); | 1560 | //qDebug("iii %d ", i); |
1552 | w = colWid; | 1561 | w = colWid; |
1553 | if ( ((i) % 7) >= 7-colModulo ) { | 1562 | if ( ((i) % 7) >= 7-colModulo ) { |
1554 | ++w; | 1563 | ++w; |