Microsoft Formsで作ったフォームに新規に投稿があった際に、Power Automateを使って自動で担当窓口にメールを送ったり、投稿内容を自動でTeamsに転記する等の自動化を実装したことがあるかたは多いと思います。
ですが、新規に問い合わせがあったことを単に担当者全員に通知しても「結局この問い合わせ対応は誰が担当するのか」などの譲り合いがおきたりして着手が滞る場合があります。問い合わせ対応が主業務でない場合はなおさらです。
問い合わせ対応が主業務ではないチームで問い合わせに対する初動を起こしやすくするために作成したのが掲題の「輪番での担当者アサイン」と「担当者へのメンション」の自動化です。
**自動でアサインされた担当者が主業務で忙しいため問い合わせの対応ができない場合は、「アサインされた担当者が、別の担当者に対応を引き取ってもらうよう調整する」**という運用ルールも合わせて取り入れると良いと思います。
フローをGitHubにアップロードしました。「問い合わせ一覧.xlsx」については後述します。
・フローをエクスポートしたzipファイル
・問合わせ一覧.xlsx(問い合わせ一覧テーブルと担当者一覧テーブル)
#説明
担当者一覧の定義はGitHubにアップロードしている「問合わせ一覧.xlsx」を使います。
このExcelファイルは「担当者一覧」と「問い合わせ一覧」という2つシートがあります。
それぞれのシートにはシート名と同じ名前のテーブルがあります。
##説明:担当者一覧
「担当者一覧」テーブルは、フローが輪番で担当者を指定するためのインプット情報として使います。最低限必要な列は「No」列と「担当者メールアドレス」列です。
「担当者名」列は運用でこのシートの更新を行うひとが分かりやすいように設けています。フローの処理には使いません。
新規に問い合わせがあるとフローがNoの順番に担当者を指名します。 つまり、ある問い合わせがあったときにNoが1 のNestor Wike さんが指名されたら、次の問い合わせがあったときにはNoが2のMegan Bowenさんが指名されます。
そのように 3 → 4 → 5 → … と担当者が指名され、最後のNoまでたどり着くとまた1に戻ります。
##説明:担当者を輪番で指定する仕組み
下図のスコープ名の通り、「問い合わせNo」÷「担当者数」+1という計算式で担当者Noを決めています。
「問い合わせNo」はMicrosoft Forms が既定で持っている、フォームごとの投稿IDを指しています。
「担当者数」は、担当者一覧テーブルの行数をフローで取得したものです。行数を取得するアクションは無いのでテーブル内で存在する行の一覧を取得したうえで、Apply to eachで行数を数えています。
最後に+1をしている理由は、割り算をするときに余りが0というケースがあるためです。担当者一覧のNoの開始番号を1にしたいため、フローの計算結果に0がでないように1を足しています。
##説明:問い合わせ一覧
「問い合わせ一覧」テーブルは、問い合わせがあった内容と担当者を記録するために使います。
このテーブルでは新規の問い合わせがあるたびにフローによって行を追加します。ですが、輪番での担当者指定のインプット情報としては使いません。
#操作
フローのインポートと必要な設定について説明します。
##フローをインポートして編集画面を開く
フローの定義ファイルをインポートします。
・問い合わせが投稿されたら担当者に輪番でメンションする_20211014142439.zip
インポート手順:
https://docs.microsoft.com/ja-jp/learn/modules/administer-flows/2-flow-export-import
インポートが完了したら、フローの編集画面を開きます。
これから、トリガーとアクションに必要な設定を行います。この編集画面はこのまま開いた状態にして次の手順に進みます。
##問い合わせフォームを作成する
問い合わせを受け付けるフォームを作成します。
Microsoft Forms を開いて、フォームを作成する対象のチームを選択します。
質問項目を作成します。例としてここではテキスト入力の質問項目をひとつ作成します。
アドレスに表示されているURLの最後尾にあるFormIdをコピーします。
##問い合わせ内容の「動的なコンテンツ」を再設定する
FormIdを変更した際はフォームに入力された値を表す「動的なコンテンツ」も合わせて再設定する必要があるようです。
既に配置されている「動的なコンテンツ」は「×」をクリックして削除します。
##担当者一覧を用意する
担当者一覧テーブルに輪番での担当者指定をするメンバーを記入します。
更新したExcelファイルをTeamsにアップロードします。
どのチャネルにファイルを置くかは特に制約は無いですが、Power Automateによる投稿を行うチャネルに置くと分かりやすいです。
フローの編集画面で、先ほどアップロードしたExcelファイルにある「担当者一覧」テーブルを参照するように設定をします。
同様に「問い合わせ一覧」テーブルを参照するようにファイルパスやテーブルの参照設定をします。
##投稿先のチャネルを指定
フローの最後のアクションとしてチャネルへの投稿を行います。投稿先のチームとチャネルをドロップダウンから指定します。指定が完了したらフローを保存します。
インポートしたフローは既定でオフになります。そのため、フローをテスト実行する前にオンにします。
問い合わせNoは1です。
フローが 1(問い合わせNo)を6(担当者の人数)で割った余りに1を足した「2」を担当者一覧テーブルの「No」列から探します。その結果、「No」列の2にあたるメンバーがメンションされました。
#最後に
今回のフローでは担当者一覧をメンテナンスしやすいようにExcelのテーブルをインプット情報としています。ですが、メンションの対象が特定の人物に紐づかないメールアドレスであったり、メンテナンスを行うひとがフローの操作を理解しているひとであれば、フロー内で担当者を定義することもできます。