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.
@@ -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
- isDateKindColumn() {
72
- return this.column.dataType === GridColumnDataType.Date ||
73
- this.column.dataType === GridColumnDataType.DateTime ||
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
- * @hidden @internal
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
- isPercentColumn() {
86
- return this.column.dataType === GridColumnDataType.Percent;
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.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", 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"] }, { kind: "pipe", type: i2.IgxSummaryFormatterPipe, name: "summaryFormatter" }, { kind: "pipe", type: i1.DecimalPipe, name: "number" }, { kind: "pipe", type: i1.PercentPipe, name: "percent" }, { kind: "pipe", type: i1.CurrencyPipe, name: "currency" }, { kind: "pipe", type: i1.DatePipe, name: "date" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
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.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" }]
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":"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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 { 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,{"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"]}
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"]}