Bug 325459 Month view's relayout fails and variouos fixes to duration manipulation. Team effort here, parts of the patch by mvl, michael.buettner@sun.com, and me. r=dmose

This commit is contained in:
jminta%gmail.com 2006-02-08 02:23:27 +00:00
parent a602db42c7
commit 9459b034ff
2 changed files with 62 additions and 52 deletions

View File

@ -709,58 +709,61 @@
throw NS_ERROR_FAILURE;
// If we've already drawn a view once, then in almost all cases we
// can resuse most of the grid. We may need to add or subtract a row
// can reuse most of the grid. We may need to add or subtract a row
// but this is still much faster than recreating all rows.
var canReuse = false;
if (this.mDateBoxes) {
canReuse = true;
var oldDuration = this.mDateBoxes[this.mDateBoxes.length-1].date.subtractDate(this.mDateBoxes[0].date);
var newDuration = this.mEndDate.subtractDate(this.mStartDate);
newDuration.isNegative = true;
newDuration.normalize();
newDuration.addDuration(oldDuration);
switch (newDuration.days + newDuration.weeks*7) {
case 0: // Perfect!
break;
case -7:
// The new month takes up an extra week, so we need to create
// a new row and fill it with day-boxes
var newGridRow = createXULElement("row");
newGridRow.setAttribute("flex", "1");
newGridRow.setAttribute("class", "calendar-month-view-grid-row");
this.monthgridrows.appendChild(newGridRow);
for (var i = 0; i < 7; i++) {
var box = createXULElement("calendar-month-day-box");
box.setAttribute("context", this.getAttribute("context"));
box.setAttribute("item-context", this.getAttribute("item-context") || this.getAttribute("context"));
box.setAttribute("class", boxClass);
box.monthView = this;
newGridRow.appendChild(box);
var boxdata = {
date: null,
row: curRow,
box: box
};
this.mDateBoxes.push(boxdata);
}
break;
case 7:
// The old month took up an extra week, so remove a row
this.monthgridrows.removeChild(this.monthgridrows.lastChild);
this.mDateBoxes.splice(this.mDateBoxes.length - 7, 7);
break;
default: //Right now, this can never happen, but some day it might
canReuse = false;
break;
}
}
if (canReuse) {
this.reuseExistingGrid();
} else {
if (!this.mDateBoxes) {
// There are no dateBoxes, so we must start from scratch.
this.createDayGrid();
return;
}
var oldDuration = this.mDateBoxes[this.mDateBoxes.length-1].date.subtractDate(this.mDateBoxes[0].date);
var newDuration = this.mEndDate.subtractDate(this.mStartDate);
newDuration.isNegative = true;
newDuration.normalize();
newDuration.addDuration(oldDuration);
if ((newDuration.days + newDuration.weeks*7) == 0) {
// OK, our grid is perfect, so just reuse it exactly.
this.reuseExistingGrid();
return;
} else if ((newDuration.days + newDuration.weeks*7) != 7) {
// This case shouldn't ever happen, at least until we introduce
// the ability to remove weekends
this.createDayGrid();
return;
}
// OK, so we're off by one week. We either need to add or subtract
// a row depending on whether the newDuration is positive or negative
if (!newDuration.isNegative) {
// The new month takes up an extra week, so we need to create
// a new row and fill it with day-boxes
var newGridRow = createXULElement("row");
newGridRow.setAttribute("flex", "1");
newGridRow.setAttribute("class", "calendar-month-view-grid-row");
var newRowIndex = this.monthgridrows.length;
this.monthgridrows.appendChild(newGridRow);
for (var i = 0; i < 7; i++) {
var box = createXULElement("calendar-month-day-box");
box.setAttribute("context", this.getAttribute("context"));
box.setAttribute("item-context", this.getAttribute("item-context") || this.getAttribute("context"));
box.monthView = this;
newGridRow.appendChild(box);
var boxdata = {
date: null,
row: newRowIndex,
box: box
};
this.mDateBoxes.push(boxdata);
}
} else {
// The old month took up an extra week, so remove a row
this.monthgridrows.removeChild(this.monthgridrows.lastChild);
this.mDateBoxes.splice(this.mDateBoxes.length - 7, 7);
}
this.reuseExistingGrid();
]]></body>
</method>
@ -875,7 +878,7 @@
if (dayCount == 7) {
// start adding to the next row
curRow = gridrows.childNodes[gridRowCount];
curRow = this.monthgridrows.childNodes[gridRowCount];
gridRowCount++;
dayCount = 0;

View File

@ -196,12 +196,15 @@ NS_IMETHODIMP calDuration::SetSeconds(PRInt16 aValue)
NS_IMETHODIMP calDuration::GetInSeconds(PRInt32 *_retval)
{
*_retval =
PRInt32 retval =
(((PRInt32)((PRInt16)mDuration.weeks * SECONDS_PER_WEEK)) +
((PRInt32)((PRInt16)mDuration.days * SECONDS_PER_DAY)) +
((PRInt32)((PRInt16)mDuration.hours * SECONDS_PER_HOUR)) +
((PRInt32)((PRInt16)mDuration.minutes * SECONDS_PER_MINUTE)) +
((PRInt32)((PRInt16)mDuration.seconds)));
if (mDuration.is_neg)
retval=-retval;
*_retval = retval;
return NS_OK;
}
@ -238,7 +241,11 @@ NS_IMETHODIMP calDuration::AddDuration(calIDuration *aDuration)
struct icaldurationtype idt;
aDuration->ToIcalDuration(&idt);
if (!idt.is_neg) {
// Calculate the new absolute value of the duration
// For two negative durations, the abs. value will increase,
// so use + in that case.
// Of course, also use + when both durations are positive.
if (idt.is_neg != mDuration.is_neg) {
mDuration.weeks += idt.weeks;
mDuration.days += idt.days;
mDuration.hours += idt.hours;