UNPKG

igniteui-angular

Version:

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

283 lines • 26.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { GridBaseAPIService } from '../api.service'; import { DataUtil } from '../../data-operations/data-util'; import { cloneArray } from '../../core/utils'; var IgxGridAPIService = /** @class */ (function (_super) { tslib_1.__extends(IgxGridAPIService, _super); function IgxGridAPIService() { return _super !== null && _super.apply(this, arguments) || this; } /** * @param {?} expression * @return {?} */ IgxGridAPIService.prototype.groupBy = /** * @param {?} expression * @return {?} */ function (expression) { /** @type {?} */ var groupingState = cloneArray(this.grid.groupingExpressions); /** @type {?} */ var sortingState = cloneArray(this.grid.sortingExpressions); this.prepare_sorting_expression([sortingState, groupingState], expression); this.grid.groupingExpressions = groupingState; this.arrange_sorting_expressions(); }; /** * @param {?} expressions * @return {?} */ IgxGridAPIService.prototype.groupBy_multiple = /** * @param {?} expressions * @return {?} */ function (expressions) { var e_1, _a; /** @type {?} */ var groupingState = cloneArray(this.grid.groupingExpressions); /** @type {?} */ var sortingState = cloneArray(this.grid.sortingExpressions); try { for (var expressions_1 = tslib_1.__values(expressions), expressions_1_1 = expressions_1.next(); !expressions_1_1.done; expressions_1_1 = expressions_1.next()) { var each = expressions_1_1.value; this.prepare_sorting_expression([sortingState, groupingState], each); } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (expressions_1_1 && !expressions_1_1.done && (_a = expressions_1.return)) _a.call(expressions_1); } finally { if (e_1) throw e_1.error; } } this.grid.groupingExpressions = groupingState; this.arrange_sorting_expressions(); }; /** * @param {?=} name * @return {?} */ IgxGridAPIService.prototype.clear_groupby = /** * @param {?=} name * @return {?} */ function (name) { var _this = this; var e_2, _a; /** @type {?} */ var groupingState = cloneArray(this.grid.groupingExpressions); /** @type {?} */ var sortingState = cloneArray(this.grid.sortingExpressions); if (name) { /** @type {?} */ var names_1 = typeof name === 'string' ? [name] : name; /** @type {?} */ var groupedCols = groupingState.filter(function (state) { return names_1.indexOf(state.fieldName) < 0; }); /** @type {?} */ var newSortingExpr = sortingState.filter(function (state) { return names_1.indexOf(state.fieldName) < 0; }); this.grid.groupingExpressions = groupedCols; this.grid.sortingExpressions = newSortingExpr; names_1.forEach(function (colName) { /** @type {?} */ var grExprIndex = groupingState.findIndex(function (exp) { return exp.fieldName === colName; }); /** @type {?} */ var grpExpandState = _this.grid.groupingExpansionState; /* remove expansion states related to the cleared group and all with deeper hierarchy than the cleared group */ _this.grid.groupingExpansionState = grpExpandState .filter(function (val) { return val.hierarchy && val.hierarchy.length <= grExprIndex; }); }); } else { // clear all this.grid.groupingExpressions = []; this.grid.groupingExpansionState = []; var _loop_1 = function (grExpr) { /** @type {?} */ var sortExprIndex = sortingState.findIndex(function (exp) { return exp.fieldName === grExpr.fieldName; }); if (sortExprIndex > -1) { sortingState.splice(sortExprIndex, 1); } }; try { for (var groupingState_1 = tslib_1.__values(groupingState), groupingState_1_1 = groupingState_1.next(); !groupingState_1_1.done; groupingState_1_1 = groupingState_1.next()) { var grExpr = groupingState_1_1.value; _loop_1(grExpr); } } catch (e_2_1) { e_2 = { error: e_2_1 }; } finally { try { if (groupingState_1_1 && !groupingState_1_1.done && (_a = groupingState_1.return)) _a.call(groupingState_1); } finally { if (e_2) throw e_2.error; } } this.grid.sortingExpressions = sortingState; } }; /** * @param {?} groupRow * @return {?} */ IgxGridAPIService.prototype.groupBy_get_expanded_for_group = /** * @param {?} groupRow * @return {?} */ function (groupRow) { /** @type {?} */ var grState = this.grid.groupingExpansionState; /** @type {?} */ var hierarchy = DataUtil.getHierarchy(groupRow); return grState.find(function (state) { return DataUtil.isHierarchyMatch(state.hierarchy || [{ fieldName: groupRow.expression.fieldName, value: groupRow.value }], hierarchy); }); }; /** * @param {?} groupRow * @param {?} rowID * @return {?} */ IgxGridAPIService.prototype.groupBy_is_row_in_group = /** * @param {?} groupRow * @param {?} rowID * @return {?} */ function (groupRow, rowID) { /** @type {?} */ var grid = this.grid; /** @type {?} */ var rowInGroup = false; groupRow.records.forEach(function (row) { if (grid.primaryKey ? row[grid.primaryKey] === rowID : row === rowID) { rowInGroup = true; } }); return rowInGroup; }; /** * @param {?} groupRow * @return {?} */ IgxGridAPIService.prototype.groupBy_toggle_group = /** * @param {?} groupRow * @return {?} */ function (groupRow) { /** @type {?} */ var grid = this.grid; /** @type {?} */ var expansionState = grid.groupingExpansionState; /** @type {?} */ var toggleRowEditingOverlay; /** @type {?} */ var isEditRowInGroup = false; if (grid.rowEditable) { /** @type {?} */ var rowState = this.grid.crudService.row; // Toggle only row editing overlays that are inside current expanded/collapsed group. isEditRowInGroup = rowState ? this.groupBy_is_row_in_group(groupRow, rowState.id) : false; } /** @type {?} */ var state = this.groupBy_get_expanded_for_group(groupRow); if (state) { state.expanded = !state.expanded; if (isEditRowInGroup) { toggleRowEditingOverlay = state.expanded; } } else { expansionState.push({ expanded: !grid.groupsExpanded, hierarchy: DataUtil.getHierarchy(groupRow) }); if (isEditRowInGroup) { toggleRowEditingOverlay = false; } } this.grid.groupingExpansionState = expansionState; if (grid.rowEditable) { grid.repositionRowEditingOverlay(grid.rowInEditMode); } }; /** * @protected * @param {?} fieldName * @return {?} */ IgxGridAPIService.prototype.remove_grouping_expression = /** * @protected * @param {?} fieldName * @return {?} */ function (fieldName) { /** @type {?} */ var groupingExpressions = this.grid.groupingExpressions; /** @type {?} */ var index = groupingExpressions.findIndex(function (expr) { return expr.fieldName === fieldName; }); if (index !== -1) { groupingExpressions.splice(index, 1); } }; /** * @return {?} */ IgxGridAPIService.prototype.arrange_sorting_expressions = /** * @return {?} */ function () { /** @type {?} */ var groupingState = this.grid.groupingExpressions; this.grid.sortingExpressions.sort(function (a, b) { /** @type {?} */ var groupExprA = groupingState.find(function (expr) { return expr.fieldName === a.fieldName; }); /** @type {?} */ var groupExprB = groupingState.find(function (expr) { return expr.fieldName === b.fieldName; }); if (groupExprA && groupExprB) { return groupingState.indexOf(groupExprA) > groupingState.indexOf(groupExprB) ? 1 : -1; } else if (groupExprA) { return -1; } else if (groupExprB) { return 1; } else { return 0; } }); }; /** * @param {?} gRow * @return {?} */ IgxGridAPIService.prototype.get_groupBy_record_id = /** * @param {?} gRow * @return {?} */ function (gRow) { /** @type {?} */ var recordId = '{ '; /** @type {?} */ var hierrarchy = DataUtil.getHierarchy(gRow); for (var i = 0; i < hierrarchy.length; i++) { /** @type {?} */ var groupByKey = hierrarchy[i]; recordId += "'" + groupByKey.fieldName + "': '" + groupByKey.value + "'"; if (i < hierrarchy.length - 1) { recordId += ', '; } } recordId += ' }'; return recordId; }; return IgxGridAPIService; }(GridBaseAPIService)); export { IgxGridAPIService }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-api.service.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/grid/grid-api.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { GridBaseAPIService } from '../api.service';\nimport { IgxGridComponent } from './grid.component';\nimport { IGroupByRecord } from '../../data-operations/groupby-record.interface';\nimport { IGroupByExpandState } from '../../data-operations/groupby-expand-state.interface';\nimport { DataUtil } from '../../data-operations/data-util';\nimport { cloneArray } from '../../core/utils';\nimport { IGroupingExpression } from '../../data-operations/grouping-expression.interface';\n\nexport class IgxGridAPIService extends GridBaseAPIService<IgxGridComponent> {\n\n    public groupBy(expression: IGroupingExpression): void {\n        const groupingState = cloneArray(this.grid.groupingExpressions);\n        const sortingState = cloneArray(this.grid.sortingExpressions);\n        this.prepare_sorting_expression([sortingState, groupingState], expression);\n        this.grid.groupingExpressions = groupingState;\n        this.arrange_sorting_expressions();\n    }\n\n    public groupBy_multiple(expressions: IGroupingExpression[]): void {\n        const groupingState = cloneArray(this.grid.groupingExpressions);\n        const sortingState = cloneArray(this.grid.sortingExpressions);\n\n        for (const each of expressions) {\n            this.prepare_sorting_expression([sortingState, groupingState], each);\n        }\n\n        this.grid.groupingExpressions = groupingState;\n        this.arrange_sorting_expressions();\n    }\n\n    public clear_groupby(name?: string | Array<string>) {\n        const groupingState = cloneArray(this.grid.groupingExpressions);\n        const sortingState = cloneArray(this.grid.sortingExpressions);\n\n        if (name) {\n            const names = typeof name === 'string' ? [ name ] : name;\n            const groupedCols = groupingState.filter((state) => names.indexOf(state.fieldName) < 0);\n            const newSortingExpr = sortingState.filter((state) => names.indexOf(state.fieldName) < 0);\n            this.grid.groupingExpressions = groupedCols;\n            this.grid.sortingExpressions = newSortingExpr;\n            names.forEach((colName) => {\n                const grExprIndex = groupingState.findIndex((exp) => exp.fieldName === colName);\n                const grpExpandState = this.grid.groupingExpansionState;\n                /* remove expansion states related to the cleared group\n                and all with deeper hierarchy than the cleared group */\n                this.grid.groupingExpansionState = grpExpandState\n                    .filter((val) => {\n                        return val.hierarchy && val.hierarchy.length <= grExprIndex;\n                    });\n            });\n        } else {\n            // clear all\n            this.grid.groupingExpressions = [];\n            this.grid.groupingExpansionState = [];\n            for (const grExpr of groupingState) {\n                const sortExprIndex = sortingState.findIndex((exp) => exp.fieldName === grExpr.fieldName);\n                if (sortExprIndex > -1) {\n                    sortingState.splice(sortExprIndex, 1);\n                }\n            }\n            this.grid.sortingExpressions = sortingState;\n        }\n    }\n\n    public groupBy_get_expanded_for_group(groupRow: IGroupByRecord): IGroupByExpandState {\n        const grState = this.grid.groupingExpansionState;\n        const hierarchy = DataUtil.getHierarchy(groupRow);\n        return grState.find((state) =>\n            DataUtil.isHierarchyMatch(state.hierarchy || [{ fieldName: groupRow.expression.fieldName, value: groupRow.value }], hierarchy));\n    }\n\n    public groupBy_is_row_in_group(groupRow: IGroupByRecord, rowID): boolean {\n        const grid = this.grid;\n        let rowInGroup = false;\n        groupRow.records.forEach(row => {\n            if (grid.primaryKey ? row[grid.primaryKey] === rowID : row === rowID) {\n                rowInGroup = true;\n            }\n        });\n        return rowInGroup;\n    }\n\n    public groupBy_toggle_group(groupRow: IGroupByRecord) {\n        const grid = this.grid;\n        const expansionState = grid.groupingExpansionState;\n        let toggleRowEditingOverlay: boolean;\n        let isEditRowInGroup = false;\n        if (grid.rowEditable) {\n            const rowState = this.grid.crudService.row;\n\n            // Toggle only row editing overlays that are inside current expanded/collapsed group.\n            isEditRowInGroup = rowState ? this.groupBy_is_row_in_group(groupRow, rowState.id) : false;\n        }\n        const state: IGroupByExpandState = this.groupBy_get_expanded_for_group(groupRow);\n        if (state) {\n            state.expanded = !state.expanded;\n            if (isEditRowInGroup) {\n                toggleRowEditingOverlay = state.expanded;\n            }\n        } else {\n            expansionState.push({\n                expanded: !grid.groupsExpanded,\n                hierarchy: DataUtil.getHierarchy(groupRow)\n            });\n            if (isEditRowInGroup) {\n                toggleRowEditingOverlay = false;\n            }\n        }\n        this.grid.groupingExpansionState = expansionState;\n        if (grid.rowEditable) {\n            grid.repositionRowEditingOverlay(grid.rowInEditMode);\n        }\n    }\n\n    protected remove_grouping_expression(fieldName) {\n        const groupingExpressions = this.grid.groupingExpressions;\n        const index = groupingExpressions.findIndex((expr) => expr.fieldName === fieldName);\n        if (index !== -1) {\n            groupingExpressions.splice(index, 1);\n        }\n    }\n\n    public arrange_sorting_expressions() {\n        const groupingState = this.grid.groupingExpressions;\n        this.grid.sortingExpressions.sort((a, b) => {\n            const groupExprA = groupingState.find((expr) => expr.fieldName === a.fieldName);\n            const groupExprB = groupingState.find((expr) => expr.fieldName === b.fieldName);\n            if (groupExprA && groupExprB) {\n                return groupingState.indexOf(groupExprA) > groupingState.indexOf(groupExprB) ? 1 : -1;\n            } else if (groupExprA) {\n                return -1;\n            } else if (groupExprB) {\n                return 1;\n            } else {\n                return 0;\n            }\n        });\n    }\n\n    public get_groupBy_record_id(gRow: IGroupByRecord): string {\n        let recordId = '{ ';\n        const hierrarchy = DataUtil.getHierarchy(gRow);\n\n        for (let i = 0; i < hierrarchy.length; i++) {\n            const groupByKey = hierrarchy[i];\n            recordId += `'${groupByKey.fieldName}': '${groupByKey.value}'`;\n\n            if (i < hierrarchy.length - 1) {\n                recordId += ', ';\n            }\n        }\n        recordId += ' }';\n\n        return recordId;\n    }\n\n}\n"]}