質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

Q&A

0回答

442閲覧

Googleフォームの回答結果を元にフォーム回答者のカレンダーにイベントを登録したい

m736593

総合スコア4

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

0グッド

2クリップ

投稿2018/07/26 09:18

前提・実現したいこと

Googleフォームで日付の入力欄と選択肢を用意し、回答結果を元にフォーム回答者のカレンダーにイベントを登録したいと考えています。
具体的には、フォームで入力された日付の決め打ちの時間で、フォーム回答者のデフォルトカレンダーに、選択された選択肢の内容を名前にしたイベントを登録しようとしました。

発生している問題・エラーメッセージ

デフォルトカレンダーを CalendarApp.getDefaultCalendar()で取得しようとしましたが、それではフォーム回答者のデフォルトカレンダーではなく、開発者である私のカレンダーになってしまいました。

該当のソースコード

function onFormSubmit(e) { var email = e.response.getRespondentEmail(); var responses = e.response.getItemResponses(); var item_date = responses[0].getResponse(); var item_option = responses[1].getResponse(); var calendar = CalendarApp.getCalendarsByName(email)[0]; // var calendar = CalendarApp.getDefaultCalendar(); var date = new Date(item_date); var start = new Date(date.getFullYear(),date.getMonth(),date.getDate(),9,0,0); var end = new Date(date.getFullYear(),date.getMonth(),date.getDate(),10,0,0); var event = calendar.createEvent(item_option,start,end); event.addPopupReminder(5); }

試したこと

var email = e.response.getRespondentEmail()で回答者のメールアドレスを取得し、CalendarApp.getCalendarsByName(email)[0]で回答者のデフォルトカレンダーを取得はできたのですが、実際にユーザーに試してもらったところ、カレンダーへのアクセス許可を求められることもなく、イベントは追加されませんでした。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問