Web Components Hierarchical Grid 集計
Web Components Hierarchical Grid の Ignite UI for Web Components 集計機能は、グループ フッターとして列ごとのレベルで機能します。Web Components IgcHierarchicalGrid 集計は、列内のデータ タイプに応じて、あるいは IgcHierarchicalGridComponent
にカスタム テンプレートを実装することによって、定義済みのデフォルト集計項目を使用して別のコンテナの列情報を表示できます。
Web Components Hierarchical Grid 集計概要の例
[!Note] 列の集計は列値すべての関数ですが、フィルタリングが適用された場合、列の集計はフィルターされた結果値の関数になります。
IgcHierarchicalGridComponent
集計を列ごとに有効にして必要な列のみアクティブ化できます。IgcHierarchicalGridComponent
集計は、列のデータ型に基づいてデフォルト集計の定義済みセットを提供します。
string
および boolean
dataType
の場合、以下の関数が利用できます:
- Count
number
、currency
、および percent
データ型の場合、以下の関数を使用できます。
- Count
- Min
- Max
- Average
- Sum
date
データ型の場合、以下の関数が利用できます:
- Count
- Earliest
- Latest
すべての利用可能な列データ型は、公式の列タイプトピックにあります。
hasSummary
プロパティを true に設定すると IgcHierarchicalGridComponent
集計が列レベルで有効になります。各列の集計は列のデータ型に基づいて解決されます。IgcHierarchicalGridComponent
のデフォルトの列データ型は string
のため、number
または date
固有の集計を適用するには、dataType
プロパティを number
または date
に設定します。集計値は、グリッドの locale
および列 pipeArgs
に従ってローカライズされて表示されます。
<igc-hierarchical-grid auto-generate="false" name="hierarchicalGrid" id="hierarchicalGrid" primary-key="ID">
<igc-column field="Artist" header="Artist" has-summary="true"> </igc-column>
<igc-column field="Photo" header="Photo" data-type="image"> </igc-column>
<igc-column field="Debut" header="Debut" has-summary="true"> </igc-column>
<igc-column field="GrammyNominations" header="Grammy Nominations" data-type="number" has-summary="true"> </igc-column>
<igc-column field="GrammyAwards" header="Grammy Awards" data-type="number" has-summary="true"> </igc-column>
<igc-row-island child-data-key="Albums" auto-generate="false">
<igc-column field="Album" header="Album" data-type="string"> </igc-column>
<igc-column field="LaunchDate" header="Launch Date" data-type="date"> </igc-column>
<igc-column field="BillboardReview" header="Billboard Review" data-type="number" has-summary="true"> </igc-column>
<igc-column field="USBillboard200" header="US Billboard 200" data-type="number" has-summary="true"> </igc-column>
</igc-row-island>
</igc-hierarchical-grid>
特定の列や列のリストを有効または無効にする他の方法として IgcHierarchicalGridComponent
のパブリック メソッド enableSummaries
/disableSummaries
を使用する方法があります。
<igc-hierarchical-grid auto-generate="false" name="hierarchicalGrid" id="hierarchicalGrid" primary-key="ID">
<igc-column field="Artist" header="Artist" has-summary="true"> </igc-column>
<igc-column field="Photo" header="Photo" data-type="image"> </igc-column>
<igc-column field="Debut" header="Debut" has-summary="true"> </igc-column>
<igc-column field="GrammyNominations" header="Grammy Nominations" data-type="number" has-summary="true"> </igc-column>
<igc-column field="GrammyAwards" header="Grammy Awards" data-type="number" has-summary="true"> </igc-column>
</igc-hierarchical-grid>
<button id="enableBtn">Enable Summary</button>
<button id="disableBtn">Disable Summary </button>
constructor() {
var hierarchicalGrid = this.hierarchicalGrid = document.getElementById('hierarchicalGrid') as IgcHierarchicalGrid;
var enableBtn = this.enableBtn = document.getElementById('enableBtn') as HTMLButtonElement;
var disableBtn = this.disableBtn = document.getElementById('disableBtn') as HTMLButtonElement;
hierarchicalGrid.data = this.data;
enableBtn.addEventListener("click", this.enableSummary);
disableBtn.addEventListener("click", this.disableSummary);
}
public enableSummary() {
this.hierarchicalGrid.enableSummaries([
{fieldName: 'GrammyNominations'},
{fieldName: 'GrammyAwards'}
]);
}
public disableSummary() {
this.hierarchicalGrid.disableSummaries(['GrammyNominations']);
}
カスタム Hierarchical Grid 集計
これらの機能が要件を満たさない場合は、カスタム集計を提供できます。
これを実現するには、列のデータ型とニーズに応じて、基本クラス IgcSummaryOperand
、IgcNumberSummaryOperand
、または IgcDateSummaryOperand
のいずれかをオーバーライドする必要があります。このように既存の関数を再定義、または新しい関数を追加できます。IgcSummaryOperand
クラスは、count
メソッドに対してのみデフォルトの実装を提供します。IgcNumberSummaryOperand
は IgcSummaryOperand
を拡張し、Min
、Max
、Sum
、および Average
の実装を提供します。IgcDateSummaryOperand
は IgcSummaryOperand
を拡張し、さらに特定の列の Earliest
と Latest
を提供します。
import { IgcSummaryResult, IgcSummaryOperand, IgcNumberSummaryOperand, IgcDateSummaryOperand } from 'igniteui-webcomponents-grids';
class MySummary extends IgcNumberSummaryOperand {
constructor() {
super();
}
operate(data?: any[]): IgcSummaryResult[] {
const result = super.operate(data);
result.push({
key: 'test',
label: 'Test',
summaryResult: data.filter(rec => rec > 10 && rec < 30).length
});
return result;
}
}
例で見られるように、基本クラスは operate
メソッドを公開しているため、すべてのデフォルトの集計を取得して結果を変更するか、まったく新しい集計結果を計算するかを選択できます。
このメソッドは IgcSummaryResult
のリストを返します。
interface IgcSummaryResult {
key: string;
label: string;
summaryResult: any;
}
そして、集計を計算するためのオプションのパラメーターを受け取ります。 以下のすべてのデータにアクセスするカスタム集計セクションを参照してください。
[!Note] 集計行の高さを適切に計算するには、データが空の場合でも、Hierarchical Grid が常に適切な長さの
IgcSummaryResult
の配列を返すOperate
メソッドを必要とします。
次に、カスタム集計を GrammyAwards
列に追加しましょう。これを実現するには、以下で作成するクラスに summaries
プロパティを設定します。
<igc-hierarchical-grid auto-generate="false" name="hierarchicalGrid" id="hierarchicalGrid" primary-key="ID">
<igc-column field="Artist" header="Artist" has-summary="true"> </igc-column>
<igc-column field="Photo" header="Photo" data-type="image"> </igc-column>
<igc-column field="Debut" header="Debut" has-summary="true"> </igc-column>
<igc-column field="GrammyNominations" header="Grammy Nominations" data-type="number" has-summary="true"> </igc-column>
<igc-column field="GrammyAwards" header="Grammy Awards" data-type="number" has-summary="true" id="grammyAwards"> </igc-column>
</igc-hierarchical-grid>
constructor() {
var hierarchicalGrid = this.hierarchicalGrid = document.getElementById('hierarchicalGrid') as IgcHierarchicalGrid;
var grammyAwards = this.grammyAwards = document.getElementById('grammyAwards') as IgcColumnComponent;
hierarchicalGrid.data = this.data;
grammyAwards.summaries = this.mySummary;
}
export class HierarchicalGridComponent implements OnInit {
mySummary = MySummary;
}
すべてのデータにアクセスするカスタム集計
カスタム列集計内のすべての Hierarchical Grid データにアクセスできます。SummaryOperand Operate
メソッドには、2 つの追加のオプション パラメーターが導入されています。
以下のコード スニペットで示されるように operate メソッドには以下の 3 つのパラメーターがあります。
- columnData - 現在の列の値のみを含む配列を提供します。
- allGridData - グリッド データソース全体を提供します。
- fieldName - 現在の列フィールド
class MySummary extends IgcNumberSummaryOperand {
constructor() {
super();
}
operate(columnData: any[], allGridData = [], fieldName?): IgcSummaryResult[] {
const result = super.operate(allData.map(r => r[fieldName]));
result.push({ key: 'test', label: 'Total Discontinued', summaryResult: allData.filter((rec) => rec.Discontinued).length });
return result;
}
}
集計テンプレート
Summary
は、列の集計の結果をコンテキストとして提供する列の集計を対象としています。
<igc-column id="column" has-summary="true">
</igc-column>
constructor() {
var column = this.column = document.getElementById('column') as IgcColumnComponent;
column.summaryTemplate = this.summaryTemplate;
}
public summaryTemplate = (ctx: IgcSummaryTemplateContext) => {
return html`
<span> My custom summary template</span>
<span>${ ctx.implicit[0].label } - ${ ctx.implicit[0].summaryResult }</span>
`;
}
デフォルトの集計が定義されている場合、集計領域の高さは、集計の数が最も多い列とグリッドの --ig-size
に応じてデザインにより計算されます。summaryRowHeight
入力プロパティを使用して、デフォルト値をオーバーライドします。引数として数値が必要であり、falsy の値を設定すると、グリッド フッターのデフォルトのサイズ設定動作がトリガーされます。
集計のフォーマット
デフォルトでは、組み込みの集計オペランドによって生成される集計結果は、グリッド locale
および列 pipeArgs
に従ってローカライズおよびフォーマットされます。カスタム オペランドを使用する場合、locale
と pipeArgs
は適用されません。集計結果のデフォルトの外観を変更する場合は、summaryFormatter
プロパティを使用してフォーマットできます。
public dateSummaryFormat(summary: IgcSummaryResult, summaryOperand: IgcSummaryOperand): string {
const result = summary.summaryResult;
if (summaryOperand instanceof IgcDateSummaryOperand && summary.key !== "count" && result !== null && result !== undefined) {
const format = new Intl.DateTimeFormat("en", { year: "numeric" });
return format.format(new Date(result));
}
return result;
}
<igc-column id="column"></igx-column>
constructor() {
var column = this.column = document.getElementById('column') as IgcColumnComponent;
column.summaryFormatter = this.dateSummaryFormat;
}
キーボード ナビゲーション
集計行は、以下のキーボード操作でナビゲーションできます。
- 上矢印 - 1 つ上のセルへ移動。
- 下矢印 - 1 つ下のセルへ移動。
- 左矢印 - 1 つ左のセルへ移動。
- 右矢印 - 1 つ右のセルへ移動。
- CTRL + 左矢印 または HOME - 左端のセルへ移動。
- CTRL + 右矢印 または END - 右端のセルへ移動。
スタイル設定
定義済みのテーマに加えて、利用可能な CSS プロパティのいくつかを設定することで、グリッドをさらにカスタマイズできます。 一部の色を変更したい場合は、最初にグリッドのクラスを設定する必要があります。
<igc-hierarchical-grid id="hierarchicalGrid"></igc-hierarchical-grid>
次に、そのクラスに関連する CSS プロパティを設定します。
#hierarchicalGrid {
--ig-grid-summary-background-color:#e0f3ff;
--ig-grid-summary-focus-background-color: rgba( #94d1f7, .3 );
--ig-grid-summary-label-color: rgb(228, 27, 117);
--ig-grid-summary-result-color: black;
}
デモ
API リファレンス
その他のリソース
コミュニティに参加して新しいアイデアをご提案ください。