目的
グループメンバーがフォームから投稿したテーマの中からランダムで一つ取得して、MTG前にチャネルに投稿してくれるアプリを作りたい
背景
会社では毎週決まった時間に所属グループ全員が集まるMTGがあり、そこで3,4人に分かれたブレイクアウトルームを作り、
コミュニケーションを取る時間を設けています。
毎週グループリーダーがその場でテーマを決めるのは大変なので、メンバーから募集を募ることにしました。
そこで、メンバーにはフォームから自分が考えたテーマを投稿してもらい、集まったテーマ一覧の中からランダムに一つピックアップして、MTG時間に投稿してくれるようしたいと思います。
使う技術・ツール
【1】Microsoft Forms
→ メンバーがテーマを投稿するためのフォームを作るのに使います
【2】Power Automate
→ 投稿されたテーマをSharePointリストに追加する処理と、Teamsのチャネルに自動投稿する処理に使います。
【3】Microsoft Teams
→ ここのチャネルに選ばれたテーマを投稿するようにします
【4】Share Point
→ Formsから取得したテーマをリストに保存するのに使います
実装
1、まずは投稿できるフォームを作成
↑Microsoft Formsにアクセスして、フォームの作成を始めます。
タイトルと説明を入れて、入力フォームを一つ追加します。
テーマの入力に関しては「長い回答」「必須」どちらもオンにします。
次に投稿したテーマは誰がしたか分かると躊躇してしまう方もいるかもしれませんので、投稿は匿名にしたいと思います。
これでFormsの方の設定は完了です!
2、投稿されたテーマをShare Pointのリストに格納するようにする
ここでは一連の処理をPower Automateを使って実現させます。
大まかにやる内容は、
1、Formsに誰かが投稿した時を検知する
2、その投稿内容を取得
3、取得した投稿内容をSharePointリストに保存
になります。それではやっていきましょう
上のリンクからPowerAutomateに遷移して、サイドバーにある「作成」を選択
その中から、「自動化したクラウドフロー」というのを選択します
選択するとモーダルが出てくるので、フローのトリガーに「forms」と入力してください。
すると検索結果に「新しい応答が送信されるとき」というのが出てくるので、それを選択。
また、今回のフロー名も適当に入れてください。
最後に作成ボタンをクリックします。
作成が終わると以下のような画面になります。
これから実際にフローを作っていきます。
まず取得するFormsのIDを設定します
以下のスクショの用に候補の中に先ほど作成したフォーム名が出てくると思うので選択
※もし、どこかのチームの中にFormを作成した場合はここに出てこないので、カスタム値から自分で入力する必要があります。
カスタム値は以下のスクショの用に対象のFormsのURLのクエリパラーメータから取得することができます
これで設定したFormに誰か投稿した時のイベントを検知することができるようになりました。
次に、その受け取った投稿を取得するフローを追加します。
新しいステップから検索で「forms」と入力すると、検索結果一覧に「応答の詳細を取得する」というアクションが出てくるので選択
フォームIDは先ほどと同じものにして、応答IDには動的なコンテンツに表示される「応答ID」を入れます。
これで投稿されたテーマを取得することができました。
次はその値をSharePointリストに追加していきます。
先ほどと同じように新しいステップをクリックして、今度は「share point」と入力すると、「項目の作成」というのが出てくるので、それを選択します。
SharePointは会社の情報が含まれるため、詳しくは割愛しますが、SharePoint内にサイトとその中にリストを作っておけば一覧から選択できると思います。
以上で、フォームに投稿~投稿されたらPowerAutomateの方で検知して値を取得~その値をSharePointに保存までいきました!
実際にテストして動かしてみます。
右上のテストボタンを押して、出てくるサイドバーから「フローの実行」をクリック。
そのあと対象のFormsから何か投稿してみるとフローが実行されます。
問題なくフローが実行されたそうです!
前編はここまでで、後半でSharePointリストからランダムに一つテーマを取得して、Teamsに投稿する処理をやっていきます。
後編はこちら↓
https://qiita.com/flutter_daisuki/items/5dfa11d0bb83d57f021a