今回は商品のレンタルのステータスをビジネスプロセスフロー (BPF)で管理しているアプリがあったとします。
こんな時、たとえばBPFのアクティブステージ (現在有効なステージ。画面上で言うとRequest) の状態ごとに表示させる項目をビジネスルールで変更させたり、画面表のロック (読み取り/編集可能) などを制御したいケースってあるかと思います。
たとえば、アクティブステージがRequest、つまりレンタル申請された時では最低限の情報のみ表示させ、Rentalのステージになった時には承認結果を表示させたい、などの時です。
ただこういった時、BPFが一体何なのかを親テーブル (ここではBPFが関連づけられているItem Rental Service テーブルとする)では確認することができません。
そのため、ビジネスルールを親テーブルで設定しようとしても、親テーブルではアクティブステージの列を持っていないためアクションを行うことができません。
今回はそのケースを解消する仕組みとして、アクティブステージを即座に親テーブルに連携する機能をローコードプラグインで作成したいと思います。
目次
Power Automate での連携の課題
Power Automate でBPFが更新された時をトリガーに、親テーブルにアクティブステージを同期する方法もあります。
しかし、実際の運用としてPower Apps でBPFを変更してもコミットを待たないのでブラウザキャッシュが優先され、アクティブステージはリアルタイムで反映されません。
つまり、Power Automate による親テーブル連携が実施されたかな?と言うタイミングでPower Apps にてブラウザやデータの更新を手動で行う必要があります。これではせっかくアクティブステージによって表示項目をコントロールしたりしたいのに、自動的に反映されずユーザービリティがよろしくないです。
この課題を解消することができるのがプラグインです。Dataverseにて実行されるためパフォーマンスも高いです。
Microsoft Dataverse のローコード プラグインでアプリ開発を効率化する – Power Apps | Microsoft Learn
今回はこのBPFのアクティブステージを親テーブルに連携する方法を通して、ローコードプラグインの利用方法をご紹介します。
用語の解説
ローコードプラグイン
ローコードプラグインは、Dataverse 内で特定のコマンド セットを実行する再利用可能なリアルタイム ワークフローであり、サーバー側で実行されます。
以前はワークフロー機能がありましたが非推奨機能となりました。そのため、プラグイン開発はC#のようなプロ開発の言語を学ぶ必要がありました。
このローコードプラグインはそのとっつきにくさを解消し、Power Fxで作成することができます。
Power Automate のクラウドフローのように、インスタント、自動化の両方が用意されています。
スケジュール実行はありません。
タイプ | トリガー | パラメーターのサポート | サポート対象 スコープ |
---|---|---|---|
即時 | 手動で実行 | はい | グローバルとテーブル |
自動 | Dataverse テーブル イベント | いいえ | テーブル |
ローコードで作成するプラグインは、Dataverse アクセラレーターというモデル駆動型アプリにて行えます。
アプリの外観はこちらのようなものです。
このアプリは基本的には現在、自動的に全環境にインストールされています。
プラグインの実行と作成が分かれていますのでご注意ください。
それでは早速プラグインをローコードで作成していきましょう。
前提条件
今回サンプルとして利用するアプリはこのようなビジネスプロセスフローで、以下のようなステージを持っています。
- Request
- Rental
- Closed
またBPFに関連づけられている親テーブルには以下のような選択肢列Active Stage Option
を用意しておきます。
それぞれステージと同じ名前の選択肢を持っています。
この選択肢列を親テーブルのフォームに表示しておきます。
プラグインをローコードで作成
Dataverse アクセラレーターアプリを開きます。
アプリを利用する際は、表示言語は英語を推奨します。日本語で利用すると現時点でDisplay Nameで撮ってくるところのPower Fxの動きが若干不安定と思います。
自動化プラグインを利用します。
Display Name にはプラグインの名称をつけ、ビジネスプロセスフローのテーブルを指定します。
Updateされた時に起動するようにします。
Power Fx の式は複雑ですがこのようにしました。
関数はWith 関数にて、BPFで更新されたアクティブステージの値が何かによってSwitch関数で切り替えられ、ActiveStageOption という変数に格納されるようにしています。
コピーしました!
With({
ItemRentalRecord: ThisRecord.<親テーブルの検索列>
ActiveStageOption: Switch(ThisRecord.activestageid.stagename,
"Request", <選択肢列名>.<選択肢(Request)>,
"Rental", <選択肢列名>.<選択肢(Rental)>,
"Closed", <選択肢列名>.<選択肢(Closed)>'
)
},
Patch([@<親テーブル名>], ItemRentalRecord, {<選択肢列名>: ActiveStageOption}))
Advanced optionのところは特に何も指定せずそのままとします。もし処理前(Pre-operation)にしてしまうと、アクティブステージが更新される前に取得してしまうので、正しいアクティブステージがとれません。
実行
ここで、テスト的に実行しましたが、モデル駆動型アプリの新しい外観では正しく反映されませんでした。そのため、古い外観で実行しました。この場合、うまく動きました。
ローコードプラグインはプレビュー機能なので、それなりに制限があります。
アクティブステージが即時反映されていることがわかります。
以上ご参考になれば幸いです。