はじめに
Kintone Portal Designer を使ったポータルカスタマイズに関する記事の第2弾です!
ポータルの背景画像をkintoneのアプリで管理しよう!〜kintoneのポータルカスタマイズ紹介 #1〜は、すでにお読みになりましたか?
まだの方は、ぜひ読んでいただけるとうれしいです。
今回の記事では、優先する組織を判別して、ポータルの内容を出し分けるカスタマイズを紹介したいと思います。
アプリに登録されたリッチエディターの内容をポータルのお知らせ欄に表示します。
使い方
こちらの記事は
Kintone Portal Designer
を使う前提でお話します。
「Kintone Portal Designer」の使い方については、
Kintone Portal Designerを使ってポータルをデザインしようを参照してください。
本カスタマイズを利用する場合、カスタマイズを適用するユーザーに「優先する組織」を設定してください。
「優先する組織」が設定されていない場合、ポータルへ表示する内容を管理するアプリに登録された、いずれかのポータルの内容が表示されます。
STEP1ポータルに表示する内容を管理するアプリの作成
まずは、kintoneでアプリを作りましょう。
新しくアプリを作成して、以下のフィールドを設置してください。
あとで必要になるので、以下の内容をメモしておきましょう
- 組織選択フィールド
- リッチエディター
次に、1つレコードを登録しておきましょう。
組織選択フィールドには何も登録せず、リッチエディターに「Hello kintone」と書いて保存しましょう。
あとで必要になるので、以下の内容をメモしておきましょう
- アプリのアプリID
- 作成したレコードのレコード番号
URLを見ることでアプリIDとレコード番号を確認できます。
例:https://{subdomain}.cybozu.com/k/{ アプリID }/show#record={ レコード番号 }
アプリの使い方
-
組織選択フィールド
組織選択フィールドには、レコードの内容を表示させたい組織を入力します。
入力された組織が優先する組織に該当する人のみに表示されます。 -
リッチエディター
リッチエディターには、お知らせ欄に表示させたい内容を入力します。
リッチエディターの内容がそのままお知らせ欄に表示されます。
STEP2カスタマイズに必要なファイルのダウンロード
以下のzipファイルをダウンロードして、解凍してください。
STEP3カスタマイズの変更
解凍したzipファイルの中にある「OrganizationSwitcher.json」を「Kintone Portal Designer」にインポートしましょう。
インポートの方法がわからない場合は、
Kintone Portal Designerを使ってポータルをデザインしようを参照してください。
ここからは、「Kintone Portal Designer」を使いながら、メモした内容に合わせて、JavaScriptの内容を変更します。
アプリIDを指定
以下の部分の「12345」をメモしたアプリIDに変更しましょう。
|
|
優先する組織が含まれるレコードがなかったときに表示するレコードの指定
以下の部分の「1」をメモしたレコード番号に変更しましょう。
|
|
フィールドコードの指定
先ほどメモした、リッチエディターのフィールドコードと、組織選択フィールドのフィールドコードを指定しましょう。
|
|
STEP4表示の確認
ここまで変更できたら「Save」を押して、ポータルに戻ってみましょう。
「Hello kintone」と表示されているはずです。
STEP5優先する組織に指定されたレコードの内容が表示されるかを確認する
先ほど登録したアプリに新しく別のレコードを登録しましょう。
組織選択フィールドには、ご自身の優先する組織を入力しましょう。
リッチエディターには「My Team Portal」と入力し、レコードを保存してください。
ポータルに戻ってみましょう。「My Team Portal」と表示されているはずです。
コードの解説
ここからは、詳しくJavaScriptの内容について解説していきます。
今回使用したコードは大きく分けて「自分の優先する組織が含まれるレコードを取得」と「リッチエディターの内容をポータルに表示」の2つで構成されています。
自分の優先する組織が含まれるレコードを取得
kintone REST APIの 複数のレコードを取得するを使用しています。
APIを実行して、レコードが取得できた時は、取得したレコードのリッチエディターの内容を返します。
取得できたレコードが0件のときは、DEFAULT_RECORD_NUMBER
に設定されたレコードを取得する処理を行います。
|
|
'query': ORGANIZATION_CODE + ' in (PRIMARY_ORGANIZATION()) limit 1'
の部分を確認してください。
ここでは、組織選択フィールドに優先する組織PRIMARY_ORGANIZATION()
が含まれるレコードをひとつだけ取得しています。
処理を実行するユーザーに「優先する組織」が設定されていない場合、組織in(PRIMARY_ORGANIZATION())
の条件は無視され、それ以外の絞り込み条件を満たすすべてのレコードが取得されます。
詳しくは
クエリの書き方の「関数」部分を参照してください。
上記の処理で「取得できたレコードが0件」だった時に実行される処理はこちらです。
|
|
DEFAULT_RECORD_NUMBER
に登録されているレコードのリッチエディターの内容を返します。
リッチエディターの内容をポータルに表示
以下の部分は、1で得られたリッチエディターの内容が表示される場所を取得しています。
今回はHTMLにIDを追加し、そのIDを使って、表示する場所を取得しています。
|
|
リッチエディターのvalueに格納されたhtmlにはスタイルが適用されているため、そのhtmlをそのまま表示させています。
|
|
実行とエラー
最後の行で、今までのコードを実行しています。
|
|
どこかでエラーが出た時は、以下の処理が実行されます。
|
|
おわりに
今後も、kintoneのポータルのカスタマイズに関する記事を発信していく予定です。
ぜひ楽しみにお待ちください。
このTipsは、2019年10月版kintoneで動作を確認しています。