Read the statement by Michael Teeuw here.
Calendar has stopped working
-
@Jonsar said in Calendar has stopped working:
Sorry. I can with the html version
what does that mean? does it download the ics file or not?
not view the cal in the web,… that is the embedded version, we need the raw data… -
@Jonsar ok, lets turn on debugging
change config.js
logLevel: ["INFO", "LOG", "WARN", "ERROR"],
to
logLevel: ["INFO", "LOG", "WARN", "ERROR","DEBUG"],
then start mm like this
cd ~/MagicMirror npm start >somefile.txt 2>&1
wait til the error,
ctrl-q to stop MM
then edit the somefile.txterror should be at the bottom
-
@sdetweil Thanks for all your help.
These are the last 4 or so entries. It seems that it’s trying to pick up entries from 2021 and then comes across an old entry that it can’t parse.
{“type”:“VEVENT”,“params”:[],“uid”:“040000008200E00074C5B7101A82E0080000000093B227D5977DD701000000000000000010000000E1C248455EE3E241BFC9D2FBFB730A57”,“summary”:“Materials Due - MunichRe - Speaking & Writing Communication Skills”,“start”:$
[18.09.2022 22:22.12.572] [DEBUG] start: Tue Sep 21 2021 09:00:00 GMT-0400 (Eastern Daylight Time)
[18.09.2022 22:22.12.573] [DEBUG] end:: Tue Sep 21 2021 09:30:00 GMT-0400 (Eastern Daylight Time)
[18.09.2022 22:22.12.573] [DEBUG] duration: 1800000
[18.09.2022 22:22.12.573] [DEBUG] title: Materials Due - MunichRe - Speaking & Writing Communication Skills
[18.09.2022 22:22.12.574] [DEBUG] Processing entry…
[18.09.2022 22:22.12.574] [DEBUG] Event:
{“type”:“VEVENT”,“params”:[],“uid”:“040000008200E00074C5B7101A82E00800000000EBF569C6329CD7010000000000000000100000007A6D0A4DBF5A8C43863B8DBA1D58CFC5”,“summary”:“DIANA - Calendly”,“start”:“2021-09-21T17:30:00.000Z”,“datetype”:“date-time”,$
[18.09.2022 22:22.12.575] [DEBUG] start: Tue Sep 21 2021 13:30:00 GMT-0400 (Eastern Daylight Time)
[18.09.2022 22:22.12.575] [DEBUG] end:: Tue Sep 21 2021 15:00:00 GMT-0400 (Eastern Daylight Time)
[18.09.2022 22:22.12.576] [DEBUG] duration: 5400000
[18.09.2022 22:22.12.576] [DEBUG] title: DIANA - Calendly
[18.09.2022 22:22.12.577] [DEBUG] Processing entry…
[18.09.2022 22:22.12.577] [DEBUG] Event:
{“type”:“VEVENT”,“params”:[],“rrule”:{“_cache”:{“all”:false,“before”:[],“after”:[],“between”:[]},“origOptions”:{“tzid”:“undefined”,“dtstart”:“2021-09-21T22:30:00.000Z”,“freq”:2,“until”:“2021-11-23T23:30:00.000Z”,“interval”:1,“byweekday”:$
[18.09.2022 22:22.12.578] [DEBUG] start: Tue Sep 21 2021 18:30:00 GMT-0400 (Eastern Daylight Time)
[18.09.2022 22:22.12.578] [DEBUG] end:: Tue Sep 21 2021 21:30:00 GMT-0400 (Eastern Daylight Time)
[18.09.2022 22:22.12.579] [DEBUG] duration: 10800000
[18.09.2022 22:22.12.579] [DEBUG] title: Sarah ASL 1C (Units 7-9)
[18.09.2022 22:22.12.580] [DEBUG] Search for recurring events between: Sun Sep 18 2022 22:22:12 GMT-0400 (Eastern Daylight Time) and Sun Sep 17 2023 23:59:59 GMT-0400 (Eastern Daylight Time)
[18.09.2022 22:22.12.598] [DEBUG] Title: Sarah ASL 1C (Units 7-9), with dates: [null,null,null,null,null,null,null,null,null,null]
[18.09.2022 22:22.12.598] [DEBUG] event.recurrences: [object Object]
[18.09.2022 22:22.12.604] [ERROR] Calendar Error. Could not fetch calendar: https://outlook.office365.com/owa/calendar/4d70fc7a1bf94d5ab75018902050b8f9@tssg.ca/34612ac6511e4af9824700a66f879c90976 RangeError:$
at Date.toISOString (:null:null)
at /home/pi/MagicMirror/modules/default/calendar/calendarutils.js:314:28
at Array.forEach (:null:null)
at Object.filterEvents (/home/pi/MagicMirror/modules/default/calendar/calendarutils.js:142:24)
at /home/pi/MagicMirror/modules/default/calendar/calendarfetcher.js:74:29
at processTicksAndRejections (node:internal/process/task_queues:96:5) -
@Jonsar said in Calendar has stopped working:
dates: [null,null,null,null,null,null,null,null,null,null]
hm… i fixed that problem last year…
-
@sdetweil Your help is greatly appreciated. It really is a great feature we constantly use for the family to keep everyone informed. If you can suggest a fix, that would be awesome.
-
@Jonsar looking at it… no idea yet
-
@Jonsar ok, fun time… MS screws us again
they changed the format of the timezone reporting…lovely
not our code, but the calendar parser we use (that I fixed the last 2 times)
workaround
cd ~/MagicMirror/node_modules/node-ical
nano ical.js , scroll down to line 120
delete the whole line and paste in the new one (cursor has to be on that line to paste it there)change this (line 120 is the code, 119 is the comment)
// If this is the custom timezone from MS Outlook if (tz === 'tzone://Microsoft/Custom' ) {
to this
// If this is the custom timezone from MS Outlook if (tz === 'tzone://Microsoft/Custom' || tz === 'Customized Time Zone' || tz.startsWith('tzone://Microsoft/')) {
also need to fix our code
cd ~/MagicMirror/modules/default/calendar
nano calendarutils.js
change this , line 518
getIanaTZFromMS: function (msTZName) { // Get hash entry
to this
getIanaTZFromMS: function (msTZName) { if(msTZName ==='Customized Time Zone'){ return moment.tz.guess() } // Get hash entry
-
@sdetweil said in Calendar has stopped working:
cd ~/MagicMirror/modules/default/calendar
Thanks for this. It didn’t exactly work. It definitely got further than before but I ended up with this error.
Invalid time value
at Date.toISOString (:null:null)
at /home/pi/MagicMirror/modules/default/calendar/calendarutils.js:314:28
at Array.forEach (:null:null)
at Object.filterEvents (/home/pi/MagicMirror/modules/default/calendar/calendarutils.js:142:24)
at /home/pi/MagicMirror/modules/default/calendar/calendarfetcher.js:74:29
at processTicksAndRejections (node:internal/process/task_queues:96:5) -
@Jonsar can u show me the cal event data in the logs right before the error?
-
@sdetweil said in Calendar has stopped working:
|| tz === ‘Customized Time Zone’
I see there were two place in ical.js
and there is a timezone like this
‘Customized Time Zone 1’
so this will fail
tz === 'Customized Time Zone'
change to this
tz.startsWith('Customized Time Zone')
in all three places … 2 in node ical.j one in caldendarutils.js