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

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

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

Googleは多種多様なAPIを提供していて、その多くはウェブ開発者向けのAPIです。それらのAPIは消費者に人気なGoogleのサービス(Google Maps, Google Earth, AdSense, Adwords, Google Apps,YouTube等)に基づいています。

Slack

Slackは、Tiny Speckという企業からリリースされたコミュニケーションツールです。GoogleDriveやGitHubなど、さまざまな外部サービスと連携することができます。

Google

Googleは、アメリカ合衆国に位置する、インターネット関連のサービスや製品を提供している企業です。検索エンジンからアプリケーションの提供まで、多岐にわたるサービスを提供しています。

Q&A

0回答

582閲覧

グーグルフォームの回答をスラックに通知させたい

kossi

総合スコア4

Google API

Googleは多種多様なAPIを提供していて、その多くはウェブ開発者向けのAPIです。それらのAPIは消費者に人気なGoogleのサービス(Google Maps, Google Earth, AdSense, Adwords, Google Apps,YouTube等)に基づいています。

Slack

Slackは、Tiny Speckという企業からリリースされたコミュニケーションツールです。GoogleDriveやGitHubなど、さまざまな外部サービスと連携することができます。

Google

Googleは、アメリカ合衆国に位置する、インターネット関連のサービスや製品を提供している企業です。検索エンジンからアプリケーションの提供まで、多岐にわたるサービスを提供しています。

0グッド

3クリップ

投稿2019/12/04 14:14

前提・実現したいこと

2つのグーグルフォームからスラックに通知が来るように設定しているのですが、3つ目のフォームを同じように作成したところ【アポ取れました】という通知は来るのですが、フォームの内容が反映されなくなりました。
ここに質問の内容を詳しく書いてください。
フォーム回答がスラックに反映されるようにしたいのですが、表示されない原因わかりますでしょうか?

色々とネットで検索して試してみたのですが、解決できず、、ご教示いただけますと幸いです。

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

TypeError: undefined からプロパティ「response」を読み取れません。

該当のソースコード

function sendToSlack(fallback, fields, channel) { const url = "https://hooks.slack.com/services/@@@@@@@@" const data = { "channel" : channel, "username" : "Googleフォーム Bot", // 1: bot 名 "attachments" : [{ "fallback" : fallback, "text" : "アポ取れました", "fields": fields, "color": "good", // 3: 左線の色 }], "icon_emoji" : ":envelope_with_arrow:" // 2: アイコン画像 }; const payload = JSON.stringify(data); const options = { "method" : "POST", "contentType" : "application/json", "payload" : payload, "muteHttpExceptions": true, }; const response = UrlFetchApp.fetch(url, options); Logger.log(response) } function test() { sendToSlack("テスト通知確認です", [], "#@@@"); } function responseToText(itemResponse) { switch (itemResponse.getItem().getType()) { case FormApp.ItemType.CHECKBOX: return itemResponse.getResponse().join("\n"); break; case FormApp.ItemType.GRID: const gridResponses = itemResponse.getResponse(); return itemResponse.getItem().asGridItem().getRows().map(function(rowName, index) { Logger.log(rowName); return rowName + ": " + gridResponses[index]; }).join("\n"); break; case FormApp.ItemType.CHECKBOX_GRID: const checkboxGridResponses = itemResponse.getResponse() return itemResponse.getItem().asCheckboxGridItem().getRows().map(function(rowName, index) { Logger.log(rowName); return rowName + ": " + checkboxGridResponses[index]; }).join("\n"); break; default: return itemResponse.getResponse(); } } // FormApp.getActiveForm() function onFormSubmit(e){ const itemResponses = e.response.getItemResponses(); const fallback = itemResponses.map(function(itemResponse) { return itemResponse.getItem().getTitle() + ": " + itemResponse.getResponse(); }).join("\n"); const fields = itemResponses.map(function(itemResponse) { const value = responseToText(itemResponse); return { "title": itemResponse.getItem().getTitle(), "value": value, "short": false, // 4: 左右2列で表示 } }); sendToSlack(fallback, fields, "#@@@"); }

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

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

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

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

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

papinianus

2019/12/10 11:53

同じコードで、できているのといないのがあるってことは、コードにバグはない可能性が高いです。NDAを結んでフォームやデータを見てもらえる人を探してください
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問