micomia株式会社の畑井です。
今回はある画面でリスト表示されている投稿などをタップして詳細が見れるような機能についてどうやって作るのか解説していきます。
今回お題として扱うのはユーザーの一覧表示と詳細表示画面となります。
1.ページを2枚作る

画像で表示しているプロジェクトではフォルダが複数ありますが、今回利用するのは「SampleList」と「SampleListDetail」の2つだけとなります。
2.Widgetを配置する

AppBarを削除して、Columnの中にListViewを入れ、ListViewの中にContainerを入れ、Containerの中にTextを入れています。

ListViewにAdd Queryで表示するデータを選択します。
今回はデータを次のページに渡すことだけを伝えることができれば問題ないのでどこのプロジェクトでも大抵定義されているusersコレクションを利用します。
usersコレクションをまだ定義していない方は下記の画像を参考に入力してみてください。

下記のような画面が表示されますが、Confirmで大丈夫です。

下の画像が完成状態です。

ListViewから取得してくる情報を画面に表示させてあげましょう。
今回はusers Documentのdisplay_nameで名前を表示させてあげるでいいと思います。
3.画面遷移を実装する

ContainerをクリックしてActionsからNavigate ToのSampleListDetailをクリックして上の画像のような状態にしましょう。
次に上の画像の画面右下にあるParametersというところの「+Define」をクリックします。
ここではパラメーターとして画面を移動する際に何のデータを一緒に持っていくかを決めていきます。

今回はListViewにあるDocument Referenceを次のページに持って行ってあげるとそのページでDocument Referenceを読み込んでドキュメント情報を取得できるので画像のように定義してConfirmを押しました。

Passという緑に光るボタンが現れますのでクリックしてListViewにあるDocument Referenceをセットしてあげます。
下の画像のようにセットしてみてください。

次の設定をするために移動先のSampleListDetailに移動します。
4.移動先のページでデータを受け取ろう

SampleListDetailのWidget Treeの一番上にあるWidgetをクリックして、Add QueryからDocument from ReferenceでPage ParametersにあるuserRefをセットしてあげます。画面遷移の時にセットしたParameterはPage Parameterという名前で遷移先の画面に現れます。

このページにDocument from ReferenceでセットしたのでText Widgetを置いてみるとデータが取れるようになっていることが確認できると思います。
複数のText Widgetを置くことで詳細情報を表示する画面を作ることができると思います。



.webp%3Falt%3Dmedia%26token%3D44d272c7-1e7a-46d7-86de-dc2bec67a3e4&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3Dbc168691-5281-4eab-8c08-ed7fe5624582&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D8f9453ad-d017-4640-8b7b-4c5d55391f46&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D904686c4-e792-4c6a-b5ce-e7648fd53404&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D8db330f1-3fab-48b7-8dcf-dd8c6f47836a&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3Ddef3da75-721c-4e42-8cd8-f06795bb771f&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D8fec979d-a6dc-4d03-960f-330f997108a7&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D6bddee16-071d-41fd-8a4b-f2026bcff617&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D9ba70870-6b39-4eab-b9c2-e126ef08cb09&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D8a795f56-e8a9-4be1-937b-65c1a89922b3&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3Dbe65d589-2f4c-4ad8-82a1-7ddb73af2620&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D0aa104f5-928b-4ddf-a535-d8574b7667a8&w=3840&q=75)

.webp%3Falt%3Dmedia%26token%3D45131e3d-4777-421a-a556-bcc8d462dfe1&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D09daf923-4a62-4c31-af6f-f3d99a9f635b&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D0e63e93b-1558-48a5-8b24-d1ae7cfa487f&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D240fcc34-b7e7-4c86-b294-fdfc2a66db21&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3Db288c602-2902-4f93-8eca-903ec8f86440&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D6040f2d9-1a54-476c-9999-5e0aeb8e8a74&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D3c4b1b17-9fec-405e-9e02-8d34961b6f16&w=3840&q=75)