UNPKG

@catull/igniteui-angular

Version:

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

241 lines 32.2 kB
import { __read, __spread, __values } from "tslib"; import { IgxSorting, IgxDataRecordSorting } from './sorting-strategy'; import { IgxGrouping } from './grouping-strategy'; import { PagingError } from './paging-state.interface'; import { FilteringStrategy } from './filtering-strategy'; import { cloneValue, mergeObjects } from '../core/utils'; import { TransactionType } from '../services/transaction/transaction'; import { getHierarchy, isHierarchyMatch } from './operations'; /** * @hidden */ export var DataType; (function (DataType) { DataType["String"] = "string"; DataType["Number"] = "number"; DataType["Boolean"] = "boolean"; DataType["Date"] = "date"; })(DataType || (DataType = {})); /** * @hidden */ var DataUtil = /** @class */ (function () { function DataUtil() { } DataUtil.sort = function (data, expressions, sorting) { if (sorting === void 0) { sorting = new IgxSorting(); } return sorting.sort(data, expressions); }; DataUtil.treeGridSort = function (hierarchicalData, expressions, sorting, parent) { if (sorting === void 0) { sorting = new IgxDataRecordSorting(); } var res = []; hierarchicalData.forEach(function (hr) { var rec = DataUtil.cloneTreeGridRecord(hr); rec.parent = parent; if (rec.children) { rec.children = DataUtil.treeGridSort(rec.children, expressions, sorting, rec); } res.push(rec); }); res = DataUtil.sort(res, expressions, sorting); return res; }; DataUtil.cloneTreeGridRecord = function (hierarchicalRecord) { var rec = { rowID: hierarchicalRecord.rowID, data: hierarchicalRecord.data, children: hierarchicalRecord.children, isFilteredOutParent: hierarchicalRecord.isFilteredOutParent, level: hierarchicalRecord.level, expanded: hierarchicalRecord.expanded }; return rec; }; DataUtil.group = function (data, state, grid, groupsRecords, fullResult) { if (grid === void 0) { grid = null; } if (groupsRecords === void 0) { groupsRecords = []; } if (fullResult === void 0) { fullResult = { data: [], metadata: [] }; } var grouping = new IgxGrouping(); groupsRecords.splice(0, groupsRecords.length); return grouping.groupBy(data, state, grid, groupsRecords, fullResult); }; DataUtil.page = function (data, state) { if (!state) { return data; } var len = data.length; var index = state.index; var res = []; var recordsPerPage = state.recordsPerPage; state.metadata = { countPages: 0, countRecords: data.length, error: PagingError.None }; if (index < 0 || isNaN(index)) { state.metadata.error = PagingError.IncorrectPageIndex; return res; } if (recordsPerPage <= 0 || isNaN(recordsPerPage)) { state.metadata.error = PagingError.IncorrectRecordsPerPage; return res; } state.metadata.countPages = Math.ceil(len / recordsPerPage); if (!len) { return data; } if (index >= state.metadata.countPages) { state.metadata.error = PagingError.IncorrectPageIndex; return res; } return data.slice(index * recordsPerPage, (index + 1) * recordsPerPage); }; DataUtil.filter = function (data, state) { if (!state.strategy) { state.strategy = new FilteringStrategy(); } return state.strategy.filter(data, state.expressionsTree, state.advancedExpressionsTree); }; DataUtil.correctPagingState = function (state, length) { var maxPage = Math.ceil(length / state.recordsPerPage) - 1; if (!isNaN(maxPage) && state.index > maxPage) { state.index = maxPage; } }; DataUtil.getHierarchy = function (gRow) { return getHierarchy(gRow); }; DataUtil.isHierarchyMatch = function (h1, h2) { return isHierarchyMatch(h1, h2); }; /** * Merges all changes from provided transactions into provided data collection * @param data Collection to merge * @param transactions Transactions to merge into data * @param primaryKey Primary key of the collection, if any * @param deleteRows Should delete rows with DELETE transaction type from data * @returns Provided data collections updated with all provided transactions */ DataUtil.mergeTransactions = function (data, transactions, primaryKey, deleteRows) { if (deleteRows === void 0) { deleteRows = false; } data.forEach(function (item, index) { var rowId = primaryKey ? item[primaryKey] : item; var transaction = transactions.find(function (t) { return t.id === rowId; }); if (transaction && transaction.type === TransactionType.UPDATE) { data[index] = transaction.newValue; } }); if (deleteRows) { transactions .filter(function (t) { return t.type === TransactionType.DELETE; }) .forEach(function (t) { var index = primaryKey ? data.findIndex(function (d) { return d[primaryKey] === t.id; }) : data.findIndex(function (d) { return d === t.id; }); if (0 <= index && index < data.length) { data.splice(index, 1); } }); } data.push.apply(data, __spread(transactions .filter(function (t) { return t.type === TransactionType.ADD; }) .map(function (t) { return t.newValue; }))); return data; }; /** * Merges all changes from provided transactions into provided hierarchical data collection * @param data Collection to merge * @param transactions Transactions to merge into data * @param childDataKey Data key of child collections * @param primaryKey Primary key of the collection, if any * @param deleteRows Should delete rows with DELETE transaction type from data * @returns Provided data collections updated with all provided transactions */ DataUtil.mergeHierarchicalTransactions = function (data, transactions, childDataKey, primaryKey, deleteRows) { var e_1, _a; if (deleteRows === void 0) { deleteRows = false; } var _loop_1 = function (transaction) { if (transaction.path) { var parent_1 = this_1.findParentFromPath(data, primaryKey, childDataKey, transaction.path); var collection = parent_1 ? parent_1[childDataKey] : data; switch (transaction.type) { case TransactionType.ADD: // if there is no parent this is ADD row at root level if (parent_1 && !parent_1[childDataKey]) { parent_1[childDataKey] = collection = []; } collection.push(transaction.newValue); break; case TransactionType.UPDATE: var updateIndex = collection.findIndex(function (x) { return x[primaryKey] === transaction.id; }); if (updateIndex !== -1) { collection[updateIndex] = mergeObjects(cloneValue(collection[updateIndex]), transaction.newValue); } break; case TransactionType.DELETE: if (deleteRows) { var deleteIndex = collection.findIndex(function (r) { return r[primaryKey] === transaction.id; }); if (deleteIndex !== -1) { collection.splice(deleteIndex, 1); } } break; } } else { // if there is no path this is ADD row in root. Push the newValue to data data.push(transaction.newValue); } }; var this_1 = this; try { for (var transactions_1 = __values(transactions), transactions_1_1 = transactions_1.next(); !transactions_1_1.done; transactions_1_1 = transactions_1.next()) { var transaction = transactions_1_1.value; _loop_1(transaction); } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (transactions_1_1 && !transactions_1_1.done && (_a = transactions_1.return)) _a.call(transactions_1); } finally { if (e_1) throw e_1.error; } } return data; }; DataUtil.parseValue = function (dataType, value) { if (dataType === DataType.Number) { value = parseFloat(value); } return value; }; DataUtil.findParentFromPath = function (data, primaryKey, childDataKey, path) { var e_2, _a; var collection = data; var result; var _loop_2 = function (id) { result = collection && collection.find(function (x) { return x[primaryKey] === id; }); if (!result) { return "break"; } collection = result[childDataKey]; }; try { for (var path_1 = __values(path), path_1_1 = path_1.next(); !path_1_1.done; path_1_1 = path_1.next()) { var id = path_1_1.value; var state_1 = _loop_2(id); if (state_1 === "break") break; } } catch (e_2_1) { e_2 = { error: e_2_1 }; } finally { try { if (path_1_1 && !path_1_1.done && (_a = path_1.return)) _a.call(path_1); } finally { if (e_2) throw e_2.error; } } return result; }; return DataUtil; }()); export { DataUtil }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-util.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/data-operations/data-util.ts"],"names":[],"mappings":"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","sourcesContent":["import { IFilteringState } from './filtering-state.interface';\n\nimport { IgxSorting, IgxDataRecordSorting, IGridSortingStrategy } from './sorting-strategy';\nimport { IgxGrouping } from './grouping-strategy';\nimport { IGroupByResult } from './grouping-result.interface';\n\nimport { IPagingState, PagingError } from './paging-state.interface';\n\nimport { IGroupByKey } from './groupby-expand-state.interface';\nimport { IGroupByRecord } from './groupby-record.interface';\nimport { IGroupingState } from './groupby-state.interface';\nimport { ISortingExpression } from './sorting-expression.interface';\nimport { FilteringStrategy } from './filtering-strategy';\nimport { ITreeGridRecord } from '../grids/tree-grid';\nimport { cloneValue, mergeObjects } from '../core/utils';\nimport { Transaction, TransactionType, HierarchicalTransaction } from '../services/transaction/transaction';\nimport { getHierarchy, isHierarchyMatch } from './operations';\n\n/**\n * @hidden\n */\nexport enum DataType {\n    String = 'string',\n    Number = 'number',\n    Boolean = 'boolean',\n    Date = 'date'\n}\n\n/**\n * @hidden\n */\nexport class DataUtil {\n    public static sort<T>(data: T[], expressions: ISortingExpression[], sorting: IGridSortingStrategy = new IgxSorting()): T[] {\n        return sorting.sort(data, expressions);\n    }\n\n    public static treeGridSort(hierarchicalData: ITreeGridRecord[],\n        expressions: ISortingExpression[],\n        sorting: IGridSortingStrategy = new IgxDataRecordSorting(),\n        parent?: ITreeGridRecord): ITreeGridRecord[] {\n        let res: ITreeGridRecord[] = [];\n        hierarchicalData.forEach((hr: ITreeGridRecord) => {\n            const rec: ITreeGridRecord = DataUtil.cloneTreeGridRecord(hr);\n            rec.parent = parent;\n            if (rec.children) {\n                rec.children = DataUtil.treeGridSort(rec.children, expressions, sorting, rec);\n            }\n            res.push(rec);\n        });\n\n        res = DataUtil.sort(res, expressions, sorting);\n\n        return res;\n    }\n\n    public static cloneTreeGridRecord(hierarchicalRecord: ITreeGridRecord) {\n        const rec: ITreeGridRecord = {\n            rowID: hierarchicalRecord.rowID,\n            data: hierarchicalRecord.data,\n            children: hierarchicalRecord.children,\n            isFilteredOutParent: hierarchicalRecord.isFilteredOutParent,\n            level: hierarchicalRecord.level,\n            expanded: hierarchicalRecord.expanded\n        };\n        return rec;\n    }\n\n    public static group<T>(data: T[], state: IGroupingState, grid: any = null,\n        groupsRecords: any[] = [], fullResult: IGroupByResult = { data: [], metadata: [] }): IGroupByResult {\n        const grouping = new IgxGrouping();\n        groupsRecords.splice(0, groupsRecords.length);\n        return grouping.groupBy(data, state, grid, groupsRecords, fullResult);\n    }\n\n    public static page<T>(data: T[], state: IPagingState): T[] {\n        if (!state) {\n            return data;\n        }\n        const len = data.length;\n        const index = state.index;\n        const res = [];\n        const recordsPerPage = state.recordsPerPage;\n        state.metadata = {\n            countPages: 0,\n            countRecords: data.length,\n            error: PagingError.None\n        };\n        if (index < 0 || isNaN(index)) {\n            state.metadata.error = PagingError.IncorrectPageIndex;\n            return res;\n        }\n        if (recordsPerPage <= 0 || isNaN(recordsPerPage)) {\n            state.metadata.error = PagingError.IncorrectRecordsPerPage;\n            return res;\n        }\n        state.metadata.countPages = Math.ceil(len / recordsPerPage);\n        if (!len) {\n            return data;\n        }\n        if (index >= state.metadata.countPages) {\n            state.metadata.error = PagingError.IncorrectPageIndex;\n            return res;\n        }\n        return data.slice(index * recordsPerPage, (index + 1) * recordsPerPage);\n    }\n\n    public static filter<T>(data: T[], state: IFilteringState): T[] {\n        if (!state.strategy) {\n            state.strategy = new FilteringStrategy();\n        }\n        return state.strategy.filter(data, state.expressionsTree, state.advancedExpressionsTree);\n    }\n\n    public static correctPagingState(state: IPagingState, length: number) {\n        const maxPage = Math.ceil(length / state.recordsPerPage) - 1;\n        if (!isNaN(maxPage) && state.index > maxPage) {\n            state.index = maxPage;\n        }\n    }\n\n    public static getHierarchy(gRow: IGroupByRecord): Array<IGroupByKey> {\n        return getHierarchy(gRow);\n    }\n\n    public static isHierarchyMatch(h1: Array<IGroupByKey>, h2: Array<IGroupByKey>): boolean {\n        return isHierarchyMatch(h1, h2);\n    }\n\n    /**\n     * Merges all changes from provided transactions into provided data collection\n     * @param data Collection to merge\n     * @param transactions Transactions to merge into data\n     * @param primaryKey Primary key of the collection, if any\n     * @param deleteRows Should delete rows with DELETE transaction type from data\n     * @returns Provided data collections updated with all provided transactions\n     */\n    public static mergeTransactions<T>(data: T[], transactions: Transaction[], primaryKey?: any, deleteRows: boolean = false): T[] {\n        data.forEach((item: any, index: number) => {\n            const rowId = primaryKey ? item[primaryKey] : item;\n            const transaction = transactions.find(t => t.id === rowId);\n            if (transaction && transaction.type === TransactionType.UPDATE) {\n                data[index] = transaction.newValue;\n            }\n        });\n\n        if (deleteRows) {\n            transactions\n                .filter(t => t.type === TransactionType.DELETE)\n                .forEach(t => {\n                    const index = primaryKey ? data.findIndex(d => d[primaryKey] === t.id) : data.findIndex(d => d === t.id);\n                    if (0 <= index && index < data.length) {\n                        data.splice(index, 1);\n                    }\n                });\n        }\n\n        data.push(...transactions\n            .filter(t => t.type === TransactionType.ADD)\n            .map(t => t.newValue));\n\n        return data;\n    }\n\n    /**\n     * Merges all changes from provided transactions into provided hierarchical data collection\n     * @param data Collection to merge\n     * @param transactions Transactions to merge into data\n     * @param childDataKey Data key of child collections\n     * @param primaryKey Primary key of the collection, if any\n     * @param deleteRows Should delete rows with DELETE transaction type from data\n     * @returns Provided data collections updated with all provided transactions\n     */\n    public static mergeHierarchicalTransactions(\n        data: any[],\n        transactions: HierarchicalTransaction[],\n        childDataKey: any,\n        primaryKey?: any,\n        deleteRows: boolean = false): any[] {\n        for (const transaction of transactions) {\n            if (transaction.path) {\n                const parent = this.findParentFromPath(data, primaryKey, childDataKey, transaction.path);\n                let collection: any[] = parent ? parent[childDataKey] : data;\n                switch (transaction.type) {\n                    case TransactionType.ADD:\n                        //  if there is no parent this is ADD row at root level\n                        if (parent && !parent[childDataKey]) {\n                            parent[childDataKey] = collection = [];\n                        }\n                        collection.push(transaction.newValue);\n                        break;\n                    case TransactionType.UPDATE:\n                        const updateIndex = collection.findIndex(x => x[primaryKey] === transaction.id);\n                        if (updateIndex !== -1) {\n                            collection[updateIndex] = mergeObjects(cloneValue(collection[updateIndex]), transaction.newValue);\n                        }\n                        break;\n                    case TransactionType.DELETE:\n                        if (deleteRows) {\n                            const deleteIndex = collection.findIndex(r => r[primaryKey] === transaction.id);\n                            if (deleteIndex !== -1) {\n                                collection.splice(deleteIndex, 1);\n                            }\n                        }\n                        break;\n                }\n            } else {\n                //  if there is no path this is ADD row in root. Push the newValue to data\n                data.push(transaction.newValue);\n            }\n        }\n        return data;\n    }\n\n    public static parseValue(dataType: DataType, value: any): any {\n        if (dataType === DataType.Number) {\n            value = parseFloat(value);\n        }\n\n        return value;\n    }\n\n    private static findParentFromPath(data: any[], primaryKey: any, childDataKey: any, path: any[]): any {\n        let collection: any[] = data;\n        let result: any;\n\n        for (const id of path) {\n            result = collection && collection.find(x => x[primaryKey] === id);\n            if (!result) {\n                break;\n            }\n\n            collection = result[childDataKey];\n        }\n\n        return result;\n    }\n}\n"]}