フィールドの表示/非表示を切り替えてみよう

目次

前回は、レコードの画面に任意のテキストを表示するカスタマイズを通して、kintoneイベントの使い方やkintoneのレコード画面にテキストを表示する方法を学びました。
今回は、フィールドの表示/非表示を切り替えるカスタマイズを通して、次のことを学びます。

  • 複数のイベントで同じ処理を実行する方法
  • 条件によってフィールドの表示/非表示を切り替える方法

動作イメージ

今回のカスタマイズを適用すると、レコード追加画面と編集画面で、「入金ステータス」が確認済のときに「入金日」「入金確認者」が表示されます。

カスタマイズを適用するアプリ

次のフィールドを配置したアプリを作成します。

フィールド名 フィールドタイプ フィールドコード 備考
入金ステータス ラジオボタン 入金ステータス 次の選択肢を設定する
  • 未入金
  • 確認済
入金日 日付 入金日
入金確認者 ユーザー選択 入金確認者

フィールドの表示/非表示を切り替える

ラジオボタンの値に応じてフィールドの表示/非表示を切り替えてみましょう。
実装するのは、「入金ステータス」に応じて「入金日」と「入金確認者」のフィールドの表示/非表示を切り替えるカスタマイズです。

サンプルコード

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
(() => {
  'use strict';
  // 制御に利用するラジオボタンのフィールドコード
  const statusFieldCode = '入金ステータス';
  // 表示非表示を切り替えるフィールドのフィールドコード
  const fieldCodes = ['入金日', '入金確認者'];

  // 「入金ステータス」フィールドによって、特定のフィールドの表示/非表示を切り替える
  kintone.events.on([
    'app.record.create.show',
    'app.record.edit.show',
    `app.record.create.change.${statusFieldCode}`,
    `app.record.edit.change.${statusFieldCode}`
  ], (event) => {
    const record = event.record;
    const statusFieldValue = record[statusFieldCode].value;
    fieldCodes.forEach((fieldCode) => {
      if (statusFieldValue === '確認済') {
        kintone.app.record.setFieldShown(fieldCode, true);
      } else {
        kintone.app.record.setFieldShown(fieldCode, false);
      }
    });

    return event;
  });
})();

ソースコードの解説

このカスタマイズのポイントは次の3つです。

  • イベントを複数指定する。
  • 表示されているレコードの情報を取得する。
  • フィールドの表示/非表示を切り替える。

イベントを複数指定する

このカスタマイズでは、ユーザーが次の4つの操作のいずれかを行ったとき、処理を実行します。

  • レコード追加画面を表示したとき
  • レコード編集画面を表示したとき
  • レコード追加画面で「入金ステータス」の値を変更したとき
  • レコード編集画面で「入金ステータス」の値を変更したとき

複数のイベントで同じ処理を実行したい場合には、kintone.events.on()の第1引数に配列でイベントタイプを指定します。

 9
10
11
12
13
14
15
16
  kintone.events.on([
    'app.record.create.show',
    'app.record.edit.show',
    `app.record.create.change.${statusFieldCode}`,
    `app.record.edit.change.${statusFieldCode}`
  ], (event) => {
    // 実行したい処理
  });

表示されているレコードの情報を取得する

表示されているレコードの情報は、kintone.events.on()の第1引数、つまりeventという変数に入っています。
このeventのことを、イベントオブジェクトと呼びます。

レコードの情報は、イベントオプジェクトのrecordプロパティに格納されており、event.recordで取得します。
各フィールドの値はevent.record['フィールドコード'].valueで取得できます。
したがって「入金ステータス」の値はevent.record['入金ステータス'].valueで取得できます。

今回、フィールドコードはstatusFieldCodeという変数に代入しているため、statusFieldCodeを使って取得します。

 9
10
11
12
13
14
15
16
  kintone.events.on([
    'app.record.create.show',
    'app.record.edit.show',
    `app.record.create.change.${statusFieldCode}`,
    `app.record.edit.change.${statusFieldCode}`
  ], (event) => {
    const record = event.record;
    const statusFieldValue = record[statusFieldCode].value;

フィールドの表示/非表示を切り替える

フィールドの表示/非表示を切り替えるには、 kintone.app.record.setFieldShown() というメソッドを使います。
第1引数には表示を切り替えたいフィールドのフィールドコード、第2引数にはフィールドを表示するかどうかを設定する真偽値を設定します。
フィールドを表示したい場合にはtrue、非表示にしたい場合にはfalseを指定します。

1
kintone.app.record.setFieldShown('表示を切り替えたいフィールドのフィールドコード', 真偽値);

たとえば「入金日」というフィールドコードのフィールドを非表示にしたい場合には、次のように書きます。

1
kintone.app.record.setFieldShown('入金日', false);

今回は「入金日」と「入金確認者」という複数のフィールドを非表示にしたいため、フィールドコードをあらかじめ配列に定義して配列のメソッドのforEachを使って繰り返し処理します。
「入金ステータス」が「確認済」だったら表示、それ以外だったら非表示にするという分岐もforEachの中で行います。

17
18
19
20
21
22
23
    fieldCodes.forEach((fieldCode) => {
      if (statusFieldValue === '確認済') {
        kintone.app.record.setFieldShown(fieldCode, true);
      } else {
        kintone.app.record.setFieldShown(fieldCode, false);
      }
    });

まとめ

フィールドの表示/非表示を切り替えるには、kintone.app.record.setFieldShown()というAPIを使うと実現できることを学びました。
また、イベントタイプを配列形式で指定すると、複数のイベントで同じ処理を実行できます。
レコード追加画面と編集画面では同じ処理を実行したいケースも多いため、配列で指定する方法を覚えておくと便利です。

次回は、 フィールドの編集可/編集不可を切り替えてみよう を学びます。