以下のふーさんに対するおいしみさんのリプを見て、Power Apps単体でTeamsに画像を含むテキストの投稿を実際にやってみた記事です。
普通にリッチテキスト内に画像を貼り付けて投稿してもTeams上では表示できない
リッチテキストエディタ(RichTextEditor1)とボタンを配置し、ボタンのOnSelectを以下の数式に設定します。
data:image/s3,"s3://crabby-images/548c8/548c87191c45d4a63ab3111160c28c34090b2b99" alt=""
MicrosoftTeams.PostMessageToConversation(
"User",
"Channel",
ParseJSON(JSON({
recipient:
{
groupId: "groupId",
channelId: "channelId"
},
messageBody: RichTextEditor1.HtmlText,
subject: "件名"
}
))
)
普通にmessageBodyにリッチテキストエディタの出力を設定しただけでは、画像がうまく表示されません。
data:image/s3,"s3://crabby-images/15104/15104007dc101761df8c1ef06ac426e223430546" alt=""
Hostedcontentsに特定の形式のJSONを入力する
おいしみさんが紹介しているHiroさんの記事によると、Hostedcontentsに特定の形式のJSONを入力すればPower AppsやPower AutomateからTeamsに画像つきの投稿ができるそうです。
[Tips] Power Automate から Teams に投稿するメッセージに画像を埋め込む #PowerAutomate - Qiita
Send chatMessage in a channel or a chat - Microsoft Graph v1.0 | Microsoft Learn
ラベルでRichTextEditor1.HtmlTextを確認すると画像の拡張子やbase64の情報が含まれているので、これらを抜き出して置換&Hostedcontentsに入力すれば良さそうです。
data:image/s3,"s3://crabby-images/5a840/5a840b520ade71332be90700539e0babf05b1df3" alt=""
作り方
ボタンに以下の数式を設定します。
With(
{Html:MatchAll(RichTextEditor1.HtmlText, "<img.+?src=""data:(?<contentType>.+?);base64,(?<contentBytes>.+?)"" />")},
ClearCollect(
ColPostText,
{
recipient:
{
groupId: "groupId",
channelId: "channelId"
},
messageBody: RichTextEditor1.HtmlText,
subject: "件名",
hostedContents:
ShowColumns(
AddColumns(
Html,
@microsoft.graph.temporaryId,
Text(StartMatch)
),
contentBytes,contentType,@microsoft.graph.temporaryId
)
}
);
ForAll(
Html As html,
UpdateIf(
ColPostText, true,
{messageBody:Substitute(messageBody, html.FullMatch, "<img src=""../hostedContents/" & html.StartMatch & "/$value"">")}
)
);
MicrosoftTeams.PostMessageToConversation(
"User",
"Channel",
ParseJSON(JSON(First(ColPostText)))
)
)
Power Apps側で入力した画像とテキストをそのままTeamsに投稿できました。
data:image/s3,"s3://crabby-images/01182/01182744e94c997f3ee6fe8322ebfa8dad7de9f9" alt=""
以降で詳細なコードの説明をします。
With+MatchAll関数で抽出対象を変数に格納
data:image/s3,"s3://crabby-images/200e1/200e1c4139f85cc750ec86a599b25ddef03b0de7" alt=""
MatchAll関数で正規表現によって抽出部分を検索し、その結果をWith関数でHtmlに格納しておきます。
コレクションにコネクタへの入力値を設定する
data:image/s3,"s3://crabby-images/1373b/1373b66ed0cef41a14a0dd40836c6e7faf8bbe76" alt=""
次にForAllで置換処理を行う都合上、変数ではなく一行のコレクションに入力値を設定します。
recipientには、投稿先のグループIDとチャネルIDを設定します。
URLやこちらの方法を参考にPower AutomateのコードのプレビューからIDを取得・入力してください。
data:image/s3,"s3://crabby-images/b42ac/b42ac02d9e6cb8fe456ac6531dc5208fcdad7015" alt=""
messageBodyはリッチテキストエディタの出力、subjectには件名に設定するテキストを設定します。
hostedContentsはWith関数で設定したHtmlのStartMatchをtemporaryIdにするためにAddColumns関数で型変換と列名変更、その後ShowColumns関数で列をスキーマに合わせます。
data:image/s3,"s3://crabby-images/10250/10250f5e3da0e9b6b0ce94ca8ac64c9d9e34e7e7" alt=""
messageBodyを置換処理
data:image/s3,"s3://crabby-images/928a7/928a7ad346c781279176cb12a6d9ecb7cd0abe7a" alt=""
messageBodyに対してSubstitute関数で置換処理を行います。
Htmlには画像の分だけレコードが存在するので、これをForAll関数で繰り返し処理すれば対象の文字列をすべて置換できます。
data:image/s3,"s3://crabby-images/27d8f/27d8fe9c291e7e81a5c01203766e6e957871cb00" alt=""
data:image/s3,"s3://crabby-images/e587a/e587a0955e74c2d61bde40f95d9321369879486b" alt=""
Teamsに投稿
data:image/s3,"s3://crabby-images/a789e/a789eb39643793bcb225b8a28cb888a5dcf22616" alt=""
TeamsコネクタのPostMessageToConversationを用いてTeamsに投稿します。
ParseJSON、JSON関数でUntypedObject型への変換が必要です。
data:image/s3,"s3://crabby-images/7c582/7c5821303a9a48f6c685add770bdcac498e06110" alt=""
コメント