2024年8月20日火曜日

Chartist.jsをOracle APEXのアプリケーションに組み込む

Chartist.jsを、Oracle APEXのアプリケーションに組み込んでみます。使用するChartist.jsのバージョンは、ESモジュールとして書き直されたv1系列を使用します。

Oracle JETやその他のチャート描画ライブラリの組み込み作業で表示したチャートと、同じチャートを表示してみます。カスタム要素は作成せず、スクリプトはテンプレートに直接埋め込みます。また、importmapは定義せず、ESモジュールのURLはスクリプト内に記述します。


直接Chartist.jsで描画


  
チャートに描画するデータを保持するページ・アイテムとしてP1_GROUPSP1_VALUEを作成します。タイプ非表示です。

ページ・アイテムP1_GROUPS計算を作成し、ページの描画前にデータを設定します。計算タイプとしてSQL問合せ(単一の値を返す)を選択し、SQL問合せに以下を記述します。
select
    json_arrayagg(
        ename
    order by empno asc )
from emp where deptno = 10

ページ・アイテムP1_VALUEにも計算を作成、ページ描画前に値を設定します。SQL問合せに以下を記述します。
select
    json_arrayagg(
        sal
    order by empno asc )
from emp where deptno = 10

静的コンテンツのリージョンの名前Chartist.jsとし、ソースHTMLコードに以下を記述します。


Chartist.jsでは、チャートの見かけはCSSで定義します。

ページ・プロパティCSSファイルURLに以下を記述します。

https://cdn.jsdelivr.net/chartist.js/latest/chartist.min.css

インラインに以下を記述し、バー(storke)の太さstroke-width)を指定します。
.ct-series-a .ct-bar {
  /* Colour of your bars */
  stroke: #309fdb;
  /* The width of your bars */
  stroke-width: 20px;
}

以上で実装は完了です。ページを実行すると以下のように表示されます。



対話モード・レポートへの組み込み



対話モード・レポートソースSQL問合せとして以下を記述します。
select
    dname,
    json_arrayagg(
        ename
    order by empno asc ) groups,
    json_arrayagg(
        sal
    order by empno asc) value,
    '' chart
from emp_dept_v group by dname

対話モード・レポートの列CHARTを選択します。識別タイププレーン・テキストです。

列の書式HTML式として以下を記述します。



以上で実装は完了です。ページを実行すると以下のように表示されます。




テンプレート・コンポーネントの作成




Chartist.jsのバー・チャートを描画するテンプレート・コンポーネントについて、設定内容を説明します。

テンプレート・コンポーネントの名前Chartist.js Bar Chartとしました。テンプレート部分には以下を記述しています。


カスタム属性としてCSS ClassesGroupsValueOrientationChart Cssを作成しています。GroupsValueタイプセッション・ステート値Chart Cssはテキストです。


チャートの向きの指定であるOrientation静的LOVは、horizontalの戻り値としてtrueverticalの戻り値としてfalseを設定します。


ロードするファイルURLカスケード・スタイルシートに以下を記述します。

https://cdn.jsdelivr.net/chartist.js/latest/chartist.min.css


以上でテンプレート・コンポーネントは完成です。

対話モード・レポートにChartist.jsのテンプレート・コンポーネントを実装します。

CHARTを選択し、識別タイプChartist.js Bar Chartとします。

CSS Classesにチャートの幅となるw400を設定します。GroupsとしてGROUPSValueとしてVALUEOrientationとしてhorizontalを設定します。Chart CSSにはct-chart ct-major-tenthを設定します。


チャートの見かけを調整するため、ページ・プロパティCSSインラインに以下を記述します。
.ct-series-a .ct-bar {
  /* Colour of your bars */
  stroke: #309fdb;
  /* The width of your bars */
  stroke-width: 15px;
}

以上で実装は完了です。ページを実行すると以下のように表示されます。


今回の記事は以上になります。

作成したAPEXアプリケーションのエクスポートを以下に置きました。
https://github.com/ujnak/apexapps/blob/master/exports/integrating-chartist-js-v1.zip

Oracle APEXのアプリケーション作成の参考になれば幸いです。