ダッシュボード dashboards
AEM の使用時、ページやアセットなど様々なタイプの多数のコンテンツを管理できます。AEM ダッシュボードの簡単でカスタマイズ可能な方法を使用して、統合されたデータを表示するページを定義できます。
ダッシュボードの管理 administering-dashboards
ダッシュボードの作成 creating-a-dashboard
- 「ツール」セクションで、「設定コンソール」をクリックします。
- ツリー内で、「ダッシュボード」をダブルクリックします。
- 「ダッシュボード」をクリックします。
- タイトル(「My Dashboard」など)と 名前 を入力します。
- 「作成」をクリックします。
ダッシュボードのクローン作成 cloning-a-dashboard
複数のダッシュボードを作成して、コンテンツについての情報を様々な表示からすばやく確認することができます。新しいダッシュボードを作成しやすくするために、AEM ではクローン機能が提供されています。この機能を使用して既存のダッシュボードを複製できます。ダッシュボードのクローンを作成するには、次の手順を実行します。
-
「ツール」セクションで、「設定コンソール」をクリックします。
-
ツリー内で、「ダッシュボード」をクリックします。
-
クローンを作成するダッシュボードをクリックします。
-
「クローン」をクリックします。
-
新しいダッシュボードの 名前 を入力します。
ダッシュボードの削除 removing-a-dashboard
-
「ツール」セクションで、「設定コンソール」をクリックします。
-
ツリー内で、「ダッシュボード」をクリックします。
-
削除するダッシュボードをクリックします。
-
「削除」をクリックします。
-
「はい」をクリックして実行を確認します。
ダッシュボードコンポーネント dashboard-components
概要 overview
ダッシュボードコンポーネントは、通常の AEM コンポーネントにすぎません。ここでは、AEM に付属しているレポート用コンポーネントについて説明します。
Web 分析レポート用コンポーネント web-analytics-reporting-components
AEM には、SiteCatalyst データの複数の指標をレンダリングする一連のコンポーネントが付属しています。これらのコンポーネントは、サイドキックの「ダッシュボード」セクションに一覧表示されます。
レポート用コンポーネントにはそれぞれ少なくとも次の 3 つのタブがあります。
-
基本:主要な設定が含まれています。
-
レポート:各レポート専用の設定が含まれています。
-
スタイル:グラフのサイズや余白などのスタイル設定が含まれています。
レポート用コンポーネントはデフォルト設定で初期化されており、このデフォルト設定を使用してダッシュボードをすばやく設定できます。
基本設定 basic-configuration
「基本」タブから次の設定エントリにアクセスできます。
タイトル:ダッシュボードに表示するタイトル。
リクエストタイプ:データをリクエストする方法。
SiteCatalyst 設定(オプション):SiteCatalyst との接続に使用する設定。指定がない場合、ダッシュボードページで(ページプロパティによって)設定されると見なされます。
レポートスイート ID (オプション):グラフの生成に使用する SiteCatalyst レポートスイート。
レポート設定 report-configuration
Web 統計を表示するために、取得するデータの日付範囲を定義する必要があります。「レポート」タブにある 2 つのフィールドを使用して、日付範囲を定義できます。
開始日:データの取得を開始する絶対日付または相対日付。
終了日:データの取得を終了する絶対日付または相対日付。
各コンポーネントで、固有の設定も定義されます。
オーバータイムレポート overtime-report
日付の粗さ:X 軸の単位時間(日、時間など)。
メトリクス:表示するイベントのリスト。
要素:グラフ内のメトリクスデータを細分化する要素のリスト。
ランクリストレポート ranked-list-report
要素:グラフ内のメトリクスデータを細分化する要素。
メトリクス:表示するイベント。
不可. 上位項目の数:レポートで表示する項目の数。
ランクレポート ranked-report
メトリクス:表示するイベント。
要素:グラフ内のメトリクスデータを細分化する要素。
トップサイトセクションレポート top-site-section-report
このコンポーネントは、以下の設定に従い、訪問回数の多い web サイトのセクションを示すグラフを表示します。
不可. 上位項目の数:レポートで一度に表示するセクションの数。
トレンドレポート trended-report
日付の粗さ:X 軸の単位時間(日、時間など)。
メトリクス:表示するイベント。
要素:グラフ内のメトリクスデータを細分化する要素。
ダッシュボードの拡張 extending-dashboard
概要 overview-1
ダッシュボードは通常のページ(cq:Page
)なので、あらゆるコンポーネントを使用してダッシュボードを構成できます。
デフォルトのコンポーネントグループ Dashboard
には分析レポート用コンポーネントが含まれていて、これらのコンポーネントはテンプレート上でデフォルトで有効になっています。
ダッシュボードテンプレートの作成 creating-a-dashboard-template
テンプレートは、新しいダッシュボードのデフォルトのコンテンツを定義するものです。様々なタイプのダッシュボードを作成するために、複数のテンプレートを使用できます。
ダッシュボードテンプレートはその他のページテンプレートと同様に作成されますが、/libs/cq/dashboards/templates/
に保存される点が異なります。contentpage テンプレートの作成の節を参照してください。
ダッシュボードコンポーネントの開発 developing-a-dashboard-component
ダッシュボードコンポーネントの開発は、通常の AEM コンポーネントの作成から成り立っています。ここでは、作成者の上位 10 人を表示するコンポーネントを例に説明します。
上位作成者コンポーネントは、/apps/geometrixx-outdoors/components/reporting
のリポジトリに格納され、構成内容は次のとおりです。
-
jcr データを読み取り、
jsp
プレースホルダーを定義するhtml
ファイル。 -
データを取得して整理し、
js
プレースホルダーに入力するhtml
ファイルを 1 つ含むクライアント側ライブラリ。
次の JavaScript ファイルは、geout.reporting.topauthors
のクライアントライブラリでコンポーネントの子として定義されます。
QueryBuilder を使用してリポジトリに対してクエリを実行し、cq:AuditEvent
ノードを読み取ります。クエリの結果として JSON オブジェクトが返され、このオブジェクトから作成者の貢献度が抽出されます。
top_authors.js top-authors-js
$.ajax({
url: "/bin/querybuilder.json",
cache: false,
data: {
"orderby": "cq:time",
"orderby.sort": "desc",
"p.hits": "full",
"p.limit": 100,
"path": "/var/audit/com.day.cq.wcm.core.page/",
"type": "cq:AuditEvent"
},
dataType: "json"
}).done(function( res ) {
var authors = {};
// from JSON to Object
for(var r in res.hits) {
var userId = res.hits[r].userId;
if(userId == undefined) {
continue;
}
var auth = authors[userId] || {userId : userId};
auth.contrib = (auth.contrib || 0) +1;
authors[userId] = auth;
}
// order by contribution
var orderedByContrib = [];
for(var a in authors) {
orderedByContrib.push(authors[a]);
}
orderedByContrib.sort(function(a,b){return b.contrib - a.contrib});
// produce the list
for (var i=0, tot=orderedByContrib.length; i < tot; i++) {
var current = orderedByContrib[i];
$("<div> #" + (i + 1) +" "+ current.userId + " (" + current.contrib +" contrib.)</div>").appendTo("#authors-list");
}
});
JSP
には、global.jsp
と clientlib
の両方が含まれます。
top_authors.jsp top-authors-jsp
<%@page session="false" contentType="text/html; charset=utf-8" %><%
%><%
%><%@include file="/libs/foundation/global.jsp" %><%
%>
<ui:includeClientLib categories="geout.reporting.topauthors" />
<%
String reportletTitle = properties.get("title", "Top Authors");
%>
<html>
<h3><%=xssAPI.encodeForHTML(reportletTitle) %></h3>
<div id="authors-list"></div>
</html>