igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
270 lines • 19.8 kB
JavaScript
/**
* @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"]}