igniteui-angular 14.1.0-alpha.1 → 14.1.0-alpha.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/date-picker/date-picker.component.mjs +2 -1
- package/esm2020/lib/date-range-picker/date-range-picker.component.mjs +3 -3
- package/esm2020/lib/grids/columns/column.component.mjs +1 -1
- package/esm2020/lib/grids/grid-base.directive.mjs +1 -1
- package/esm2020/lib/grids/hierarchical-grid/hierarchical-grid.component.mjs +2 -2
- package/esm2020/lib/grids/pivot-grid/pivot-grid.component.mjs +42 -3
- package/esm2020/lib/grids/state.directive.mjs +113 -7
- package/esm2020/lib/grids/summaries/summary-cell.component.mjs +36 -25
- package/esm2020/lib/grids/watch-changes.mjs +1 -1
- package/esm2020/lib/time-picker/time-picker.component.mjs +3 -2
- package/fesm2015/igniteui-angular.mjs +16722 -16564
- package/fesm2015/igniteui-angular.mjs.map +1 -1
- package/fesm2020/igniteui-angular.mjs +16588 -16433
- package/fesm2020/igniteui-angular.mjs.map +1 -1
- package/lib/grids/pivot-grid/pivot-grid.component.d.ts +24 -1
- package/lib/grids/state.directive.d.ts +31 -2
- package/lib/grids/summaries/summary-cell.component.d.ts +3 -11
- package/package.json +1 -1
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
import { Component, Input, HostBinding, HostListener, ChangeDetectionStrategy } from '@angular/core';
|
|
2
2
|
import { GridColumnDataType } from '../../data-operations/data-util';
|
|
3
|
-
import { getLocaleCurrencyCode } from '@angular/common';
|
|
3
|
+
import { formatCurrency, formatDate, formatNumber, formatPercent, getLocaleCurrencyCode, getLocaleCurrencySymbol } from '@angular/common';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "@angular/common";
|
|
6
|
-
import * as i2 from "../common/pipes";
|
|
7
6
|
export class IgxSummaryCellComponent {
|
|
8
7
|
constructor(element) {
|
|
9
8
|
this.element = element;
|
|
@@ -56,41 +55,53 @@ export class IgxSummaryCellComponent {
|
|
|
56
55
|
return this.column.pipeArgs.currencyCode ?
|
|
57
56
|
this.column.pipeArgs.currencyCode : getLocaleCurrencyCode(this.grid.locale);
|
|
58
57
|
}
|
|
59
|
-
translateSummary(summary) {
|
|
60
|
-
return this.grid.resourceStrings[`igx_grid_summary_${summary.key}`] || summary.label;
|
|
61
|
-
}
|
|
62
|
-
/**
|
|
63
|
-
* @hidden @internal
|
|
64
|
-
*/
|
|
65
|
-
isNumberColumn() {
|
|
66
|
-
return this.column.dataType === GridColumnDataType.Number;
|
|
67
|
-
}
|
|
68
58
|
/**
|
|
69
59
|
* @hidden @internal
|
|
70
60
|
*/
|
|
71
|
-
|
|
72
|
-
return this.column.
|
|
73
|
-
this.column.
|
|
74
|
-
this.column.dataType === GridColumnDataType.Time;
|
|
61
|
+
get currencySymbol() {
|
|
62
|
+
return this.column.pipeArgs.display ?
|
|
63
|
+
this.column.pipeArgs.display : getLocaleCurrencySymbol(this.grid.locale);
|
|
75
64
|
}
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
*/
|
|
79
|
-
isCurrencyColumn() {
|
|
80
|
-
return this.column.dataType === GridColumnDataType.Currency;
|
|
65
|
+
translateSummary(summary) {
|
|
66
|
+
return this.grid.resourceStrings[`igx_grid_summary_${summary.key}`] || summary.label;
|
|
81
67
|
}
|
|
82
68
|
/**
|
|
83
69
|
* @hidden @internal
|
|
84
70
|
*/
|
|
85
|
-
|
|
86
|
-
|
|
71
|
+
formatSummaryResult(summary) {
|
|
72
|
+
if (summary.summaryResult === undefined || summary.summaryResult === null || summary.summaryResult === '') {
|
|
73
|
+
return '';
|
|
74
|
+
}
|
|
75
|
+
if (this.summaryFormatter) {
|
|
76
|
+
return this.summaryFormatter(summary, this.column.summaries);
|
|
77
|
+
}
|
|
78
|
+
const args = this.column.pipeArgs;
|
|
79
|
+
const locale = this.grid.locale;
|
|
80
|
+
if (summary.key === 'count') {
|
|
81
|
+
return formatNumber(summary.summaryResult, locale);
|
|
82
|
+
}
|
|
83
|
+
if (summary.defaultFormatting) {
|
|
84
|
+
switch (this.column.dataType) {
|
|
85
|
+
case GridColumnDataType.Number:
|
|
86
|
+
return formatNumber(summary.summaryResult, locale, args.digitsInfo);
|
|
87
|
+
case GridColumnDataType.Date:
|
|
88
|
+
case GridColumnDataType.DateTime:
|
|
89
|
+
case GridColumnDataType.Time:
|
|
90
|
+
return formatDate(summary.summaryResult, args.format, locale, args.timezone);
|
|
91
|
+
case GridColumnDataType.Currency:
|
|
92
|
+
return formatCurrency(summary.summaryResult, locale, this.currencySymbol, this.currencyCode, args.digitsInfo);
|
|
93
|
+
case GridColumnDataType.Percent:
|
|
94
|
+
return formatPercent(summary.summaryResult, locale, args.digitsInfo);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
return summary.summaryResult;
|
|
87
98
|
}
|
|
88
99
|
}
|
|
89
100
|
IgxSummaryCellComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: IgxSummaryCellComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
90
|
-
IgxSummaryCellComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.1", type: IgxSummaryCellComponent, selector: "igx-grid-summary-cell", inputs: { summaryResults: "summaryResults", column: "column", firstCellIndentation: "firstCellIndentation", hasSummary: "hasSummary", density: "density", summaryFormatter: "summaryFormatter", summaryTemplate: "summaryTemplate", active: "active", rowIndex: "rowIndex" }, host: { listeners: { "pointerdown": "activate()" }, properties: { "class.igx-grid-summary--active": "this.active", "attr.data-rowIndex": "this.rowIndex", "attr.data-visibleIndex": "this.visibleColumnIndex", "attr.id": "this.attrCellID" } }, ngImport: i0, template: "<ng-container *ngIf=\"hasSummary\">\n <ng-container *ngTemplateOutlet=\"summaryTemplate ? summaryTemplate : defaultSummary; context: { $implicit: summaryResults }\">\n </ng-container>\n</ng-container>\n <ng-template #defaultSummary>\n <ng-container *ngFor=\"let summary of summaryResults\" >\n <div class=\"igx-grid-summary__item\" [style.height.px]=\"itemHeight\">\n\n <span class=\"igx-grid-summary__label\" [title]=\"summary.label\">{{ translateSummary(summary) }}</span>\n <span class=\"igx-grid-summary__result\" [title]=\"summary
|
|
101
|
+
IgxSummaryCellComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.1", type: IgxSummaryCellComponent, selector: "igx-grid-summary-cell", inputs: { summaryResults: "summaryResults", column: "column", firstCellIndentation: "firstCellIndentation", hasSummary: "hasSummary", density: "density", summaryFormatter: "summaryFormatter", summaryTemplate: "summaryTemplate", active: "active", rowIndex: "rowIndex" }, host: { listeners: { "pointerdown": "activate()" }, properties: { "class.igx-grid-summary--active": "this.active", "attr.data-rowIndex": "this.rowIndex", "attr.data-visibleIndex": "this.visibleColumnIndex", "attr.id": "this.attrCellID" } }, ngImport: i0, template: "<ng-container *ngIf=\"hasSummary\">\n <ng-container *ngTemplateOutlet=\"summaryTemplate ? summaryTemplate : defaultSummary; context: { $implicit: summaryResults }\">\n </ng-container>\n</ng-container>\n <ng-template #defaultSummary>\n <ng-container *ngFor=\"let summary of summaryResults\" >\n <div class=\"igx-grid-summary__item\" [style.height.px]=\"itemHeight\">\n\n <span class=\"igx-grid-summary__label\" [title]=\"summary.label\">{{ translateSummary(summary) }}</span>\n <span class=\"igx-grid-summary__result\" [title]=\"formatSummaryResult(summary)\">\n {{\n formatSummaryResult(summary)\n }}\n </span>\n </div>\n </ng-container>\n </ng-template>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
91
102
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: IgxSummaryCellComponent, decorators: [{
|
|
92
103
|
type: Component,
|
|
93
|
-
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'igx-grid-summary-cell', template: "<ng-container *ngIf=\"hasSummary\">\n <ng-container *ngTemplateOutlet=\"summaryTemplate ? summaryTemplate : defaultSummary; context: { $implicit: summaryResults }\">\n </ng-container>\n</ng-container>\n <ng-template #defaultSummary>\n <ng-container *ngFor=\"let summary of summaryResults\" >\n <div class=\"igx-grid-summary__item\" [style.height.px]=\"itemHeight\">\n\n <span class=\"igx-grid-summary__label\" [title]=\"summary.label\">{{ translateSummary(summary) }}</span>\n <span class=\"igx-grid-summary__result\" [title]=\"summary
|
|
104
|
+
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'igx-grid-summary-cell', template: "<ng-container *ngIf=\"hasSummary\">\n <ng-container *ngTemplateOutlet=\"summaryTemplate ? summaryTemplate : defaultSummary; context: { $implicit: summaryResults }\">\n </ng-container>\n</ng-container>\n <ng-template #defaultSummary>\n <ng-container *ngFor=\"let summary of summaryResults\" >\n <div class=\"igx-grid-summary__item\" [style.height.px]=\"itemHeight\">\n\n <span class=\"igx-grid-summary__label\" [title]=\"summary.label\">{{ translateSummary(summary) }}</span>\n <span class=\"igx-grid-summary__result\" [title]=\"formatSummaryResult(summary)\">\n {{\n formatSummaryResult(summary)\n }}\n </span>\n </div>\n </ng-container>\n </ng-template>\n" }]
|
|
94
105
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { summaryResults: [{
|
|
95
106
|
type: Input
|
|
96
107
|
}], column: [{
|
|
@@ -125,4 +136,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImpor
|
|
|
125
136
|
type: HostListener,
|
|
126
137
|
args: ['pointerdown']
|
|
127
138
|
}] } });
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"summary-cell.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/summaries/summary-cell.component.ts","../../../../../../projects/igniteui-angular/src/lib/grids/summaries/summary-cell.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, HostBinding, HostListener, ChangeDetectionStrategy, ElementRef, TemplateRef } from '@angular/core';\nimport {\n    IgxSummaryOperand,\n    IgxSummaryResult\n} from './grid-summary';\nimport { GridColumnDataType } from '../../data-operations/data-util';\nimport { getLocaleCurrencyCode } from '@angular/common';\nimport { ISelectionNode } from '../common/types';\nimport { ColumnType } from '../common/grid.interface';\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    selector: 'igx-grid-summary-cell',\n    templateUrl: './summary-cell.component.html'\n})\nexport class IgxSummaryCellComponent {\n\n    @Input()\n    public summaryResults: IgxSummaryResult[];\n\n    @Input()\n    public column: ColumnType;\n\n    @Input()\n    public firstCellIndentation = 0;\n\n    @Input()\n    public hasSummary = false;\n\n    @Input()\n    public density;\n\n    @Input()\n    public summaryFormatter: (summaryResult: IgxSummaryResult, summaryOperand: IgxSummaryOperand) => any;\n\n    @Input()\n    public summaryTemplate: TemplateRef<any>;\n\n    /** @hidden */\n    @Input()\n    @HostBinding('class.igx-grid-summary--active')\n    public active: boolean;\n\n    @Input()\n    @HostBinding('attr.data-rowIndex')\n    public rowIndex: number;\n\n    constructor(private element: ElementRef) {\n    }\n\n    @HostBinding('attr.data-visibleIndex')\n    public get visibleColumnIndex(): number {\n        return this.column.visibleIndex;\n    }\n\n    @HostBinding('attr.id')\n    public get attrCellID() {\n        return `${this.grid.id}_${this.rowIndex}_${this.visibleColumnIndex}`;\n    }\n\n    @HostListener('pointerdown')\n    public activate() {\n        const currNode = this.grid.navigation.activeNode;\n        if (currNode && this.rowIndex === currNode.row && this.visibleColumnIndex === currNode.column) {\n            return;\n        }\n\n        this.grid.navigation.setActiveNode({ row: this.rowIndex, column: this.visibleColumnIndex }, 'summaryCell');\n        this.grid.cdr.detectChanges();\n    }\n\n    protected get selectionNode(): ISelectionNode {\n        return {\n            row: this.rowIndex,\n            column: this.column.columnLayoutChild ? this.column.parent.visibleIndex : this.visibleColumnIndex,\n            isSummaryRow: true\n        };\n    }\n\n    public get width() {\n        return this.column.getCellWidth();\n    }\n\n    public get nativeElement(): any {\n        return this.element.nativeElement;\n    }\n\n    public get columnDatatype(): GridColumnDataType {\n        return this.column.dataType;\n    }\n\n    public get itemHeight() {\n        return this.column.grid.defaultSummaryHeight;\n    }\n\n    /**\n     * @hidden\n     */\n    public get grid() {\n        return (this.column.grid as any);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get currencyCode(): string {\n        return this.column.pipeArgs.currencyCode ?\n            this.column.pipeArgs.currencyCode : getLocaleCurrencyCode(this.grid.locale);\n    }\n\n    public translateSummary(summary: IgxSummaryResult): string {\n        return this.grid.resourceStrings[`igx_grid_summary_${summary.key}`] || summary.label;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public isNumberColumn(): boolean {\n        return this.column.dataType === GridColumnDataType.Number;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public isDateKindColumn(): boolean {\n        return this.column.dataType === GridColumnDataType.Date ||\n               this.column.dataType === GridColumnDataType.DateTime ||\n               this.column.dataType === GridColumnDataType.Time;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public isCurrencyColumn(): boolean {\n        return this.column.dataType === GridColumnDataType.Currency;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public isPercentColumn(): boolean {\n        return this.column.dataType === GridColumnDataType.Percent;\n    }\n}\n","<ng-container *ngIf=\"hasSummary\">\n    <ng-container *ngTemplateOutlet=\"summaryTemplate ? summaryTemplate : defaultSummary; context: { $implicit: summaryResults }\">\n    </ng-container>\n</ng-container>\n    <ng-template #defaultSummary>\n        <ng-container *ngFor=\"let summary of summaryResults\" >\n            <div class=\"igx-grid-summary__item\" [style.height.px]=\"itemHeight\">\n\n                <span class=\"igx-grid-summary__label\" [title]=\"summary.label\">{{ translateSummary(summary) }}</span>\n                <span class=\"igx-grid-summary__result\" [title]=\"summary.summaryResult\">\n                    {{\n                        summaryFormatter\n                        ? (summary | summaryFormatter:column.summaries:summaryFormatter)\n                        : (isNumberColumn() && summary.defaultFormatting)\n                        ? (summary.summaryResult | number:column.pipeArgs.digitsInfo:grid.locale)\n                        : (isDateKindColumn() && summary.defaultFormatting)\n                        ? (summary.summaryResult | date:column.pipeArgs.format:column.pipeArgs.timezone:grid.locale)\n                        : (isCurrencyColumn() && summary.defaultFormatting)\n                        ? (summary.summaryResult | currency:currencyCode:column.pipeArgs.display:column.pipeArgs.digitsInfo:grid.locale)\n                        : (isPercentColumn() && summary.defaultFormatting)\n                        ? (summary.summaryResult | percent:column.pipeArgs.digitsInfo:grid.locale)\n                        : (summary.key === 'count')\n                        ? (summary.summaryResult | number:undefined:grid.locale)\n                        : summary.summaryResult\n                    }}\n                </span>\n            </div>\n        </ng-container>\n    </ng-template>\n"]}
|
|
139
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"summary-cell.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/summaries/summary-cell.component.ts","../../../../../../projects/igniteui-angular/src/lib/grids/summaries/summary-cell.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,WAAW,EAAE,YAAY,EAAE,uBAAuB,EAA2B,MAAM,eAAe,CAAC;AAK9H,OAAO,EAAE,kBAAkB,EAAE,MAAM,iCAAiC,CAAC;AACrE,OAAO,EAAE,cAAc,EAAE,UAAU,EAAE,YAAY,EAAE,aAAa,EAAE,qBAAqB,EAAE,uBAAuB,EAAE,MAAM,iBAAiB,CAAC;;;AAS1I,MAAM,OAAO,uBAAuB;IAgChC,YAAoB,OAAmB;QAAnB,YAAO,GAAP,OAAO,CAAY;QAvBhC,yBAAoB,GAAG,CAAC,CAAC;QAGzB,eAAU,GAAG,KAAK,CAAC;IAqB1B,CAAC;IAED,IACW,kBAAkB;QACzB,OAAO,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC;IACpC,CAAC;IAED,IACW,UAAU;QACjB,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;IACzE,CAAC;IAGM,QAAQ;QACX,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC;QACjD,IAAI,QAAQ,IAAI,IAAI,CAAC,QAAQ,KAAK,QAAQ,CAAC,GAAG,IAAI,IAAI,CAAC,kBAAkB,KAAK,QAAQ,CAAC,MAAM,EAAE;YAC3F,OAAO;SACV;QAED,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,kBAAkB,EAAE,EAAE,aAAa,CAAC,CAAC;QAC3G,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAClC,CAAC;IAED,IAAc,aAAa;QACvB,OAAO;YACH,GAAG,EAAE,IAAI,CAAC,QAAQ;YAClB,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,kBAAkB;YACjG,YAAY,EAAE,IAAI;SACrB,CAAC;IACN,CAAC;IAED,IAAW,KAAK;QACZ,OAAO,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;IACtC,CAAC;IAED,IAAW,aAAa;QACpB,OAAO,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;IACtC,CAAC;IAED,IAAW,cAAc;QACrB,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;IAChC,CAAC;IAED,IAAW,UAAU;QACjB,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,oBAAoB,CAAC;IACjD,CAAC;IAED;;OAEG;IACH,IAAW,IAAI;QACX,OAAQ,IAAI,CAAC,MAAM,CAAC,IAAY,CAAC;IACrC,CAAC;IAED;;OAEG;IACH,IAAW,YAAY;QACnB,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;YACtC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACpF,CAAC;IAED;;OAEG;IACH,IAAW,cAAc;QACrB,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;YACjC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACjF,CAAC;IAEM,gBAAgB,CAAC,OAAyB;QAC7C,OAAO,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,oBAAoB,OAAO,CAAC,GAAG,EAAE,CAAC,IAAI,OAAO,CAAC,KAAK,CAAC;IACzF,CAAC;IAED;;OAEG;IACI,mBAAmB,CAAC,OAAyB;QAChD,IAAI,OAAO,CAAC,aAAa,KAAK,SAAS,IAAI,OAAO,CAAC,aAAa,KAAK,IAAI,IAAI,OAAO,CAAC,aAAa,KAAK,EAAE,EAAE;YACvG,OAAO,EAAE,CAAC;SACb;QAED,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,OAAO,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;SAChE;QAED,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;QAClC,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;QAEhC,IAAI,OAAO,CAAC,GAAG,KAAK,OAAO,EAAE;YACzB,OAAO,YAAY,CAAC,OAAO,CAAC,aAAa,EAAE,MAAM,CAAC,CAAA;SACrD;QAED,IAAI,OAAO,CAAC,iBAAiB,EAAE;YAC3B,QAAQ,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE;gBAC1B,KAAK,kBAAkB,CAAC,MAAM;oBAC1B,OAAO,YAAY,CAAC,OAAO,CAAC,aAAa,EAAE,MAAM,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;gBACxE,KAAK,kBAAkB,CAAC,IAAI,CAAC;gBAC7B,KAAK,kBAAkB,CAAC,QAAQ,CAAC;gBACjC,KAAK,kBAAkB,CAAC,IAAI;oBACxB,OAAO,UAAU,CAAC,OAAO,CAAC,aAAa,EAAE,IAAI,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;gBACjF,KAAK,kBAAkB,CAAC,QAAQ;oBAC5B,OAAO,cAAc,CAAC,OAAO,CAAC,aAAa,EAAE,MAAM,EAAE,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;gBAClH,KAAK,kBAAkB,CAAC,OAAO;oBAC3B,OAAO,aAAa,CAAC,OAAO,CAAC,aAAa,EAAE,MAAM,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;aAC5E;SACJ;QACD,OAAO,OAAO,CAAC,aAAa,CAAC;IACjC,CAAC;;oHA7IQ,uBAAuB;wGAAvB,uBAAuB,4jBCfpC,4yBAiBA;2FDFa,uBAAuB;kBALnC,SAAS;sCACW,uBAAuB,CAAC,MAAM,YACrC,uBAAuB;iGAM1B,cAAc;sBADpB,KAAK;gBAIC,MAAM;sBADZ,KAAK;gBAIC,oBAAoB;sBAD1B,KAAK;gBAIC,UAAU;sBADhB,KAAK;gBAIC,OAAO;sBADb,KAAK;gBAIC,gBAAgB;sBADtB,KAAK;gBAIC,eAAe;sBADrB,KAAK;gBAMC,MAAM;sBAFZ,KAAK;;sBACL,WAAW;uBAAC,gCAAgC;gBAKtC,QAAQ;sBAFd,KAAK;;sBACL,WAAW;uBAAC,oBAAoB;gBAOtB,kBAAkB;sBAD5B,WAAW;uBAAC,wBAAwB;gBAM1B,UAAU;sBADpB,WAAW;uBAAC,SAAS;gBAMf,QAAQ;sBADd,YAAY;uBAAC,aAAa","sourcesContent":["import { Component, Input, HostBinding, HostListener, ChangeDetectionStrategy, ElementRef, TemplateRef } from '@angular/core';\nimport {\n    IgxSummaryOperand,\n    IgxSummaryResult\n} from './grid-summary';\nimport { GridColumnDataType } from '../../data-operations/data-util';\nimport { formatCurrency, formatDate, formatNumber, formatPercent, getLocaleCurrencyCode, getLocaleCurrencySymbol } from '@angular/common';\nimport { ISelectionNode } from '../common/types';\nimport { ColumnType } from '../common/grid.interface';\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    selector: 'igx-grid-summary-cell',\n    templateUrl: './summary-cell.component.html'\n})\nexport class IgxSummaryCellComponent {\n\n    @Input()\n    public summaryResults: IgxSummaryResult[];\n\n    @Input()\n    public column: ColumnType;\n\n    @Input()\n    public firstCellIndentation = 0;\n\n    @Input()\n    public hasSummary = false;\n\n    @Input()\n    public density;\n\n    @Input()\n    public summaryFormatter: (summaryResult: IgxSummaryResult, summaryOperand: IgxSummaryOperand) => any;\n\n    @Input()\n    public summaryTemplate: TemplateRef<any>;\n\n    /** @hidden */\n    @Input()\n    @HostBinding('class.igx-grid-summary--active')\n    public active: boolean;\n\n    @Input()\n    @HostBinding('attr.data-rowIndex')\n    public rowIndex: number;\n\n    constructor(private element: ElementRef) {\n    }\n\n    @HostBinding('attr.data-visibleIndex')\n    public get visibleColumnIndex(): number {\n        return this.column.visibleIndex;\n    }\n\n    @HostBinding('attr.id')\n    public get attrCellID() {\n        return `${this.grid.id}_${this.rowIndex}_${this.visibleColumnIndex}`;\n    }\n\n    @HostListener('pointerdown')\n    public activate() {\n        const currNode = this.grid.navigation.activeNode;\n        if (currNode && this.rowIndex === currNode.row && this.visibleColumnIndex === currNode.column) {\n            return;\n        }\n\n        this.grid.navigation.setActiveNode({ row: this.rowIndex, column: this.visibleColumnIndex }, 'summaryCell');\n        this.grid.cdr.detectChanges();\n    }\n\n    protected get selectionNode(): ISelectionNode {\n        return {\n            row: this.rowIndex,\n            column: this.column.columnLayoutChild ? this.column.parent.visibleIndex : this.visibleColumnIndex,\n            isSummaryRow: true\n        };\n    }\n\n    public get width() {\n        return this.column.getCellWidth();\n    }\n\n    public get nativeElement(): any {\n        return this.element.nativeElement;\n    }\n\n    public get columnDatatype(): GridColumnDataType {\n        return this.column.dataType;\n    }\n\n    public get itemHeight() {\n        return this.column.grid.defaultSummaryHeight;\n    }\n\n    /**\n     * @hidden\n     */\n    public get grid() {\n        return (this.column.grid as any);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get currencyCode(): string {\n        return this.column.pipeArgs.currencyCode ?\n            this.column.pipeArgs.currencyCode : getLocaleCurrencyCode(this.grid.locale);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get currencySymbol(): string {\n        return this.column.pipeArgs.display ?\n            this.column.pipeArgs.display : getLocaleCurrencySymbol(this.grid.locale);\n    }\n\n    public translateSummary(summary: IgxSummaryResult): string {\n        return this.grid.resourceStrings[`igx_grid_summary_${summary.key}`] || summary.label;\n    }\n\n    /** \n     * @hidden @internal\n     */\n    public formatSummaryResult(summary: IgxSummaryResult): string {\n        if (summary.summaryResult === undefined || summary.summaryResult === null || summary.summaryResult === '') {\n            return '';\n        }\n\n        if (this.summaryFormatter) {\n            return this.summaryFormatter(summary, this.column.summaries);\n        }\n\n        const args = this.column.pipeArgs;\n        const locale = this.grid.locale;\n\n        if (summary.key === 'count') {\n            return formatNumber(summary.summaryResult, locale)\n        }\n\n        if (summary.defaultFormatting) {\n            switch (this.column.dataType) {\n                case GridColumnDataType.Number:\n                    return formatNumber(summary.summaryResult, locale, args.digitsInfo);\n                case GridColumnDataType.Date:\n                case GridColumnDataType.DateTime:\n                case GridColumnDataType.Time:\n                    return formatDate(summary.summaryResult, args.format, locale, args.timezone);\n                case GridColumnDataType.Currency:\n                    return formatCurrency(summary.summaryResult, locale, this.currencySymbol, this.currencyCode, args.digitsInfo);\n                case GridColumnDataType.Percent:\n                    return formatPercent(summary.summaryResult, locale, args.digitsInfo);\n            }\n        }\n        return summary.summaryResult;\n    }\n}\n","<ng-container *ngIf=\"hasSummary\">\n    <ng-container *ngTemplateOutlet=\"summaryTemplate ? summaryTemplate : defaultSummary; context: { $implicit: summaryResults }\">\n    </ng-container>\n</ng-container>\n    <ng-template #defaultSummary>\n        <ng-container *ngFor=\"let summary of summaryResults\" >\n            <div class=\"igx-grid-summary__item\" [style.height.px]=\"itemHeight\">\n\n                <span class=\"igx-grid-summary__label\" [title]=\"summary.label\">{{ translateSummary(summary) }}</span>\n                <span class=\"igx-grid-summary__result\" [title]=\"formatSummaryResult(summary)\">\n                    {{\n                        formatSummaryResult(summary)\n                    }}\n                </span>\n            </div>\n        </ng-container>\n    </ng-template>\n"]}
|
|
@@ -88,4 +88,4 @@ export function notifyChanges(repaint = false) {
|
|
|
88
88
|
return propDesc;
|
|
89
89
|
};
|
|
90
90
|
}
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watch-changes.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/grids/watch-changes.ts"],"names":[],"mappings":"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","sourcesContent":["import { SimpleChanges, SimpleChange } from '@angular/core';\n\n/**\n * @hidden\n */\nexport function WatchChanges(): PropertyDecorator {\n    return (target: any, key: string, propDesc?: PropertyDescriptor) => {\n        const privateKey = '_' + key.toString();\n        propDesc = propDesc || {\n            configurable: true,\n            enumerable: true,\n        };\n        propDesc.get = propDesc.get || (function (this: any) {\n            return this[privateKey];\n        });\n        const originalSetter = propDesc.set || (function (this: any, val: any) {\n            this[privateKey] = val;\n        });\n\n        propDesc.set = function (this: any, val: any) {\n            const init = this._init;\n            const oldValue = this[key];\n            if (val !== oldValue || (typeof val === 'object' && val === oldValue)) {\n                originalSetter.call(this, val);\n                if (this.ngOnChanges && !init) {\n                    // in case wacthed prop changes trigger ngOnChanges manually\n                    const changes: SimpleChanges = {\n                        [key]: new SimpleChange(oldValue, val, false)\n                    };\n                    this.ngOnChanges(changes);\n                }\n            }\n        };\n        return propDesc;\n    };\n}\n\nexport function WatchColumnChanges(): PropertyDecorator {\n    return (target: any, key: string, propDesc?: PropertyDescriptor) => {\n        const privateKey = '_' + key.toString();\n        propDesc = propDesc || {\n            configurable: true,\n            enumerable: true,\n        };\n        propDesc.get = propDesc.get || (function (this: any) {\n            return this[privateKey];\n        });\n        const originalSetter = propDesc.set || (function (this: any, val: any) {\n            this[privateKey] = val;\n        });\n\n        propDesc.set = function (this: any, val: any) {\n            const oldValue = this[key];\n            originalSetter.call(this, val);\n            if (val !== oldValue || (typeof val === 'object' && val === oldValue)) {\n                if (this.columnChange) {\n                    this.columnChange.emit();\n                }\n            }\n        };\n        return propDesc;\n    };\n}\n\nexport function notifyChanges(repaint = false) {\n    return (_: any, key: string, propDesc?: PropertyDescriptor) => {\n\n        const privateKey = `__${key}`;\n\n        propDesc = propDesc || {\n            enumerable: true,\n            configurable: true\n        };\n\n\n        const originalSetter = propDesc ? propDesc.set : null;\n        propDesc.get = propDesc.get || (function (this) {\n            return this[privateKey];\n        });\n\n        propDesc.set = function (this, newValue) {\n            if (originalSetter) {\n                originalSetter.call(this, newValue);\n                if (this.grid) {\n                    this.grid.notifyChanges(repaint && !this.grid.isPivot);\n                }\n            } else {\n                if (newValue === this[key]) {\n                    return;\n                }\n                this[privateKey] = newValue;\n                if (this.grid) {\n                    this.grid.notifyChanges(repaint && !this.grid.isPivot);\n                }\n            }\n        };\n        return propDesc as any;\n    };\n}\n"]}
|