カスタマイズビューを作成してみよう
カスタマイズビューとは
kintoneのカスタマイズビューは、表形式やカレンダー形式の一覧の代わりに、HTMLで自由に表示をカスタマイズできる一覧です。
カスタマイズビューと、レコード一覧イベントを使ったJavaScriptカスタマイズを組み合わせると、レコードの一覧を表計算ソフトやカード形式のような見た目で表示させることができます。
カスタマイズビューでは、レコードの一覧の表示形式を「カスタマイズ」に設定して、一覧を作成します。
カスタマイズ形式の一覧を作成または編集するには、kintoneシステム管理権限が必要です。
カスタマイズビューを作ってみよう
手始めに「Hello World!」と表示させるだけのカスタマイズビューを作ってみましょう。
まず、何もフィールドを配置せずにアプリを作成します。
次に、レコードの一覧の表示形式を「カスタマイズ」に設定して、一覧を作成します。
手順の詳細は、
一覧を設定する
を確認してください。
-
「一覧ID」の値をメモに控えておきましょう。
-
「ページネーションを表示する」のチェックは選択したままにします。
-
HTMLには、次の内容を記載します。
1 2
<div id="customizeview-simple"> </div>
カスタマイズファイルを作成します。次の内容をテキストエディタに貼り付け、ファイルを保存します。
- 4行目の
一覧ID
を、一覧を作成するときに確認した「一覧ID」の値に置き換えます。 - ファイル名は任意ですが、ファイルの拡張子は「js」にしてください。
ここでは例として、「customizeview-simple.js」とします。 - 文字コードは「UTF-8(BOMなし)」を指定してください。
|
|
最後に、カスタマイズファイルをアプリに適用します。
手順の詳細は、
JavaScript / CSSファイルを取り込む
を確認してください。
「PC用のJavaScriptファイル」に、作成した「customizeview-simple.js」を指定します。
画面左上の【保存】をクリックし、画面右上の【アプリを更新】をクリックします。
カスタマイズビューを開いて、「Hello Word!」と表示されれば成功です。
カスタマイズビューを作るときの3つのポイント
カスタマイズビューを作るときのポイントは3つあります。
1. 特定の一覧でのみカスタマイズを適用する
レコード一覧のイベントでカスタマイズを適用すると、すべての一覧に対して、カスタマイズが反映されてしまいます。
作成したカスタマイズビューだけカスタマイズを適用したい場合には、イベントオブジェクトのviewId
とカスタマイズビューの一覧IDを照合させます。
IDが一致しなければ、カスタマイズを反映させないようにします。
|
|
2. ベースとなるHTMLとJavaScriptカスタマイズを組み合わせる
カスタマイズビューでは、あらかじめ一覧の設定の「HTML」に、ベースとなるHTMLを書いておきます。
レコードの情報などの動的に表示させたい内容は、アプリに適用したJavaScriptファイルでデータを生成し、ベースとなるHTMLに差し込んで表示させます。
先ほどの例では、「HTML」にdiv要素だけのベースとなるHTMLを書き、カスタマイズファイルで「Hello World!」という内容の要素を生成して表示させました。
3. 「ページネーションを表示する」
例では、レコードの内容を使いませんでしたが、カスタマイズビューでは、イベントオブジェクトのレコードの情報を使うことが多いです。
「ページネーションを表示する」のチェックボックスを選択すると、レコード一覧画面を表示したとき、イベントオブジェクトでレコード情報が返されます。
イベントオブジェクトのレコード情報を利用する場合は、チェックを選択しておきましょう。
インクリメンタルサーチができるカスタマイズビューを作ろう
アプリストアの
問い合わせ管理アプリ
を使って、インクリメンタルサーチができる一覧を作ってみましょう。
今回は、インクリメンタルサーチができる一覧を作るために、 Listjs というライブラリを利用します。
STEP1:カスタマイズビューを作る
問い合わせ管理アプリ
をkintoneに追加しましょう。
「サンプルデータを含める」のチェックボックスを選択した状態で、アプリを追加してください。
次に、レコードの一覧の表示形式を「カスタマイズ」に設定して、一覧を作成します。
HTMLには、次の内容を記述します。
|
|
このとき、一覧IDをメモしておきます。カスタマイズファイルで利用します。
最後に、画面左上の【保存】をクリックし、画面右上の【アプリを更新】をクリックします。
STEP2:カスタマイズファイルを作る
今回のカスタマイズファイルを作成しましょう。
ここでは、例としてファイル名を「customizeview-listjs.js」とします。
文字コードは「UTF-8(BOMなし)」を指定してください。
このカスタマイズでは、レコードの一覧画面を表示したときのイベントを利用します。
特定のカスタマイズビューだけカスタマイズを適用したい場合は、イベントオブジェクトのviewId
とカスタマイズビューの一覧IDを照合させるんでしたね。
STEP1でメモしておいた一覧IDに置き換えます。
|
|
次に、List.jsの使い方をドキュメントで確認しましょう。
List.jsは、
Really simple examples
というページでさまざまなサンプルコードを公開しています。
今回は「Example 2: Create list on initialization: Version 1」を参考に、イベントオブジェクトのレコード情報を使って、一覧を作っていきましょう。
これから出てくるコードを、カスタマイズファイル内の同じコメントの箇所と置き換えてください。
まず、一覧の項目に表示する内容を作ります。
map
メソッドを使って、キーと値が対となるようにレコードオブジェクトの配列を整形します。
|
|
続いて、一覧の項目として、valueNames
とitem
をそれぞれキーにもつオブジェクトを作ります。
|
|
最後に、一覧を生成します。
今回、一覧を表示する要素のIDは、customizeview-listjs
なので、Listの第一引数に指定します。
|
|
これで、List.jsを使った一覧のカスタマイズファイルが完成しました。
次のステップで、カスタマイズを適用していきましょう。
STEP3:カスタマイズを適用する
カスタマイズをアプリに適用します。
「PC用のJavaScriptファイル」に、次の順でURLとファイルを指定します。
- https://cdnjs.cloudflare.com/ajax/libs/list.js/2.3.1/list.min.js
- customizeview-listjs(カスタマイズファイル)
画面左上の【保存】をクリックし、画面右上の【アプリを更新】をクリックすれば完了です。
動作確認
kintoneで一覧画面を開いてみましょう。
レコードの内容が表示されて、インクリメンタルサーチができたら成功です。
まとめ
今回は、カスタマイズビューについて学習しました。
HTMLの知識が必要ではありますが、カスタマイズビューを使えば幅広いことができます。
次回は、
Webhookを使ってみよう
について学習しましょう。