Power Apps component frameworkを使うとTypeScriptでPower Appsのコンポーネントを作成できるとのこと。
今回は前回作成したソリューションzipファイルをインポートし、作成したコンポーネントをキャンバスとかモデル駆動型とかで使ってみる。
事前準備:環境の設定を変更
Power Apps component frameworkをキャンバスアプリで使うには、まず環境の設定を変更する必要がある。
[設定]→[管理センター]を押して、
data:image/s3,"s3://crabby-images/0c787/0c78785a20efe9422821c6927632435f1e22b9d8" alt=""
data:image/s3,"s3://crabby-images/0c787/0c78785a20efe9422821c6927632435f1e22b9d8" alt=""
環境を選択し[設定]を押す。
data:image/s3,"s3://crabby-images/db965/db9655f17e647ca0d692652d83f6c91b904e81b1" alt=""
data:image/s3,"s3://crabby-images/db965/db9655f17e647ca0d692652d83f6c91b904e81b1" alt=""
[製品]の[機能]を選択し、
data:image/s3,"s3://crabby-images/fcb29/fcb294070570e9210c83c2add57a92062724e6ce" alt=""
data:image/s3,"s3://crabby-images/fcb29/fcb294070570e9210c83c2add57a92062724e6ce" alt=""
[コードコンポーネントでキャンバスアプリの公開を許可する]を[オン]にして保存を押す。
data:image/s3,"s3://crabby-images/66dc4/66dc48722a092db6bb8a1db5404193926711a2e5" alt=""
data:image/s3,"s3://crabby-images/66dc4/66dc48722a092db6bb8a1db5404193926711a2e5" alt=""
これで設定は完了。
ソリューションをインポート
そしたらまずは、前回作成したソリューションzipファイルを環境にインポートする。
上記の設定を行った環境の[ソリューション]を開いて、[インポート]→[参照]を押下。
data:image/s3,"s3://crabby-images/1134c/1134c421b1bf7cc0b1b84714a8130f1570a40e0e" alt=""
data:image/s3,"s3://crabby-images/1134c/1134c421b1bf7cc0b1b84714a8130f1570a40e0e" alt=""
前回作成したzipファイルを選んで、
data:image/s3,"s3://crabby-images/177c2/177c2a2fa186cea9203bc184c574c2cef6eb07dd" alt=""
data:image/s3,"s3://crabby-images/177c2/177c2a2fa186cea9203bc184c574c2cef6eb07dd" alt=""
インポート!
data:image/s3,"s3://crabby-images/f4bec/f4beca3b10d79d180bf3e5f3b2725d790f62087f" alt=""
data:image/s3,"s3://crabby-images/f4bec/f4beca3b10d79d180bf3e5f3b2725d790f62087f" alt=""
無事にインポートが完了するはず。
data:image/s3,"s3://crabby-images/4a4e0/4a4e0fa24a512357fb986e82d0bf4c6c4369b38f" alt=""
data:image/s3,"s3://crabby-images/4a4e0/4a4e0fa24a512357fb986e82d0bf4c6c4369b38f" alt=""
キャンバスアプリで使ってみる
まずはキャンバスアプリで作成したコンポーネントを使ってみる。
左のタブの[+]を押して、[コンポーネントをさらに取得]を押下。
data:image/s3,"s3://crabby-images/4d279/4d279731bf686f858b072a20e300a67290d60727" alt=""
data:image/s3,"s3://crabby-images/4d279/4d279731bf686f858b072a20e300a67290d60727" alt=""
[コード]タブを選ぶと作成したコンポーネントが表示されるので、[インポート]を押下。
data:image/s3,"s3://crabby-images/3f9b6/3f9b67be530a69f930ece87fbd703735a6563447" alt=""
data:image/s3,"s3://crabby-images/3f9b6/3f9b67be530a69f930ece87fbd703735a6563447" alt=""
するとこんな感じでキャンバスアプリに作成したコンポーネントが表示される!
data:image/s3,"s3://crabby-images/aded0/aded0413c0ee7439f6bc5333d05bb31a14af4eb4" alt=""
data:image/s3,"s3://crabby-images/aded0/aded0413c0ee7439f6bc5333d05bb31a14af4eb4" alt=""
こんな感じでラベルとバインドすることもできるし、
data:image/s3,"s3://crabby-images/19c12/19c124f6395b10b38dd83bc3ac5d3bd1716d8ca7" alt=""
data:image/s3,"s3://crabby-images/19c12/19c124f6395b10b38dd83bc3ac5d3bd1716d8ca7" alt=""
OnChangeプロパティにこんな式を書いてやれば、
data:image/s3,"s3://crabby-images/614d0/614d0862c8266d93645f6e35f6428f50ba9637e4" alt=""
スライダーの値が変わるたびにNotifyが表示される!
data:image/s3,"s3://crabby-images/fc50a/fc50a2be66db2fd0ddd4bd938db14e76cd3828da" alt=""
data:image/s3,"s3://crabby-images/fc50a/fc50a2be66db2fd0ddd4bd938db14e76cd3828da" alt=""
Power Apps Studioで作ったカスタムコンポーネントと違って、OnChangeみたいな動作のプロパティを定義できるのがかなり大きなポイントかなと。
イベントプロパティを作れると色々と便利なコンポーネントが作れそう!
モデル駆動型アプリで使ってみる
続いてモデル駆動型アプリで作成したコンポーネントを使ってみる。
今回はこんな感じで整数型の列を持つテーブルのフォームを、整数をスライダーで選択できるようにしてみる。
data:image/s3,"s3://crabby-images/ecd09/ecd095e549c6da89e392fdbe8233e9a0f0bf7bc7" alt=""
data:image/s3,"s3://crabby-images/ecd09/ecd095e549c6da89e392fdbe8233e9a0f0bf7bc7" alt=""
新しくメインフォームを作成し、
data:image/s3,"s3://crabby-images/b5e48/b5e4888b09dc933147bccd246a485d50548cd887" alt=""
data:image/s3,"s3://crabby-images/b5e48/b5e4888b09dc933147bccd246a485d50548cd887" alt=""
フォームに適当な名前を付けたら保存して、[クラシックに切り替える]を押下する。
data:image/s3,"s3://crabby-images/d9334/d933418dbfb6d0fc360bb5e78b55e122a0976f6d" alt=""
data:image/s3,"s3://crabby-images/d9334/d933418dbfb6d0fc360bb5e78b55e122a0976f6d" alt=""
クラシック表示で整数列の入力部分をダブルクリックすると、
data:image/s3,"s3://crabby-images/8e647/8e647046b66cacb5fc15baeb439c8a5944184f7e" alt=""
data:image/s3,"s3://crabby-images/8e647/8e647046b66cacb5fc15baeb439c8a5944184f7e" alt=""
フィールドのプロパティが表示されるので、[コントロール]タブの[コントロールの追加]を押下する。
data:image/s3,"s3://crabby-images/e49cd/e49cdf981eddb05c4ce4194c52ef711c2783b07b" alt=""
data:image/s3,"s3://crabby-images/e49cd/e49cdf981eddb05c4ce4194c52ef711c2783b07b" alt=""
すると作成したコンポーネントが表示されるので[追加]を押して、
data:image/s3,"s3://crabby-images/c59a9/c59a9c1d6519eb9f257be243de3c5f57c1c98ef0" alt=""
data:image/s3,"s3://crabby-images/c59a9/c59a9c1d6519eb9f257be243de3c5f57c1c98ef0" alt=""
今回は全部の画面でこのコントロールが表示されるよう設定し、OKを押す。
data:image/s3,"s3://crabby-images/4f057/4f057d8feb5fb269832f6a8f641f96b9eb9a6b66" alt=""
data:image/s3,"s3://crabby-images/4f057/4f057d8feb5fb269832f6a8f641f96b9eb9a6b66" alt=""
そしたらフォームを[保存]して[公開]する。
data:image/s3,"s3://crabby-images/56d99/56d99dfdc67f8ac1bf33f6d366f934dcccf5396f" alt=""
data:image/s3,"s3://crabby-images/56d99/56d99dfdc67f8ac1bf33f6d366f934dcccf5396f" alt=""
[フォームの設定]から[フォームの順序]でさっきのフォームを優先的に表示するよう設定したら、
data:image/s3,"s3://crabby-images/5be9b/5be9bc57df42cbee7f65e4e7af2cf68ce681ea2b" alt=""
data:image/s3,"s3://crabby-images/5be9b/5be9bc57df42cbee7f65e4e7af2cf68ce681ea2b" alt=""
[データ]タブから[レコードの追加]を選んでみると、
data:image/s3,"s3://crabby-images/bad1a/bad1aed8fdb8af0e23c87ccbfa7f8302cdb42bdc" alt=""
data:image/s3,"s3://crabby-images/bad1a/bad1aed8fdb8af0e23c87ccbfa7f8302cdb42bdc" alt=""
こんな感じで整数をスライダーで選択できるようになる!
data:image/s3,"s3://crabby-images/d34fd/d34fd62c367bb41ec16167ecfc2e9c8e184442e7" alt=""
data:image/s3,"s3://crabby-images/d34fd/d34fd62c367bb41ec16167ecfc2e9c8e184442e7" alt=""
こんな感じで色々と便利なコンポーネントが作成できそうなPower Apps component framework。
SharePoint Frameworkとどことなく似ているので、色々と便利な開発ができそう!
コメント