From c0cfb375c362ddb63e95c27897343a99f22ded99 Mon Sep 17 00:00:00 2001 From: nathangray Date: Wed, 6 Jan 2021 10:30:15 -0700 Subject: [PATCH] * Calendar: Fix bug where yearly planner would not show events that went outside the displayed time period --- calendar/js/et2_widget_planner.js | 18 ++++++++++-------- calendar/js/et2_widget_planner.ts | 17 ++++++++++------- 2 files changed, 20 insertions(+), 15 deletions(-) diff --git a/calendar/js/et2_widget_planner.js b/calendar/js/et2_widget_planner.js index bbf528f0af..e33f3ae7ce 100644 --- a/calendar/js/et2_widget_planner.js +++ b/calendar/js/et2_widget_planner.js @@ -272,10 +272,12 @@ var et2_calendar_planner = /** @class */ (function (_super) { break; } } - if (typeof rows[label_index] === 'undefined') { - rows[label_index] = []; + if (label_index) { + if (typeof rows[label_index] === 'undefined') { + rows[label_index] = []; + } + rows[label_index].push(event); } - rows[label_index].push(event); // end in a different month? var end = new Date(event.end); end = new Date(end.valueOf() + end.getTimezoneOffset() * 60 * 1000); @@ -284,10 +286,10 @@ var et2_calendar_planner = /** @class */ (function (_super) { var month = start.getMonth(); key = sprintf('%04d-%02d', year, month); do { - var end_label_index = label_index; - for (var i = end_label_index; i < labels.length; i++) { - if (labels[i].id == key) { - end_label_index = i; + var end_label_index = typeof label_index == "boolean" ? 0 : label_index; + for (var i_1 = end_label_index; i_1 < labels.length; i_1++) { + if (labels[i_1].id == key) { + end_label_index = i_1; if (typeof rows[end_label_index] === 'undefined') { rows[end_label_index] = []; } @@ -295,7 +297,7 @@ var et2_calendar_planner = /** @class */ (function (_super) { } } if (end_label_index != label_index) { - rows[label_index].push(event); + rows[end_label_index].push(event); } if (++month > 11) { ++year; diff --git a/calendar/js/et2_widget_planner.ts b/calendar/js/et2_widget_planner.ts index bd0a30482b..9b0b46517f 100644 --- a/calendar/js/et2_widget_planner.ts +++ b/calendar/js/et2_widget_planner.ts @@ -607,7 +607,7 @@ export class et2_calendar_planner extends et2_calendar_view implements et2_IDeta var start = new Date(event.start); start = new Date(start.valueOf() + start.getTimezoneOffset() * 60 * 1000); var key = sprintf('%04d-%02d', start.getFullYear(), start.getMonth()); - var label_index = false; + var label_index : number|boolean = false; for(var i = 0; i < labels.length; i++) { if(labels[i].id == key) @@ -616,11 +616,14 @@ export class et2_calendar_planner extends et2_calendar_view implements et2_IDeta break; } } - if(typeof rows[label_index] === 'undefined') + if(label_index) { - rows[label_index] = []; + if(typeof rows[label_index] === 'undefined') + { + rows[label_index] = []; + } + rows[label_index].push(event); } - rows[label_index].push(event); // end in a different month? var end = new Date(event.end); @@ -632,9 +635,9 @@ export class et2_calendar_planner extends et2_calendar_view implements et2_IDeta do { - var end_label_index = label_index; + var end_label_index = typeof label_index == "boolean" ? 0 : label_index; - for(var i = end_label_index; i < labels.length; i++) + for(let i = end_label_index; i < labels.length; i++) { if(labels[i].id == key) { @@ -648,7 +651,7 @@ export class et2_calendar_planner extends et2_calendar_view implements et2_IDeta } if(end_label_index != label_index) { - rows[label_index].push(event); + rows[end_label_index].push(event); } if (++month > 11) {