-rw-r--r-- | korganizer/koagendaview.cpp | 3 | ||||
-rw-r--r-- | korganizer/kotodoview.cpp | 29 | ||||
-rw-r--r-- | korganizer/kotodoviewitem.cpp | 30 | ||||
-rw-r--r-- | libkcal/todo.cpp | 6 |
4 files changed, 44 insertions, 24 deletions
diff --git a/korganizer/koagendaview.cpp b/korganizer/koagendaview.cpp index bbc43e4..42a6f7c 100644 --- a/korganizer/koagendaview.cpp +++ b/korganizer/koagendaview.cpp | |||
@@ -1036,257 +1036,256 @@ void KOAgendaView::fillAgenda() | |||
1036 | globalFlagBlockAgenda = 1; | 1036 | globalFlagBlockAgenda = 1; |
1037 | // clearView(); | 1037 | // clearView(); |
1038 | //qDebug("fillAgenda()++++ "); | 1038 | //qDebug("fillAgenda()++++ "); |
1039 | globalFlagBlockAgendaItemPaint = 1; | 1039 | globalFlagBlockAgendaItemPaint = 1; |
1040 | mAllDayAgenda->changeColumns(mSelectedDates.count()); | 1040 | mAllDayAgenda->changeColumns(mSelectedDates.count()); |
1041 | mAgenda->changeColumns(mSelectedDates.count()); | 1041 | mAgenda->changeColumns(mSelectedDates.count()); |
1042 | qApp->processEvents(); | 1042 | qApp->processEvents(); |
1043 | mEventIndicatorTop->changeColumns(mSelectedDates.count()); | 1043 | mEventIndicatorTop->changeColumns(mSelectedDates.count()); |
1044 | mEventIndicatorBottom->changeColumns(mSelectedDates.count()); | 1044 | mEventIndicatorBottom->changeColumns(mSelectedDates.count()); |
1045 | setHolidayMasks(); | 1045 | setHolidayMasks(); |
1046 | 1046 | ||
1047 | //mAgenda->hideUnused(); | 1047 | //mAgenda->hideUnused(); |
1048 | //mAllDayAgenda->hideUnused(); | 1048 | //mAllDayAgenda->hideUnused(); |
1049 | 1049 | ||
1050 | // mAgenda->blockNextRepaint( false ); | 1050 | // mAgenda->blockNextRepaint( false ); |
1051 | // mAgenda->viewport()->repaint(); | 1051 | // mAgenda->viewport()->repaint(); |
1052 | // mAgenda->blockNextRepaint( true ); | 1052 | // mAgenda->blockNextRepaint( true ); |
1053 | mMinY.resize(mSelectedDates.count()); | 1053 | mMinY.resize(mSelectedDates.count()); |
1054 | mMaxY.resize(mSelectedDates.count()); | 1054 | mMaxY.resize(mSelectedDates.count()); |
1055 | 1055 | ||
1056 | QPtrList<Event> dayEvents; | 1056 | QPtrList<Event> dayEvents; |
1057 | 1057 | ||
1058 | // ToDo items shall be displayed for the day they are due, but only showed today if they are already overdue. | 1058 | // ToDo items shall be displayed for the day they are due, but only showed today if they are already overdue. |
1059 | // Therefore, gtodoset all of them. | 1059 | // Therefore, gtodoset all of them. |
1060 | QPtrList<Todo> todos = calendar()->todos(); | 1060 | QPtrList<Todo> todos = calendar()->todos(); |
1061 | 1061 | ||
1062 | mAgenda->setDateList(mSelectedDates); | 1062 | mAgenda->setDateList(mSelectedDates); |
1063 | 1063 | ||
1064 | QDate today = QDate::currentDate(); | 1064 | QDate today = QDate::currentDate(); |
1065 | 1065 | ||
1066 | DateList::ConstIterator dit; | 1066 | DateList::ConstIterator dit; |
1067 | int curCol = 0; | 1067 | int curCol = 0; |
1068 | for( dit = mSelectedDates.begin(); dit != mSelectedDates.end(); ++dit ) { | 1068 | for( dit = mSelectedDates.begin(); dit != mSelectedDates.end(); ++dit ) { |
1069 | QDate currentDate = *dit; | 1069 | QDate currentDate = *dit; |
1070 | // kdDebug() << "KOAgendaView::fillAgenda(): " << currentDate.toString() | 1070 | // kdDebug() << "KOAgendaView::fillAgenda(): " << currentDate.toString() |
1071 | // << endl; | 1071 | // << endl; |
1072 | 1072 | ||
1073 | dayEvents = calendar()->events(currentDate,true); | 1073 | dayEvents = calendar()->events(currentDate,true); |
1074 | 1074 | ||
1075 | // Default values, which can never be reached | 1075 | // Default values, which can never be reached |
1076 | mMinY[curCol] = mAgenda->timeToY(QTime(23,59)) + 1; | 1076 | mMinY[curCol] = mAgenda->timeToY(QTime(23,59)) + 1; |
1077 | mMaxY[curCol] = mAgenda->timeToY(QTime(0,0)) - 1; | 1077 | mMaxY[curCol] = mAgenda->timeToY(QTime(0,0)) - 1; |
1078 | 1078 | ||
1079 | unsigned int numEvent; | 1079 | unsigned int numEvent; |
1080 | for(numEvent=0;numEvent<dayEvents.count();++numEvent) { | 1080 | for(numEvent=0;numEvent<dayEvents.count();++numEvent) { |
1081 | Event *event = dayEvents.at(numEvent); | 1081 | Event *event = dayEvents.at(numEvent); |
1082 | if ( !KOPrefs::instance()->mShowSyncEvents && event->uid().left(2) == QString("la") ) | 1082 | if ( !KOPrefs::instance()->mShowSyncEvents && event->uid().left(2) == QString("la") ) |
1083 | if ( event->uid().left(15) == QString("last-syncEvent-") ) | 1083 | if ( event->uid().left(15) == QString("last-syncEvent-") ) |
1084 | continue; | 1084 | continue; |
1085 | // kdDebug() << " Event: " << event->summary() << endl; | 1085 | // kdDebug() << " Event: " << event->summary() << endl; |
1086 | 1086 | ||
1087 | int beginX = currentDate.daysTo(event->dtStart().date()) + curCol; | 1087 | int beginX = currentDate.daysTo(event->dtStart().date()) + curCol; |
1088 | int endX = currentDate.daysTo(event->dtEnd().date()) + curCol; | 1088 | int endX = currentDate.daysTo(event->dtEnd().date()) + curCol; |
1089 | 1089 | ||
1090 | // kdDebug() << " beginX: " << beginX << " endX: " << endX << endl; | 1090 | // kdDebug() << " beginX: " << beginX << " endX: " << endX << endl; |
1091 | 1091 | ||
1092 | if (event->doesFloat()) { | 1092 | if (event->doesFloat()) { |
1093 | if (event->recurrence()->doesRecur()) { | 1093 | if (event->recurrence()->doesRecur()) { |
1094 | mAllDayAgenda->insertAllDayItem(event,currentDate,curCol,curCol); | 1094 | mAllDayAgenda->insertAllDayItem(event,currentDate,curCol,curCol); |
1095 | } else { | 1095 | } else { |
1096 | if (beginX <= 0 && curCol == 0) { | 1096 | if (beginX <= 0 && curCol == 0) { |
1097 | mAllDayAgenda->insertAllDayItem(event,currentDate,beginX,endX); | 1097 | mAllDayAgenda->insertAllDayItem(event,currentDate,beginX,endX); |
1098 | } else if (beginX == curCol) { | 1098 | } else if (beginX == curCol) { |
1099 | mAllDayAgenda->insertAllDayItem(event,currentDate,beginX,endX); | 1099 | mAllDayAgenda->insertAllDayItem(event,currentDate,beginX,endX); |
1100 | } | 1100 | } |
1101 | } | 1101 | } |
1102 | } else if (event->isMultiDay()) { | 1102 | } else if (event->isMultiDay()) { |
1103 | if ( event->doesRecur () ) { | 1103 | if ( event->doesRecur () ) { |
1104 | QDate dateit = currentDate; | 1104 | QDate dateit = currentDate; |
1105 | int count = 0; | 1105 | int count = 0; |
1106 | int max = event->dtStart().daysTo( event->dtEnd() ) +2; | 1106 | int max = event->dtStart().daysTo( event->dtEnd() ) +2; |
1107 | while (! event->recursOn( dateit ) && count <= max ) { | 1107 | while (! event->recursOn( dateit ) && count <= max ) { |
1108 | ++count; | 1108 | ++count; |
1109 | dateit = dateit.addDays( -1 ); | 1109 | dateit = dateit.addDays( -1 ); |
1110 | } | 1110 | } |
1111 | bool ok; | 1111 | bool ok; |
1112 | QDateTime nextOcstart = event->getNextOccurence( QDateTime(dateit) ,&ok ); | 1112 | QDateTime nextOcstart = event->getNextOccurence( QDateTime(dateit) ,&ok ); |
1113 | if ( ok ) | 1113 | if ( ok ) |
1114 | { | 1114 | { |
1115 | int secs = event->dtStart().secsTo( event->dtEnd() ); | 1115 | int secs = event->dtStart().secsTo( event->dtEnd() ); |
1116 | QDateTime nextOcend =nextOcstart.addSecs( secs ); ; | 1116 | QDateTime nextOcend =nextOcstart.addSecs( secs ); ; |
1117 | beginX = currentDate.daysTo(nextOcstart.date()) + curCol; | 1117 | beginX = currentDate.daysTo(nextOcstart.date()) + curCol; |
1118 | endX = currentDate.daysTo(nextOcend.date()) + curCol; | 1118 | endX = currentDate.daysTo(nextOcend.date()) + curCol; |
1119 | 1119 | ||
1120 | } | 1120 | } |
1121 | } | 1121 | } |
1122 | int startY = mAgenda->timeToY(event->dtStart().time()); | 1122 | int startY = mAgenda->timeToY(event->dtStart().time()); |
1123 | int endY = mAgenda->timeToY(event->dtEnd().time()) - 1; | 1123 | int endY = mAgenda->timeToY(event->dtEnd().time()) - 1; |
1124 | //qDebug("insert %d %d %d %d %d ",beginX,endX,startY,endY , curCol ); | 1124 | //qDebug("insert %d %d %d %d %d ",beginX,endX,startY,endY , curCol ); |
1125 | if ((beginX <= 0 && curCol == 0) || beginX == curCol) { | 1125 | if ((beginX <= 0 && curCol == 0) || beginX == curCol) { |
1126 | //qDebug("insert!!! "); | 1126 | //qDebug("insert!!! "); |
1127 | mAgenda->insertMultiItem(event,currentDate,beginX,endX,startY,endY); | 1127 | mAgenda->insertMultiItem(event,currentDate,beginX,endX,startY,endY); |
1128 | } | 1128 | } |
1129 | if (beginX == curCol) { | 1129 | if (beginX == curCol) { |
1130 | mMaxY[curCol] = mAgenda->timeToY(QTime(23,59)); | 1130 | mMaxY[curCol] = mAgenda->timeToY(QTime(23,59)); |
1131 | if (startY < mMinY[curCol]) mMinY[curCol] = startY; | 1131 | if (startY < mMinY[curCol]) mMinY[curCol] = startY; |
1132 | } else if (endX == curCol) { | 1132 | } else if (endX == curCol) { |
1133 | mMinY[curCol] = mAgenda->timeToY(QTime(0,0)); | 1133 | mMinY[curCol] = mAgenda->timeToY(QTime(0,0)); |
1134 | if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; | 1134 | if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; |
1135 | } else { | 1135 | } else { |
1136 | mMinY[curCol] = mAgenda->timeToY(QTime(0,0)); | 1136 | mMinY[curCol] = mAgenda->timeToY(QTime(0,0)); |
1137 | mMaxY[curCol] = mAgenda->timeToY(QTime(23,59)); | 1137 | mMaxY[curCol] = mAgenda->timeToY(QTime(23,59)); |
1138 | } | 1138 | } |
1139 | } else { | 1139 | } else { |
1140 | int startY = mAgenda->timeToY(event->dtStart().time()); | 1140 | int startY = mAgenda->timeToY(event->dtStart().time()); |
1141 | int endY = mAgenda->timeToY(event->dtEnd().time()) - 1; | 1141 | int endY = mAgenda->timeToY(event->dtEnd().time()) - 1; |
1142 | if (endY < startY) endY = startY; | 1142 | if (endY < startY) endY = startY; |
1143 | mAgenda->insertItem(event,currentDate,curCol,startY,endY); | 1143 | mAgenda->insertItem(event,currentDate,curCol,startY,endY); |
1144 | if (startY < mMinY[curCol]) mMinY[curCol] = startY; | 1144 | if (startY < mMinY[curCol]) mMinY[curCol] = startY; |
1145 | if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; | 1145 | if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; |
1146 | } | 1146 | } |
1147 | } | 1147 | } |
1148 | // ---------- [display Todos -------------- | 1148 | // ---------- [display Todos -------------- |
1149 | unsigned int numTodo; | 1149 | unsigned int numTodo; |
1150 | for (numTodo = 0; numTodo < todos.count(); ++numTodo) { | 1150 | for (numTodo = 0; numTodo < todos.count(); ++numTodo) { |
1151 | Todo *todo = todos.at(numTodo); | 1151 | Todo *todo = todos.at(numTodo); |
1152 | 1152 | ||
1153 | if ( ! todo->hasDueDate() && !todo->hasCompletedDate()) continue; // todo shall not be displayed if it has no date | 1153 | if ( ! todo->hasDueDate() && !todo->hasCompletedDate()) continue; // todo shall not be displayed if it has no date |
1154 | 1154 | ||
1155 | // ToDo items shall be displayed for the day they are due, but only showed today if they are already overdue. | 1155 | // ToDo items shall be displayed for the day they are due, but only showed today if they are already overdue. |
1156 | // Already completed items can be displayed on their original due date | 1156 | // Already completed items can be displayed on their original due date |
1157 | //if not KOPrefs::instance()->mShowTodoInAgenda, show overdue in agenda | 1157 | //if not KOPrefs::instance()->mShowTodoInAgenda, show overdue in agenda |
1158 | bool overdue = (!todo->isCompleted()) && (todo->dtDue() < today) && KOPrefs::instance()->mShowTodoInAgenda; | 1158 | bool overdue = (!todo->isCompleted()) && (todo->dtDue() < today) && KOPrefs::instance()->mShowTodoInAgenda; |
1159 | bool fillIn = false; | 1159 | bool fillIn = false; |
1160 | if ( todo->hasCompletedDate() && todo->completed().date() == currentDate ) | 1160 | if ( todo->hasCompletedDate() && todo->completed().date() == currentDate ) |
1161 | fillIn = true; | 1161 | fillIn = true; |
1162 | if ( ! fillIn && !todo->hasCompletedDate() ) | 1162 | if ( ! fillIn && !todo->hasCompletedDate() ) |
1163 | fillIn = ((todo->dtDue().date() == currentDate) && !overdue) || ((currentDate == today) && overdue); | 1163 | fillIn = ((todo->dtDue().date() == currentDate) && !overdue) || ((currentDate == today) && overdue); |
1164 | qDebug("refill todo "); | ||
1165 | if ( fillIn ) { | 1164 | if ( fillIn ) { |
1166 | if ( (todo->doesFloat() || overdue ) && !todo->hasCompletedDate() ) { // Todo has no due-time set or is already overdue | 1165 | if ( (todo->doesFloat() || overdue ) && !todo->hasCompletedDate() ) { // Todo has no due-time set or is already overdue |
1167 | if ( KOPrefs::instance()->mShowTodoInAgenda ) | 1166 | if ( KOPrefs::instance()->mShowTodoInAgenda ) |
1168 | mAllDayAgenda->insertAllDayItem(todo, currentDate, curCol, curCol); | 1167 | mAllDayAgenda->insertAllDayItem(todo, currentDate, curCol, curCol); |
1169 | } | 1168 | } |
1170 | else { | 1169 | else { |
1171 | QDateTime dt; | 1170 | QDateTime dt; |
1172 | if ( todo->hasCompletedDate() ) | 1171 | if ( todo->hasCompletedDate() ) |
1173 | dt = todo->completed(); | 1172 | dt = todo->completed(); |
1174 | else | 1173 | else |
1175 | dt = todo->dtDue();; | 1174 | dt = todo->dtDue();; |
1176 | 1175 | ||
1177 | 1176 | ||
1178 | int endY = mAgenda->timeToY(dt.time()) - 1; | 1177 | int endY = mAgenda->timeToY(dt.time()) - 1; |
1179 | int hi = (18/KOPrefs::instance()->mHourSize); | 1178 | int hi = (18/KOPrefs::instance()->mHourSize); |
1180 | //qDebug("hei %d ",KOPrefs::instance()->mHourSize); | 1179 | //qDebug("hei %d ",KOPrefs::instance()->mHourSize); |
1181 | int startY = endY -hi; | 1180 | int startY = endY -hi; |
1182 | 1181 | ||
1183 | mAgenda->insertItem(todo,currentDate,curCol,startY,endY); | 1182 | mAgenda->insertItem(todo,currentDate,curCol,startY,endY); |
1184 | 1183 | ||
1185 | if (startY < mMinY[curCol]) mMinY[curCol] = startY; | 1184 | if (startY < mMinY[curCol]) mMinY[curCol] = startY; |
1186 | if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; | 1185 | if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; |
1187 | } | 1186 | } |
1188 | } | 1187 | } |
1189 | } | 1188 | } |
1190 | // ---------- display Todos] -------------- | 1189 | // ---------- display Todos] -------------- |
1191 | 1190 | ||
1192 | ++curCol; | 1191 | ++curCol; |
1193 | } | 1192 | } |
1194 | mAgenda->hideUnused(); | 1193 | mAgenda->hideUnused(); |
1195 | mAllDayAgenda->hideUnused(); | 1194 | mAllDayAgenda->hideUnused(); |
1196 | mAgenda->checkScrollBoundaries(); | 1195 | mAgenda->checkScrollBoundaries(); |
1197 | 1196 | ||
1198 | deleteSelectedDateTime(); | 1197 | deleteSelectedDateTime(); |
1199 | 1198 | ||
1200 | createDayLabels(); | 1199 | createDayLabels(); |
1201 | emit incidenceSelected( 0 ); | 1200 | emit incidenceSelected( 0 ); |
1202 | 1201 | ||
1203 | if ( globalFlagBlockAgenda == 2 ) { | 1202 | if ( globalFlagBlockAgenda == 2 ) { |
1204 | if ( KOPrefs::instance()->mSetTimeToDayStartAt ) | 1203 | if ( KOPrefs::instance()->mSetTimeToDayStartAt ) |
1205 | setStartHour( KOPrefs::instance()->mDayBegins ); | 1204 | setStartHour( KOPrefs::instance()->mDayBegins ); |
1206 | else if ( KOPrefs::instance()->mCenterOnCurrentTime ) | 1205 | else if ( KOPrefs::instance()->mCenterOnCurrentTime ) |
1207 | setStartHour( QTime::currentTime ().hour() ); | 1206 | setStartHour( QTime::currentTime ().hour() ); |
1208 | // qApp->processEvents(); | 1207 | // qApp->processEvents(); |
1209 | } | 1208 | } |
1210 | qApp->processEvents(); | 1209 | qApp->processEvents(); |
1211 | //qDebug("qApp->processEvents(); END "); | 1210 | //qDebug("qApp->processEvents(); END "); |
1212 | globalFlagBlockAgenda = 0; | 1211 | globalFlagBlockAgenda = 0; |
1213 | 1212 | ||
1214 | // mAgenda->hideUnused(); | 1213 | // mAgenda->hideUnused(); |
1215 | //mAllDayAgenda->hideUnused(); | 1214 | //mAllDayAgenda->hideUnused(); |
1216 | mAllDayAgenda->drawContentsToPainter(); | 1215 | mAllDayAgenda->drawContentsToPainter(); |
1217 | mAgenda->drawContentsToPainter(); | 1216 | mAgenda->drawContentsToPainter(); |
1218 | repaintAgenda(); | 1217 | repaintAgenda(); |
1219 | // mAgenda->finishUpdate(); | 1218 | // mAgenda->finishUpdate(); |
1220 | //mAllDayAgenda->finishUpdate(); | 1219 | //mAllDayAgenda->finishUpdate(); |
1221 | 1220 | ||
1222 | // repaintAgenda(); | 1221 | // repaintAgenda(); |
1223 | //qApp->processEvents(); | 1222 | //qApp->processEvents(); |
1224 | // globalFlagBlockAgenda = 0; | 1223 | // globalFlagBlockAgenda = 0; |
1225 | } | 1224 | } |
1226 | void KOAgendaView::repaintAgenda() | 1225 | void KOAgendaView::repaintAgenda() |
1227 | { | 1226 | { |
1228 | // mAllDayAgenda->drawContentsToPainter(); | 1227 | // mAllDayAgenda->drawContentsToPainter(); |
1229 | // mAllDayAgenda->viewport()->repaint( false ); | 1228 | // mAllDayAgenda->viewport()->repaint( false ); |
1230 | // mAgenda->drawContentsToPainter(); | 1229 | // mAgenda->drawContentsToPainter(); |
1231 | // mAgenda->viewport()->repaint( false ); | 1230 | // mAgenda->viewport()->repaint( false ); |
1232 | // qApp->processEvents(); | 1231 | // qApp->processEvents(); |
1233 | 1232 | ||
1234 | //qDebug("KOAgendaView::repaintAgenda() "); | 1233 | //qDebug("KOAgendaView::repaintAgenda() "); |
1235 | //qApp->processEvents(); | 1234 | //qApp->processEvents(); |
1236 | mAgenda->viewport()->repaint( false ); | 1235 | mAgenda->viewport()->repaint( false ); |
1237 | mAllDayAgenda->viewport()->repaint( false ); | 1236 | mAllDayAgenda->viewport()->repaint( false ); |
1238 | mAgenda->finishUpdate(); | 1237 | mAgenda->finishUpdate(); |
1239 | mAllDayAgenda->finishUpdate(); | 1238 | mAllDayAgenda->finishUpdate(); |
1240 | } | 1239 | } |
1241 | 1240 | ||
1242 | 1241 | ||
1243 | void KOAgendaView::clearView() | 1242 | void KOAgendaView::clearView() |
1244 | { | 1243 | { |
1245 | // kdDebug() << "ClearView" << endl; | 1244 | // kdDebug() << "ClearView" << endl; |
1246 | mAllDayAgenda->clear(); | 1245 | mAllDayAgenda->clear(); |
1247 | mAgenda->clear(); | 1246 | mAgenda->clear(); |
1248 | } | 1247 | } |
1249 | 1248 | ||
1250 | void KOAgendaView::printPreview(CalPrinter *calPrinter, const QDate &fd, | 1249 | void KOAgendaView::printPreview(CalPrinter *calPrinter, const QDate &fd, |
1251 | const QDate &td) | 1250 | const QDate &td) |
1252 | { | 1251 | { |
1253 | #ifndef KORG_NOPRINTER | 1252 | #ifndef KORG_NOPRINTER |
1254 | if (fd == td) | 1253 | if (fd == td) |
1255 | calPrinter->preview(CalPrinter::Day, fd, td); | 1254 | calPrinter->preview(CalPrinter::Day, fd, td); |
1256 | else | 1255 | else |
1257 | calPrinter->preview(CalPrinter::Week, fd, td); | 1256 | calPrinter->preview(CalPrinter::Week, fd, td); |
1258 | #endif | 1257 | #endif |
1259 | } | 1258 | } |
1260 | 1259 | ||
1261 | // void KOAgendaView::updateMovedTodo() | 1260 | // void KOAgendaView::updateMovedTodo() |
1262 | // { | 1261 | // { |
1263 | // // updateConfig(); | 1262 | // // updateConfig(); |
1264 | // // emit updateTodoViews(); | 1263 | // // emit updateTodoViews(); |
1265 | // } | 1264 | // } |
1266 | 1265 | ||
1267 | void KOAgendaView::newEvent(int gx, int gy) | 1266 | void KOAgendaView::newEvent(int gx, int gy) |
1268 | { | 1267 | { |
1269 | if (!mSelectedDates.count()) return; | 1268 | if (!mSelectedDates.count()) return; |
1270 | 1269 | ||
1271 | QDate day = mSelectedDates[gx]; | 1270 | QDate day = mSelectedDates[gx]; |
1272 | 1271 | ||
1273 | QTime time = mAgenda->gyToTime(gy); | 1272 | QTime time = mAgenda->gyToTime(gy); |
1274 | QDateTime dt(day,time); | 1273 | QDateTime dt(day,time); |
1275 | // if ( dt < QDateTime::currentDateTime () ) | 1274 | // if ( dt < QDateTime::currentDateTime () ) |
1276 | // dt = QDateTime::currentDateTime ().addSecs( 3600 ); | 1275 | // dt = QDateTime::currentDateTime ().addSecs( 3600 ); |
1277 | emit newEventSignal(dt); | 1276 | emit newEventSignal(dt); |
1278 | } | 1277 | } |
1279 | 1278 | ||
1280 | void KOAgendaView::newEvent(int gxStart, int gyStart, int gxEnd, int gyEnd) | 1279 | void KOAgendaView::newEvent(int gxStart, int gyStart, int gxEnd, int gyEnd) |
1281 | { | 1280 | { |
1282 | if (!mSelectedDates.count()) return; | 1281 | if (!mSelectedDates.count()) return; |
1283 | 1282 | ||
1284 | QDate dayStart = mSelectedDates[gxStart]; | 1283 | QDate dayStart = mSelectedDates[gxStart]; |
1285 | QDate dayEnd = mSelectedDates[gxEnd]; | 1284 | QDate dayEnd = mSelectedDates[gxEnd]; |
1286 | 1285 | ||
1287 | QTime timeStart = mAgenda->gyToTime(gyStart); | 1286 | QTime timeStart = mAgenda->gyToTime(gyStart); |
1288 | QTime timeEnd = mAgenda->gyToTime( gyEnd + 1 ); | 1287 | QTime timeEnd = mAgenda->gyToTime( gyEnd + 1 ); |
1289 | 1288 | ||
1290 | QDateTime dtStart(dayStart,timeStart); | 1289 | QDateTime dtStart(dayStart,timeStart); |
1291 | QDateTime dtEnd(dayEnd,timeEnd); | 1290 | QDateTime dtEnd(dayEnd,timeEnd); |
1292 | 1291 | ||
@@ -1383,168 +1382,168 @@ void KOAgendaView::writeSettings(KConfig *config) | |||
1383 | config->setGroup("Views"); | 1382 | config->setGroup("Views"); |
1384 | 1383 | ||
1385 | //#ifndef KORG_NOSPLITTER | 1384 | //#ifndef KORG_NOSPLITTER |
1386 | QValueList<int> list = mSplitterAgenda->sizes(); | 1385 | QValueList<int> list = mSplitterAgenda->sizes(); |
1387 | config->writeEntry("Separator AgendaView",list); | 1386 | config->writeEntry("Separator AgendaView",list); |
1388 | //qDebug("write %d %d ", list[0],list[1] ); | 1387 | //qDebug("write %d %d ", list[0],list[1] ); |
1389 | //#endif | 1388 | //#endif |
1390 | } | 1389 | } |
1391 | 1390 | ||
1392 | void KOAgendaView::setHolidayMasks() | 1391 | void KOAgendaView::setHolidayMasks() |
1393 | { | 1392 | { |
1394 | mHolidayMask.resize(mSelectedDates.count()); | 1393 | mHolidayMask.resize(mSelectedDates.count()); |
1395 | 1394 | ||
1396 | uint i; | 1395 | uint i; |
1397 | for(i=0;i<mSelectedDates.count();++i) { | 1396 | for(i=0;i<mSelectedDates.count();++i) { |
1398 | QDate date = mSelectedDates[i]; | 1397 | QDate date = mSelectedDates[i]; |
1399 | bool showSaturday = KOPrefs::instance()->mExcludeSaturdays && (date.dayOfWeek() == 6); | 1398 | bool showSaturday = KOPrefs::instance()->mExcludeSaturdays && (date.dayOfWeek() == 6); |
1400 | bool showSunday = KOPrefs::instance()->mExcludeHolidays && (date.dayOfWeek() == 7); | 1399 | bool showSunday = KOPrefs::instance()->mExcludeHolidays && (date.dayOfWeek() == 7); |
1401 | bool showHoliday = false; | 1400 | bool showHoliday = false; |
1402 | if ( KOPrefs::instance()->mExcludeHolidays ) { | 1401 | if ( KOPrefs::instance()->mExcludeHolidays ) { |
1403 | QPtrList<Event> events = calendar()->events( date, true ); | 1402 | QPtrList<Event> events = calendar()->events( date, true ); |
1404 | Event *event; | 1403 | Event *event; |
1405 | for( event = events.first(); event; event = events.next() ) { | 1404 | for( event = events.first(); event; event = events.next() ) { |
1406 | if ( event->categories().contains("Holiday") || | 1405 | if ( event->categories().contains("Holiday") || |
1407 | event->categories().contains(i18n("Holiday"))) { | 1406 | event->categories().contains(i18n("Holiday"))) { |
1408 | showHoliday = true; | 1407 | showHoliday = true; |
1409 | break; | 1408 | break; |
1410 | } | 1409 | } |
1411 | } | 1410 | } |
1412 | 1411 | ||
1413 | } | 1412 | } |
1414 | 1413 | ||
1415 | #ifndef KORG_NOPLUGINS | 1414 | #ifndef KORG_NOPLUGINS |
1416 | bool showHoliday = KOPrefs::instance()->mExcludeHolidays && | 1415 | bool showHoliday = KOPrefs::instance()->mExcludeHolidays && |
1417 | !KOCore::self()->holiday(date).isEmpty(); | 1416 | !KOCore::self()->holiday(date).isEmpty(); |
1418 | #endif | 1417 | #endif |
1419 | bool showDay = showSaturday || showSunday || showHoliday; | 1418 | bool showDay = showSaturday || showSunday || showHoliday; |
1420 | 1419 | ||
1421 | if (showDay) { | 1420 | if (showDay) { |
1422 | mHolidayMask.at(i) = true; | 1421 | mHolidayMask.at(i) = true; |
1423 | } else { | 1422 | } else { |
1424 | mHolidayMask.at(i) = false; | 1423 | mHolidayMask.at(i) = false; |
1425 | } | 1424 | } |
1426 | } | 1425 | } |
1427 | 1426 | ||
1428 | mAgenda->setHolidayMask(&mHolidayMask); | 1427 | mAgenda->setHolidayMask(&mHolidayMask); |
1429 | mAllDayAgenda->setHolidayMask(&mHolidayMask); | 1428 | mAllDayAgenda->setHolidayMask(&mHolidayMask); |
1430 | } | 1429 | } |
1431 | 1430 | ||
1432 | void KOAgendaView::setContentsPos(int y) | 1431 | void KOAgendaView::setContentsPos(int y) |
1433 | { | 1432 | { |
1434 | mAgenda->setContentsPos(0,y); | 1433 | mAgenda->setContentsPos(0,y); |
1435 | } | 1434 | } |
1436 | 1435 | ||
1437 | void KOAgendaView::setExpandedButton( bool expanded ) | 1436 | void KOAgendaView::setExpandedButton( bool expanded ) |
1438 | { | 1437 | { |
1439 | if ( expanded ) { | 1438 | if ( expanded ) { |
1440 | mExpandButton->setPixmap( mExpandedPixmap ); | 1439 | mExpandButton->setPixmap( mExpandedPixmap ); |
1441 | } else { | 1440 | } else { |
1442 | mExpandButton->setPixmap( mNotExpandedPixmap ); | 1441 | mExpandButton->setPixmap( mNotExpandedPixmap ); |
1443 | } | 1442 | } |
1444 | } | 1443 | } |
1445 | 1444 | ||
1446 | void KOAgendaView::clearSelection() | 1445 | void KOAgendaView::clearSelection() |
1447 | { | 1446 | { |
1448 | mAgenda->deselectItem(); | 1447 | mAgenda->deselectItem(); |
1449 | mAllDayAgenda->deselectItem(); | 1448 | mAllDayAgenda->deselectItem(); |
1450 | } | 1449 | } |
1451 | 1450 | ||
1452 | void KOAgendaView::newTimeSpanSelectedAllDay(int gxStart, int gyStart, | 1451 | void KOAgendaView::newTimeSpanSelectedAllDay(int gxStart, int gyStart, |
1453 | int gxEnd, int gyEnd) | 1452 | int gxEnd, int gyEnd) |
1454 | { | 1453 | { |
1455 | mTimeSpanInAllDay = true; | 1454 | mTimeSpanInAllDay = true; |
1456 | newTimeSpanSelected(gxStart,gyStart,gxEnd,gyEnd); | 1455 | newTimeSpanSelected(gxStart,gyStart,gxEnd,gyEnd); |
1457 | } | 1456 | } |
1458 | 1457 | ||
1459 | 1458 | ||
1460 | 1459 | ||
1461 | 1460 | ||
1462 | void KOAgendaView::newTimeSpanSelected(int gxStart, int gyStart, | 1461 | void KOAgendaView::newTimeSpanSelected(int gxStart, int gyStart, |
1463 | int gxEnd, int gyEnd) | 1462 | int gxEnd, int gyEnd) |
1464 | { | 1463 | { |
1465 | if (!mSelectedDates.count()) return; | 1464 | if (!mSelectedDates.count()) return; |
1466 | 1465 | ||
1467 | QDate dayStart = mSelectedDates[gxStart]; | 1466 | QDate dayStart = mSelectedDates[gxStart]; |
1468 | QDate dayEnd = mSelectedDates[gxEnd]; | 1467 | QDate dayEnd = mSelectedDates[gxEnd]; |
1469 | 1468 | ||
1470 | QTime timeStart = mAgenda->gyToTime(gyStart); | 1469 | QTime timeStart = mAgenda->gyToTime(gyStart); |
1471 | QTime timeEnd = mAgenda->gyToTime( gyEnd + 1 ); | 1470 | QTime timeEnd = mAgenda->gyToTime( gyEnd + 1 ); |
1472 | 1471 | ||
1473 | QDateTime dtStart(dayStart,timeStart); | 1472 | QDateTime dtStart(dayStart,timeStart); |
1474 | QDateTime dtEnd(dayEnd,timeEnd); | 1473 | QDateTime dtEnd(dayEnd,timeEnd); |
1475 | 1474 | ||
1476 | mTimeSpanBegin = dtStart; | 1475 | mTimeSpanBegin = dtStart; |
1477 | mTimeSpanEnd = dtEnd; | 1476 | mTimeSpanEnd = dtEnd; |
1478 | 1477 | ||
1479 | } | 1478 | } |
1480 | 1479 | ||
1481 | void KOAgendaView::deleteSelectedDateTime() | 1480 | void KOAgendaView::deleteSelectedDateTime() |
1482 | { | 1481 | { |
1483 | mTimeSpanBegin.setDate(QDate()); | 1482 | mTimeSpanBegin.setDate(QDate()); |
1484 | mTimeSpanEnd.setDate(QDate()); | 1483 | mTimeSpanEnd.setDate(QDate()); |
1485 | mTimeSpanInAllDay = false; | 1484 | mTimeSpanInAllDay = false; |
1486 | } | 1485 | } |
1487 | 1486 | ||
1488 | void KOAgendaView::keyPressEvent ( QKeyEvent * e ) | 1487 | void KOAgendaView::keyPressEvent ( QKeyEvent * e ) |
1489 | { | 1488 | { |
1490 | e->ignore(); | 1489 | e->ignore(); |
1491 | } | 1490 | } |
1492 | 1491 | ||
1493 | void KOAgendaView::scrollOneHourUp() | 1492 | void KOAgendaView::scrollOneHourUp() |
1494 | { | 1493 | { |
1495 | 1494 | ||
1496 | mAgenda->scrollBy ( 0, -mAgenda->contentsHeight () / 24 ); | 1495 | mAgenda->scrollBy ( 0, -mAgenda->contentsHeight () / 24 ); |
1497 | } | 1496 | } |
1498 | void KOAgendaView::scrollOneHourDown() | 1497 | void KOAgendaView::scrollOneHourDown() |
1499 | { | 1498 | { |
1500 | mAgenda->scrollBy ( 0, mAgenda->contentsHeight () / 24 ); | 1499 | mAgenda->scrollBy ( 0, mAgenda->contentsHeight () / 24 ); |
1501 | } | 1500 | } |
1502 | 1501 | ||
1503 | void KOAgendaView::setStartHour( int h ) | 1502 | void KOAgendaView::setStartHour( int h ) |
1504 | { | 1503 | { |
1505 | mAgenda->setStartHour( h ); | 1504 | mAgenda->setStartHour( h ); |
1506 | 1505 | ||
1507 | } | 1506 | } |
1508 | 1507 | ||
1509 | void KOAgendaView::updateTodo( Todo * t, int ) | 1508 | void KOAgendaView::updateTodo( Todo * t, int ) |
1510 | { | 1509 | { |
1511 | 1510 | ||
1512 | bool remove = false; | 1511 | bool remove = false; |
1513 | bool removeAD = false; | 1512 | bool removeAD = false; |
1514 | QDate da; | 1513 | QDate da; |
1515 | if ( t->hasCompletedDate() ) | 1514 | if ( t->hasCompletedDate() ) |
1516 | da = t->completed().date(); | 1515 | da = t->completed().date(); |
1517 | else | 1516 | else |
1518 | da = t->dtDue().date(); | 1517 | da = t->dtDue().date(); |
1519 | if ( ! t->hasDueDate() && !t->hasCompletedDate() ) { | 1518 | if ( ! t->hasDueDate() && !t->hasCompletedDate() ) { |
1520 | remove = true; | 1519 | remove = true; |
1521 | removeAD = true; | 1520 | removeAD = true; |
1522 | } | 1521 | } |
1523 | else { | 1522 | else { |
1524 | bool overdue = (!t->isCompleted()) && (t->dtDue() < QDate::currentDate()) && KOPrefs::instance()->mShowTodoInAgenda ; | 1523 | bool overdue = (!t->isCompleted()) && (t->dtDue() < QDate::currentDate()) && KOPrefs::instance()->mShowTodoInAgenda ; |
1525 | if ( overdue && | 1524 | if ( overdue && |
1526 | QDate::currentDate() >= mSelectedDates.first() && | 1525 | QDate::currentDate() >= mSelectedDates.first() && |
1527 | QDate::currentDate() <= mSelectedDates.last()) { | 1526 | QDate::currentDate() <= mSelectedDates.last()) { |
1528 | removeAD = false; | 1527 | removeAD = false; |
1529 | remove = true; | 1528 | remove = true; |
1530 | } | 1529 | } |
1531 | else { | 1530 | else { |
1532 | 1531 | ||
1533 | if ( da < mSelectedDates.first() || | 1532 | if ( da < mSelectedDates.first() || |
1534 | da > mSelectedDates.last() ) { | 1533 | da > mSelectedDates.last() ) { |
1535 | remove = true; | 1534 | remove = true; |
1536 | removeAD = true; | 1535 | removeAD = true; |
1537 | } else { | 1536 | } else { |
1538 | remove = t->doesFloat() && !t->hasCompletedDate(); | 1537 | remove = t->doesFloat() && !t->hasCompletedDate(); |
1539 | removeAD = !remove; | 1538 | removeAD = !remove; |
1540 | } | 1539 | } |
1541 | } | 1540 | } |
1542 | } | 1541 | } |
1543 | int days = mSelectedDates.first().daysTo( da ); | 1542 | int days = mSelectedDates.first().daysTo( da ); |
1544 | // qDebug("daysto %d ", days ); | 1543 | // qDebug("daysto %d ", days ); |
1545 | mAgenda->updateTodo( t , days, remove); | 1544 | mAgenda->updateTodo( t , days, remove); |
1546 | if ( KOPrefs::instance()->mShowTodoInAgenda ) | 1545 | if ( KOPrefs::instance()->mShowTodoInAgenda ) |
1547 | mAllDayAgenda->updateTodo( t , days, removeAD); | 1546 | mAllDayAgenda->updateTodo( t , days, removeAD); |
1548 | //qDebug("KOAgendaView::updateTodo( Todo *, int ) "); | 1547 | //qDebug("KOAgendaView::updateTodo( Todo *, int ) "); |
1549 | 1548 | ||
1550 | } | 1549 | } |
diff --git a/korganizer/kotodoview.cpp b/korganizer/kotodoview.cpp index 14e8b5c..902f3f4 100644 --- a/korganizer/kotodoview.cpp +++ b/korganizer/kotodoview.cpp | |||
@@ -732,267 +732,276 @@ void KOTodoView::showDates(const QDate &, const QDate &) | |||
732 | void KOTodoView::showEvents(QPtrList<Event>) | 732 | void KOTodoView::showEvents(QPtrList<Event>) |
733 | { | 733 | { |
734 | kdDebug() << "KOTodoView::selectEvents(): not yet implemented" << endl; | 734 | kdDebug() << "KOTodoView::selectEvents(): not yet implemented" << endl; |
735 | } | 735 | } |
736 | 736 | ||
737 | void KOTodoView::printPreview(CalPrinter *calPrinter, const QDate &fd, | 737 | void KOTodoView::printPreview(CalPrinter *calPrinter, const QDate &fd, |
738 | const QDate &td) | 738 | const QDate &td) |
739 | { | 739 | { |
740 | #ifndef KORG_NOPRINTER | 740 | #ifndef KORG_NOPRINTER |
741 | calPrinter->preview(CalPrinter::Todolist, fd, td); | 741 | calPrinter->preview(CalPrinter::Todolist, fd, td); |
742 | #endif | 742 | #endif |
743 | } | 743 | } |
744 | 744 | ||
745 | void KOTodoView::editItem(QListViewItem *item ) | 745 | void KOTodoView::editItem(QListViewItem *item ) |
746 | { | 746 | { |
747 | // qDebug("editItem(QListViewItem *item ) "); | 747 | // qDebug("editItem(QListViewItem *item ) "); |
748 | emit editTodoSignal(((KOTodoViewItem *)item)->todo()); | 748 | emit editTodoSignal(((KOTodoViewItem *)item)->todo()); |
749 | } | 749 | } |
750 | 750 | ||
751 | void KOTodoView::showItem(QListViewItem *item,const QPoint &,int) | 751 | void KOTodoView::showItem(QListViewItem *item,const QPoint &,int) |
752 | { | 752 | { |
753 | emit showTodoSignal(((KOTodoViewItem *)item)->todo()); | 753 | emit showTodoSignal(((KOTodoViewItem *)item)->todo()); |
754 | } | 754 | } |
755 | 755 | ||
756 | void KOTodoView::popupMenu(QListViewItem *item,const QPoint &,int column) | 756 | void KOTodoView::popupMenu(QListViewItem *item,const QPoint &,int column) |
757 | { | 757 | { |
758 | pendingSubtodo = 0; | 758 | pendingSubtodo = 0; |
759 | mActiveItem = (KOTodoViewItem *)item; | 759 | mActiveItem = (KOTodoViewItem *)item; |
760 | if (item) { | 760 | if (item) { |
761 | switch (column){ | 761 | switch (column){ |
762 | case 1: | 762 | case 1: |
763 | mPriorityPopupMenu->popup(QCursor::pos ()); break; | 763 | mPriorityPopupMenu->popup(QCursor::pos ()); break; |
764 | case 2: | 764 | case 2: |
765 | mPercentageCompletedPopupMenu->popup(QCursor::pos ()); break; | 765 | mPercentageCompletedPopupMenu->popup(QCursor::pos ()); break; |
766 | case 3: | 766 | case 3: |
767 | moveTodo(); | 767 | moveTodo(); |
768 | break; | 768 | break; |
769 | case 8: | 769 | case 8: |
770 | getCategoryPopupMenu((KOTodoViewItem *)item)->popup(QCursor::pos ()); break; | 770 | getCategoryPopupMenu((KOTodoViewItem *)item)->popup(QCursor::pos ()); break; |
771 | default: | 771 | default: |
772 | mItemPopupMenu->popup(QCursor::pos()); | 772 | mItemPopupMenu->popup(QCursor::pos()); |
773 | } | 773 | } |
774 | } else mPopupMenu->popup(QCursor::pos()); | 774 | } else mPopupMenu->popup(QCursor::pos()); |
775 | } | 775 | } |
776 | void KOTodoView::newTodo() | 776 | void KOTodoView::newTodo() |
777 | { | 777 | { |
778 | emit newTodoSignal(); | 778 | emit newTodoSignal(); |
779 | } | 779 | } |
780 | 780 | ||
781 | void KOTodoView::newSubTodo() | 781 | void KOTodoView::newSubTodo() |
782 | { | 782 | { |
783 | if (mActiveItem) { | 783 | if (mActiveItem) { |
784 | emit newSubTodoSignal(mActiveItem->todo()); | 784 | emit newSubTodoSignal(mActiveItem->todo()); |
785 | } | 785 | } |
786 | } | 786 | } |
787 | void KOTodoView::unparentTodo() | 787 | void KOTodoView::unparentTodo() |
788 | { | 788 | { |
789 | if (mActiveItem) { | 789 | if (mActiveItem) { |
790 | emit unparentTodoSignal(mActiveItem->todo()); | 790 | emit unparentTodoSignal(mActiveItem->todo()); |
791 | } | 791 | } |
792 | } | 792 | } |
793 | 793 | ||
794 | void KOTodoView::reparentTodo() | 794 | void KOTodoView::reparentTodo() |
795 | { | 795 | { |
796 | if (mActiveItem) { | 796 | if (mActiveItem) { |
797 | qDebug("KOTodoView::reparentTodo() "); | 797 | qDebug("KOTodoView::reparentTodo() "); |
798 | topLevelWidget()->setCaption(i18n("Click on new parent item")); | 798 | topLevelWidget()->setCaption(i18n("Click on new parent item")); |
799 | pendingSubtodo = mActiveItem; | 799 | pendingSubtodo = mActiveItem; |
800 | } | 800 | } |
801 | } | 801 | } |
802 | void KOTodoView::editTodo() | 802 | void KOTodoView::editTodo() |
803 | { | 803 | { |
804 | if (mActiveItem) { | 804 | if (mActiveItem) { |
805 | emit editTodoSignal(mActiveItem->todo()); | 805 | emit editTodoSignal(mActiveItem->todo()); |
806 | } | 806 | } |
807 | } | 807 | } |
808 | void KOTodoView::cloneTodo() | 808 | void KOTodoView::cloneTodo() |
809 | { | 809 | { |
810 | if (mActiveItem) { | 810 | if (mActiveItem) { |
811 | emit cloneTodoSignal((Incidence*)mActiveItem->todo()); | 811 | emit cloneTodoSignal((Incidence*)mActiveItem->todo()); |
812 | } | 812 | } |
813 | } | 813 | } |
814 | void KOTodoView::cancelTodo() | 814 | void KOTodoView::cancelTodo() |
815 | { | 815 | { |
816 | if (mActiveItem) { | 816 | if (mActiveItem) { |
817 | emit cancelTodoSignal((Incidence*)mActiveItem->todo()); | 817 | emit cancelTodoSignal((Incidence*)mActiveItem->todo()); |
818 | } | 818 | } |
819 | } | 819 | } |
820 | void KOTodoView::moveTodo() | 820 | void KOTodoView::moveTodo() |
821 | { | 821 | { |
822 | if (mActiveItem) { | 822 | if (mActiveItem) { |
823 | emit moveTodoSignal((Incidence*)mActiveItem->todo()); | 823 | emit moveTodoSignal((Incidence*)mActiveItem->todo()); |
824 | } | 824 | } |
825 | } | 825 | } |
826 | void KOTodoView::beamTodo() | 826 | void KOTodoView::beamTodo() |
827 | { | 827 | { |
828 | if (mActiveItem) { | 828 | if (mActiveItem) { |
829 | emit beamTodoSignal((Incidence*)mActiveItem->todo()); | 829 | emit beamTodoSignal((Incidence*)mActiveItem->todo()); |
830 | } | 830 | } |
831 | } | 831 | } |
832 | 832 | ||
833 | 833 | ||
834 | void KOTodoView::showTodo() | 834 | void KOTodoView::showTodo() |
835 | { | 835 | { |
836 | if (mActiveItem) { | 836 | if (mActiveItem) { |
837 | emit showTodoSignal(mActiveItem->todo()); | 837 | emit showTodoSignal(mActiveItem->todo()); |
838 | } | 838 | } |
839 | } | 839 | } |
840 | 840 | ||
841 | void KOTodoView::deleteTodo() | 841 | void KOTodoView::deleteTodo() |
842 | { | 842 | { |
843 | if (mActiveItem) { | 843 | if (mActiveItem) { |
844 | emit deleteTodoSignal(mActiveItem->todo()); | 844 | emit deleteTodoSignal(mActiveItem->todo()); |
845 | } | 845 | } |
846 | } | 846 | } |
847 | 847 | ||
848 | void KOTodoView::setNewPriority(int index) | 848 | void KOTodoView::setNewPriority(int index) |
849 | { | 849 | { |
850 | if (mActiveItem && !mActiveItem->todo()->isReadOnly ()) { | 850 | if (mActiveItem && !mActiveItem->todo()->isReadOnly ()) { |
851 | mActiveItem->todo()->setPriority(mPriority[index]); | 851 | mActiveItem->todo()->setPriority(mPriority[index]); |
852 | mActiveItem->construct(); | 852 | mActiveItem->construct(); |
853 | todoModified (mActiveItem->todo(), KOGlobals::PRIORITY_MODIFIED); | 853 | todoModified (mActiveItem->todo(), KOGlobals::PRIORITY_MODIFIED); |
854 | mActiveItem->todo()->setRevision( mActiveItem->todo()->revision()+1 ); | 854 | mActiveItem->todo()->setRevision( mActiveItem->todo()->revision()+1 ); |
855 | } | 855 | } |
856 | } | 856 | } |
857 | 857 | ||
858 | void KOTodoView::setNewPercentage(int index) | 858 | void KOTodoView::setNewPercentage(int index) |
859 | { | 859 | { |
860 | if (mActiveItem && !mActiveItem->todo()->isReadOnly ()) { | 860 | if (mActiveItem && !mActiveItem->todo()->isReadOnly ()) { |
861 | if (mPercentage[index] == 100) { | 861 | |
862 | mActiveItem->todo()->setCompleted(QDateTime::currentDateTime()); | 862 | if ( mPercentage[index] == 100 && !mActiveItem->isOn() ) { |
863 | } else { | 863 | mActiveItem->setOn( true ); |
864 | mActiveItem->todo()->setCompleted(false); | 864 | return; |
865 | } else if ( mPercentage[index] != 100 && mActiveItem->isOn() ) { | ||
866 | KOTodoViewItem* par = (static_cast<KOTodoViewItem*>(mActiveItem->parent())); | ||
867 | if ( par && par->isOn() ) | ||
868 | par->setOn( false ); | ||
869 | } | ||
870 | if (mPercentage[index] == 100) { | ||
871 | mActiveItem->todo()->setCompleted(QDateTime::currentDateTime()); | ||
872 | } else { | ||
873 | mActiveItem->todo()->setCompleted(false); | ||
874 | } | ||
875 | mActiveItem->todo()->setPercentComplete(mPercentage[index]); | ||
876 | mActiveItem->construct(); | ||
877 | todoModified (mActiveItem->todo (), KOGlobals::COMPLETION_MODIFIED); | ||
878 | mActiveItem->todo()->setRevision( mActiveItem->todo()->revision()+1 ); | ||
865 | } | 879 | } |
866 | mActiveItem->todo()->setPercentComplete(mPercentage[index]); | ||
867 | mActiveItem->construct(); | ||
868 | todoModified (mActiveItem->todo (), KOGlobals::COMPLETION_MODIFIED); | ||
869 | mActiveItem->todo()->setRevision( mActiveItem->todo()->revision()+1 ); | ||
870 | } | ||
871 | } | 880 | } |
872 | 881 | ||
873 | 882 | ||
874 | QPopupMenu * KOTodoView::getCategoryPopupMenu (KOTodoViewItem *todoItem) | 883 | QPopupMenu * KOTodoView::getCategoryPopupMenu (KOTodoViewItem *todoItem) |
875 | { | 884 | { |
876 | QPopupMenu* tempMenu = new QPopupMenu (this); | 885 | QPopupMenu* tempMenu = new QPopupMenu (this); |
877 | QStringList checkedCategories = todoItem->todo()->categories (); | 886 | QStringList checkedCategories = todoItem->todo()->categories (); |
878 | 887 | ||
879 | tempMenu->setCheckable (true); | 888 | tempMenu->setCheckable (true); |
880 | for (QStringList::Iterator it = KOPrefs::instance()->mCustomCategories.begin (); | 889 | for (QStringList::Iterator it = KOPrefs::instance()->mCustomCategories.begin (); |
881 | it != KOPrefs::instance()->mCustomCategories.end (); | 890 | it != KOPrefs::instance()->mCustomCategories.end (); |
882 | ++it) { | 891 | ++it) { |
883 | int index = tempMenu->insertItem (*it); | 892 | int index = tempMenu->insertItem (*it); |
884 | mCategory[index] = *it; | 893 | mCategory[index] = *it; |
885 | if (checkedCategories.find (*it) != checkedCategories.end ()) tempMenu->setItemChecked (index, true); | 894 | if (checkedCategories.find (*it) != checkedCategories.end ()) tempMenu->setItemChecked (index, true); |
886 | } | 895 | } |
887 | 896 | ||
888 | connect (tempMenu, SIGNAL (activated (int)), SLOT (changedCategories (int))); | 897 | connect (tempMenu, SIGNAL (activated (int)), SLOT (changedCategories (int))); |
889 | return tempMenu; | 898 | return tempMenu; |
890 | 899 | ||
891 | 900 | ||
892 | } | 901 | } |
893 | void KOTodoView::changedCategories(int index) | 902 | void KOTodoView::changedCategories(int index) |
894 | { | 903 | { |
895 | if (mActiveItem && !mActiveItem->todo()->isReadOnly ()) { | 904 | if (mActiveItem && !mActiveItem->todo()->isReadOnly ()) { |
896 | QStringList categories = mActiveItem->todo()->categories (); | 905 | QStringList categories = mActiveItem->todo()->categories (); |
897 | if (categories.find (mCategory[index]) != categories.end ()) | 906 | if (categories.find (mCategory[index]) != categories.end ()) |
898 | categories.remove (mCategory[index]); | 907 | categories.remove (mCategory[index]); |
899 | else | 908 | else |
900 | categories.insert (categories.end(), mCategory[index]); | 909 | categories.insert (categories.end(), mCategory[index]); |
901 | categories.sort (); | 910 | categories.sort (); |
902 | mActiveItem->todo()->setCategories (categories); | 911 | mActiveItem->todo()->setCategories (categories); |
903 | mActiveItem->construct(); | 912 | mActiveItem->construct(); |
904 | mActiveItem->todo()->setRevision( mActiveItem->todo()->revision()+1 ); | 913 | mActiveItem->todo()->setRevision( mActiveItem->todo()->revision()+1 ); |
905 | todoModified (mActiveItem->todo (), KOGlobals::CATEGORY_MODIFIED); | 914 | todoModified (mActiveItem->todo (), KOGlobals::CATEGORY_MODIFIED); |
906 | } | 915 | } |
907 | } | 916 | } |
908 | void KOTodoView::itemDoubleClicked(QListViewItem *item) | 917 | void KOTodoView::itemDoubleClicked(QListViewItem *item) |
909 | { | 918 | { |
910 | if ( pendingSubtodo != 0 ) { | 919 | if ( pendingSubtodo != 0 ) { |
911 | topLevelWidget()->setCaption(i18n("Reparenting aborted!")); | 920 | topLevelWidget()->setCaption(i18n("Reparenting aborted!")); |
912 | } | 921 | } |
913 | pendingSubtodo = 0; | 922 | pendingSubtodo = 0; |
914 | if (!item) { | 923 | if (!item) { |
915 | newTodo(); | 924 | newTodo(); |
916 | return; | 925 | return; |
917 | } | 926 | } |
918 | if ( KOPrefs::instance()->mEditOnDoubleClick ) | 927 | if ( KOPrefs::instance()->mEditOnDoubleClick ) |
919 | editItem( item ); | 928 | editItem( item ); |
920 | else | 929 | else |
921 | showItem( item , QPoint(), 0 ); | 930 | showItem( item , QPoint(), 0 ); |
922 | } | 931 | } |
923 | void KOTodoView::itemClicked(QListViewItem *item) | 932 | void KOTodoView::itemClicked(QListViewItem *item) |
924 | { | 933 | { |
925 | 934 | ||
926 | if (!item) { | 935 | if (!item) { |
927 | if ( pendingSubtodo != 0 ) { | 936 | if ( pendingSubtodo != 0 ) { |
928 | topLevelWidget()->setCaption(i18n("Reparenting aborted!")); | 937 | topLevelWidget()->setCaption(i18n("Reparenting aborted!")); |
929 | } | 938 | } |
930 | pendingSubtodo = 0; | 939 | pendingSubtodo = 0; |
931 | return; | 940 | return; |
932 | } | 941 | } |
933 | KOTodoViewItem *todoItem = (KOTodoViewItem *)item; | 942 | KOTodoViewItem *todoItem = (KOTodoViewItem *)item; |
934 | if ( pendingSubtodo != 0 ) { | 943 | if ( pendingSubtodo != 0 ) { |
935 | bool allowReparent = true; | 944 | bool allowReparent = true; |
936 | QListViewItem *par = item; | 945 | QListViewItem *par = item; |
937 | while ( par ) { | 946 | while ( par ) { |
938 | if ( par == pendingSubtodo ) { | 947 | if ( par == pendingSubtodo ) { |
939 | allowReparent = false; | 948 | allowReparent = false; |
940 | break; | 949 | break; |
941 | } | 950 | } |
942 | par = par->parent(); | 951 | par = par->parent(); |
943 | } | 952 | } |
944 | if ( !allowReparent ) { | 953 | if ( !allowReparent ) { |
945 | topLevelWidget()->setCaption(i18n("Recursive reparenting not possible!")); | 954 | topLevelWidget()->setCaption(i18n("Recursive reparenting not possible!")); |
946 | qDebug("Recursive reparenting not possible "); | 955 | qDebug("Recursive reparenting not possible "); |
947 | pendingSubtodo = 0; | 956 | pendingSubtodo = 0; |
948 | } else { | 957 | } else { |
949 | Todo* newParent = todoItem->todo(); | 958 | Todo* newParent = todoItem->todo(); |
950 | Todo* newSub = pendingSubtodo->todo(); | 959 | Todo* newSub = pendingSubtodo->todo(); |
951 | pendingSubtodo = 0; | 960 | pendingSubtodo = 0; |
952 | emit reparentTodoSignal( newParent,newSub ); | 961 | emit reparentTodoSignal( newParent,newSub ); |
953 | return; | 962 | return; |
954 | } | 963 | } |
955 | } | 964 | } |
956 | #if 0 | 965 | #if 0 |
957 | // handled by the item itself | 966 | // handled by the item itself |
958 | bool completed = todoItem->todo()->isCompleted(); // Completed or not? | 967 | bool completed = todoItem->todo()->isCompleted(); // Completed or not? |
959 | qDebug("com %d ",completed ); | 968 | qDebug("com %d ",completed ); |
960 | qDebug("itemclicked "); | 969 | qDebug("itemclicked "); |
961 | if (todoItem->isOn()) { | 970 | if (todoItem->isOn()) { |
962 | qDebug("on "); | 971 | qDebug("on "); |
963 | if (!completed) { | 972 | if (!completed) { |
964 | qDebug("set true "); | 973 | qDebug("set true "); |
965 | todoItem->todo()->setCompleted(QDateTime::currentDateTime()); | 974 | todoItem->todo()->setCompleted(QDateTime::currentDateTime()); |
966 | } | 975 | } |
967 | } else { | 976 | } else { |
968 | qDebug("not on "); | 977 | qDebug("not on "); |
969 | if (completed) { | 978 | if (completed) { |
970 | qDebug("set false "); | 979 | qDebug("set false "); |
971 | todoItem->todo()->setCompleted(false); | 980 | todoItem->todo()->setCompleted(false); |
972 | } | 981 | } |
973 | } | 982 | } |
974 | #endif | 983 | #endif |
975 | } | 984 | } |
976 | 985 | ||
977 | void KOTodoView::setDocumentId( const QString &id ) | 986 | void KOTodoView::setDocumentId( const QString &id ) |
978 | { | 987 | { |
979 | kdDebug() << "KOTodoView::setDocumentId()" << endl; | 988 | kdDebug() << "KOTodoView::setDocumentId()" << endl; |
980 | 989 | ||
981 | mDocPrefs->setDoc( id ); | 990 | mDocPrefs->setDoc( id ); |
982 | } | 991 | } |
983 | 992 | ||
984 | void KOTodoView::itemStateChanged( QListViewItem *item ) | 993 | void KOTodoView::itemStateChanged( QListViewItem *item ) |
985 | { | 994 | { |
986 | if (!item) return; | 995 | if (!item) return; |
987 | 996 | ||
988 | KOTodoViewItem *todoItem = (KOTodoViewItem *)item; | 997 | KOTodoViewItem *todoItem = (KOTodoViewItem *)item; |
989 | 998 | ||
990 | // kdDebug() << "KOTodoView::itemStateChanged(): " << todoItem->todo()->summary() << endl; | 999 | // kdDebug() << "KOTodoView::itemStateChanged(): " << todoItem->todo()->summary() << endl; |
991 | 1000 | ||
992 | if( mDocPrefs ) mDocPrefs->writeEntry( todoItem->todo()->uid(), todoItem->isOpen() ); | 1001 | if( mDocPrefs ) mDocPrefs->writeEntry( todoItem->todo()->uid(), todoItem->isOpen() ); |
993 | } | 1002 | } |
994 | 1003 | ||
995 | void KOTodoView::saveLayout(KConfig *config, const QString &group) const | 1004 | void KOTodoView::saveLayout(KConfig *config, const QString &group) const |
996 | { | 1005 | { |
997 | mTodoListView->saveLayout(config,group); | 1006 | mTodoListView->saveLayout(config,group); |
998 | } | 1007 | } |
diff --git a/korganizer/kotodoviewitem.cpp b/korganizer/kotodoviewitem.cpp index 2822237..1edddac 100644 --- a/korganizer/kotodoviewitem.cpp +++ b/korganizer/kotodoviewitem.cpp | |||
@@ -78,299 +78,307 @@ void KOTodoViewItem::construct() | |||
78 | // qDebug("KOTodoViewItem::construct() "); | 78 | // qDebug("KOTodoViewItem::construct() "); |
79 | m_init = true; | 79 | m_init = true; |
80 | QString keyd = "=="; | 80 | QString keyd = "=="; |
81 | QString keyt = "=="; | 81 | QString keyt = "=="; |
82 | QString skeyd = "=="; | 82 | QString skeyd = "=="; |
83 | QString skeyt = "=="; | 83 | QString skeyt = "=="; |
84 | 84 | ||
85 | setOn(mTodo->isCompleted()); | 85 | setOn(mTodo->isCompleted()); |
86 | setText(0,mTodo->summary()); | 86 | setText(0,mTodo->summary()); |
87 | setText(1,QString::number(mTodo->priority())); | 87 | setText(1,QString::number(mTodo->priority())); |
88 | setText(2,i18n("%1 %").arg(QString::number(mTodo->percentComplete()))); | 88 | setText(2,i18n("%1 %").arg(QString::number(mTodo->percentComplete()))); |
89 | if (mTodo->percentComplete()<100) { | 89 | if (mTodo->percentComplete()<100) { |
90 | if (mTodo->isCompleted()) setSortKey(2,QString::number(999)); | 90 | if (mTodo->isCompleted()) setSortKey(2,QString::number(999)); |
91 | else setSortKey(2,QString::number(mTodo->percentComplete())); | 91 | else setSortKey(2,QString::number(mTodo->percentComplete())); |
92 | } | 92 | } |
93 | else { | 93 | else { |
94 | if (mTodo->isCompleted()) setSortKey(2,QString::number(999)); | 94 | if (mTodo->isCompleted()) setSortKey(2,QString::number(999)); |
95 | else setSortKey(2,QString::number(99)); | 95 | else setSortKey(2,QString::number(99)); |
96 | } | 96 | } |
97 | if (mTodo->hasDueDate()) { | 97 | if (mTodo->hasDueDate()) { |
98 | setText(3, mTodo->dtDueDateStr()); | 98 | setText(3, mTodo->dtDueDateStr()); |
99 | QDate d = mTodo->dtDue().date(); | 99 | QDate d = mTodo->dtDue().date(); |
100 | keyd.sprintf("%04d%02d%02d",d.year(),d.month(),d.day()); | 100 | keyd.sprintf("%04d%02d%02d",d.year(),d.month(),d.day()); |
101 | // setSortKey(3,keyd); | 101 | // setSortKey(3,keyd); |
102 | if (mTodo->doesFloat()) { | 102 | if (mTodo->doesFloat()) { |
103 | setText(4,""); | 103 | setText(4,""); |
104 | } | 104 | } |
105 | else { | 105 | else { |
106 | setText(4,mTodo->dtDueTimeStr()); | 106 | setText(4,mTodo->dtDueTimeStr()); |
107 | QTime t = mTodo->dtDue().time(); | 107 | QTime t = mTodo->dtDue().time(); |
108 | keyt.sprintf("%02d%02d",t.hour(),t.minute()); | 108 | keyt.sprintf("%02d%02d",t.hour(),t.minute()); |
109 | //setSortKey(4,keyt); | 109 | //setSortKey(4,keyt); |
110 | } | 110 | } |
111 | } else { | 111 | } else { |
112 | setText(3,""); | 112 | setText(3,""); |
113 | setText(4,""); | 113 | setText(4,""); |
114 | } | 114 | } |
115 | setSortKey(3,keyd); | 115 | setSortKey(3,keyd); |
116 | setSortKey(4,keyt); | 116 | setSortKey(4,keyt); |
117 | 117 | ||
118 | if (mTodo->isCompleted()) setSortKey(1,"6" + QString::number(mTodo->priority())+keyd+keyt); | 118 | if (mTodo->isCompleted()) setSortKey(1,"6" + QString::number(mTodo->priority())+keyd+keyt); |
119 | else setSortKey(1,QString::number(mTodo->priority())+keyd+keyt); | 119 | else setSortKey(1,QString::number(mTodo->priority())+keyd+keyt); |
120 | 120 | ||
121 | 121 | ||
122 | 122 | ||
123 | if (mTodo->hasStartDate()) { | 123 | if (mTodo->hasStartDate()) { |
124 | setText(5, mTodo->dtStartDateStr()); | 124 | setText(5, mTodo->dtStartDateStr()); |
125 | QDate d = mTodo->dtStart().date(); | 125 | QDate d = mTodo->dtStart().date(); |
126 | skeyd.sprintf("%04d%02d%02d",d.year(),d.month(),d.day()); | 126 | skeyd.sprintf("%04d%02d%02d",d.year(),d.month(),d.day()); |
127 | 127 | ||
128 | if (mTodo->doesFloat()) { | 128 | if (mTodo->doesFloat()) { |
129 | setText(6,""); | 129 | setText(6,""); |
130 | } | 130 | } |
131 | else { | 131 | else { |
132 | setText(6,mTodo->dtStartTimeStr()); | 132 | setText(6,mTodo->dtStartTimeStr()); |
133 | QTime t = mTodo->dtStart().time(); | 133 | QTime t = mTodo->dtStart().time(); |
134 | skeyt.sprintf("%02d%02d",t.hour(),t.minute()); | 134 | skeyt.sprintf("%02d%02d",t.hour(),t.minute()); |
135 | 135 | ||
136 | } | 136 | } |
137 | } else { | 137 | } else { |
138 | setText(5,""); | 138 | setText(5,""); |
139 | setText(6,""); | 139 | setText(6,""); |
140 | } | 140 | } |
141 | setSortKey(5,skeyd); | 141 | setSortKey(5,skeyd); |
142 | setSortKey(6,skeyt); | 142 | setSortKey(6,skeyt); |
143 | 143 | ||
144 | setText(7,mTodo->cancelled() ? i18n("Yes") : i18n("No")); | 144 | setText(7,mTodo->cancelled() ? i18n("Yes") : i18n("No")); |
145 | setText(8,mTodo->categoriesStr()); | 145 | setText(8,mTodo->categoriesStr()); |
146 | 146 | ||
147 | #if 0 | 147 | #if 0 |
148 | // Find sort id in description. It's the text behind the last '#' character | 148 | // Find sort id in description. It's the text behind the last '#' character |
149 | // found in the description. White spaces are removed from beginning and end | 149 | // found in the description. White spaces are removed from beginning and end |
150 | // of sort id. | 150 | // of sort id. |
151 | int pos = mTodo->description().findRev('#'); | 151 | int pos = mTodo->description().findRev('#'); |
152 | if (pos < 0) { | 152 | if (pos < 0) { |
153 | setText(6,""); | 153 | setText(6,""); |
154 | } else { | 154 | } else { |
155 | QString str = mTodo->description().mid(pos+1); | 155 | QString str = mTodo->description().mid(pos+1); |
156 | str.stripWhiteSpace(); | 156 | str.stripWhiteSpace(); |
157 | setText(6,str); | 157 | setText(6,str); |
158 | } | 158 | } |
159 | #endif | 159 | #endif |
160 | 160 | ||
161 | m_known = false; | 161 | m_known = false; |
162 | m_init = false; | 162 | m_init = false; |
163 | 163 | ||
164 | setMyPixmap(); | 164 | setMyPixmap(); |
165 | 165 | ||
166 | } | 166 | } |
167 | void KOTodoViewItem::setMyPixmap() | 167 | void KOTodoViewItem::setMyPixmap() |
168 | { | 168 | { |
169 | int size = 5; | 169 | int size = 5; |
170 | QPixmap pixi = QPixmap( 1, 1 ); | 170 | QPixmap pixi = QPixmap( 1, 1 ); |
171 | // if ( !mTodo->isCompleted() && mTodo->hasDueDate() && mTodo->dtDue() < QDateTime::currentDateTime() ) { | 171 | // if ( !mTodo->isCompleted() && mTodo->hasDueDate() && mTodo->dtDue() < QDateTime::currentDateTime() ) { |
172 | // pixi = SmallIcon("redcross16"); | 172 | // pixi = SmallIcon("redcross16"); |
173 | // } else { | 173 | // } else { |
174 | QPainter p; | 174 | QPainter p; |
175 | 175 | ||
176 | int pixSize = 0; | 176 | int pixSize = 0; |
177 | QPixmap pPix = QPixmap( size, size ); | 177 | QPixmap pPix = QPixmap( size, size ); |
178 | if ( mTodo->description().length() > 0 ) { | 178 | if ( mTodo->description().length() > 0 ) { |
179 | pixi.resize(size, pixSize+size); | 179 | pixi.resize(size, pixSize+size); |
180 | pPix.fill( Qt::darkGreen ); | 180 | pPix.fill( Qt::darkGreen ); |
181 | p.begin( &pixi ); | 181 | p.begin( &pixi ); |
182 | p. drawPixmap ( 0, pixSize, pPix); | 182 | p. drawPixmap ( 0, pixSize, pPix); |
183 | p.end(); | 183 | p.end(); |
184 | pixSize += size; | 184 | pixSize += size; |
185 | } | 185 | } |
186 | if ( mTodo->isAlarmEnabled() ) { | 186 | if ( mTodo->isAlarmEnabled() ) { |
187 | pixi.resize(size, pixSize+size); | 187 | pixi.resize(size, pixSize+size); |
188 | pPix.fill( Qt::red ); | 188 | pPix.fill( Qt::red ); |
189 | p.begin( &pixi ); | 189 | p.begin( &pixi ); |
190 | p. drawPixmap ( 0, pixSize, pPix); | 190 | p. drawPixmap ( 0, pixSize, pPix); |
191 | p.end(); | 191 | p.end(); |
192 | pixSize += size; | 192 | pixSize += size; |
193 | } | 193 | } |
194 | // } | 194 | // } |
195 | if ( pixi.width() > 1 ) { | 195 | if ( pixi.width() > 1 ) { |
196 | setPixmap ( 0,pixi ) ; | 196 | setPixmap ( 0,pixi ) ; |
197 | } else { | 197 | } else { |
198 | setPixmap ( 0,QPixmap() ) ; | 198 | setPixmap ( 0,QPixmap() ) ; |
199 | } | 199 | } |
200 | } | 200 | } |
201 | void KOTodoViewItem::stateChange(bool state) | 201 | void KOTodoViewItem::stateChange(bool state) |
202 | { | 202 | { |
203 | // qDebug("KOTodoViewItem::stateChange "); | 203 | // qDebug("KOTodoViewItem::stateChange "); |
204 | // do not change setting on startup | 204 | // do not change setting on startup |
205 | if ( m_init ) return; | 205 | if ( m_init ) return; |
206 | qDebug("KOTodoViewItem::stateChange "); | 206 | if (isOn()!=state) { |
207 | setOn(state); | ||
208 | //qDebug("SETON "); | ||
209 | return; | ||
210 | } | ||
207 | QString keyd = "=="; | 211 | QString keyd = "=="; |
208 | QString keyt = "=="; | 212 | QString keyt = "=="; |
209 | 213 | //qDebug("KOTodoViewItem::stateChange %s ", text(0).latin1()); | |
210 | mTodo->setCompleted(state); | 214 | mTodo->setCompleted(state); |
211 | if (state) mTodo->setCompleted(QDateTime::currentDateTime()); | 215 | if (state) mTodo->setCompleted(QDateTime::currentDateTime()); |
212 | if (isOn()!=state) { | ||
213 | setOn(state); | ||
214 | } | ||
215 | 216 | ||
216 | if (mTodo->hasDueDate()) { | 217 | if (mTodo->hasDueDate()) { |
217 | setText(3, mTodo->dtDueDateStr()); | 218 | setText(3, mTodo->dtDueDateStr()); |
218 | QDate d = mTodo->dtDue().date(); | 219 | QDate d = mTodo->dtDue().date(); |
219 | keyd.sprintf("%04d%02d%02d",d.year(),d.month(),d.day()); | 220 | keyd.sprintf("%04d%02d%02d",d.year(),d.month(),d.day()); |
220 | setSortKey(3,keyd); | 221 | setSortKey(3,keyd); |
221 | if (mTodo->doesFloat()) { | 222 | if (mTodo->doesFloat()) { |
222 | setText(4,""); | 223 | setText(4,""); |
223 | } | 224 | } |
224 | else { | 225 | else { |
225 | setText(4,mTodo->dtDueTimeStr()); | 226 | setText(4,mTodo->dtDueTimeStr()); |
226 | QTime t = mTodo->dtDue().time(); | 227 | QTime t = mTodo->dtDue().time(); |
227 | keyt.sprintf("%02d%02d",t.hour(),t.minute()); | 228 | keyt.sprintf("%02d%02d",t.hour(),t.minute()); |
228 | setSortKey(4,keyt); | 229 | setSortKey(4,keyt); |
229 | } | 230 | } |
230 | } | 231 | } |
231 | if (mTodo->isCompleted()) setSortKey(1,QString::number(9)+keyd+keyt); | 232 | if (mTodo->isCompleted()) setSortKey(1,QString::number(9)+keyd+keyt); |
232 | else setSortKey(1,QString::number(mTodo->priority())+keyd+keyt); | 233 | else setSortKey(1,QString::number(mTodo->priority())+keyd+keyt); |
233 | 234 | ||
234 | setText(2,i18n("%1 %").arg(QString::number(mTodo->percentComplete()))); | 235 | setText(2,i18n("%1 %").arg(QString::number(mTodo->percentComplete()))); |
235 | if (mTodo->percentComplete()<100) { | 236 | if (mTodo->percentComplete()<100) { |
236 | if (mTodo->isCompleted()) setSortKey(2,QString::number(999)); | 237 | if (mTodo->isCompleted()) setSortKey(2,QString::number(999)); |
237 | else setSortKey(2,QString::number(mTodo->percentComplete())); | 238 | else setSortKey(2,QString::number(mTodo->percentComplete())); |
238 | } | 239 | } |
239 | else { | 240 | else { |
240 | if (mTodo->isCompleted()) setSortKey(2,QString::number(999)); | 241 | if (mTodo->isCompleted()) setSortKey(2,QString::number(999)); |
241 | else setSortKey(2,QString::number(99)); | 242 | else setSortKey(2,QString::number(99)); |
242 | } | 243 | } |
243 | QListViewItem * myChild = firstChild(); | 244 | if ( state ) { |
244 | KOTodoViewItem *item; | 245 | QListViewItem * myChild = firstChild(); |
245 | while( myChild ) { | 246 | KOTodoViewItem *item; |
246 | item = static_cast<KOTodoViewItem*>(myChild); | 247 | while( myChild ) { |
247 | item->stateChange(state); | 248 | //qDebug("stateCH "); |
248 | myChild = myChild->nextSibling(); | 249 | item = static_cast<KOTodoViewItem*>(myChild); |
250 | item->stateChange(state); | ||
251 | myChild = myChild->nextSibling(); | ||
252 | } | ||
253 | } else { | ||
254 | QListViewItem * myChild = parent(); | ||
255 | if ( myChild ) | ||
256 | (static_cast<KOTodoViewItem*>(myChild))->stateChange(state); | ||
249 | } | 257 | } |
250 | mTodoView->modified(true); | 258 | mTodoView->modified(true); |
251 | setMyPixmap(); | 259 | setMyPixmap(); |
252 | mTodoView->setTodoModified( mTodo ); | 260 | mTodoView->setTodoModified( mTodo ); |
253 | } | 261 | } |
254 | 262 | ||
255 | bool KOTodoViewItem::isAlternate() | 263 | bool KOTodoViewItem::isAlternate() |
256 | { | 264 | { |
257 | #ifndef KORG_NOLVALTERNATION | 265 | #ifndef KORG_NOLVALTERNATION |
258 | KOTodoListView *lv = static_cast<KOTodoListView *>(listView()); | 266 | KOTodoListView *lv = static_cast<KOTodoListView *>(listView()); |
259 | if (lv && lv->alternateBackground().isValid()) | 267 | if (lv && lv->alternateBackground().isValid()) |
260 | { | 268 | { |
261 | KOTodoViewItem *above = 0; | 269 | KOTodoViewItem *above = 0; |
262 | above = dynamic_cast<KOTodoViewItem *>(itemAbove()); | 270 | above = dynamic_cast<KOTodoViewItem *>(itemAbove()); |
263 | m_known = above ? above->m_known : true; | 271 | m_known = above ? above->m_known : true; |
264 | if (m_known) | 272 | if (m_known) |
265 | { | 273 | { |
266 | m_odd = above ? !above->m_odd : false; | 274 | m_odd = above ? !above->m_odd : false; |
267 | } | 275 | } |
268 | else | 276 | else |
269 | { | 277 | { |
270 | KOTodoViewItem *item; | 278 | KOTodoViewItem *item; |
271 | bool previous = true; | 279 | bool previous = true; |
272 | if (QListViewItem::parent()) | 280 | if (QListViewItem::parent()) |
273 | { | 281 | { |
274 | item = dynamic_cast<KOTodoViewItem *>(QListViewItem::parent()); | 282 | item = dynamic_cast<KOTodoViewItem *>(QListViewItem::parent()); |
275 | if (item) | 283 | if (item) |
276 | previous = item->m_odd; | 284 | previous = item->m_odd; |
277 | item = dynamic_cast<KOTodoViewItem *>(QListViewItem::parent()->firstChild()); | 285 | item = dynamic_cast<KOTodoViewItem *>(QListViewItem::parent()->firstChild()); |
278 | } | 286 | } |
279 | else | 287 | else |
280 | { | 288 | { |
281 | item = dynamic_cast<KOTodoViewItem *>(lv->firstChild()); | 289 | item = dynamic_cast<KOTodoViewItem *>(lv->firstChild()); |
282 | } | 290 | } |
283 | 291 | ||
284 | while(item) | 292 | while(item) |
285 | { | 293 | { |
286 | item->m_odd = previous = !previous; | 294 | item->m_odd = previous = !previous; |
287 | item->m_known = true; | 295 | item->m_known = true; |
288 | item = dynamic_cast<KOTodoViewItem *>(item->nextSibling()); | 296 | item = dynamic_cast<KOTodoViewItem *>(item->nextSibling()); |
289 | } | 297 | } |
290 | } | 298 | } |
291 | return m_odd; | 299 | return m_odd; |
292 | } | 300 | } |
293 | return false; | 301 | return false; |
294 | #else | 302 | #else |
295 | return false; | 303 | return false; |
296 | #endif | 304 | #endif |
297 | } | 305 | } |
298 | 306 | ||
299 | void KOTodoViewItem::paintCell(QPainter *p, const QColorGroup &cg, int column, int width, int alignment) | 307 | void KOTodoViewItem::paintCell(QPainter *p, const QColorGroup &cg, int column, int width, int alignment) |
300 | { | 308 | { |
301 | QColorGroup _cg = cg; | 309 | QColorGroup _cg = cg; |
302 | QColorGroup::ColorRole role; | 310 | QColorGroup::ColorRole role; |
303 | if ( KOPrefs::instance()->mTodoViewUsesForegroundColor ) | 311 | if ( KOPrefs::instance()->mTodoViewUsesForegroundColor ) |
304 | role = QColorGroup::Text; | 312 | role = QColorGroup::Text; |
305 | else | 313 | else |
306 | role = QColorGroup::Base; | 314 | role = QColorGroup::Base; |
307 | //#ifndef KORG_NOLVALTERNATION | 315 | //#ifndef KORG_NOLVALTERNATION |
308 | // if (isAlternate()) | 316 | // if (isAlternate()) |
309 | // _cg.setColor(QColorGroup::Base, static_cast< KOTodoListView* >(listView())->alternateBackground()); | 317 | // _cg.setColor(QColorGroup::Base, static_cast< KOTodoListView* >(listView())->alternateBackground()); |
310 | bool setColor = KOPrefs::instance()->mTodoViewUsesCatColors; | 318 | bool setColor = KOPrefs::instance()->mTodoViewUsesCatColors; |
311 | QColor colorToSet; | 319 | QColor colorToSet; |
312 | if ( setColor ) { | 320 | if ( setColor ) { |
313 | QStringList categories = mTodo->categories(); | 321 | QStringList categories = mTodo->categories(); |
314 | QString cat = categories.first(); | 322 | QString cat = categories.first(); |
315 | if ( !cat.isEmpty()) { | 323 | if ( !cat.isEmpty()) { |
316 | colorToSet = *(KOPrefs::instance()->categoryColor(cat) ); | 324 | colorToSet = *(KOPrefs::instance()->categoryColor(cat) ); |
317 | } else | 325 | } else |
318 | setColor = false; | 326 | setColor = false; |
319 | } | 327 | } |
320 | if (mTodo->hasDueDate()) { | 328 | if (mTodo->hasDueDate()) { |
321 | if (mTodo->dtDue().date()==QDate::currentDate() && | 329 | if (mTodo->dtDue().date()==QDate::currentDate() && |
322 | !mTodo->isCompleted()) { | 330 | !mTodo->isCompleted()) { |
323 | //_cg.setColor( role , KOPrefs::instance()->mTodoDueTodayColor); | 331 | //_cg.setColor( role , KOPrefs::instance()->mTodoDueTodayColor); |
324 | colorToSet = KOPrefs::instance()->mTodoDueTodayColor; | 332 | colorToSet = KOPrefs::instance()->mTodoDueTodayColor; |
325 | setColor = true; | 333 | setColor = true; |
326 | } | 334 | } |
327 | if (mTodo->dtDue().date() < QDate::currentDate() && | 335 | if (mTodo->dtDue().date() < QDate::currentDate() && |
328 | !mTodo->isCompleted()) { | 336 | !mTodo->isCompleted()) { |
329 | //_cg.setColor( role, KOPrefs::instance()->mTodoOverdueColor); | 337 | //_cg.setColor( role, KOPrefs::instance()->mTodoOverdueColor); |
330 | colorToSet = KOPrefs::instance()->mTodoOverdueColor; | 338 | colorToSet = KOPrefs::instance()->mTodoOverdueColor; |
331 | setColor = true; | 339 | setColor = true; |
332 | } | 340 | } |
333 | } | 341 | } |
334 | 342 | ||
335 | if ( setColor ) { | 343 | if ( setColor ) { |
336 | _cg.setColor(role,colorToSet ); | 344 | _cg.setColor(role,colorToSet ); |
337 | if ( role == QColorGroup::Base) { | 345 | if ( role == QColorGroup::Base) { |
338 | int rgb = colorToSet.red(); | 346 | int rgb = colorToSet.red(); |
339 | rgb += colorToSet.blue()/2; | 347 | rgb += colorToSet.blue()/2; |
340 | rgb += colorToSet.green(); | 348 | rgb += colorToSet.green(); |
341 | if ( rgb < 200 ) | 349 | if ( rgb < 200 ) |
342 | _cg.setColor(QColorGroup::Text,Qt::white ); | 350 | _cg.setColor(QColorGroup::Text,Qt::white ); |
343 | } | 351 | } |
344 | } | 352 | } |
345 | //#endif | 353 | //#endif |
346 | if ( column > 0 ){ | 354 | if ( column > 0 ){ |
347 | if ( column == 2 && !KOPrefs::instance()->mTodoViewShowsPercentage ) { | 355 | if ( column == 2 && !KOPrefs::instance()->mTodoViewShowsPercentage ) { |
348 | p->save(); | 356 | p->save(); |
349 | int progress = (int)(( (width-6)*mTodo->percentComplete())/100.0 + 0.5); | 357 | int progress = (int)(( (width-6)*mTodo->percentComplete())/100.0 + 0.5); |
350 | 358 | ||
351 | p->fillRect( 0, 0, width, height(), _cg.base() ); // background | 359 | p->fillRect( 0, 0, width, height(), _cg.base() ); // background |
352 | // p->setPen(Qt::black ); //border | 360 | // p->setPen(Qt::black ); //border |
353 | // p->setBrush( KOPrefs::instance()->mHighlightColorKGlobalSettings::baseColor() ); //filling | 361 | // p->setBrush( KOPrefs::instance()->mHighlightColorKGlobalSettings::baseColor() ); //filling |
354 | QColor fc = KOPrefs::instance()->mHighlightColor; | 362 | QColor fc = KOPrefs::instance()->mHighlightColor; |
355 | if ( mTodo->percentComplete() == 100 ) | 363 | if ( mTodo->percentComplete() == 100 ) |
356 | fc = darkGreen; | 364 | fc = darkGreen; |
357 | p->drawRect( 2, 2, width-4, height()-4); | 365 | p->drawRect( 2, 2, width-4, height()-4); |
358 | p->fillRect( 3, 3, progress, height()-6, | 366 | p->fillRect( 3, 3, progress, height()-6, |
359 | fc ); | 367 | fc ); |
360 | p->restore(); | 368 | p->restore(); |
361 | } else { | 369 | } else { |
362 | QCheckListItem::paintCell(p, _cg, column, width, alignment); | 370 | QCheckListItem::paintCell(p, _cg, column, width, alignment); |
363 | } | 371 | } |
364 | return; | 372 | return; |
365 | } | 373 | } |
366 | 374 | ||
367 | int align = alignment; | 375 | int align = alignment; |
368 | 376 | ||
369 | if ( !p ) | 377 | if ( !p ) |
370 | return; | 378 | return; |
371 | 379 | ||
372 | p->fillRect( 0, 0, width, height(), _cg.brush( QColorGroup::Base ) ); | 380 | p->fillRect( 0, 0, width, height(), _cg.brush( QColorGroup::Base ) ); |
373 | 381 | ||
374 | QListView *lv = listView(); | 382 | QListView *lv = listView(); |
375 | if ( !lv ) | 383 | if ( !lv ) |
376 | return; | 384 | return; |
diff --git a/libkcal/todo.cpp b/libkcal/todo.cpp index 7d04793..7f1de78 100644 --- a/libkcal/todo.cpp +++ b/libkcal/todo.cpp | |||
@@ -182,199 +182,203 @@ QDateTime Todo::dtDue() const | |||
182 | QString Todo::dtDueTimeStr() const | 182 | QString Todo::dtDueTimeStr() const |
183 | { | 183 | { |
184 | return KGlobal::locale()->formatTime(mDtDue.time()); | 184 | return KGlobal::locale()->formatTime(mDtDue.time()); |
185 | } | 185 | } |
186 | 186 | ||
187 | QString Todo::dtDueDateStr(bool shortfmt) const | 187 | QString Todo::dtDueDateStr(bool shortfmt) const |
188 | { | 188 | { |
189 | return KGlobal::locale()->formatDate(mDtDue.date(),shortfmt); | 189 | return KGlobal::locale()->formatDate(mDtDue.date(),shortfmt); |
190 | } | 190 | } |
191 | 191 | ||
192 | QString Todo::dtDueStr(bool shortfmt) const | 192 | QString Todo::dtDueStr(bool shortfmt) const |
193 | { | 193 | { |
194 | return KGlobal::locale()->formatDateTime(mDtDue, shortfmt); | 194 | return KGlobal::locale()->formatDateTime(mDtDue, shortfmt); |
195 | } | 195 | } |
196 | 196 | ||
197 | bool Todo::hasDueDate() const | 197 | bool Todo::hasDueDate() const |
198 | { | 198 | { |
199 | return mHasDueDate; | 199 | return mHasDueDate; |
200 | } | 200 | } |
201 | 201 | ||
202 | void Todo::setHasDueDate(bool f) | 202 | void Todo::setHasDueDate(bool f) |
203 | { | 203 | { |
204 | if (mReadOnly) return; | 204 | if (mReadOnly) return; |
205 | mHasDueDate = f; | 205 | mHasDueDate = f; |
206 | updated(); | 206 | updated(); |
207 | } | 207 | } |
208 | 208 | ||
209 | 209 | ||
210 | #if 0 | 210 | #if 0 |
211 | void Todo::setStatus(const QString &statStr) | 211 | void Todo::setStatus(const QString &statStr) |
212 | { | 212 | { |
213 | if (mReadOnly) return; | 213 | if (mReadOnly) return; |
214 | QString ss(statStr.upper()); | 214 | QString ss(statStr.upper()); |
215 | 215 | ||
216 | if (ss == "X-ACTION") | 216 | if (ss == "X-ACTION") |
217 | mStatus = NEEDS_ACTION; | 217 | mStatus = NEEDS_ACTION; |
218 | else if (ss == "NEEDS ACTION") | 218 | else if (ss == "NEEDS ACTION") |
219 | mStatus = NEEDS_ACTION; | 219 | mStatus = NEEDS_ACTION; |
220 | else if (ss == "ACCEPTED") | 220 | else if (ss == "ACCEPTED") |
221 | mStatus = ACCEPTED; | 221 | mStatus = ACCEPTED; |
222 | else if (ss == "SENT") | 222 | else if (ss == "SENT") |
223 | mStatus = SENT; | 223 | mStatus = SENT; |
224 | else if (ss == "TENTATIVE") | 224 | else if (ss == "TENTATIVE") |
225 | mStatus = TENTATIVE; | 225 | mStatus = TENTATIVE; |
226 | else if (ss == "CONFIRMED") | 226 | else if (ss == "CONFIRMED") |
227 | mStatus = CONFIRMED; | 227 | mStatus = CONFIRMED; |
228 | else if (ss == "DECLINED") | 228 | else if (ss == "DECLINED") |
229 | mStatus = DECLINED; | 229 | mStatus = DECLINED; |
230 | else if (ss == "COMPLETED") | 230 | else if (ss == "COMPLETED") |
231 | mStatus = COMPLETED; | 231 | mStatus = COMPLETED; |
232 | else if (ss == "DELEGATED") | 232 | else if (ss == "DELEGATED") |
233 | mStatus = DELEGATED; | 233 | mStatus = DELEGATED; |
234 | 234 | ||
235 | updated(); | 235 | updated(); |
236 | } | 236 | } |
237 | 237 | ||
238 | void Todo::setStatus(int status) | 238 | void Todo::setStatus(int status) |
239 | { | 239 | { |
240 | if (mReadOnly) return; | 240 | if (mReadOnly) return; |
241 | mStatus = status; | 241 | mStatus = status; |
242 | updated(); | 242 | updated(); |
243 | } | 243 | } |
244 | 244 | ||
245 | int Todo::status() const | 245 | int Todo::status() const |
246 | { | 246 | { |
247 | return mStatus; | 247 | return mStatus; |
248 | } | 248 | } |
249 | 249 | ||
250 | QString Todo::statusStr() const | 250 | QString Todo::statusStr() const |
251 | { | 251 | { |
252 | switch(mStatus) { | 252 | switch(mStatus) { |
253 | case NEEDS_ACTION: | 253 | case NEEDS_ACTION: |
254 | return QString("NEEDS ACTION"); | 254 | return QString("NEEDS ACTION"); |
255 | break; | 255 | break; |
256 | case ACCEPTED: | 256 | case ACCEPTED: |
257 | return QString("ACCEPTED"); | 257 | return QString("ACCEPTED"); |
258 | break; | 258 | break; |
259 | case SENT: | 259 | case SENT: |
260 | return QString("SENT"); | 260 | return QString("SENT"); |
261 | break; | 261 | break; |
262 | case TENTATIVE: | 262 | case TENTATIVE: |
263 | return QString("TENTATIVE"); | 263 | return QString("TENTATIVE"); |
264 | break; | 264 | break; |
265 | case CONFIRMED: | 265 | case CONFIRMED: |
266 | return QString("CONFIRMED"); | 266 | return QString("CONFIRMED"); |
267 | break; | 267 | break; |
268 | case DECLINED: | 268 | case DECLINED: |
269 | return QString("DECLINED"); | 269 | return QString("DECLINED"); |
270 | break; | 270 | break; |
271 | case COMPLETED: | 271 | case COMPLETED: |
272 | return QString("COMPLETED"); | 272 | return QString("COMPLETED"); |
273 | break; | 273 | break; |
274 | case DELEGATED: | 274 | case DELEGATED: |
275 | return QString("DELEGATED"); | 275 | return QString("DELEGATED"); |
276 | break; | 276 | break; |
277 | } | 277 | } |
278 | return QString(""); | 278 | return QString(""); |
279 | } | 279 | } |
280 | #endif | 280 | #endif |
281 | 281 | ||
282 | bool Todo::isCompleted() const | 282 | bool Todo::isCompleted() const |
283 | { | 283 | { |
284 | if (mPercentComplete == 100) return true; | 284 | if (mPercentComplete == 100) return true; |
285 | else return false; | 285 | else return false; |
286 | } | 286 | } |
287 | 287 | ||
288 | void Todo::setCompleted(bool completed) | 288 | void Todo::setCompleted(bool completed) |
289 | { | 289 | { |
290 | if (completed) mPercentComplete = 100; | 290 | if (completed) mPercentComplete = 100; |
291 | else { | 291 | else { |
292 | mPercentComplete = 0; | 292 | mPercentComplete = 0; |
293 | mHasCompletedDate = false; | 293 | mHasCompletedDate = false; |
294 | } | 294 | } |
295 | updated(); | 295 | updated(); |
296 | } | 296 | } |
297 | 297 | ||
298 | QDateTime Todo::completed() const | 298 | QDateTime Todo::completed() const |
299 | { | 299 | { |
300 | return mCompleted; | 300 | return mCompleted; |
301 | } | 301 | } |
302 | 302 | ||
303 | QString Todo::completedStr( bool shortF ) const | 303 | QString Todo::completedStr( bool shortF ) const |
304 | { | 304 | { |
305 | return KGlobal::locale()->formatDateTime(mCompleted, shortF); | 305 | return KGlobal::locale()->formatDateTime(mCompleted, shortF); |
306 | } | 306 | } |
307 | 307 | ||
308 | void Todo::setCompleted(const QDateTime &completed) | 308 | void Todo::setCompleted(const QDateTime &completed) |
309 | { | 309 | { |
310 | qDebug("Todo::setCompleted "); | 310 | //qDebug("Todo::setCompleted "); |
311 | if ( mHasCompletedDate ) { | ||
312 | // qDebug("has completed data - return "); | ||
313 | return; | ||
314 | } | ||
311 | mHasCompletedDate = true; | 315 | mHasCompletedDate = true; |
312 | mPercentComplete = 100; | 316 | mPercentComplete = 100; |
313 | mCompleted = getEvenTime(completed); | 317 | mCompleted = getEvenTime(completed); |
314 | updated(); | 318 | updated(); |
315 | } | 319 | } |
316 | 320 | ||
317 | bool Todo::hasCompletedDate() const | 321 | bool Todo::hasCompletedDate() const |
318 | { | 322 | { |
319 | return mHasCompletedDate; | 323 | return mHasCompletedDate; |
320 | } | 324 | } |
321 | 325 | ||
322 | int Todo::percentComplete() const | 326 | int Todo::percentComplete() const |
323 | { | 327 | { |
324 | return mPercentComplete; | 328 | return mPercentComplete; |
325 | } | 329 | } |
326 | 330 | ||
327 | void Todo::setPercentComplete(int v) | 331 | void Todo::setPercentComplete(int v) |
328 | { | 332 | { |
329 | mPercentComplete = v; | 333 | mPercentComplete = v; |
330 | if ( v != 100 ) | 334 | if ( v != 100 ) |
331 | mHasCompletedDate = false; | 335 | mHasCompletedDate = false; |
332 | updated(); | 336 | updated(); |
333 | } | 337 | } |
334 | QDateTime Todo::getNextAlarmDateTime( bool * ok, int * offset ) const | 338 | QDateTime Todo::getNextAlarmDateTime( bool * ok, int * offset ) const |
335 | { | 339 | { |
336 | if ( isCompleted() || ! hasDueDate() || cancelled() ) { | 340 | if ( isCompleted() || ! hasDueDate() || cancelled() ) { |
337 | *ok = false; | 341 | *ok = false; |
338 | return QDateTime (); | 342 | return QDateTime (); |
339 | } | 343 | } |
340 | QDateTime incidenceStart; | 344 | QDateTime incidenceStart; |
341 | incidenceStart = dtDue(); | 345 | incidenceStart = dtDue(); |
342 | bool enabled = false; | 346 | bool enabled = false; |
343 | Alarm* alarm; | 347 | Alarm* alarm; |
344 | int off; | 348 | int off; |
345 | QDateTime alarmStart = QDateTime::currentDateTime().addDays( 3650 );; | 349 | QDateTime alarmStart = QDateTime::currentDateTime().addDays( 3650 );; |
346 | // if ( QDateTime::currentDateTime() > incidenceStart ){ | 350 | // if ( QDateTime::currentDateTime() > incidenceStart ){ |
347 | // *ok = false; | 351 | // *ok = false; |
348 | // return incidenceStart; | 352 | // return incidenceStart; |
349 | // } | 353 | // } |
350 | for (QPtrListIterator<Alarm> it(mAlarms); (alarm = it.current()) != 0; ++it) { | 354 | for (QPtrListIterator<Alarm> it(mAlarms); (alarm = it.current()) != 0; ++it) { |
351 | if (alarm->enabled()) { | 355 | if (alarm->enabled()) { |
352 | if ( alarm->hasTime () ) { | 356 | if ( alarm->hasTime () ) { |
353 | if ( alarm->time() < alarmStart ) { | 357 | if ( alarm->time() < alarmStart ) { |
354 | alarmStart = alarm->time(); | 358 | alarmStart = alarm->time(); |
355 | enabled = true; | 359 | enabled = true; |
356 | off = alarmStart.secsTo( incidenceStart ); | 360 | off = alarmStart.secsTo( incidenceStart ); |
357 | } | 361 | } |
358 | 362 | ||
359 | } else { | 363 | } else { |
360 | int secs = alarm->startOffset().asSeconds(); | 364 | int secs = alarm->startOffset().asSeconds(); |
361 | if ( incidenceStart.addSecs( secs ) < alarmStart ) { | 365 | if ( incidenceStart.addSecs( secs ) < alarmStart ) { |
362 | alarmStart = incidenceStart.addSecs( secs ); | 366 | alarmStart = incidenceStart.addSecs( secs ); |
363 | enabled = true; | 367 | enabled = true; |
364 | off = -secs; | 368 | off = -secs; |
365 | } | 369 | } |
366 | } | 370 | } |
367 | } | 371 | } |
368 | } | 372 | } |
369 | if ( enabled ) { | 373 | if ( enabled ) { |
370 | if ( alarmStart > QDateTime::currentDateTime() ) { | 374 | if ( alarmStart > QDateTime::currentDateTime() ) { |
371 | *ok = true; | 375 | *ok = true; |
372 | * offset = off; | 376 | * offset = off; |
373 | return alarmStart; | 377 | return alarmStart; |
374 | } | 378 | } |
375 | } | 379 | } |
376 | *ok = false; | 380 | *ok = false; |
377 | return QDateTime (); | 381 | return QDateTime (); |
378 | 382 | ||
379 | } | 383 | } |
380 | 384 | ||