kintoneにCSSも適用しやすくなって、挑戦中の方もいらっしゃるのではないでしょうか?
そして、出来ればkintoneらしくファストに仕上げるため、CSSフレームワーク(有名どころはBootstrapやFoundation等)の利用を考えられた方も少なくないと思います。
私もそうでした。
今回は、CSSフレームワークのひとつ「Foundation」をカスタマイズビューに適用してブログ風のビューに仕上げる方法を紹介します。
社内のブログや連絡掲示板としてお使いいただけると思います。
デモ環境で実際に動作を確認できます。
https://dev-demo.cybozu.com/k/171/
ログイン情報は
cybozu developer networkデモ環境
で確認してください。
次のフィールドを含むアプリをご準備ください。
フィールド名(例)
|
フィールドコード
|
フィールドタイプ
|
タイトル
|
title
|
文字列 (1行)
|
投稿者
|
author
|
文字列 (1行)
|
投稿日
|
postedDate
|
日付
|
内容
|
article
|
文字列 (複数行)
|
「一覧」の設定で「レコード一覧の表示形式」で「カスタマイズ」を選択し、「ページネーションを表示する」にチェックを入れます。
「ページネーションを表示する」にチェックを入れると、カスタマイズ形式の一覧画面でkintone JavaScript APIのevent.recordsが使用できます。
「HTML」のテキストエリアに次の「HTMLソースコード」を貼り付けます。
Foundationの
公式サンプル
や
ドキュメント
を参考にコーディングします。
1行目ではCSSを読み込んでいます。
原則としては「JavaScript / CSSでカスタマイズ」画面からCSSを適用しますが、「JavaScript / CSSでカスタマイズ」画面からCSSを読み込むとkintone全体のCSSに影響を及ぼします。
そのため、今回はHTML内にCSSを読み込むコードを記述しています。
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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
<!--
* Customize view using CSS framework
* Copyright (c) 2014 Cybozu
*
* Licensed under the MIT License
-->
<link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/npm/foundation-sites@6.7.5/dist/css/foundation.min.css">
<div id="kintone-costum-view" name="kintone-custom-view" style="margin-top:25px;">
<div class="grid-container">
<!-- Nav Bar -->
<div class="grid-x">
<div class="large-12 cell">
<h1>ブログ・連絡掲示板 <small>情報共有・連絡</small></h1>
<hr />
</div>
</div>
<!-- End Nav -->
<!-- Main Page Content -->
<div class="grid-x">
<!-- Main Blog Content -->
<div id ="articles" name="articles" class="large-12 cell" role="content">
</div>
<!-- End Main Content -->
</div>
<!-- End Main Content -->
<!-- Footer -->
<footer class="grid-x">
<div class="large-12 cell">
<hr />
<div class="grid-x">
<div class="large-6 cell">
<p>© Copyright Ryu Yamashita</p>
</div>
</div>
</div>
</footer>
<!-- End Footer -->
</div>
</div>
|
JavaScript
固定リンクがコピーされました
JavaScriptは以下を追加します。
今回のカスタマイズでは動的なUIを使用しないため、foundation.min.js
やコード内の$(document).foundation();
がなくても動作します。
- URL指定で追加
- https://js.cybozu.com/jquery/3.6.1/jquery.min.js
- https://cdn.jsdelivr.net/npm/foundation-sites@6.7.5/dist/js/foundation.min.js
- アップロードで追加
- 下記ソースコードを参考に、sample.js等のファイルを作成し保存してください。
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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
/*
* Customize view using CSS framework
* Copyright (c) 2014 Cybozu
*
* Licensed under the MIT License
* https://opensource.org/license/mit/
*/
(() => {
'use strict';
kintone.events.on('app.record.index.show', (event)=> {
// カスタムビューでなければここで終了
const check = document.getElementsByName('kintone-custom-view');
if (check.length === 0) {
return event;
}
// 今回のカスタマイズでは動的なUIを利用しないためコメントアウト
// $(document).foundation();
const rec = event.records;
// イベントの多重化による要素生成に対応
$('#articles').empty();
const appId = kintone.app.getId();
const recUrl = `/k/${appId}/show#record=`;
// 記事の中身を作成
for (let i = 0; i < rec.length; i++) {
if (i !== 0) {
$('#articles').append('<hr />');
}
$('#articles').append(`<article id="article${i}" class="articles"></article>`);
$(`#article${i}`).append(`<h3><a href="${recUrl}${rec[i].$id.value}">${rec[i].title.value}</a></h3>`);
$(`#article${i}`).append(`<h6>投稿者:${rec[i].author.value} 投稿日:${rec[i].postedDate.value}</h6>`);
$(`#article${i}`).append('<br>');
$(`#article${i}`).append(`<div id="articleRaw${i}"></div>`);
$(`#articleRaw${i}`).append(`<p>${rec[i].article.value.replace(/\r?\n/g, '<br />')}</p>`);
} // for i
return event;
}); // kintone.events
})();
|
JavaScriptソースコードの説明
主なポイントは次のとおりです。
- 動的に変化する記事内容やニュースをList要素でカスタマイズビュー(HTML)に追加
- 「Foundation」の利用のために、jQueryをロードしていることを利用して、DOM操作をjQueryで記述
今回の注意点は次のとおりです。
- 今回はCSSフレームワークとして「Foundation 6」を用いていますが、対応ブラウザー、ライセンス等利用に関する制限は各自で確認してください。
- 今回外部ライブラリを無償CDNからロードしていますので、継続性等については
公式サイト
を確認してください。
CSSフレームワーク「Foundation 6」を用いた画面カスタマイズ、いかがでしたでしょうか?
CSSフレームワークの利用は、デザインが苦手でもそれなりの見た目を手に入れることができますし、kintoneのファストさとの相性もよいと思います。
今回は簡単な例を紹介しましたが、CSSフレームワークのGrid等基本機能とkintoneのAPI等を駆使すればkintoneでポータルサイトを作り上げることもできます。
皆さまの参考になれば幸いです。