Power Apps component frameworkを使うとTypeScriptでPower Appsのコンポーネントを作成できるとのこと。
ということで、今回はこちらのサイトの通りにコンポーネントを作ってみた。
![]()
data:image/s3,"s3://crabby-images/0bd4e/0bd4ef1a62d7dadf756a3aa2d439c8db5a3877d9" alt=""
Microsoft Dataverse の Power Apps Component Framework を使用して最初のコンポーネントを作成する - Power Apps
Power Apps Component Framework を使用してコード コンポーネントを実装する方法について説明します
開発に必要なものたち
前提として以下が必要。
- Visual Studio Code
- node.js(LTSが推奨)
- Microsoft Power Platform CLI(インストール方法は後述)
- Visual Studio 2019 または Visual Studio 2019用のビルドツール
VSCode用のMicrosoft Power Platform CLIのインストール手順
VSCodeを開いて左側のタブから拡張機能を選択、検索窓に「Power Platform」と入れるとこんな感じで見つかるので「インストール」を押下。
data:image/s3,"s3://crabby-images/5ca48/5ca48655bce449efe61cebdd3cccabf0e93f08ee" alt=""
data:image/s3,"s3://crabby-images/5ca48/5ca48655bce449efe61cebdd3cccabf0e93f08ee" alt=""
早速Power Appsのコンポーネントを作ってみる!
上のツールが全部準備できたので、早速コンポーネントを作成して。
手順1:開発するフォルダを作成してそこにプロジェクトを作成する
まずは適当な開発用フォルダを作成して、
data:image/s3,"s3://crabby-images/5df3a/5df3a6790d71f22f873df20cf59e476dd55cbabd" alt=""
data:image/s3,"s3://crabby-images/5df3a/5df3a6790d71f22f873df20cf59e476dd55cbabd" alt=""
VSCodeのターミナルでそのフォルダまで移動して、こんな感じでコマンドを実行。
data:image/s3,"s3://crabby-images/81770/8177015d4e3c687b29155e43d701cd19782a861b" alt=""
data:image/s3,"s3://crabby-images/81770/8177015d4e3c687b29155e43d701cd19782a861b" alt=""
すると開発用フォルダにプロジェクトができる。
data:image/s3,"s3://crabby-images/267ca/267ca01ee22d38a4e364446e4ed2fae2159c31a9" alt=""
data:image/s3,"s3://crabby-images/267ca/267ca01ee22d38a4e364446e4ed2fae2159c31a9" alt=""
手順2:マニフェストファイルの編集
そしたら展開されたプロジェクトの中の「ContorolManifest.Input.xml」を開いて、
data:image/s3,"s3://crabby-images/264bc/264bc0299762b11965883814757b5b830781a2f0" alt=""
data:image/s3,"s3://crabby-images/264bc/264bc0299762b11965883814757b5b830781a2f0" alt=""
マニュアルの通り、こんな感じに書き替える。
data:image/s3,"s3://crabby-images/c0b3a/c0b3aa46b54e443fcc86f34d7a7ae420d43ca3f7" alt=""
data:image/s3,"s3://crabby-images/c0b3a/c0b3aa46b54e443fcc86f34d7a7ae420d43ca3f7" alt=""
手順3:ロジックの実装
マニフェストファイルを編集したら次は「index.ts」ファイルを開いて、
data:image/s3,"s3://crabby-images/9db09/9db09dbe0650d941c739687f3d479290729e65ef" alt=""
data:image/s3,"s3://crabby-images/9db09/9db09dbe0650d941c739687f3d479290729e65ef" alt=""
こんな感じで書き替える。
※エラーがたくさん出るけど無視してOK
data:image/s3,"s3://crabby-images/9f3f1/9f3f105fb6588dc5fd327ba65c468ec82c5d5f76" alt=""
※エラーがたくさん出るけど無視してOK
data:image/s3,"s3://crabby-images/9f3f1/9f3f105fb6588dc5fd327ba65c468ec82c5d5f76" alt=""
手順4:CSSの作成
作業をしているフォルダの直下に「css」という名前のフォルダを作成し、そこに「LinearInputControl.css」を作成する。
data:image/s3,"s3://crabby-images/78ee4/78ee4825fffb0983656c3c21294e1431c1f10e39" alt=""
data:image/s3,"s3://crabby-images/78ee4/78ee4825fffb0983656c3c21294e1431c1f10e39" alt=""
※CSSの中身はここでコピペ可能
https://docs.microsoft.com/ja-jp/powerapps/developer/component-framework/implementing-controls-using-typescript#adding-style-to-the-code-component
※マニフェストファイルのコピペをミスってなければ大丈夫だけど、念のためcssファイルまでのパスが正しく設定されているか、さっきのControlManifestInput.xmlを確認。
data:image/s3,"s3://crabby-images/cce0e/cce0e41b9241567e1ec70da10661fa4afb9cf9a6" alt=""
data:image/s3,"s3://crabby-images/cce0e/cce0e41b9241567e1ec70da10661fa4afb9cf9a6" alt=""
手順5:ビルドして動作確認
ここまでできたら一旦動くか確認。
こんな感じでコマンドを実行してビルドして、
data:image/s3,"s3://crabby-images/201e8/201e840da2e48dac04e9518651689328bdd95ef5" alt=""
data:image/s3,"s3://crabby-images/201e8/201e840da2e48dac04e9518651689328bdd95ef5" alt=""
ビルドが成功したらこのコマンドを実行、
data:image/s3,"s3://crabby-images/4200c/4200c356dc6d6241e531f01535f00868cf4937e3" alt=""
data:image/s3,"s3://crabby-images/4200c/4200c356dc6d6241e531f01535f00868cf4937e3" alt=""
するとブラウザが立ち上がってこんな感じで動作確認が実施できる!
data:image/s3,"s3://crabby-images/5720f/5720f23635853df23b2589e78711d71e68232734" alt=""
data:image/s3,"s3://crabby-images/5720f/5720f23635853df23b2589e78711d71e68232734" alt=""
スライダーを動かすとちゃんと数字も動く!
data:image/s3,"s3://crabby-images/11ac2/11ac2f4dd20bcac831dce8c503e0e121c7b3e11c" alt=""
data:image/s3,"s3://crabby-images/11ac2/11ac2f4dd20bcac831dce8c503e0e121c7b3e11c" alt=""
手順6:ソリューションファイルを作成
動作で問題がなければソリューションファイルを作成していく。
ここでいったんPower Appsに移動して、[ソリューション]→[新しいソリューション]→[新しい公開元]を選択。
data:image/s3,"s3://crabby-images/dc941/dc94135155f79ca669c5372973d9e56b622d6caf" alt=""
data:image/s3,"s3://crabby-images/dc941/dc94135155f79ca669c5372973d9e56b622d6caf" alt=""
適当な名前で公開元を作成し、その「名前」と「接頭辞」をどこかにメモっておく。
data:image/s3,"s3://crabby-images/4357a/4357a46e47fe8f7360f7f12fd9d1a7ebba9d9d4c" alt=""
data:image/s3,"s3://crabby-images/4357a/4357a46e47fe8f7360f7f12fd9d1a7ebba9d9d4c" alt=""
そしたら再びVSCodeに戻り、作業をしているフォルダの下に「solution」フォルダを作成、
data:image/s3,"s3://crabby-images/9a51e/9a51ea71a0f50988fef63b10a8fa9bafb3fe1010" alt=""
data:image/s3,"s3://crabby-images/9a51e/9a51ea71a0f50988fef63b10a8fa9bafb3fe1010" alt=""
ターミナルでそこまで移動して、
data:image/s3,"s3://crabby-images/c2eee/c2eee524f4a52bb2c8f47b4ba12a96e3d34a269d" alt=""
data:image/s3,"s3://crabby-images/c2eee/c2eee524f4a52bb2c8f47b4ba12a96e3d34a269d" alt=""
こんな感じでコマンドを実行する。
このとき「–publisher-name」の後ろと「–publisher-prefix」の後ろには、それぞれさっきメモした「名前」と「接頭辞」を入力する。
data:image/s3,"s3://crabby-images/15aa2/15aa29812336f5b20a59734f6bacb2f84cee84a7" alt=""
このとき「–publisher-name」の後ろと「–publisher-prefix」の後ろには、それぞれさっきメモした「名前」と「接頭辞」を入力する。
data:image/s3,"s3://crabby-images/15aa2/15aa29812336f5b20a59734f6bacb2f84cee84a7" alt=""
コマンドが成功し「solution」フォルダの中に色々できたら、
data:image/s3,"s3://crabby-images/af3ca/af3caf70d8b6147f159e84bd476a852062ff3623" alt=""
data:image/s3,"s3://crabby-images/af3ca/af3caf70d8b6147f159e84bd476a852062ff3623" alt=""
こんな感じでコマンドを入力し、プロジェクト参照を追加。
data:image/s3,"s3://crabby-images/1bff5/1bff5c9ebf04cd486a0b70ac709390d342156c28" alt=""
data:image/s3,"s3://crabby-images/1bff5/1bff5c9ebf04cd486a0b70ac709390d342156c28" alt=""
そしたら以下どちらかのコマンドを実行し、zipファイルを作成する。
- msbuild /t:restore
- dotnet build
無事にビルドが成功すると、こんな感じでzipファイルが作成されているはず!
data:image/s3,"s3://crabby-images/a3537/a35370208a36d63744dbc019165f3aa53b9e8db7" alt=""
data:image/s3,"s3://crabby-images/a3537/a35370208a36d63744dbc019165f3aa53b9e8db7" alt=""
※コマンドは全部ここでコピペ可能
https://docs.microsoft.com/ja-jp/powerapps/developer/component-framework/implementing-controls-using-typescript#packaging-your-code-components
今回はここまで
思ったより記事が長くなってしまったので今回はここまで。
次回、作成したソリューションzipファイルをPower Appsの中で使ってみる。
コメント