UNPKG

igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

270 lines • 19.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Pipe } from '@angular/core'; import { cloneArray } from '../../core/utils'; import { DataUtil } from '../../data-operations/data-util'; import { GridBaseAPIService } from '../api.service'; /** * @hidden */ export class IgxGridSortingPipe { /** * @param {?} gridAPI */ constructor(gridAPI) { this.gridAPI = (/** @type {?} */ (gridAPI)); } /** * @param {?} collection * @param {?} expressions * @param {?} id * @param {?} pipeTrigger * @return {?} */ transform(collection, expressions, id, pipeTrigger) { /** @type {?} */ const grid = this.gridAPI.grid; /** @type {?} */ let result; if (!expressions.length) { result = collection; } else { result = DataUtil.sort(cloneArray(collection), expressions); } grid.filteredSortedData = result; return result; } } IgxGridSortingPipe.decorators = [ { type: Pipe, args: [{ name: 'gridSort', pure: true },] } ]; /** @nocollapse */ IgxGridSortingPipe.ctorParameters = () => [ { type: GridBaseAPIService } ]; if (false) { /** * @type {?} * @private */ IgxGridSortingPipe.prototype.gridAPI; } /** * @hidden */ export class IgxGridPreGroupingPipe { /** * @param {?} gridAPI */ constructor(gridAPI) { this.gridAPI = (/** @type {?} */ (gridAPI)); } /** * @param {?} collection * @param {?} expression * @param {?} expansion * @param {?} defaultExpanded * @param {?} id * @param {?} groupsRecords * @param {?} pipeTrigger * @return {?} */ transform(collection, expression, expansion, defaultExpanded, id, groupsRecords, pipeTrigger) { /** @type {?} */ const state = { expressions: [], expansion: [], defaultExpanded }; /** @type {?} */ const grid = this.gridAPI.grid; state.expressions = grid.groupingExpressions; if (!state.expressions.length) { // empty the array without changing reference groupsRecords.splice(0, groupsRecords.length); return { data: collection, metadata: collection }; } state.expansion = grid.groupingExpansionState; state.defaultExpanded = grid.groupsExpanded; return DataUtil.group(cloneArray(collection), state, groupsRecords); } } IgxGridPreGroupingPipe.decorators = [ { type: Pipe, args: [{ name: 'gridPreGroupBy', pure: true },] } ]; /** @nocollapse */ IgxGridPreGroupingPipe.ctorParameters = () => [ { type: GridBaseAPIService } ]; if (false) { /** * @type {?} * @private */ IgxGridPreGroupingPipe.prototype.gridAPI; } /** * @hidden */ export class IgxGridPostGroupingPipe { /** * @param {?} gridAPI */ constructor(gridAPI) { this.gridAPI = (/** @type {?} */ (gridAPI)); } /** * @param {?} collection * @param {?} expression * @param {?} expansion * @param {?} defaultExpanded * @param {?} id * @param {?} pipeTrigger * @return {?} */ transform(collection, expression, expansion, defaultExpanded, id, pipeTrigger) { /** @type {?} */ const state = { expressions: [], expansion: [], defaultExpanded }; /** @type {?} */ const grid = this.gridAPI.grid; state.expressions = grid.groupingExpressions; if (!state.expressions.length) { return collection.data; } state.expansion = grid.groupingExpansionState; state.defaultExpanded = grid.groupsExpanded; return DataUtil.restoreGroups({ data: cloneArray(collection.data), metadata: cloneArray(collection.metadata) }, state); } } IgxGridPostGroupingPipe.decorators = [ { type: Pipe, args: [{ name: 'gridPostGroupBy', pure: true },] } ]; /** @nocollapse */ IgxGridPostGroupingPipe.ctorParameters = () => [ { type: GridBaseAPIService } ]; if (false) { /** * @type {?} * @private */ IgxGridPostGroupingPipe.prototype.gridAPI; } /** * @hidden */ export class IgxGridPagingPipe { /** * @param {?} gridAPI */ constructor(gridAPI) { this.gridAPI = gridAPI; } /** * @param {?} collection * @param {?=} page * @param {?=} perPage * @param {?=} id * @param {?=} pipeTrigger * @return {?} */ transform(collection, page = 0, perPage = 15, id, pipeTrigger) { if (!this.gridAPI.grid.paging) { return collection; } /** @type {?} */ const state = { index: page, recordsPerPage: perPage }; /** @type {?} */ const result = { data: DataUtil.page(cloneArray(collection.data), state), metadata: DataUtil.page(cloneArray(collection.metadata), state) }; this.gridAPI.grid.pagingState = state; return result; } } IgxGridPagingPipe.decorators = [ { type: Pipe, args: [{ name: 'gridPaging', pure: true },] } ]; /** @nocollapse */ IgxGridPagingPipe.ctorParameters = () => [ { type: GridBaseAPIService } ]; if (false) { /** * @type {?} * @private */ IgxGridPagingPipe.prototype.gridAPI; } /** * @hidden */ export class IgxGridFilteringPipe { /** * @param {?} gridAPI */ constructor(gridAPI) { this.gridAPI = gridAPI; } /** * @param {?} collection * @param {?} expressionsTree * @param {?} id * @param {?} pipeTrigger * @return {?} */ transform(collection, expressionsTree, id, pipeTrigger) { /** @type {?} */ const grid = this.gridAPI.grid; /** @type {?} */ const state = { expressionsTree: expressionsTree }; if (!state.expressionsTree || !state.expressionsTree.filteringOperands || state.expressionsTree.filteringOperands.length === 0) { return collection; } /** @type {?} */ const result = DataUtil.filter(cloneArray(collection), state); grid.filteredData = result; return result; } } IgxGridFilteringPipe.decorators = [ { type: Pipe, args: [{ name: 'gridFiltering', pure: true },] } ]; /** @nocollapse */ IgxGridFilteringPipe.ctorParameters = () => [ { type: GridBaseAPIService } ]; if (false) { /** * @type {?} * @private */ IgxGridFilteringPipe.prototype.gridAPI; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid.pipes.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/grid/grid.pipes.ts"],"names":[],"mappings":"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","sourcesContent":["import { Pipe, PipeTransform } from '@angular/core';\nimport { cloneArray } from '../../core/utils';\nimport { DataUtil } from '../../data-operations/data-util';\nimport { IGroupByExpandState } from '../../data-operations/groupby-expand-state.interface';\nimport { IGroupByResult } from '../../data-operations/grouping-strategy';\nimport { IFilteringExpressionsTree } from '../../data-operations/filtering-expressions-tree';\nimport { ISortingExpression } from '../../data-operations/sorting-expression.interface';\nimport { IgxGridAPIService } from './grid-api.service';\nimport { IgxGridComponent } from './grid.component';\nimport { IGroupingExpression } from '../../data-operations/grouping-expression.interface';\nimport { GridBaseAPIService } from '../api.service';\nimport { IgxGridBaseComponent, IGridDataBindable } from '../grid-base.component';\n\n/**\n *@hidden\n */\n@Pipe({\n    name: 'gridSort',\n    pure: true\n})\nexport class IgxGridSortingPipe implements PipeTransform {\n    private gridAPI: IgxGridAPIService;\n\n    constructor(gridAPI: GridBaseAPIService<IgxGridBaseComponent & IGridDataBindable>) {\n        this.gridAPI = <IgxGridAPIService>gridAPI;\n    }\n\n    public transform(collection: any[], expressions: ISortingExpression[], id: string, pipeTrigger: number): any[] {\n        const grid = this.gridAPI.grid;\n        let result: any[];\n\n        if (!expressions.length) {\n            result = collection;\n        } else {\n            result = DataUtil.sort(cloneArray(collection), expressions);\n        }\n        grid.filteredSortedData = result;\n\n        return result;\n    }\n}\n\n/**\n *@hidden\n */\n@Pipe({\n    name: 'gridPreGroupBy',\n    pure: true\n})\nexport class IgxGridPreGroupingPipe implements PipeTransform {\n    private gridAPI: IgxGridAPIService;\n\n    constructor(gridAPI: GridBaseAPIService<IgxGridBaseComponent & IGridDataBindable>) {\n        this.gridAPI = <IgxGridAPIService>gridAPI;\n    }\n\n    public transform(collection: any[], expression: IGroupingExpression | IGroupingExpression[],\n        expansion: IGroupByExpandState | IGroupByExpandState[], defaultExpanded: boolean,\n        id: string, groupsRecords: any[], pipeTrigger: number): IGroupByResult {\n\n        const state = { expressions: [], expansion: [], defaultExpanded };\n        const grid: IgxGridComponent = this.gridAPI.grid;\n        state.expressions = grid.groupingExpressions;\n\n        if (!state.expressions.length) {\n            // empty the array without changing reference\n            groupsRecords.splice(0, groupsRecords.length);\n            return {\n                data: collection,\n                metadata: collection\n            };\n        }\n\n        state.expansion = grid.groupingExpansionState;\n        state.defaultExpanded = grid.groupsExpanded;\n\n        return DataUtil.group(cloneArray(collection), state, groupsRecords);\n    }\n}\n\n/**\n *@hidden\n */\n@Pipe({\n    name: 'gridPostGroupBy',\n    pure: true\n})\nexport class IgxGridPostGroupingPipe implements PipeTransform {\n    private gridAPI: IgxGridAPIService;\n\n    constructor(gridAPI: GridBaseAPIService<IgxGridBaseComponent & IGridDataBindable>) {\n        this.gridAPI = <IgxGridAPIService>gridAPI;\n    }\n\n    public transform(collection: IGroupByResult, expression: IGroupingExpression | IGroupingExpression[],\n        expansion: IGroupByExpandState | IGroupByExpandState[], defaultExpanded: boolean,\n        id: string, pipeTrigger: number): any[] {\n\n        const state = { expressions: [], expansion: [], defaultExpanded };\n        const grid: IgxGridComponent = this.gridAPI.grid;\n        state.expressions = grid.groupingExpressions;\n\n        if (!state.expressions.length) {\n            return collection.data;\n        }\n\n        state.expansion = grid.groupingExpansionState;\n        state.defaultExpanded = grid.groupsExpanded;\n\n        return DataUtil.restoreGroups({\n            data: cloneArray(collection.data),\n            metadata: cloneArray(collection.metadata)\n        }, state);\n    }\n}\n\n/**\n *@hidden\n */\n@Pipe({\n    name: 'gridPaging',\n    pure: true\n})\nexport class IgxGridPagingPipe implements PipeTransform {\n\n    constructor(private gridAPI: GridBaseAPIService<IgxGridBaseComponent & IGridDataBindable>) { }\n\n    public transform(collection: IGroupByResult, page = 0, perPage = 15, id: string, pipeTrigger: number): IGroupByResult {\n\n        if (!this.gridAPI.grid.paging) {\n            return collection;\n        }\n\n        const state = {\n            index: page,\n            recordsPerPage: perPage\n        };\n\n        const result: IGroupByResult = {\n            data: DataUtil.page(cloneArray(collection.data), state),\n            metadata: DataUtil.page(cloneArray(collection.metadata), state)\n        };\n        this.gridAPI.grid.pagingState = state;\n        return result;\n    }\n}\n\n/**\n *@hidden\n */\n@Pipe({\n    name: 'gridFiltering',\n    pure: true\n})\nexport class IgxGridFilteringPipe implements PipeTransform {\n\n    constructor(private gridAPI: GridBaseAPIService<IgxGridBaseComponent & IGridDataBindable>) { }\n\n    public transform(collection: any[], expressionsTree: IFilteringExpressionsTree,\n        id: string, pipeTrigger: number) {\n        const grid = this.gridAPI.grid;\n        const state = { expressionsTree: expressionsTree };\n\n        if (!state.expressionsTree ||\n            !state.expressionsTree.filteringOperands ||\n            state.expressionsTree.filteringOperands.length === 0) {\n            return collection;\n        }\n\n        const result = DataUtil.filter(cloneArray(collection), state);\n        grid.filteredData = result;\n        return result;\n    }\n}\n"]}