igniteui-angular 13.2.2 → 13.2.5
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/directives/for-of/for_of.directive.mjs +2 -2
- package/esm2020/lib/grids/api.service.mjs +3 -4
- package/esm2020/lib/grids/columns/column-layout.component.mjs +3 -3
- package/esm2020/lib/grids/columns/column.component.mjs +4 -4
- package/esm2020/lib/grids/common/crud.service.mjs +3 -3
- package/esm2020/lib/grids/common/events.mjs +1 -1
- package/esm2020/lib/grids/filtering/advanced-filtering/advanced-filtering-dialog.component.mjs +2 -2
- package/esm2020/lib/grids/filtering/grid-filtering.service.mjs +7 -7
- package/esm2020/lib/grids/grid/grid.component.mjs +11 -11
- package/esm2020/lib/grids/grid-base.directive.mjs +84 -68
- package/esm2020/lib/grids/grid-mrl-navigation.service.mjs +2 -2
- package/esm2020/lib/grids/grid-public-row.mjs +3 -3
- package/esm2020/lib/grids/grouping/group-by-area.directive.mjs +2 -2
- package/esm2020/lib/grids/grouping/tree-grid-group-by-area.component.mjs +6 -6
- package/esm2020/lib/grids/hierarchical-grid/hierarchical-grid-base.directive.mjs +4 -5
- package/esm2020/lib/grids/hierarchical-grid/hierarchical-grid.component.mjs +26 -14
- package/esm2020/lib/grids/hierarchical-grid/row-island.component.mjs +7 -11
- package/esm2020/lib/grids/pivot-grid/pivot-grid.component.mjs +22 -9
- package/esm2020/lib/grids/state.directive.mjs +9 -9
- package/esm2020/lib/grids/summaries/grid-summary.service.mjs +5 -5
- package/esm2020/lib/grids/tree-grid/tree-grid.component.mjs +27 -9
- package/esm2020/lib/services/exporter-common/base-export-service.mjs +3 -3
- package/esm2020/lib/splitter/splitter-pane/splitter-pane.component.mjs +61 -11
- package/esm2020/lib/splitter/splitter.component.mjs +20 -3
- package/fesm2015/igniteui-angular.mjs +294 -173
- package/fesm2015/igniteui-angular.mjs.map +1 -1
- package/fesm2020/igniteui-angular.mjs +292 -173
- package/fesm2020/igniteui-angular.mjs.map +1 -1
- package/lib/core/styles/themes/schemas/dark/_stepper.scss +6 -1
- package/lib/grids/common/events.d.ts +1 -0
- package/lib/grids/grid-base.directive.d.ts +7 -1
- package/lib/grids/hierarchical-grid/hierarchical-grid.component.d.ts +2 -1
- package/lib/grids/hierarchical-grid/row-island.component.d.ts +1 -0
- package/lib/grids/pivot-grid/pivot-grid.component.d.ts +4 -0
- package/lib/grids/tree-grid/tree-grid.component.d.ts +2 -2
- package/lib/splitter/splitter-pane/splitter-pane.component.d.ts +19 -5
- package/migrations/update-13_0_0/changes/inputs.json +416 -1
- package/migrations/update-13_0_0/index.js +208 -0
- package/package.json +1 -1
- package/styles/igniteui-indigo-dark.css +1 -1
- package/styles/maps/igniteui-indigo-dark.css.map +1 -1
|
@@ -70,7 +70,7 @@ export class IgxGroupByAreaDirective {
|
|
|
70
70
|
const drag = event.detail.owner;
|
|
71
71
|
if (drag instanceof IgxColumnMovingDragDirective) {
|
|
72
72
|
const column = drag.column;
|
|
73
|
-
if (!this.grid.
|
|
73
|
+
if (!this.grid.columns.find(c => c === column)) {
|
|
74
74
|
return;
|
|
75
75
|
}
|
|
76
76
|
const isGrouped = this.expressions.findIndex((item) => item.fieldName === column.field) !== -1;
|
|
@@ -155,4 +155,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
|
155
155
|
type: Pipe,
|
|
156
156
|
args: [{ name: 'igxGroupByMeta' }]
|
|
157
157
|
}] });
|
|
158
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-by-area.directive.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/grouping/group-by-area.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Directive,\r\n    ElementRef,\r\n    EventEmitter,\r\n    HostBinding,\r\n    Input,\r\n    Output,\r\n    Pipe,\r\n    PipeTransform,\r\n    QueryList,\r\n    TemplateRef,\r\n    ViewChildren\r\n} from '@angular/core';\r\nimport { IChipsAreaReorderEventArgs, IgxChipComponent } from '../../chips/public_api';\r\nimport { DisplayDensity } from '../../core/displayDensity';\r\nimport { PlatformUtil } from '../../core/utils';\r\nimport { IGroupingExpression } from '../../data-operations/grouping-expression.interface';\r\nimport { SortingDirection } from '../../data-operations/sorting-strategy';\r\nimport { FlatGridType, GridType } from '../common/grid.interface';\r\nimport { IgxColumnMovingDragDirective } from '../moving/moving.drag.directive';\r\n\r\n/**\r\n * An internal component representing a base group-by drop area.\r\n *\r\n * @hidden @internal\r\n */\r\n @Directive()\r\nexport abstract class IgxGroupByAreaDirective {\r\n    /**\r\n     * The drop area template if provided by the parent grid.\r\n     * Otherwise, uses the default internal one.\r\n     */\r\n    @Input()\r\n    public dropAreaTemplate: TemplateRef<void>;\r\n\r\n    @Input()\r\n    public density: DisplayDensity = DisplayDensity.comfortable;\r\n\r\n    @HostBinding('class.igx-grid-grouparea')\r\n    public defaultClass =  true;\r\n\r\n    @HostBinding('class.igx-grid-grouparea--cosy')\r\n    public get cosyStyle() {\r\n        return this.density === 'cosy';\r\n    }\r\n\r\n    @HostBinding('class.igx-grid-grouparea--compact')\r\n    public get compactStyle() {\r\n        return this.density === 'compact';\r\n    }\r\n\r\n    /** The parent grid containing the component. */\r\n    @Input()\r\n    public grid: FlatGridType | GridType;\r\n\r\n    /**\r\n     * The group-by expressions provided by the parent grid.\r\n     */\r\n    @Input()\r\n    public get expressions(): IGroupingExpression[] {\r\n        return this._expressions;\r\n    }\r\n\r\n    public set expressions(value: IGroupingExpression[]) {\r\n        this._expressions = value;\r\n        this.chipExpressions = this._expressions;\r\n        this.expressionsChanged();\r\n        this.expressionsChange.emit(this._expressions);\r\n    }\r\n\r\n    /**\r\n     * The default message for the default drop area template.\r\n     * Obviously, if another template is provided, this is ignored.\r\n     */\r\n    @Input()\r\n    public get dropAreaMessage(): string {\r\n        return this._dropAreaMessage ?? this.grid.resourceStrings.igx_grid_groupByArea_message;\r\n    }\r\n\r\n    public set dropAreaMessage(value: string) {\r\n        this._dropAreaMessage = value;\r\n    }\r\n\r\n    @Output()\r\n    public expressionsChange = new EventEmitter<IGroupingExpression[]>();\r\n\r\n    @ViewChildren(IgxChipComponent)\r\n    public chips: QueryList<IgxChipComponent>;\r\n\r\n    public chipExpressions: IGroupingExpression[];\r\n\r\n    /** The native DOM element. Used in sizing calculations. */\r\n    public get nativeElement() {\r\n        return this.ref.nativeElement;\r\n    }\r\n\r\n    private _expressions: IGroupingExpression[] = [];\r\n    private _dropAreaMessage: string;\r\n\r\n    constructor(private ref: ElementRef<HTMLElement>, protected platform: PlatformUtil) { }\r\n\r\n\r\n    public get dropAreaVisible(): boolean {\r\n        return (this.grid.columnInDrag && this.grid.columnInDrag.groupable) ||\r\n            !this.expressions.length;\r\n    }\r\n\r\n    public handleKeyDown(id: string, event: KeyboardEvent) {\r\n        if (this.platform.isActivationKey(event)) {\r\n            this.updateGroupSorting(id);\r\n        }\r\n    }\r\n\r\n    public handleClick(id: string) {\r\n        if (!this.grid.getColumnByName(id).groupable) {\r\n            return;\r\n        }\r\n        this.updateGroupSorting(id);\r\n    }\r\n\r\n     public onDragDrop(event) {\r\n        const drag: IgxColumnMovingDragDirective = event.detail.owner;\r\n        if (drag instanceof IgxColumnMovingDragDirective) {\r\n            const column = drag.column;\r\n            if (!this.grid.columnList.find(c => c === column)) {\r\n                return;\r\n            }\r\n\r\n            const isGrouped = this.expressions.findIndex((item) => item.fieldName === column.field) !== -1;\r\n            if (column.groupable && !isGrouped && !column.columnGroup && !!column.field) {\r\n                const groupingExpression = {\r\n                    fieldName: column.field,\r\n                    dir: this.grid.sortingExpressions.find(expr => expr.fieldName === column.field)?.dir || SortingDirection.Asc,\r\n                    ignoreCase: column.sortingIgnoreCase,\r\n                    strategy: column.sortStrategy,\r\n                    groupingComparer: column.groupingComparer\r\n                };\r\n\r\n                this.groupBy(groupingExpression);\r\n            }\r\n        }\r\n    }\r\n\r\n    protected getReorderedExpressions(chipsArray: IgxChipComponent[]) {\r\n        const newExpressions = [];\r\n\r\n        chipsArray.forEach(chip => {\r\n            const expr = this.expressions.find(item => item.fieldName === chip.id);\r\n\r\n            // disallow changing order if there are columns with groupable: false\r\n            if (!this.grid.getColumnByName(expr.fieldName)?.groupable) {\r\n                return;\r\n            }\r\n\r\n            newExpressions.push(expr);\r\n        });\r\n\r\n        return newExpressions;\r\n    }\r\n\r\n    protected updateGroupSorting(id: string) {\r\n        const expr = this.expressions.find(e => e.fieldName === id);\r\n        expr.dir = 3 - expr.dir;\r\n        this.grid.pipeTrigger++;\r\n        this.grid.notifyChanges();\r\n    }\r\n\r\n    protected expressionsChanged() {\r\n    }\r\n\r\n    public abstract handleReorder(event: IChipsAreaReorderEventArgs);\r\n\r\n    public abstract handleMoveEnd();\r\n\r\n    public abstract groupBy(expression: IGroupingExpression);\r\n\r\n    public abstract clearGrouping(name: string);\r\n\r\n}\r\n\r\n/**\r\n * A pipe to circumvent the use of getters/methods just to get some additional\r\n * information from the grouping expression and pass it to the chip representing\r\n * that expression.\r\n *\r\n * @hidden @internal\r\n */\r\n@Pipe({ name: 'igxGroupByMeta' })\r\nexport class IgxGroupByMetaPipe implements PipeTransform {\r\n\r\n    public transform(key: string, grid: GridType) {\r\n        const column = grid.getColumnByName(key);\r\n        return { groupable: !!column?.groupable, title: column?.header || key };\r\n    }\r\n}\r\n"]}
|
|
158
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-by-area.directive.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/grouping/group-by-area.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EAET,YAAY,EACZ,WAAW,EACX,KAAK,EACL,MAAM,EACN,IAAI,EAIJ,YAAY,EACf,MAAM,eAAe,CAAC;AACvB,OAAO,EAA8B,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AACtF,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAG3D,OAAO,EAAE,gBAAgB,EAAE,MAAM,wCAAwC,CAAC;AAE1E,OAAO,EAAE,4BAA4B,EAAE,MAAM,iCAAiC,CAAC;;;AAE/E;;;;GAIG;AAEH,MAAM,OAAgB,uBAAuB;IAwEzC,YAAoB,GAA4B,EAAY,QAAsB;QAA9D,QAAG,GAAH,GAAG,CAAyB;QAAY,aAAQ,GAAR,QAAQ,CAAc;QA/D3E,YAAO,GAAmB,cAAc,CAAC,WAAW,CAAC;QAGrD,iBAAY,GAAI,IAAI,CAAC;QA6CrB,sBAAiB,GAAG,IAAI,YAAY,EAAyB,CAAC;QAY7D,iBAAY,GAA0B,EAAE,CAAC;IAGqC,CAAC;IA1DvF,IACW,SAAS;QAChB,OAAO,IAAI,CAAC,OAAO,KAAK,MAAM,CAAC;IACnC,CAAC;IAED,IACW,YAAY;QACnB,OAAO,IAAI,CAAC,OAAO,KAAK,SAAS,CAAC;IACtC,CAAC;IAMD;;OAEG;IACH,IACW,WAAW;QAClB,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;IAED,IAAW,WAAW,CAAC,KAA4B;QAC/C,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,YAAY,CAAC;QACzC,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACnD,CAAC;IAED;;;OAGG;IACH,IACW,eAAe;QACtB,OAAO,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,4BAA4B,CAAC;IAC3F,CAAC;IAED,IAAW,eAAe,CAAC,KAAa;QACpC,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;IAClC,CAAC;IAUD,2DAA2D;IAC3D,IAAW,aAAa;QACpB,OAAO,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC;IAClC,CAAC;IAQD,IAAW,eAAe;QACtB,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC;YAC/D,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;IACjC,CAAC;IAEM,aAAa,CAAC,EAAU,EAAE,KAAoB;QACjD,IAAI,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,KAAK,CAAC,EAAE;YACtC,IAAI,CAAC,kBAAkB,CAAC,EAAE,CAAC,CAAC;SAC/B;IACL,CAAC;IAEM,WAAW,CAAC,EAAU;QACzB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC,SAAS,EAAE;YAC1C,OAAO;SACV;QACD,IAAI,CAAC,kBAAkB,CAAC,EAAE,CAAC,CAAC;IAChC,CAAC;IAEO,UAAU,CAAC,KAAK;QACpB,MAAM,IAAI,GAAiC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QAC9D,IAAI,IAAI,YAAY,4BAA4B,EAAE;YAC9C,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YAC3B,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,MAAM,CAAC,EAAE;gBAC5C,OAAO;aACV;YAED,MAAM,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,KAAK,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;YAC/F,IAAI,MAAM,CAAC,SAAS,IAAI,CAAC,SAAS,IAAI,CAAC,MAAM,CAAC,WAAW,IAAI,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE;gBACzE,MAAM,kBAAkB,GAAG;oBACvB,SAAS,EAAE,MAAM,CAAC,KAAK;oBACvB,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,KAAK,MAAM,CAAC,KAAK,CAAC,EAAE,GAAG,IAAI,gBAAgB,CAAC,GAAG;oBAC5G,UAAU,EAAE,MAAM,CAAC,iBAAiB;oBACpC,QAAQ,EAAE,MAAM,CAAC,YAAY;oBAC7B,gBAAgB,EAAE,MAAM,CAAC,gBAAgB;iBAC5C,CAAC;gBAEF,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC;aACpC;SACJ;IACL,CAAC;IAES,uBAAuB,CAAC,UAA8B;QAC5D,MAAM,cAAc,GAAG,EAAE,CAAC;QAE1B,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACtB,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,KAAK,IAAI,CAAC,EAAE,CAAC,CAAC;YAEvE,qEAAqE;YACrE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,SAAS,EAAE;gBACvD,OAAO;aACV;YAED,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9B,CAAC,CAAC,CAAC;QAEH,OAAO,cAAc,CAAC;IAC1B,CAAC;IAES,kBAAkB,CAAC,EAAU;QACnC,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,EAAE,CAAC,CAAC;QAC5D,IAAI,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;IAC9B,CAAC;IAES,kBAAkB;IAC5B,CAAC;;oHA7IiB,uBAAuB;wGAAvB,uBAAuB,sbA2D3B,gBAAgB;2FA3DZ,uBAAuB;kBAD3C,SAAS;4HAOA,gBAAgB;sBADtB,KAAK;gBAIC,OAAO;sBADb,KAAK;gBAIC,YAAY;sBADlB,WAAW;uBAAC,0BAA0B;gBAI5B,SAAS;sBADnB,WAAW;uBAAC,gCAAgC;gBAMlC,YAAY;sBADtB,WAAW;uBAAC,mCAAmC;gBAOzC,IAAI;sBADV,KAAK;gBAOK,WAAW;sBADrB,KAAK;gBAiBK,eAAe;sBADzB,KAAK;gBAUC,iBAAiB;sBADvB,MAAM;gBAIA,KAAK;sBADX,YAAY;uBAAC,gBAAgB;;AA8FlC;;;;;;GAMG;AAEH,MAAM,OAAO,kBAAkB;IAEpB,SAAS,CAAC,GAAW,EAAE,IAAc;QACxC,MAAM,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;QACzC,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,IAAI,GAAG,EAAE,CAAC;IAC5E,CAAC;;+GALQ,kBAAkB;6GAAlB,kBAAkB;2FAAlB,kBAAkB;kBAD9B,IAAI;mBAAC,EAAE,IAAI,EAAE,gBAAgB,EAAE","sourcesContent":["import {\n    Directive,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    Output,\n    Pipe,\n    PipeTransform,\n    QueryList,\n    TemplateRef,\n    ViewChildren\n} from '@angular/core';\nimport { IChipsAreaReorderEventArgs, IgxChipComponent } from '../../chips/public_api';\nimport { DisplayDensity } from '../../core/displayDensity';\nimport { PlatformUtil } from '../../core/utils';\nimport { IGroupingExpression } from '../../data-operations/grouping-expression.interface';\nimport { SortingDirection } from '../../data-operations/sorting-strategy';\nimport { FlatGridType, GridType } from '../common/grid.interface';\nimport { IgxColumnMovingDragDirective } from '../moving/moving.drag.directive';\n\n/**\n * An internal component representing a base group-by drop area.\n *\n * @hidden @internal\n */\n @Directive()\nexport abstract class IgxGroupByAreaDirective {\n    /**\n     * The drop area template if provided by the parent grid.\n     * Otherwise, uses the default internal one.\n     */\n    @Input()\n    public dropAreaTemplate: TemplateRef<void>;\n\n    @Input()\n    public density: DisplayDensity = DisplayDensity.comfortable;\n\n    @HostBinding('class.igx-grid-grouparea')\n    public defaultClass =  true;\n\n    @HostBinding('class.igx-grid-grouparea--cosy')\n    public get cosyStyle() {\n        return this.density === 'cosy';\n    }\n\n    @HostBinding('class.igx-grid-grouparea--compact')\n    public get compactStyle() {\n        return this.density === 'compact';\n    }\n\n    /** The parent grid containing the component. */\n    @Input()\n    public grid: FlatGridType | GridType;\n\n    /**\n     * The group-by expressions provided by the parent grid.\n     */\n    @Input()\n    public get expressions(): IGroupingExpression[] {\n        return this._expressions;\n    }\n\n    public set expressions(value: IGroupingExpression[]) {\n        this._expressions = value;\n        this.chipExpressions = this._expressions;\n        this.expressionsChanged();\n        this.expressionsChange.emit(this._expressions);\n    }\n\n    /**\n     * The default message for the default drop area template.\n     * Obviously, if another template is provided, this is ignored.\n     */\n    @Input()\n    public get dropAreaMessage(): string {\n        return this._dropAreaMessage ?? this.grid.resourceStrings.igx_grid_groupByArea_message;\n    }\n\n    public set dropAreaMessage(value: string) {\n        this._dropAreaMessage = value;\n    }\n\n    @Output()\n    public expressionsChange = new EventEmitter<IGroupingExpression[]>();\n\n    @ViewChildren(IgxChipComponent)\n    public chips: QueryList<IgxChipComponent>;\n\n    public chipExpressions: IGroupingExpression[];\n\n    /** The native DOM element. Used in sizing calculations. */\n    public get nativeElement() {\n        return this.ref.nativeElement;\n    }\n\n    private _expressions: IGroupingExpression[] = [];\n    private _dropAreaMessage: string;\n\n    constructor(private ref: ElementRef<HTMLElement>, protected platform: PlatformUtil) { }\n\n\n    public get dropAreaVisible(): boolean {\n        return (this.grid.columnInDrag && this.grid.columnInDrag.groupable) ||\n            !this.expressions.length;\n    }\n\n    public handleKeyDown(id: string, event: KeyboardEvent) {\n        if (this.platform.isActivationKey(event)) {\n            this.updateGroupSorting(id);\n        }\n    }\n\n    public handleClick(id: string) {\n        if (!this.grid.getColumnByName(id).groupable) {\n            return;\n        }\n        this.updateGroupSorting(id);\n    }\n\n     public onDragDrop(event) {\n        const drag: IgxColumnMovingDragDirective = event.detail.owner;\n        if (drag instanceof IgxColumnMovingDragDirective) {\n            const column = drag.column;\n            if (!this.grid.columns.find(c => c === column)) {\n                return;\n            }\n\n            const isGrouped = this.expressions.findIndex((item) => item.fieldName === column.field) !== -1;\n            if (column.groupable && !isGrouped && !column.columnGroup && !!column.field) {\n                const groupingExpression = {\n                    fieldName: column.field,\n                    dir: this.grid.sortingExpressions.find(expr => expr.fieldName === column.field)?.dir || SortingDirection.Asc,\n                    ignoreCase: column.sortingIgnoreCase,\n                    strategy: column.sortStrategy,\n                    groupingComparer: column.groupingComparer\n                };\n\n                this.groupBy(groupingExpression);\n            }\n        }\n    }\n\n    protected getReorderedExpressions(chipsArray: IgxChipComponent[]) {\n        const newExpressions = [];\n\n        chipsArray.forEach(chip => {\n            const expr = this.expressions.find(item => item.fieldName === chip.id);\n\n            // disallow changing order if there are columns with groupable: false\n            if (!this.grid.getColumnByName(expr.fieldName)?.groupable) {\n                return;\n            }\n\n            newExpressions.push(expr);\n        });\n\n        return newExpressions;\n    }\n\n    protected updateGroupSorting(id: string) {\n        const expr = this.expressions.find(e => e.fieldName === id);\n        expr.dir = 3 - expr.dir;\n        this.grid.pipeTrigger++;\n        this.grid.notifyChanges();\n    }\n\n    protected expressionsChanged() {\n    }\n\n    public abstract handleReorder(event: IChipsAreaReorderEventArgs);\n\n    public abstract handleMoveEnd();\n\n    public abstract groupBy(expression: IGroupingExpression);\n\n    public abstract clearGrouping(name: string);\n\n}\n\n/**\n * A pipe to circumvent the use of getters/methods just to get some additional\n * information from the grouping expression and pass it to the chip representing\n * that expression.\n *\n * @hidden @internal\n */\n@Pipe({ name: 'igxGroupByMeta' })\nexport class IgxGroupByMetaPipe implements PipeTransform {\n\n    public transform(key: string, grid: GridType) {\n        const column = grid.getColumnByName(key);\n        return { groupable: !!column?.groupable, title: column?.header || key };\n    }\n}\n"]}
|
|
@@ -28,13 +28,13 @@ export class IgxTreeGridGroupByAreaComponent extends IgxGroupByAreaDirective {
|
|
|
28
28
|
return this._hideGroupedColumns;
|
|
29
29
|
}
|
|
30
30
|
set hideGroupedColumns(value) {
|
|
31
|
-
if (this.grid.
|
|
31
|
+
if (this.grid.columns && this.expressions) {
|
|
32
32
|
this.setColumnsVisibility(value);
|
|
33
33
|
}
|
|
34
34
|
this._hideGroupedColumns = value;
|
|
35
35
|
}
|
|
36
36
|
ngAfterContentInit() {
|
|
37
|
-
if (this.grid.
|
|
37
|
+
if (this.grid.columns && this.expressions) {
|
|
38
38
|
this.groupingDiffer = this.differs.find(this.expressions).create();
|
|
39
39
|
this.updateColumnsVisibility();
|
|
40
40
|
}
|
|
@@ -85,9 +85,9 @@ export class IgxTreeGridGroupByAreaComponent extends IgxGroupByAreaDirective {
|
|
|
85
85
|
this.updateColumnsVisibility();
|
|
86
86
|
}
|
|
87
87
|
updateColumnsVisibility() {
|
|
88
|
-
if (this.groupingDiffer && this.grid.
|
|
88
|
+
if (this.groupingDiffer && this.grid.columns && !this.grid.hasColumnLayouts) {
|
|
89
89
|
const changes = this.groupingDiffer.diff(this.expressions);
|
|
90
|
-
if (changes && this.grid.
|
|
90
|
+
if (changes && this.grid.columns.length > 0) {
|
|
91
91
|
changes.forEachAddedItem((rec) => {
|
|
92
92
|
const col = this.grid.getColumnByName(rec.item.fieldName);
|
|
93
93
|
col.hidden = this.hideGroupedColumns;
|
|
@@ -100,7 +100,7 @@ export class IgxTreeGridGroupByAreaComponent extends IgxGroupByAreaDirective {
|
|
|
100
100
|
}
|
|
101
101
|
}
|
|
102
102
|
setColumnsVisibility(value) {
|
|
103
|
-
if (this.grid.
|
|
103
|
+
if (this.grid.columns.length > 0 && !this.grid.hasColumnLayouts) {
|
|
104
104
|
this.expressions.forEach((expr) => {
|
|
105
105
|
const col = this.grid.getColumnByName(expr.fieldName);
|
|
106
106
|
col.hidden = value;
|
|
@@ -116,4 +116,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
|
116
116
|
}], ctorParameters: function () { return [{ type: i0.IterableDiffers }, { type: i0.ElementRef }, { type: i1.PlatformUtil }]; }, propDecorators: { hideGroupedColumns: [{
|
|
117
117
|
type: Input
|
|
118
118
|
}] } });
|
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-grid-group-by-area.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/grouping/tree-grid-group-by-area.component.ts","../../../../../../projects/igniteui-angular/src/lib/grids/grouping/group-by-area.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    Component,\n    ElementRef,\n    Input,\n    IterableDiffer,\n    IterableDiffers,\n    OnDestroy,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { IChipsAreaReorderEventArgs } from '../../chips/public_api';\nimport { PlatformUtil } from '../../core/utils';\nimport { IGroupingExpression } from '../../data-operations/grouping-expression.interface';\nimport { ISortingExpression } from '../../data-operations/sorting-strategy';\nimport { IgxGroupByAreaDirective } from './group-by-area.directive';\n\n/**\n * An internal component representing the group-by drop area for the igx-grid component.\n *\n * @hidden @internal\n */\n@Component({\n    selector: 'igx-tree-grid-group-by-area',\n    templateUrl: 'group-by-area.component.html',\n    providers: [{ provide: IgxGroupByAreaDirective, useExisting: IgxTreeGridGroupByAreaComponent }]\n})\nexport class IgxTreeGridGroupByAreaComponent extends IgxGroupByAreaDirective implements AfterContentInit, OnDestroy {\n    @Input()\n    public get hideGroupedColumns() {\n        return this._hideGroupedColumns;\n    }\n\n    public set hideGroupedColumns(value: boolean) {\n        if (this.grid.columnList && this.expressions) {\n            this.setColumnsVisibility(value);\n        }\n\n        this._hideGroupedColumns = value;\n    }\n\n    private _hideGroupedColumns = false;\n    private groupingDiffer: IterableDiffer<IGroupingExpression>;\n    private destroy$ = new Subject<any>();\n\n    constructor(private differs: IterableDiffers, ref: ElementRef<HTMLElement>, platform: PlatformUtil) {\n        super(ref, platform);\n    }\n\n    public ngAfterContentInit(): void {\n        if (this.grid.columnList && this.expressions) {\n            this.groupingDiffer = this.differs.find(this.expressions).create();\n            this.updateColumnsVisibility();\n        }\n\n        this.grid.sortingExpressionsChange.pipe(takeUntil(this.destroy$)).subscribe((sortingExpressions: ISortingExpression[]) => {\n            if (!this.expressions || !this.expressions.length) {\n                return;\n            }\n\n            let changed = false;\n\n            sortingExpressions.forEach((sortExpr: ISortingExpression) => {\n                const fieldName = sortExpr.fieldName;\n                const groupingExpr = this.expressions.find(ex => ex.fieldName === fieldName);\n                if (groupingExpr && groupingExpr.dir !== sortExpr.dir) {\n                    groupingExpr.dir = sortExpr.dir;\n                    changed = true;\n                }\n            });\n\n            if (changed) {\n                this.expressions = [...this.expressions];\n            }\n        });\n    }\n\n    public ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.complete();\n    }\n\n    public handleReorder(event: IChipsAreaReorderEventArgs) {\n        const { chipsArray, originalEvent } = event;\n        const newExpressions = this.getReorderedExpressions(chipsArray);\n\n        this.chipExpressions = newExpressions;\n\n        // When reordered using keyboard navigation, we don't have `onMoveEnd` event.\n        if (originalEvent instanceof KeyboardEvent) {\n            this.expressions = newExpressions;\n        }\n    }\n\n    public handleMoveEnd() {\n        this.expressions = this.chipExpressions;\n    }\n\n    public groupBy(expression: IGroupingExpression) {\n        this.expressions.push(expression);\n        this.expressions = [...this.expressions];\n    }\n\n    public clearGrouping(name: string) {\n        this.expressions = this.expressions.filter(item => item.fieldName !== name);\n        this.grid.sortingExpressions = this.grid.sortingExpressions.filter(item => item.fieldName !== name);\n        this.grid.notifyChanges(true);\n    }\n\n    protected expressionsChanged() {\n        this.updateColumnsVisibility();\n    }\n\n    private updateColumnsVisibility() {\n        if (this.groupingDiffer && this.grid.columnList && !this.grid.hasColumnLayouts) {\n            const changes = this.groupingDiffer.diff(this.expressions);\n            if (changes && this.grid.columnList.length > 0) {\n                changes.forEachAddedItem((rec) => {\n                    const col = this.grid.getColumnByName(rec.item.fieldName);\n                    col.hidden = this.hideGroupedColumns;\n                });\n                changes.forEachRemovedItem((rec) => {\n                    const col = this.grid.getColumnByName(rec.item.fieldName);\n                    col.hidden = false;\n                });\n            }\n        }\n    }\n\n    private setColumnsVisibility(value) {\n        if (this.grid.columnList.length > 0 && !this.grid.hasColumnLayouts) {\n            this.expressions.forEach((expr) => {\n                const col = this.grid.getColumnByName(expr.fieldName);\n                col.hidden = value;\n            });\n        }\n    }\n}\n\n","<igx-chips-area (reorder)=\"handleReorder($event)\" (moveEnd)=\"handleMoveEnd()\">\n    <ng-container *ngFor=\"let expression of chipExpressions; let last = last;\">\n        <igx-chip\n            [id]=\"expression.fieldName\"\n            [title]=\"(expression.fieldName | igxGroupByMeta:grid).title\"\n            [displayDensity]=\"grid.displayDensity\"\n            [removable]=\"(expression.fieldName | igxGroupByMeta:grid).groupable\"\n            [draggable]=\"(expression.fieldName | igxGroupByMeta:grid).groupable\"\n            [disabled]=\"!(expression.fieldName | igxGroupByMeta:grid).groupable\"\n            (keyDown)=\"handleKeyDown($event.owner.id, $event.originalEvent)\"\n            (remove)=\"clearGrouping($event.owner.id)\"\n            (chipClick)=\"handleClick(expression.fieldName)\"\n        >\n            <span>{{ (expression.fieldName | igxGroupByMeta:grid).title }}</span>\n            <igx-icon igxSuffix>{{ expression.dir === 1 ? 'arrow_upward' : 'arrow_downward' }}</igx-icon>\n        </igx-chip>\n\n        <span class=\"igx-grid-grouparea__connector\">\n            <igx-icon [hidden]=\"(last && !dropAreaVisible)\">arrow_forward</igx-icon>\n        </span>\n    </ng-container>\n    <div igxGroupAreaDrop class=\"igx-drop-area{{ density !== 'comfortable' ? '--' + density : ''}}\"\n        [attr.gridId]=\"grid.id\"\n        [hidden]=\"!dropAreaVisible\"\n        (igxDrop)=\"onDragDrop($event)\"\n    >\n        <ng-container *ngTemplateOutlet=\"dropAreaTemplate || default\"></ng-container>\n    </div>\n</igx-chips-area>\n\n<ng-template #default>\n    <igx-icon class=\"igx-drop-area__icon\">group_work</igx-icon>\n    <span class=\"igx-drop-area__text\">{{ dropAreaMessage }}</span>\n</ng-template>\n"]}
|
|
119
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-grid-group-by-area.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/grouping/tree-grid-group-by-area.component.ts","../../../../../../projects/igniteui-angular/src/lib/grids/grouping/group-by-area.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    Component,\n    ElementRef,\n    Input,\n    IterableDiffer,\n    IterableDiffers,\n    OnDestroy,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { IChipsAreaReorderEventArgs } from '../../chips/public_api';\nimport { PlatformUtil } from '../../core/utils';\nimport { IGroupingExpression } from '../../data-operations/grouping-expression.interface';\nimport { ISortingExpression } from '../../data-operations/sorting-strategy';\nimport { IgxGroupByAreaDirective } from './group-by-area.directive';\n\n/**\n * An internal component representing the group-by drop area for the igx-grid component.\n *\n * @hidden @internal\n */\n@Component({\n    selector: 'igx-tree-grid-group-by-area',\n    templateUrl: 'group-by-area.component.html',\n    providers: [{ provide: IgxGroupByAreaDirective, useExisting: IgxTreeGridGroupByAreaComponent }]\n})\nexport class IgxTreeGridGroupByAreaComponent extends IgxGroupByAreaDirective implements AfterContentInit, OnDestroy {\n    @Input()\n    public get hideGroupedColumns() {\n        return this._hideGroupedColumns;\n    }\n\n    public set hideGroupedColumns(value: boolean) {\n        if (this.grid.columns && this.expressions) {\n            this.setColumnsVisibility(value);\n        }\n\n        this._hideGroupedColumns = value;\n    }\n\n    private _hideGroupedColumns = false;\n    private groupingDiffer: IterableDiffer<IGroupingExpression>;\n    private destroy$ = new Subject<any>();\n\n    constructor(private differs: IterableDiffers, ref: ElementRef<HTMLElement>, platform: PlatformUtil) {\n        super(ref, platform);\n    }\n\n    public ngAfterContentInit(): void {\n        if (this.grid.columns && this.expressions) {\n            this.groupingDiffer = this.differs.find(this.expressions).create();\n            this.updateColumnsVisibility();\n        }\n\n        this.grid.sortingExpressionsChange.pipe(takeUntil(this.destroy$)).subscribe((sortingExpressions: ISortingExpression[]) => {\n            if (!this.expressions || !this.expressions.length) {\n                return;\n            }\n\n            let changed = false;\n\n            sortingExpressions.forEach((sortExpr: ISortingExpression) => {\n                const fieldName = sortExpr.fieldName;\n                const groupingExpr = this.expressions.find(ex => ex.fieldName === fieldName);\n                if (groupingExpr && groupingExpr.dir !== sortExpr.dir) {\n                    groupingExpr.dir = sortExpr.dir;\n                    changed = true;\n                }\n            });\n\n            if (changed) {\n                this.expressions = [...this.expressions];\n            }\n        });\n    }\n\n    public ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.complete();\n    }\n\n    public handleReorder(event: IChipsAreaReorderEventArgs) {\n        const { chipsArray, originalEvent } = event;\n        const newExpressions = this.getReorderedExpressions(chipsArray);\n\n        this.chipExpressions = newExpressions;\n\n        // When reordered using keyboard navigation, we don't have `onMoveEnd` event.\n        if (originalEvent instanceof KeyboardEvent) {\n            this.expressions = newExpressions;\n        }\n    }\n\n    public handleMoveEnd() {\n        this.expressions = this.chipExpressions;\n    }\n\n    public groupBy(expression: IGroupingExpression) {\n        this.expressions.push(expression);\n        this.expressions = [...this.expressions];\n    }\n\n    public clearGrouping(name: string) {\n        this.expressions = this.expressions.filter(item => item.fieldName !== name);\n        this.grid.sortingExpressions = this.grid.sortingExpressions.filter(item => item.fieldName !== name);\n        this.grid.notifyChanges(true);\n    }\n\n    protected expressionsChanged() {\n        this.updateColumnsVisibility();\n    }\n\n    private updateColumnsVisibility() {\n        if (this.groupingDiffer && this.grid.columns && !this.grid.hasColumnLayouts) {\n            const changes = this.groupingDiffer.diff(this.expressions);\n            if (changes && this.grid.columns.length > 0) {\n                changes.forEachAddedItem((rec) => {\n                    const col = this.grid.getColumnByName(rec.item.fieldName);\n                    col.hidden = this.hideGroupedColumns;\n                });\n                changes.forEachRemovedItem((rec) => {\n                    const col = this.grid.getColumnByName(rec.item.fieldName);\n                    col.hidden = false;\n                });\n            }\n        }\n    }\n\n    private setColumnsVisibility(value) {\n        if (this.grid.columns.length > 0 && !this.grid.hasColumnLayouts) {\n            this.expressions.forEach((expr) => {\n                const col = this.grid.getColumnByName(expr.fieldName);\n                col.hidden = value;\n            });\n        }\n    }\n}\n\n","<igx-chips-area (reorder)=\"handleReorder($event)\" (moveEnd)=\"handleMoveEnd()\">\n    <ng-container *ngFor=\"let expression of chipExpressions; let last = last;\">\n        <igx-chip\n            [id]=\"expression.fieldName\"\n            [title]=\"(expression.fieldName | igxGroupByMeta:grid).title\"\n            [displayDensity]=\"grid.displayDensity\"\n            [removable]=\"(expression.fieldName | igxGroupByMeta:grid).groupable\"\n            [draggable]=\"(expression.fieldName | igxGroupByMeta:grid).groupable\"\n            [disabled]=\"!(expression.fieldName | igxGroupByMeta:grid).groupable\"\n            (keyDown)=\"handleKeyDown($event.owner.id, $event.originalEvent)\"\n            (remove)=\"clearGrouping($event.owner.id)\"\n            (chipClick)=\"handleClick(expression.fieldName)\"\n        >\n            <span>{{ (expression.fieldName | igxGroupByMeta:grid).title }}</span>\n            <igx-icon igxSuffix>{{ expression.dir === 1 ? 'arrow_upward' : 'arrow_downward' }}</igx-icon>\n        </igx-chip>\n\n        <span class=\"igx-grid-grouparea__connector\">\n            <igx-icon [hidden]=\"(last && !dropAreaVisible)\">arrow_forward</igx-icon>\n        </span>\n    </ng-container>\n    <div igxGroupAreaDrop class=\"igx-drop-area{{ density !== 'comfortable' ? '--' + density : ''}}\"\n        [attr.gridId]=\"grid.id\"\n        [hidden]=\"!dropAreaVisible\"\n        (igxDrop)=\"onDragDrop($event)\"\n    >\n        <ng-container *ngTemplateOutlet=\"dropAreaTemplate || default\"></ng-container>\n    </div>\n</igx-chips-area>\n\n<ng-template #default>\n    <igx-icon class=\"igx-drop-area__icon\">group_work</igx-icon>\n    <span class=\"igx-drop-area__text\">{{ dropAreaMessage }}</span>\n</ng-template>\n"]}
|
|
@@ -68,7 +68,7 @@ export class IgxHierarchicalGridBaseDirective extends IgxGridBaseDirective {
|
|
|
68
68
|
*/
|
|
69
69
|
get maxLevelHeaderDepth() {
|
|
70
70
|
if (this._maxLevelHeaderDepth === null) {
|
|
71
|
-
this._maxLevelHeaderDepth = this.
|
|
71
|
+
this._maxLevelHeaderDepth = this.columns.reduce((acc, col) => Math.max(acc, col.level), 0);
|
|
72
72
|
}
|
|
73
73
|
return this._maxLevelHeaderDepth;
|
|
74
74
|
}
|
|
@@ -111,13 +111,12 @@ export class IgxHierarchicalGridBaseDirective extends IgxGridBaseDirective {
|
|
|
111
111
|
columns.push(ref.instance);
|
|
112
112
|
});
|
|
113
113
|
const result = flatten(columns);
|
|
114
|
-
this.
|
|
115
|
-
this.columnList.notifyOnChanges();
|
|
114
|
+
this.updateColumns(result);
|
|
116
115
|
this.initPinning();
|
|
117
116
|
const factoryColumn = this.resolver.resolveComponentFactory(IgxColumnComponent);
|
|
118
117
|
const outputs = factoryColumn.outputs.filter(o => o.propName !== 'columnChange');
|
|
119
118
|
outputs.forEach(output => {
|
|
120
|
-
this.
|
|
119
|
+
this.columns.forEach(column => {
|
|
121
120
|
if (column[output.propName]) {
|
|
122
121
|
column[output.propName].pipe(takeUntil(column.destroy$)).subscribe((args) => {
|
|
123
122
|
const rowIslandColumn = this.parentIsland.childColumns.find(col => col.field === column.field);
|
|
@@ -227,4 +226,4 @@ const flatten = (arr) => {
|
|
|
227
226
|
});
|
|
228
227
|
return result;
|
|
229
228
|
};
|
|
230
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hierarchical-grid-base.directive.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid-base.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ApplicationRef,\n    ChangeDetectorRef,\n    ComponentFactoryResolver,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    Inject,\n    Injector,\n    Input,\n    IterableDiffers,\n    LOCALE_ID,\n    NgModuleRef,\n    NgZone,\n    Optional,\n    Output,\n    TemplateRef,\n    ViewChild,\n    ViewContainerRef\n} from '@angular/core';\nimport { IgxGridBaseDirective } from '../grid-base.directive';\nimport { IgxHierarchicalGridAPIService } from './hierarchical-grid-api.service';\nimport { IgxRowIslandComponent } from './row-island.component';\nimport { IgxFilteringService } from '../filtering/grid-filtering.service';\nimport { IDisplayDensityOptions, DisplayDensityToken } from '../../core/displayDensity';\nimport { IgxSummaryOperand } from '../summaries/grid-summary';\nimport { DOCUMENT } from '@angular/common';\nimport { IgxHierarchicalGridNavigationService } from './hierarchical-grid-navigation.service';\nimport { IgxGridSummaryService } from '../summaries/grid-summary.service';\nimport { IgxGridSelectionService } from '../selection/selection.service';\nimport { IgxColumnResizingService } from '../resizing/resizing.service';\nimport { GridType, IGX_GRID_SERVICE_BASE, IPathSegment } from '../common/grid.interface';\nimport { IgxColumnGroupComponent } from '../columns/column-group.component';\nimport { IgxColumnComponent } from '../columns/column.component';\nimport { IForOfState } from '../../directives/for-of/for_of.directive';\nimport { takeUntil } from 'rxjs/operators';\nimport { PlatformUtil } from '../../core/utils';\nimport { IgxFlatTransactionFactory } from '../../services/transaction/transaction-factory.service';\nimport { IgxTransactionService } from '../../services/transaction/igx-transaction';\nimport { IgxOverlayService } from '../../services/overlay/overlay';\nimport { State, Transaction, TransactionService } from '../../services/transaction/transaction';\nimport { IgxGridTransaction } from '../common/types';\n\nexport const hierarchicalTransactionServiceFactory = () => new IgxTransactionService();\n\nexport const IgxHierarchicalTransactionServiceFactory = {\n    provide: IgxGridTransaction,\n    useFactory: hierarchicalTransactionServiceFactory\n};\n\n@Directive()\nexport abstract class IgxHierarchicalGridBaseDirective extends IgxGridBaseDirective implements GridType {\n    /**\n     * Gets/Sets the key indicating whether a row has children. If row has no children it does not render an expand indicator.\n     *\n     * @example\n     * ```html\n     * <igx-hierarchical-grid #grid [data]=\"localData\" [hasChildrenKey]=\"'hasEmployees'\">\n     * </igx-hierarchical-grid>\n     * ```\n     */\n    @Input()\n    public hasChildrenKey: string;\n\n    /**\n     * Gets/Sets whether the expand/collapse all button in the header should be rendered.\n     *\n     * @remark\n     * The default value is false.\n     * @example\n     * ```html\n     * <igx-hierarchical-grid #grid [data]=\"localData\" [showExpandAll]=\"true\">\n     * </igx-hierarchical-grid>\n     * ```\n     */\n    @Input()\n    public showExpandAll = false;\n\n    /**\n     * Emitted when a new chunk of data is loaded from virtualization.\n     *\n     * @example\n     * ```typescript\n     *  <igx-hierarchical-grid [id]=\"'igx-grid-1'\" [data]=\"Data\" [autoGenerate]=\"true\" (dataPreLoad)=\"handleEvent()\">\n     *  </igx-hierarchical-grid>\n     * ```\n     */\n    @Output()\n    public dataPreLoad = new EventEmitter<IForOfState>();\n\n    /**\n     * @hidden\n     * @internal\n     */\n    @ViewChild('dragIndicatorIconBase', { read: TemplateRef, static: true })\n    public dragIndicatorIconBase: TemplateRef<any>;\n\n    /**\n     * @hidden\n     */\n    public get maxLevelHeaderDepth() {\n        if (this._maxLevelHeaderDepth === null) {\n            this._maxLevelHeaderDepth = this.columnList.reduce((acc, col) => Math.max(acc, col.level), 0);\n        }\n        return this._maxLevelHeaderDepth;\n    }\n\n    /**\n     * Gets the outlet used to attach the grid's overlays to.\n     *\n     * @remark\n     * If set, returns the outlet defined outside the grid. Otherwise returns the grid's internal outlet directive.\n     */\n    public get outlet() {\n        return this.rootGrid ? this.rootGrid.resolveOutlet() : this.resolveOutlet();\n    }\n\n    /**\n     * Sets the outlet used to attach the grid's overlays to.\n     */\n    public set outlet(val: any) {\n        this._userOutletDirective = val;\n    }\n\n    /** @hidden @internal */\n    public batchEditingChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    public get batchEditing(): boolean {\n        return this._batchEditing;\n    }\n\n    public set batchEditing(val: boolean) {\n        if (val !== this._batchEditing) {\n            delete this._transactions;\n            this.switchTransactionService(val);\n            this.subscribeToTransactions();\n            this.batchEditingChange.emit(val);\n            this._batchEditing = val;\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public parentIsland: IgxRowIslandComponent;\n    public abstract rootGrid: GridType;\n\n    public abstract expandChildren: boolean;\n\n    constructor(\n        public selectionService: IgxGridSelectionService,\n        public colResizingService: IgxColumnResizingService,\n        @Inject(IGX_GRID_SERVICE_BASE) public gridAPI: IgxHierarchicalGridAPIService,\n        protected transactionFactory: IgxFlatTransactionFactory,\n        elementRef: ElementRef<HTMLElement>,\n        zone: NgZone,\n        @Inject(DOCUMENT) public document,\n        cdr: ChangeDetectorRef,\n        resolver: ComponentFactoryResolver,\n        differs: IterableDiffers,\n        viewRef: ViewContainerRef,\n        appRef: ApplicationRef,\n        moduleRef: NgModuleRef<any>,\n        injector: Injector,\n        navigation: IgxHierarchicalGridNavigationService,\n        filteringService: IgxFilteringService,\n        @Inject(IgxOverlayService) protected overlayService: IgxOverlayService,\n        public summaryService: IgxGridSummaryService,\n        @Optional() @Inject(DisplayDensityToken) protected _displayDensityOptions: IDisplayDensityOptions,\n        @Inject(LOCALE_ID) localeId: string,\n        protected platform: PlatformUtil,\n        @Optional() @Inject(IgxGridTransaction) protected _diTransactions?: TransactionService<Transaction, State>) {\n        super(\n            selectionService,\n            colResizingService,\n            gridAPI,\n            transactionFactory,\n            elementRef,\n            zone,\n            document,\n            cdr,\n            resolver,\n            differs,\n            viewRef,\n            appRef,\n            moduleRef,\n            injector,\n            navigation,\n            filteringService,\n            overlayService,\n            summaryService,\n            _displayDensityOptions,\n            localeId,\n            platform);\n    }\n\n    /**\n     * @hidden\n     */\n    public createColumnsList(cols: Array<any>) {\n        const columns = [];\n        const topLevelCols = cols.filter(c => c.level === 0);\n        topLevelCols.forEach((col) => {\n            const ref = this._createColumn(col);\n            ref.changeDetectorRef.detectChanges();\n            columns.push(ref.instance);\n        });\n        const result = flatten(columns);\n        this.columnList.reset(result);\n        this.columnList.notifyOnChanges();\n        this.initPinning();\n\n        const factoryColumn = this.resolver.resolveComponentFactory(IgxColumnComponent);\n        const outputs = factoryColumn.outputs.filter(o => o.propName !== 'columnChange');\n        outputs.forEach(output => {\n            this.columnList.forEach(column => {\n                if (column[output.propName]) {\n                    column[output.propName].pipe(takeUntil(column.destroy$)).subscribe((args) => {\n                        const rowIslandColumn = this.parentIsland.childColumns.find(col => col.field === column.field);\n                        rowIslandColumn[output.propName].emit({ args, owner: this });\n                    });\n                }\n            });\n        });\n    }\n\n    protected _createColumn(col) {\n        let ref;\n        if (col instanceof IgxColumnGroupComponent) {\n            ref = this._createColGroupComponent(col);\n        } else {\n            ref = this._createColComponent(col);\n        }\n        return ref;\n    }\n\n    protected _createColGroupComponent(col: IgxColumnGroupComponent) {\n        const factoryGroup = this.resolver.resolveComponentFactory(IgxColumnGroupComponent);\n        const ref = this.viewRef.createComponent(IgxColumnGroupComponent, { injector: this.viewRef.injector });\n        ref.changeDetectorRef.detectChanges();\n        factoryGroup.inputs.forEach((input) => {\n            const propName = input.propName;\n            ref.instance[propName] = col[propName];\n        });\n        if (col.children.length > 0) {\n            const newChildren = [];\n            col.children.forEach(child => {\n                const newCol = this._createColumn(child).instance;\n                newCol.parent = ref.instance;\n                newChildren.push(newCol);\n            });\n            ref.instance.children.reset(newChildren);\n            ref.instance.children.notifyOnChanges();\n        }\n        return ref;\n    }\n\n    protected _createColComponent(col) {\n        const factoryColumn = this.resolver.resolveComponentFactory(IgxColumnComponent);\n        const ref = this.viewRef.createComponent(IgxColumnComponent, { injector: this.viewRef.injector });\n        factoryColumn.inputs.forEach((input) => {\n            const propName = input.propName;\n            if (!(col[propName] instanceof IgxSummaryOperand)) {\n                ref.instance[propName] = col[propName];\n            } else {\n                ref.instance[propName] = col[propName].constructor;\n            }\n        });\n        return ref;\n    }\n\n    protected getGridsForIsland(rowIslandID: string) {\n        return this.gridAPI.getChildGridsForRowIsland(rowIslandID);\n    }\n\n    protected getChildGrid(path: Array<IPathSegment>) {\n        if (!path) {\n            return;\n        }\n        return this.gridAPI.getChildGrid(path);\n    }\n}\n\nconst flatten = (arr: any[]) => {\n    let result = [];\n\n    arr.forEach(el => {\n        result.push(el);\n        if (el.children) {\n            result = result.concat(flatten(el.children.toArray()));\n        }\n    });\n    return result;\n};\n"]}
|
|
229
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hierarchical-grid-base.directive.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid-base.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ApplicationRef,\n    ChangeDetectorRef,\n    ComponentFactoryResolver,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    Inject,\n    Injector,\n    Input,\n    IterableDiffers,\n    LOCALE_ID,\n    NgModuleRef,\n    NgZone,\n    Optional,\n    Output,\n    TemplateRef,\n    ViewChild,\n    ViewContainerRef\n} from '@angular/core';\nimport { IgxGridBaseDirective } from '../grid-base.directive';\nimport { IgxHierarchicalGridAPIService } from './hierarchical-grid-api.service';\nimport { IgxRowIslandComponent } from './row-island.component';\nimport { IgxFilteringService } from '../filtering/grid-filtering.service';\nimport { IDisplayDensityOptions, DisplayDensityToken } from '../../core/displayDensity';\nimport { IgxSummaryOperand } from '../summaries/grid-summary';\nimport { DOCUMENT } from '@angular/common';\nimport { IgxHierarchicalGridNavigationService } from './hierarchical-grid-navigation.service';\nimport { IgxGridSummaryService } from '../summaries/grid-summary.service';\nimport { IgxGridSelectionService } from '../selection/selection.service';\nimport { IgxColumnResizingService } from '../resizing/resizing.service';\nimport { GridType, IGX_GRID_SERVICE_BASE, IPathSegment } from '../common/grid.interface';\nimport { IgxColumnGroupComponent } from '../columns/column-group.component';\nimport { IgxColumnComponent } from '../columns/column.component';\nimport { IForOfState } from '../../directives/for-of/for_of.directive';\nimport { takeUntil } from 'rxjs/operators';\nimport { PlatformUtil } from '../../core/utils';\nimport { IgxFlatTransactionFactory } from '../../services/transaction/transaction-factory.service';\nimport { IgxTransactionService } from '../../services/transaction/igx-transaction';\nimport { IgxOverlayService } from '../../services/overlay/overlay';\nimport { State, Transaction, TransactionService } from '../../services/transaction/transaction';\nimport { IgxGridTransaction } from '../common/types';\n\nexport const hierarchicalTransactionServiceFactory = () => new IgxTransactionService();\n\nexport const IgxHierarchicalTransactionServiceFactory = {\n    provide: IgxGridTransaction,\n    useFactory: hierarchicalTransactionServiceFactory\n};\n\n@Directive()\nexport abstract class IgxHierarchicalGridBaseDirective extends IgxGridBaseDirective implements GridType {\n    /**\n     * Gets/Sets the key indicating whether a row has children. If row has no children it does not render an expand indicator.\n     *\n     * @example\n     * ```html\n     * <igx-hierarchical-grid #grid [data]=\"localData\" [hasChildrenKey]=\"'hasEmployees'\">\n     * </igx-hierarchical-grid>\n     * ```\n     */\n    @Input()\n    public hasChildrenKey: string;\n\n    /**\n     * Gets/Sets whether the expand/collapse all button in the header should be rendered.\n     *\n     * @remark\n     * The default value is false.\n     * @example\n     * ```html\n     * <igx-hierarchical-grid #grid [data]=\"localData\" [showExpandAll]=\"true\">\n     * </igx-hierarchical-grid>\n     * ```\n     */\n    @Input()\n    public showExpandAll = false;\n\n    /**\n     * Emitted when a new chunk of data is loaded from virtualization.\n     *\n     * @example\n     * ```typescript\n     *  <igx-hierarchical-grid [id]=\"'igx-grid-1'\" [data]=\"Data\" [autoGenerate]=\"true\" (dataPreLoad)=\"handleEvent()\">\n     *  </igx-hierarchical-grid>\n     * ```\n     */\n    @Output()\n    public dataPreLoad = new EventEmitter<IForOfState>();\n\n    /**\n     * @hidden\n     * @internal\n     */\n    @ViewChild('dragIndicatorIconBase', { read: TemplateRef, static: true })\n    public dragIndicatorIconBase: TemplateRef<any>;\n\n    /**\n     * @hidden\n     */\n    public get maxLevelHeaderDepth() {\n        if (this._maxLevelHeaderDepth === null) {\n            this._maxLevelHeaderDepth = this.columns.reduce((acc, col) => Math.max(acc, col.level), 0);\n        }\n        return this._maxLevelHeaderDepth;\n    }\n\n    /**\n     * Gets the outlet used to attach the grid's overlays to.\n     *\n     * @remark\n     * If set, returns the outlet defined outside the grid. Otherwise returns the grid's internal outlet directive.\n     */\n    public get outlet() {\n        return this.rootGrid ? this.rootGrid.resolveOutlet() : this.resolveOutlet();\n    }\n\n    /**\n     * Sets the outlet used to attach the grid's overlays to.\n     */\n    public set outlet(val: any) {\n        this._userOutletDirective = val;\n    }\n\n    /** @hidden @internal */\n    public batchEditingChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    public get batchEditing(): boolean {\n        return this._batchEditing;\n    }\n\n    public set batchEditing(val: boolean) {\n        if (val !== this._batchEditing) {\n            delete this._transactions;\n            this.switchTransactionService(val);\n            this.subscribeToTransactions();\n            this.batchEditingChange.emit(val);\n            this._batchEditing = val;\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public parentIsland: IgxRowIslandComponent;\n    public abstract rootGrid: GridType;\n\n    public abstract expandChildren: boolean;\n\n    constructor(\n        public selectionService: IgxGridSelectionService,\n        public colResizingService: IgxColumnResizingService,\n        @Inject(IGX_GRID_SERVICE_BASE) public gridAPI: IgxHierarchicalGridAPIService,\n        protected transactionFactory: IgxFlatTransactionFactory,\n        elementRef: ElementRef<HTMLElement>,\n        zone: NgZone,\n        @Inject(DOCUMENT) public document,\n        cdr: ChangeDetectorRef,\n        resolver: ComponentFactoryResolver,\n        differs: IterableDiffers,\n        viewRef: ViewContainerRef,\n        appRef: ApplicationRef,\n        moduleRef: NgModuleRef<any>,\n        injector: Injector,\n        navigation: IgxHierarchicalGridNavigationService,\n        filteringService: IgxFilteringService,\n        @Inject(IgxOverlayService) protected overlayService: IgxOverlayService,\n        public summaryService: IgxGridSummaryService,\n        @Optional() @Inject(DisplayDensityToken) protected _displayDensityOptions: IDisplayDensityOptions,\n        @Inject(LOCALE_ID) localeId: string,\n        protected platform: PlatformUtil,\n        @Optional() @Inject(IgxGridTransaction) protected _diTransactions?: TransactionService<Transaction, State>) {\n        super(\n            selectionService,\n            colResizingService,\n            gridAPI,\n            transactionFactory,\n            elementRef,\n            zone,\n            document,\n            cdr,\n            resolver,\n            differs,\n            viewRef,\n            appRef,\n            moduleRef,\n            injector,\n            navigation,\n            filteringService,\n            overlayService,\n            summaryService,\n            _displayDensityOptions,\n            localeId,\n            platform);\n    }\n\n    /**\n     * @hidden\n     */\n    public createColumnsList(cols: Array<any>) {\n        const columns = [];\n        const topLevelCols = cols.filter(c => c.level === 0);\n        topLevelCols.forEach((col) => {\n            const ref = this._createColumn(col);\n            ref.changeDetectorRef.detectChanges();\n            columns.push(ref.instance);\n        });\n        const result = flatten(columns);\n        this.updateColumns(result);\n        this.initPinning();\n\n        const factoryColumn = this.resolver.resolveComponentFactory(IgxColumnComponent);\n        const outputs = factoryColumn.outputs.filter(o => o.propName !== 'columnChange');\n        outputs.forEach(output => {\n            this.columns.forEach(column => {\n                if (column[output.propName]) {\n                    column[output.propName].pipe(takeUntil(column.destroy$)).subscribe((args) => {\n                        const rowIslandColumn = this.parentIsland.childColumns.find(col => col.field === column.field);\n                        rowIslandColumn[output.propName].emit({ args, owner: this });\n                    });\n                }\n            });\n        });\n    }\n\n    protected _createColumn(col) {\n        let ref;\n        if (col instanceof IgxColumnGroupComponent) {\n            ref = this._createColGroupComponent(col);\n        } else {\n            ref = this._createColComponent(col);\n        }\n        return ref;\n    }\n\n    protected _createColGroupComponent(col: IgxColumnGroupComponent) {\n        const factoryGroup = this.resolver.resolveComponentFactory(IgxColumnGroupComponent);\n        const ref = this.viewRef.createComponent(IgxColumnGroupComponent, { injector: this.viewRef.injector });\n        ref.changeDetectorRef.detectChanges();\n        factoryGroup.inputs.forEach((input) => {\n            const propName = input.propName;\n            ref.instance[propName] = col[propName];\n        });\n        if (col.children.length > 0) {\n            const newChildren = [];\n            col.children.forEach(child => {\n                const newCol = this._createColumn(child).instance;\n                newCol.parent = ref.instance;\n                newChildren.push(newCol);\n            });\n            ref.instance.children.reset(newChildren);\n            ref.instance.children.notifyOnChanges();\n        }\n        return ref;\n    }\n\n    protected _createColComponent(col) {\n        const factoryColumn = this.resolver.resolveComponentFactory(IgxColumnComponent);\n        const ref = this.viewRef.createComponent(IgxColumnComponent, { injector: this.viewRef.injector });\n        factoryColumn.inputs.forEach((input) => {\n            const propName = input.propName;\n            if (!(col[propName] instanceof IgxSummaryOperand)) {\n                ref.instance[propName] = col[propName];\n            } else {\n                ref.instance[propName] = col[propName].constructor;\n            }\n        });\n        return ref;\n    }\n\n    protected getGridsForIsland(rowIslandID: string) {\n        return this.gridAPI.getChildGridsForRowIsland(rowIslandID);\n    }\n\n    protected getChildGrid(path: Array<IPathSegment>) {\n        if (!path) {\n            return;\n        }\n        return this.gridAPI.getChildGrid(path);\n    }\n}\n\nconst flatten = (arr: any[]) => {\n    let result = [];\n\n    arr.forEach(el => {\n        result.push(el);\n        if (el.children) {\n            result = result.concat(flatten(el.children.toArray()));\n        }\n    });\n    return result;\n};\n"]}
|