Read the statement by Michael Teeuw here.
MMM-Calendar always shows 23:59 if showEndTime: True
-
also, showEnd is a pain… technically the clock is day:00:00 to day 23:59 as 23:59+1 is 24:00/00:00 which is the next day
so, what do you think we should be showing there…
-
@SwissChemist want to try a fix for me…
edited: changed added line
edit the ~/MagicMirror/modules/default/calendar/calendarfetcher.js
find this (approx line 240) and add the one line listed below// Loop through the set of date entries to see which recurrences should be added to our event list. for (let d in dates) { const date = dates[d]; // ical.js started returning recurrences and exdates as ISOStrings without time information. // .toISOString().substring(0,10) is the method they use to calculate keys, so we'll do the same // (see https://github.com/peterbraden/ical.js/pull/84 ) const dateKey = date.toISOString().substring(0, 10); let curEvent = event; let showRecurrence = true; let duration = 0; startDate = moment(date); duration = parseInt(moment(curEvent.end).format("x")) - parseInt(moment(curEvent.start).format("x")) // --- add this linein your timezone (mine is Sep 28, 17:15)

-
Hello Sam,
thanks very much for your great support.
Good news is that the endTime issue is solved now!Nevertheless with recurring whole day events, the following entries are not correct yet:
3-weekly 13-14 is completely missing (should be 1.Okt)
Starting with the 3-weekly whole day 22.Okt (should be 21.Okt), every following ‘whole day meeting’ is shown one day too late.
You can easily see that even on your picture, as e.g. the 3-weekly whole day and the 3-weekly 13-14 should always take place at the same date.Even on your picture this is not the case… monthly whole day is shown in 3 days, monthly 17-18 is shown in 4 days.
Once more, thanks for your great support so far!
 -
yeh, that whole day thing… the spec says its whole day in the timezone where the computer is.
but the ical converter still adjusts it to UTC. (all parsed events are in UTC)3-weekly 13-14 is completely missing (should be 1.Okt)
can’t be cause u asked for WEdnesdaysBEGIN:VEVENT CREATED:20200928T173050Z DTEND;VALUE=DATE:20201002 DTSTAMP:20200928T182733Z DTSTART;VALUE=DATE:20201001 LAST-MODIFIED:20200928T182732Z RRULE:FREQ=WEEKLY;INTERVAL=3;BYDAY=WE < ---- SEQUENCE:0 SUMMARY:3-weekly whole day UID:E2C82F47-1E0F-4FD0-93C4-746B2D53488B URL;VALUE=URI: END:VEVENTso , this repeating event might start on Oct 1, but thats a thursday, so will not be shown

but later, Starting with the 3-weekly whole day 22.Okt (should be 21.Okt),
starts on 21+1 days from today 00:00:00 Oct 21, and ends on Oct 22this is a fix in the ical parser… so, it will take time to get out…
-
can we try another quick fix?
in calendar.js
// Define second, minute, hour, and day variables var oneSecond = 1000; // 1,000 milliseconds var oneMinute = oneSecond * 60; var oneHour = oneMinute * 60; var oneDay = oneHour * 24; if (event.fullDayEvent) { //subtract one second so that fullDayEvents end at 23:59:59, and not at 0:00:00 one the next day //event.endDate -= oneSecond; < ---- comment out this one line -
@sdetweil
maybe you expected already that now the endTime of each whole day event is shown one day too late. Without that fix, it has been correct.Regarding the ‘3-weekly whole day’ you gave me a perfect hint: As it is a user configured interval, you have to take care that begin of the event and day of the week you select as interval correspond. So if you configure it wrong, corresponding event will obviously not be shown, as you explained perfectly from your code analysis…

-
@sdetweil
I would not mind to see 23:59 as end of a whole day event, but it would also be fine for me to see the day where it starts again… -
@SwissChemist finding an acceptable “end” marker for “full day” event is challenging.
it certainly ends when the next day starts.
-
@SwissChemist can u look at this, your cal, in your timezone, 2.13 no modifications
showEnd:true,
maximumEntries:25,

