1
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

【FileMaker】詳細データをカードめくりしたい

Last updated at Posted at 2024-05-26

というお題をいただいたので、サンプルを作った、というのが最近ありました。
レコード移動とポータル内のレコード移動がうまく連動できれば1画面で効率よく表示ができる感じです。

※今回こちらで紹介するサンプルは、実際にお題をいただいた方にご提示したものをアレンジした形になります。

この記事の対象者

  • FileMakerで、概要レコードレイアウトに詳細レコードをなんとか1画面でうまーく表示したい人
  • 詳細レコードを矢印ボタンで表示したい人

最終ゴール

1画面内で、詳細レコードを矢印ボタンで移動させながら表示させる。
FileMaker_詳細レコードのポータル移動.gif

イメージはこちらです。
スクリーンショット 2024-05-26 14.50.09.png
ボタン移動1とボタン移動2の解説になります。

サンプルとして、とある企画会社が開催するカンファレンスで来場者に配布したアンケートの集計を画面に表示する、というものになります。
実際にアンケートに入力する流れはありません。
集計したアンケート内容を表示する、という部分になります。

実装環境

FileMaker Pro 2023で作成しましたが、本筋の部分については、特に新しい機能は使用していないので、大部分のバージョンで実装可能だと思います。
レイアウト上、比較的新しい機能を使用しているところは、お使いのバージョンで代替して実装してみてください。

それでは、作っていきましょう!

テーブル設計

テーブル

スクリーンショット 2024-05-26 14.55.34.png
1回のカンファレンスで配るアンケートを1種類(テーブル:アンケート)にし、アンケート内容は5項目(テーブル:アンケート_集計)にしました。

フィールド

アンケート

スクリーンショット 2024-05-26 14.55.48.png
アンケートタイトルと集計期間、参加人数を記録しています。
詳細レコードのカードめくり自体にはなんら影響はないので、「参加人数」フィールド以外のフィールドはなくても機能します。

アンケート_集計

スクリーンショット 2024-05-26 14.56.03.png
アンケート内容のフィールドです。
「アンケート_主キー」フィールドは、「アンケート」テーブルとつなぐキーとなります。
「gカードめくり」フィールドは、矢印ボタンで表示させるレコードの主キーを入れて操作します。
「s_件数」フィールドは、アンケートが何件集計されているかというカウントをしています。

リレーションシップ

スクリーンショット 2024-05-26 15.09.41.png
アンケートの概要と回収したアンケートの詳細をリレーションシップグラフで繋ぎます。
リレーションシップグラフだけだとちょっとイメージしずらいかなと思ったので、具体的なイメージも添えました。

レイアウト設計

関連づけられているテーブルを、「アンケート」テーブルにして、レイアウトを作成します。
スクリーンショット 2024-05-26 15.13.22.png

アンケート概要部分

アンケートの概要は、画面左側に配置している部分になります。
集計件数の回収率計算は、FileMaker Pro 2023(ver.20.2)から提供されている「レイアウト計算」機能を使っています。
それ以外の方法として、通常のフィールドに計算式を作成するなどもありますので、現場に合わせて実装してみてください。スクリーンショット 2024-05-26 15.15.25.png

アンケートテーブルの移動ボタン

移動ボタンを配置します。
今なんのアンケートを表示しているか、というアンケートタイトルを配置しても分かりやすくていいと思います。
スクリーンショット 2024-05-26 15.20.56.png

アンケート詳細の移動ボタン

1つ1つのアンケートを表示するための移動ボタンを配置します。
ここの移動ボタンを配置した部分は、先ほどのアンケートテーブルとは違い、実はポータルになっています。
スクリーンショット 2024-05-26 15.27.51.png
この部分のポイントは、書式で行数を「1」に設定することです。

アンケート詳細の移動に使うテーブルを配置

みなさん、レイアウトの外って使ってますか?
表示されていないレイアウトの外にもオブジェクトを配置できるんですよ。
そして、それはちゃんと表示されているオブジェクトと同様に機能します。
なので、アンケート詳細の移動を補助する形で、一つポータルを配置しておきます。
スクリーンショット 2024-05-26 15.32.23.png
ここのポータルで表示するTO(テーブルオカレンス)は、「アンケート_集計」です。
また、ここでもポイントがあります。
ポータルに名前をつけるのです。
ここでは、「カードめくり_サブ」とつけています。
分かりやすければ、なんでもいいです。
行数は、何行でも大丈夫ですが、「垂直スクロールを許可」にチェックを入れておくことを忘れないでください。
「垂直スクロールを許可」を忘れると、指定した行数しか移動できません。。。

