9
9

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

SharePoint ドキュメントライブラリのPDFを #PowerApps で表示する

Last updated at Posted at 2019-08-08

はじめに

本投稿は Brian Edwardsさんの投稿を応用した手法の紹介です。
オリジナルの投稿はhttps://masteroffice365.com/viewing-pdfs-from-sharepoint-within-powerapps/ こちらをご覧ください。

Acknowledgment : This post is based on the work provided by Brian Edwards linked above. I'm deeply grateful to his work.

やったこと

SharePointドキュメントライブラリのPDFは、PowerAppsで利用できる標準のSharePointコネクターではサポート外になっています。PDFコントロールにライブラリのURLをセットしても認証の問題から表示することができません。
これを解決するための方法が上記ブログに記載されています。ポイントはFlowを利用して、ライブラリのアイテムのコンテンツを取得し、その結果をResponse to PowerAppsで、ファイルとして返却するというものです。
ここではその方法を発展させ、ライブラリに存在するすべてのドキュメントを配列で返却し、ギャラリーコントロールで表示させる方法を紹介します。

Flow側

image.png

ステップ 役割
initializeArray 最後にHTTP ResponseするときのBodyを配列として初期化
Get files (properties only) 対象のライブラリに含まれるファイルのプロパティ(フォルダーパス、ファイル名、拡張子を利用)
Get file content using Path 対象のライブラリの特定のファイルのコンテンツを取得
Append to array variable Initializeした配列変数に、前のステップで取得したファイルのコンテンツとファイル名を格納
Response Foreachで取得したコンテンツに基づいて作成された配列要素をBodyとして、特殊なスキーマでResponseを返す

image.png
"Get file content using path" は、ファイルのコンテンツを、ファイルへのパスに基づいて取得するアクションです。
また後続の"Append to array variable"にある fileContent はbody('Get_file_content_using_path')?['$content'] で指定しています。
※ここで、「ファイルのコンテンツ」は出力をダウンロードすると以下のような形式になっていました。

FileContent.json
{
    "statusCode": 200,
    "headers": {
        "Transfer-Encoding": "chunked",
        "X-SharePointHealthScore": "2",
        "DATASERVICEVERSION": "3.0",
       (中略)
        "X-Powered-By": "ASP.NET",
        "Content-Disposition": "attachment",
        "Content-Type": "application/pdf",
        "Expires": "Tue, 23 Jul 2019 07:27:40 GMT",
        "Last-Modified": "Wed, 07 Aug 2019 07:27:40 GMT",
        "Content-Length": "461325"
    },
    "body": {
        "$content-type": "application/pdf",
        "$content": "JVBERi0x.......jYNJeLjz9MNCjE"
    }
}

ここから、$contentにファイルのBase64文字列が格納されていることがわかります。まさにbody('Get_file_content_using_path')?['$content']では、このBase64文字列を抽出しています。

最大のポイント:スキーマ

今回の最大のポイントは、ResponseステップでのResponse Bodyに関するスキーマです。

ResponseSchema.json
{
    "type": "array",
    "items": {
        "type": "object",
        "properties": {
            "fileContent": {
                "title": "fileContent",
                "x-ms-dynamically-added": true,
                "type": "string",
                "format": "byte"
            },
            "fileName": {
                "type": "string"
            }
        }
    }
}

重要なのは"fileContent":に続く「おまじない」パートです。これをいれることによって、PowerAppsにファイルとしてデータを返却したときと同じ結果が得られます。

PowerApps側

PowerApps側は非常にシンプルです。
image.png
App.OnStartで、Flowの実行結果をCollectionに格納します。Collection内に格納されている"fileContent"をラベルに表示させると、「appres://blobmanager/....」となっています。
つまり先ほどの特殊なスキーマによって、Base64文字列から、ローカルにキャッシュされたようなPDFファイルが作成されたことがわかります。
image.png

以上で全体の作成は完了です。Phoneレイアウトで作成した場合の作例は下記をごらんください。

9
9
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
9
9

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?