-
@sdetweil
It’s getting better and better, great!The only event, which is not correct yet, ist the 3-weekly 13-14. This should be in 21 days (Oct 22nd), exactly like the 3-weekly whole day. The following ones could be better controlled in an absolute time format…
-
@SwissChemist no… that cal entry says wednesdays, so the 21st, rule wins on exact days, start/end win on time
BEGIN:VEVENT CREATED:20200928T173453Z DTEND;TZID=Europe/Zurich:20201001T140000 DTSTAMP:20200928T182743Z DTSTART;TZID=Europe/Zurich:20201001T130000 LAST-MODIFIED:20200928T182742Z RRULE:FREQ=WEEKLY;INTERVAL=3;BYDAY=WE < ------- SEQUENCE:0 SUMMARY:3-weekly 13-14 UID:A7C8DBD0-0AA9-468B-A3F8-A5F97B797C11 URL;VALUE=URI: END:VEVENT -
Ok, then it’s my error again. In the meantime I have corrected my calendar entry. Would you need a new calenendar export, or would you like to send me your fix to test it here?
-
@SwissChemist install/upgrade to 2.13, should fix it
https://github.com/sdetweil/MagicMirror_scripts
I changed cal entry to TH, now shows 21 days, on the 22nd
-
now I have corrected my calender entry, but I still cannot see same date for ‘3-weekly whole day’ and ‘3-weekly 13-14’.
Do you see same date for these events?
Any idea what I do wrong? Thx very much!

-
@SwissChemist what is your config for these entries, so I get the start formatting the same
never mind, copied from first entry
-
@SwissChemist yeh, I can see the same thing, actually there is a bigger problem… see the time switch standard to daylight
something happens , they go from start and end on same day to start one day end the nextweekly whole day does, 6th, 13, 20, 26?? 11/2
3 weekly happens around that same time, the actual clock is 10-22:22:00:00zbut the whole day things look weird… start on one day, and on the next… is that 1 day or 2?
all of the whole day events are '2 days actually, start on one day, end on the nextone thing on the 3-weekly whole day, you have TH set as the day, if u remove that it works… the rule processor
returns a different day depending.will have to examine
so, something about the tz switch has messed this up… thanks for great testcase
-
@sdetweil i think I have a test fix, incuding the time correction over dst/std time shift
your timezone, all cal entries for whole day changed to 1 day (the 1st of the two listed)

-
@sdetweil
I am currently not sure how this will look like after changing from DST(UTC+2) to STD time(UTC+1).
For sure this will happen on sunday, 25th of October. That’s why whole day events starting on 26th look differently.
But how should it look like today? Oct 26th 01:00 - Oct 27th 00:59??? -
@SwissChemist install 2.13
and replace the ~/MagicMirror/modules/default/calendar/calendarfetcher.js
with this
https://www.dropbox.com/s/t7m1f49kvv3x2b1/calendarfetcher.js?dl=0save the old one
it should correct dst/std time changes
-
@sdetweil
3-weekly whole day now shows Okt 23, but it should be Okt 22As I have seen in the calendar file, switching from DST to STD time is correctly defined for last Sunday in October, that is 25th of October. So this should not influence an event on 22nd of October…
Regarding events after switching from DST to STD time, I don’t have a clue, as I am not a dev, just a little experienced in testing…
I tried to understand the calendar file. As far as I have seen, you have only the date for whole day events (without any time):BEGIN:VEVENT
CREATED:20201001T205859Z
DTEND;VALUE=DATE:20201023
DTSTAMP:20201001T205900Z
DTSTART;VALUE=DATE:20201022
LAST-MODIFIED:20201001T205859Z
RRULE:FREQ=WEEKLY;INTERVAL=3;BYDAY=TH
SEQUENCE:1
SUMMARY:3-weekly whole day
UID:D718FE41-FF1B-43F6-9442-E9E43A41CCF0
URL;VALUE=URI:
END:VEVENTIn this case DTSTART is 20201022 and DTEND is 20201023.
For whole day events, can’t you simply set:
‘Begin’ to value of DTSTART 00:00 and
‘End’ to value of DTEND - 1day 23:59? (just as ical most probably uses 24:00 and that’s one day later)Maybe it’s not as simple as I assume, otherwise you would have tried that already…
As we currently have TZOFFSET+0200 and switch to TZOFFSET+0100, I would rather expect that we see current events (planned after 25th Oct) on the monitor 1 hour too late.
So that’s why I currently would rather expect:
Oct 27th 01:00 - Oct 28th 00:59 for weekly whole day after switching to STD time instead of
Oct 26th 23:00 - Oct 27th 22:59But as I mentioned before, maybe everything is much more complicated than I ever can imagine…

Hello! It looks like you're interested in this conversation, but you don't have an account yet.
Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.
With your input, this post could be even better 💗
Register Login