「垂直スクロールを許可」については、以下で解説しているので、参考にしてみてください。

アンケート詳細の表示

アンケート詳細の表示は、「アンケート詳細の移動ボタン」で作ったアンケート詳細のポータルに含めても問題ないです。
今回は、移動ボタンとはあまり関係がないので、別途、フィールドを画面に配置しました。
表示するTO(テーブルオカレンス)は、「アンケート_集計 2」です。
移動したアンケート詳細の内容になります。
スクリーンショット 2024-05-26 15.36.30.png

スクリプト

共通で使うスクリプト

スクリプトの中で、共通に使うスクリプトです。

スクリプト:件数設定

スクリーンショット 2024-05-26 15.43.07.png
これは、回収されたアンケートが同時並行で追加されて行った時、アンケート件数が最初にこのレイアウトを開いた時と違ってしまう可能性があるので、最新のアンケート件数をレイアウトで使用しているグローバル変数に表示できるようにしています。

アンケート詳細のスクリプト

スクリーンショット 2024-05-26 15.41.47.png

スクリプト:最初に | アンケート集計

ポータル移動では、「ポータル内の行へ移動」を使います。
レイアウト外に配置した、ポータルです。
スクリーンショット 2024-05-26 15.44.11.png
3行目のグローバルフィールドには、表示しようとしているアンケート詳細の主キーを設定します。
4行目では、現在どのレコード番号を表示しているかをレイアウトに表示するグローバル変数に入れています。

スクリプト:前に | アンケート集計

こちらも、同様にポータル移動で処理をしています。
先ほどの「最初に、、、」のスクリプトと違うのは、移動した先が先頭だった時の処理が追加されています。
スクリーンショット 2024-05-26 15.44.17.png

スクリプト:後ろに | アンケート集計

こちらも同じく、移動した先が最後だった時の処理を追加しています。
スクリーンショット 2024-05-26 15.44.23.png

スクリプト:最後に | アンケート集計

こちらは、「最初に、、、」と似た作りになっています。
違うところは、共通処理を最初に持ってきて、最新の集計数を持ってきているところです。
スクリーンショット 2024-05-26 15.44.30.png

アンケート概要のスクリプト

次は、アンケート概要の移動ボタンです。
スクリーンショット 2024-05-26 16.02.32.png

アンケート概要は、レイアウトのTO(テーブルオカレンス)にもなっているので、そのままレコード移動が使えます。
ただ、ポータルの移動の時と同様に、最新のアンケート回収数を得たいので、共通処理も実行しています。
アンケート概要でアンケート回収数を活用したい部分は、回収率を計算する部分です。

スクリプト:最初に | アンケート

スクリーンショット 2024-05-26 15.43.44.png

スクリプト:前に | アンケート

スクリーンショット 2024-05-26 15.56.57.png

スクリプト:後ろに | アンケート

スクリーンショット 2024-05-26 15.57.04.png

スクリプト:最後に | アンケート

スクリーンショット 2024-05-26 15.57.10.png

レイアウトの初期設定

レイアウトが表示された時、アンケート回収数の取得と表示されているアンケート概要の最初のアンケート詳細を表示するために、レイアウトのスクリプトトリガのOnLayoutEnterに「最初に | アンケート集計」スクリプトを実行して初期設定をしています。
スクリーンショット 2024-05-26 16.03.27.png

動かしてみた?

実装は、ここまでです!
あまり今回のお題に関係しない部分は解説していない部分もありますが、実際に作ってデータを入れて体感してみてくださいね。
テストデータを追加するとき用に、レイアウトを一つ作っておくといいですよ。

リレーションシップを組むときに、リレーションシップを活用した詳細レコードの追加の部分にチェックを入れておくと、テストデータ追加のときに自動で「アンケート_集計::アンケート_主キー」フィールドに「アンケート::主キー」を設定してくれるので、便利です。
スクリーンショット 2024-05-26 16.09.28.png

この設定をしておくと、ポータル表示をした詳細レコードで、次のデータフィールドが現れます。
スクリーンショット 2024-05-26 16.15.56.png

では、また!

1
1
0

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
1
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?