複数のGoogleカレンダーを週間予定でLINEに通知したいのですが日をまたぐ予定は開始日にしか表示しないようにしたいです。
やりたい事
・日をまたぐ予定は次の日に反映させない。
・予定のない時はLINEに通知しない。
・例22:00-翌日8:00の場合は翌日8:00の表示を32:00と24時間を越える表示にしたい。
よろしくお願い致します。
var token = LINEtoken var calendarTitleMap = { "カレンダーID@group.calendar.google.com" : "①", "カレンダーID" : "②", "カレンダーID@group.calendar.google.com" : "③", }; var weekday = ["日", "月", "火", "水", "木", "金", "土"]; function notifyWeekly() { var calendars = CalendarApp.getAllCalendars(); var dt = new Date() var message = "当番予定\n\n"; for ( var i = 3; i < 8; i++ ) { dt.setDate(dt.getDate() + 2); message += Utilities.formatDate(dt, 'JST', '★ MM/dd(' + weekday[dt.getDay()] + ')') + "\n"; var dayText = ""; for(j in calendars) { var calendar = calendars[j]; var calendarName = calendarTitleMap[calendar.getId()] if ( calendarName == undefined ) { continue; } var events = calendar.getEventsForDay(dt); if( events.length == 0 ) { continue; } dayText += "< " + calendarName + " >\n"; for(j in events) { dayText += toDayText(events[j]); } dayText += "\n" } if ( dayText == "") { dayText += "予定はありません\n\n"; } message += dayText; } sendToLine(message); } function sendToLine(message){ var options = { "method" : "post", "headers" : {"Authorization" : "Bearer "+ token}, "payload" : "message=" + message }; UrlFetchApp.fetch("https://notify-api.line.me/api/notify", options); } function toDayText(event) { return toTimeText(event.getStartTime()) + ' - ' + toTimeText(event.getEndTime()) + " " + event.getTitle() + '\n'; } function toTimeText(str){ return Utilities.formatDate(str, 'JST', 'HH:mm'); }
あなたの回答
tips
プレビュー