igniteui-angular 15.0.0-rc.1 → 15.0.1
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/core/i18n/grid-resources.mjs +3 -2
- package/esm2020/lib/core/utils.mjs +3 -2
- package/esm2020/lib/directives/for-of/for_of.directive.mjs +4 -2
- package/esm2020/lib/grids/grid/grid.component.mjs +6 -1
- package/esm2020/lib/grids/grid-base.directive.mjs +18 -1
- package/esm2020/lib/grids/hierarchical-grid/hierarchical-grid-navigation.service.mjs +3 -2
- package/esm2020/lib/grids/hierarchical-grid/hierarchical-grid.component.mjs +3 -3
- package/esm2020/lib/grids/pivot-grid/pivot-grid-aggregate.mjs +1 -1
- package/esm2020/lib/grids/pivot-grid/pivot-grid.interface.mjs +1 -1
- package/esm2020/lib/grids/pivot-grid/pivot-util.mjs +21 -2
- package/esm2020/lib/simple-combo/simple-combo.component.mjs +3 -3
- package/fesm2015/igniteui-angular.mjs +55 -9
- package/fesm2015/igniteui-angular.mjs.map +1 -1
- package/fesm2020/igniteui-angular.mjs +54 -9
- package/fesm2020/igniteui-angular.mjs.map +1 -1
- package/lib/core/i18n/grid-resources.d.ts +1 -0
- package/lib/grids/grid-base.directive.d.ts +9 -0
- package/lib/grids/pivot-grid/pivot-grid-aggregate.d.ts +1 -5
- package/lib/grids/pivot-grid/pivot-grid.interface.d.ts +7 -1
- package/lib/grids/pivot-grid/pivot-util.d.ts +2 -0
- package/package.json +2 -2
- package/schematics/tsconfig.tsbuildinfo +1 -1
- package/schematics/utils/dependency-handler.js +24 -8
|
@@ -12,4 +12,4 @@ export var PivotDimensionType;
|
|
|
12
12
|
PivotDimensionType[PivotDimensionType["Column"] = 1] = "Column";
|
|
13
13
|
PivotDimensionType[PivotDimensionType["Filter"] = 2] = "Filter";
|
|
14
14
|
})(PivotDimensionType || (PivotDimensionType = {}));
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pivot-grid.interface.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/pivot-grid/pivot-grid.interface.ts"],"names":[],"mappings":"AAMA;;EAEE;AACF,MAAM,CAAC,MAAM,kBAAkB,GAAG;IAC9B,YAAY,EAAE,cAAc,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,EAAE,OAAO;IACtF,qBAAqB,EAAE,GAAG,EAAE,wBAAwB,EAAE,GAAG;CAC5D,CAAC;AA+JF,mDAAmD;AACnD,MAAM,CAAN,IAAY,kBAIX;AAJD,WAAY,kBAAkB;IAC1B,yDAAG,CAAA;IACH,+DAAM,CAAA;IACN,+DAAM,CAAA;AACV,CAAC,EAJW,kBAAkB,KAAlB,kBAAkB,QAI7B","sourcesContent":["import { GridColumnDataType } from '../../data-operations/data-util';\nimport { IFilteringExpressionsTree } from '../../data-operations/filtering-expressions-tree';\nimport { SortingDirection } from '../../data-operations/sorting-strategy';\nimport { ColumnType } from '../common/grid.interface';\n\n\n/**\n* Default pivot keys used for data processing in the pivot pipes.\n*/\nexport const DEFAULT_PIVOT_KEYS = {\n    aggregations: 'aggregations', records: 'records', children: 'children', level: 'level',\n    rowDimensionSeparator: '_', columnDimensionSeparator: '-'\n};\n\n\n/**\n * Event emitted when dimension collection for rows, columns of filters is changed.\n */\nexport interface IDimensionsChange {\n    /** The new list of dimensions. */\n    dimensions: IPivotDimension[],\n    /** The dimension list type - Row, Column or Filter. */\n    dimensionCollectionType: PivotDimensionType\n}\n\n/**\n* Event emitted when values list is changed.\n*/\nexport interface IValuesChange {\n    /** The new list of values. */\n    values: IPivotValue[]\n}\n\n/**\n* Interface describing Pivot data processing for dimensions.\n* Should contain a process method and return records hierarchy based on the provided dimensions.\n*/\nexport interface IPivotDimensionStrategy {\n    process(collection: any,\n        dimensions: IPivotDimension[],\n        values: IPivotValue[],\n        pivotKeys?: IPivotKeys): any[];\n}\n\n/**\n* Interface describing a PivotAggregation function. \n* Accepts an array of extracted data members and a array of the original data records.\n*/\nexport type PivotAggregation = (members: any[], data: any[]) => any;\n\n/**\n* Interface describing a IPivotAggregator class.\n* Used for specifying custom aggregator lists.\n*/\nexport interface IPivotAggregator {\n    /** Aggregation unique key. */\n    key: string;\n    /** Aggregation label to show in the UI. */\n    label: string;\n    /**\n     * Aggregator function can be a custom implementation of `PivotAggregation`, or \n     * use predefined ones from `IgxPivotAggregate` and its variants.\n     */\n    aggregator: (members: any[], data?: any[]) => any;\n}\n\n/**\n* Configuration of the pivot grid.\n*/\nexport interface IPivotConfiguration {\n    /** A strategy to transform the rows. */\n    rowStrategy?: IPivotDimensionStrategy | null;\n    /** A strategy to transform the columns. */\n    columnStrategy?: IPivotDimensionStrategy | null;\n    /** A list of the rows. */\n    rows: IPivotDimension[] | null;\n    /** A list of the columns. */\n    columns: IPivotDimension[] | null;\n    /** A list of the values. */\n    values: IPivotValue[] | null;\n    /** Dimensions to be displayed in the filter area. */\n    filters?: IPivotDimension[] | null;\n    /** Pivot data keys used for data generation. Can be used for custom remote scenarios where the data is pre-populated. */\n    pivotKeys?: IPivotKeys;\n}\n\n/**\n* Configuration of a pivot dimension.\n*/\nexport interface IPivotDimension {\n    /** Allows defining a hierarchy when multiple sub groups need to be extracted from single member. */\n    childLevel?: IPivotDimension;\n    /** Field name to use in order to extract value. */\n    memberName: string;\n    /** Function that extracts the value */\n    memberFunction?: (data: any) => any;\n    /** Enables/Disables a particular dimension from pivot structure. */\n    enabled: boolean;\n    /**\n     * A predefined or defined via the `igxPivotSelector` filter expression tree for the current dimension to be applied in the filter pipe.\n     * */\n    filter?: IFilteringExpressionsTree | null;\n    /**\n     * The sorting direction of the current dimension. Determines the order in which the values will appear in the related dimension.\n     */\n    sortDirection?: SortingDirection;\n    /**\n     * The dataType of the related data field.\n     */\n    dataType?: GridColumnDataType;\n    /** The width of the dimension cells to be rendered.Can be pixel or %. */\n    width?: string;\n    /** Level of the dimension. */\n    level?: number;\n}\n/**\n* Configuration of a pivot value aggregation.\n*/\nexport interface IPivotValue {\n    /** Field name to use in order to extract value. */\n    member: string;\n    /** Display name to show instead of member for the column header of this value. **/\n    displayName?: string;\n    /**\n     * Active aggregator definition with key, label and aggregator.\n     */\n    aggregate: IPivotAggregator;\n    /**\n     * List of aggregates to show in aggregate drop-down.\n     */\n    aggregateList?: IPivotAggregator[];\n    /** Enables/Disables a particular value from pivot aggregation. */\n    enabled: boolean;\n    /**  Allow conditionally styling of the IgxPivotGrid cells. */\n    styles?: any;\n    /** Enables a data type specific template of the cells */\n    dataType?: GridColumnDataType;\n    /** Applies display format to cell values. */\n    formatter?: (value: any, rowData?: IPivotGridRecord, columnData?: IPivotGridColumn) => any;\n}\n\n/** Interface describing the Pivot column data.\n*  Contains information on the related column dimensions and their values.\n*/\nexport interface IPivotGridColumn {\n        field: string,\n        /** Gets/Sets the group value associated with the related column dimension by its memberName. **/\n        dimensionValues: Map<string, string>;\n        /** List of dimensions associated with the column.**/\n        dimensions: IPivotDimension[];\n        value: IPivotValue\n}\n\n/** Interface describing the Pivot data keys used for data generation.\n*  Can be used for custom remote scenarios where the data is pre-populated.\n*/\nexport interface IPivotKeys {\n    /** Field that stores children for hierarchy building. */\n    children: string;\n    /** Field that stores reference to the original data records. */\n    records: string;\n    /** Field that stores aggregation values. */\n    aggregations: string;\n    /** Field that stores dimension level based on its hierarchy. */\n    level: string;\n    /** Separator used when generating the unique column field values. */\n    columnDimensionSeparator: string;\n    /** Separator used when generating the unique row field values. */\n    rowDimensionSeparator: string;\n}\n\n/** The dimension types - Row, Column or Filter. */\nexport enum PivotDimensionType {\n    Row,\n    Column,\n    Filter\n}\n\n/** Interface describing the pivot dimension data.\n* Contains additional information needed to render dimension headers.\n*/\nexport interface IPivotDimensionData {\n    /** Associated column definition. */\n    column: ColumnType;\n    /** Associated dimension definition. */\n    dimension: IPivotDimension;\n    /** List of previous dimension groups. */\n    prevDimensions: IPivotDimension[];\n    /** Whether this a child dimension. */\n    isChild?: boolean;\n}\n\nexport interface PivotRowHeaderGroupType {\n    rowIndex: number;\n    parent: any;\n    header: any;\n    headerID: string;\n    grid: any;\n}\n\nexport interface IPivotGridRecord {\n    /** Gets/Sets the group value associated with the related row dimension by its memberName. **/\n    dimensionValues: Map<string, string>;\n    /** Gets/Sets the aggregation value associated with the value path. Value path depends on configured column dimension hierarchy and values.**/\n    aggregationValues: Map<string, any>;\n    /** List of children records in case any row dimension member contain a hierarchy. Each dimension member contains its own hierarchy, which you can get by its memberName. **/\n    children?: Map<string, IPivotGridRecord[]>;\n    /** List of original data records associated with the current pivoted data. **/\n    records?: any[];\n     /** Record level**/\n    level?: number;\n    /** List of dimensions associated with the record.**/\n    dimensions: IPivotDimension[];\n}\n\nexport interface IPivotGridGroupRecord extends IPivotGridRecord {\n    height?: number;\n    rowSpan?: number;\n}\n\nexport interface IgxPivotGridValueTemplateContext {\n    $implicit: IPivotValue;\n}\n"]}
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pivot-grid.interface.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/pivot-grid/pivot-grid.interface.ts"],"names":[],"mappings":"AAMA;;EAEE;AACF,MAAM,CAAC,MAAM,kBAAkB,GAAG;IAC9B,YAAY,EAAE,cAAc,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,EAAE,OAAO;IACtF,qBAAqB,EAAE,GAAG,EAAE,wBAAwB,EAAE,GAAG;CAC5D,CAAC;AAoKF,mDAAmD;AACnD,MAAM,CAAN,IAAY,kBAIX;AAJD,WAAY,kBAAkB;IAC1B,yDAAG,CAAA;IACH,+DAAM,CAAA;IACN,+DAAM,CAAA;AACV,CAAC,EAJW,kBAAkB,KAAlB,kBAAkB,QAI7B","sourcesContent":["import { GridColumnDataType } from '../../data-operations/data-util';\nimport { IFilteringExpressionsTree } from '../../data-operations/filtering-expressions-tree';\nimport { SortingDirection } from '../../data-operations/sorting-strategy';\nimport { ColumnType } from '../common/grid.interface';\n\n\n/**\n* Default pivot keys used for data processing in the pivot pipes.\n*/\nexport const DEFAULT_PIVOT_KEYS = {\n    aggregations: 'aggregations', records: 'records', children: 'children', level: 'level',\n    rowDimensionSeparator: '_', columnDimensionSeparator: '-'\n};\n\n\n/**\n * Event emitted when dimension collection for rows, columns of filters is changed.\n */\nexport interface IDimensionsChange {\n    /** The new list of dimensions. */\n    dimensions: IPivotDimension[],\n    /** The dimension list type - Row, Column or Filter. */\n    dimensionCollectionType: PivotDimensionType\n}\n\n/**\n* Event emitted when values list is changed.\n*/\nexport interface IValuesChange {\n    /** The new list of values. */\n    values: IPivotValue[]\n}\n\n/**\n* Interface describing Pivot data processing for dimensions.\n* Should contain a process method and return records hierarchy based on the provided dimensions.\n*/\nexport interface IPivotDimensionStrategy {\n    process(collection: any,\n        dimensions: IPivotDimension[],\n        values: IPivotValue[],\n        pivotKeys?: IPivotKeys): any[];\n}\n\n/**\n* Interface describing a PivotAggregation function. \n* Accepts an array of extracted data members and a array of the original data records.\n*/\nexport type PivotAggregation = (members: any[], data: any[]) => any;\n\n/**\n* Interface describing a IPivotAggregator class.\n* Used for specifying custom aggregator lists.\n*/\nexport interface IPivotAggregator {\n    /** Aggregation unique key. */\n    key: string;\n    /** Aggregation label to show in the UI. */\n    label: string;\n    /**\n     * Aggregation name that will be used from a list of predefined aggregations.\n     * If not set will use the specified aggregator function.\n     */\n    aggregatorName?: PivotAggregationType;\n    /**\n     * Aggregator function can be a custom implementation of `PivotAggregation`, or \n     * use predefined ones from `IgxPivotAggregate` and its variants.\n     */\n    aggregator?: (members: any[], data?: any[]) => any;\n}\n\n/**\n* Configuration of the pivot grid.\n*/\nexport interface IPivotConfiguration {\n    /** A strategy to transform the rows. */\n    rowStrategy?: IPivotDimensionStrategy | null;\n    /** A strategy to transform the columns. */\n    columnStrategy?: IPivotDimensionStrategy | null;\n    /** A list of the rows. */\n    rows: IPivotDimension[] | null;\n    /** A list of the columns. */\n    columns: IPivotDimension[] | null;\n    /** A list of the values. */\n    values: IPivotValue[] | null;\n    /** Dimensions to be displayed in the filter area. */\n    filters?: IPivotDimension[] | null;\n    /** Pivot data keys used for data generation. Can be used for custom remote scenarios where the data is pre-populated. */\n    pivotKeys?: IPivotKeys;\n}\n\n/**\n* Configuration of a pivot dimension.\n*/\nexport interface IPivotDimension {\n    /** Allows defining a hierarchy when multiple sub groups need to be extracted from single member. */\n    childLevel?: IPivotDimension;\n    /** Field name to use in order to extract value. */\n    memberName: string;\n    /** Function that extracts the value */\n    memberFunction?: (data: any) => any;\n    /** Enables/Disables a particular dimension from pivot structure. */\n    enabled: boolean;\n    /**\n     * A predefined or defined via the `igxPivotSelector` filter expression tree for the current dimension to be applied in the filter pipe.\n     * */\n    filter?: IFilteringExpressionsTree | null;\n    /**\n     * The sorting direction of the current dimension. Determines the order in which the values will appear in the related dimension.\n     */\n    sortDirection?: SortingDirection;\n    /**\n     * The dataType of the related data field.\n     */\n    dataType?: GridColumnDataType;\n    /** The width of the dimension cells to be rendered.Can be pixel or %. */\n    width?: string;\n    /** Level of the dimension. */\n    level?: number;\n}\n/**\n* Configuration of a pivot value aggregation.\n*/\nexport interface IPivotValue {\n    /** Field name to use in order to extract value. */\n    member: string;\n    /** Display name to show instead of member for the column header of this value. **/\n    displayName?: string;\n    /**\n     * Active aggregator definition with key, label and aggregator.\n     */\n    aggregate: IPivotAggregator;\n    /**\n     * List of aggregates to show in aggregate drop-down.\n     */\n    aggregateList?: IPivotAggregator[];\n    /** Enables/Disables a particular value from pivot aggregation. */\n    enabled: boolean;\n    /**  Allow conditionally styling of the IgxPivotGrid cells. */\n    styles?: any;\n    /** Enables a data type specific template of the cells */\n    dataType?: GridColumnDataType;\n    /** Applies display format to cell values. */\n    formatter?: (value: any, rowData?: IPivotGridRecord, columnData?: IPivotGridColumn) => any;\n}\n\n/** Interface describing the Pivot column data.\n*  Contains information on the related column dimensions and their values.\n*/\nexport interface IPivotGridColumn {\n        field: string,\n        /** Gets/Sets the group value associated with the related column dimension by its memberName. **/\n        dimensionValues: Map<string, string>;\n        /** List of dimensions associated with the column.**/\n        dimensions: IPivotDimension[];\n        value: IPivotValue\n}\n\n/** Interface describing the Pivot data keys used for data generation.\n*  Can be used for custom remote scenarios where the data is pre-populated.\n*/\nexport interface IPivotKeys {\n    /** Field that stores children for hierarchy building. */\n    children: string;\n    /** Field that stores reference to the original data records. */\n    records: string;\n    /** Field that stores aggregation values. */\n    aggregations: string;\n    /** Field that stores dimension level based on its hierarchy. */\n    level: string;\n    /** Separator used when generating the unique column field values. */\n    columnDimensionSeparator: string;\n    /** Separator used when generating the unique row field values. */\n    rowDimensionSeparator: string;\n}\n\n/** The dimension types - Row, Column or Filter. */\nexport enum PivotDimensionType {\n    Row,\n    Column,\n    Filter\n}\n\nexport type PivotAggregationType = 'SUM' | 'AVG' | 'MIN' | 'MAX' | 'COUNT' | 'LATEST' | 'EARLIEST' ;\n\n/** Interface describing the pivot dimension data.\n* Contains additional information needed to render dimension headers.\n*/\nexport interface IPivotDimensionData {\n    /** Associated column definition. */\n    column: ColumnType;\n    /** Associated dimension definition. */\n    dimension: IPivotDimension;\n    /** List of previous dimension groups. */\n    prevDimensions: IPivotDimension[];\n    /** Whether this a child dimension. */\n    isChild?: boolean;\n}\n\nexport interface PivotRowHeaderGroupType {\n    rowIndex: number;\n    parent: any;\n    header: any;\n    headerID: string;\n    grid: any;\n}\n\nexport interface IPivotGridRecord {\n    /** Gets/Sets the group value associated with the related row dimension by its memberName. **/\n    dimensionValues: Map<string, string>;\n    /** Gets/Sets the aggregation value associated with the value path. Value path depends on configured column dimension hierarchy and values.**/\n    aggregationValues: Map<string, any>;\n    /** List of children records in case any row dimension member contain a hierarchy. Each dimension member contains its own hierarchy, which you can get by its memberName. **/\n    children?: Map<string, IPivotGridRecord[]>;\n    /** List of original data records associated with the current pivoted data. **/\n    records?: any[];\n     /** Record level**/\n    level?: number;\n    /** List of dimensions associated with the record.**/\n    dimensions: IPivotDimension[];\n}\n\nexport interface IPivotGridGroupRecord extends IPivotGridRecord {\n    height?: number;\n    rowSpan?: number;\n}\n\nexport interface IgxPivotGridValueTemplateContext {\n    $implicit: IPivotValue;\n}\n"]}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { CurrentResourceStrings } from '../../core/i18n/resources';
|
|
1
2
|
import { cloneValue } from '../../core/utils';
|
|
2
3
|
import { DataUtil, GridColumnDataType } from '../../data-operations/data-util';
|
|
3
4
|
import { FilteringLogic } from '../../data-operations/filtering-expression.interface';
|
|
@@ -212,10 +213,28 @@ export class PivotUtil {
|
|
|
212
213
|
static aggregate(records, values) {
|
|
213
214
|
const result = {};
|
|
214
215
|
for (const pivotValue of values) {
|
|
215
|
-
|
|
216
|
+
const aggregator = PivotUtil.getAggregatorForType(pivotValue.aggregate, pivotValue.dataType);
|
|
217
|
+
if (!aggregator) {
|
|
218
|
+
throw CurrentResourceStrings.GridResStrings.igx_grid_pivot_no_aggregator.replace("{0}", pivotValue.member);
|
|
219
|
+
}
|
|
220
|
+
result[pivotValue.member] = aggregator(records.map(r => r[pivotValue.member]), records);
|
|
216
221
|
}
|
|
217
222
|
return result;
|
|
218
223
|
}
|
|
224
|
+
static getAggregatorForType(aggregate, dataType) {
|
|
225
|
+
let aggregator = aggregate.aggregator;
|
|
226
|
+
if (aggregate.aggregatorName) {
|
|
227
|
+
let aggregators = IgxPivotNumericAggregate.aggregators();
|
|
228
|
+
if (!dataType || dataType === 'date' || dataType === 'dateTime') {
|
|
229
|
+
aggregators = aggregators.concat(IgxPivotDateAggregate.aggregators());
|
|
230
|
+
}
|
|
231
|
+
else if (dataType === 'time') {
|
|
232
|
+
aggregators = aggregators.concat(IgxPivotTimeAggregate.aggregators());
|
|
233
|
+
}
|
|
234
|
+
aggregator = aggregators.find(x => x.key === aggregate.aggregatorName)?.aggregator;
|
|
235
|
+
}
|
|
236
|
+
return aggregator;
|
|
237
|
+
}
|
|
219
238
|
static processHierarchy(hierarchies, pivotKeys, level = 0, rootData = false) {
|
|
220
239
|
const flatData = [];
|
|
221
240
|
hierarchies.forEach((h, key) => {
|
|
@@ -363,4 +382,4 @@ export class PivotUtil {
|
|
|
363
382
|
}
|
|
364
383
|
}
|
|
365
384
|
}
|
|
366
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pivot-util.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/pivot-grid/pivot-util.ts"],"names":[],"mappings":"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","sourcesContent":["import { cloneValue } from '../../core/utils';\nimport { DataUtil, GridColumnDataType } from '../../data-operations/data-util';\nimport { FilteringLogic } from '../../data-operations/filtering-expression.interface';\nimport { FilteringExpressionsTree } from '../../data-operations/filtering-expressions-tree';\nimport { ISortingExpression } from '../../data-operations/sorting-strategy';\nimport { PivotGridType } from '../common/grid.interface';\nimport { IGridSortingStrategy, IgxSorting } from '../common/strategy';\nimport { IgxPivotAggregate, IgxPivotDateAggregate, IgxPivotNumericAggregate, IgxPivotTimeAggregate } from './pivot-grid-aggregate';\nimport { IPivotAggregator, IPivotConfiguration, IPivotDimension, IPivotGridRecord, IPivotKeys, IPivotValue, PivotDimensionType } from './pivot-grid.interface';\n\nexport class PivotUtil {\n\n    // go through all children and apply new dimension groups as child\n    public static processGroups(recs: IPivotGridRecord[], dimension: IPivotDimension, pivotKeys: IPivotKeys) {\n        for (const rec of recs) {\n            // process existing children\n            if (rec.children && rec.children.size > 0) {\n                // process hierarchy in dept\n                rec.children.forEach((values, key) => {\n                    this.processGroups(values, dimension, pivotKeys);\n                });\n            }\n            // add children for current dimension\n            const hierarchyFields = PivotUtil\n                .getFieldsHierarchy(rec.records, [dimension], PivotDimensionType.Row, pivotKeys);\n            const values = Array.from(hierarchyFields.values()).find(x => x.dimension.memberName === dimension.memberName);\n            const siblingData = PivotUtil\n                .processHierarchy(hierarchyFields, pivotKeys, 0);\n            rec.children.set(dimension.memberName, siblingData);\n        }\n    }\n\n    public static flattenGroups(data: IPivotGridRecord[], dimension: IPivotDimension, expansionStates, defaultExpand: boolean, parent?: IPivotDimension, parentRec?: IPivotGridRecord) {\n        for (let i = 0; i < data.length; i++) {\n            const rec = data[i];\n            const field = dimension.memberName;\n            if (!field) {\n                continue;\n            }\n\n            let recordsData = rec.children.get(field);\n            if (!recordsData && parent) {\n                // check parent\n                recordsData = rec.children.get(parent.memberName);\n                if (recordsData) {\n                    dimension = parent;\n                }\n            }\n\n            if (parentRec) {\n                parentRec.dimensionValues.forEach((value, key) => {\n                    if (parent.memberName !== key) {\n                        rec.dimensionValues.set(key, value);\n                        const dim = parentRec.dimensions.find(x => x.memberName === key);\n                        rec.dimensions.unshift(dim);\n                    }\n\n                });\n            }\n\n\n            const expansionRowKey = PivotUtil.getRecordKey(rec, dimension);\n            const isExpanded = expansionStates.get(expansionRowKey) === undefined ?\n                defaultExpand :\n                expansionStates.get(expansionRowKey);\n            const shouldExpand = isExpanded || !dimension.childLevel || !rec.dimensionValues.get(dimension.memberName);\n            if (shouldExpand && recordsData) {\n                if (dimension.childLevel) {\n                    this.flattenGroups(recordsData, dimension.childLevel, expansionStates, defaultExpand, dimension, rec);\n                } else {\n                    // copy parent values and dims in child\n                    recordsData.forEach(x => {\n                        rec.dimensionValues.forEach((value, key) => {\n                            if (dimension.memberName !== key) {\n                                x.dimensionValues.set(key, value);\n                                const dim = rec.dimensions.find(y => y.memberName === key);\n                                x.dimensions.unshift(dim);\n                            }\n\n                        });\n                    });\n                }\n\n                data.splice(i + 1, 0, ...recordsData);\n                i += recordsData.length;\n\n            }\n        }\n    }\n    public static assignLevels(dims) {\n        for (const dim of dims) {\n            let currDim = dim;\n            let lvl = 0;\n            while (currDim.childLevel) {\n                currDim.level = lvl;\n                currDim = currDim.childLevel;\n                lvl++;\n            }\n            currDim.level = lvl;\n        }\n    }\n    public static getFieldsHierarchy(data: any[], dimensions: IPivotDimension[],\n        dimensionType: PivotDimensionType, pivotKeys: IPivotKeys): Map<string, any> {\n        const hierarchy = new Map<string, any>();\n        for (const rec of data) {\n            const vals = dimensionType === PivotDimensionType.Column ?\n                this.extractValuesForColumn(dimensions, rec, pivotKeys) :\n                this.extractValuesForRow(dimensions, rec, pivotKeys);\n            for (const [key, val] of vals) { // this should go in depth also vals.children\n                if (hierarchy.get(val.value) != null) {\n                    this.applyHierarchyChildren(hierarchy, val, rec, pivotKeys);\n                } else {\n                    hierarchy.set(val.value, cloneValue(val));\n                    this.applyHierarchyChildren(hierarchy, val, rec, pivotKeys);\n                }\n            }\n        }\n        return hierarchy;\n    }\n\n    public static sort(data: IPivotGridRecord[], expressions: ISortingExpression[], sorting: IGridSortingStrategy = new IgxSorting()): any[] {\n        data.forEach(rec => {\n            const children = rec.children;\n            if (children) {\n                children.forEach(x => {\n                    this.sort(x, expressions, sorting);\n                });\n            }\n        });\n        return DataUtil.sort(data, expressions, sorting);\n    }\n\n    public static extractValueFromDimension(dim: IPivotDimension, recData: any) {\n        return dim.memberFunction ? dim.memberFunction.call(null, recData) : recData[dim.memberName];\n    }\n\n    public static getDimensionDepth(dim: IPivotDimension): number {\n        let lvl = 0;\n        while (dim.childLevel) {\n            lvl++;\n            dim = dim.childLevel;\n        }\n        return lvl;\n    }\n\n    public static extractValuesForRow(dims: IPivotDimension[], recData: any, pivotKeys: IPivotKeys) {\n        const values = new Map<string, any>();\n        for (const col of dims) {\n            if (recData[pivotKeys.level] && recData[pivotKeys.level] > 0) {\n                const childData = recData[pivotKeys.records];\n                return this.getFieldsHierarchy(childData, [col], PivotDimensionType.Row, pivotKeys);\n            }\n\n            const value = this.extractValueFromDimension(col, recData);\n            const objValue = {};\n            objValue['value'] = value;\n            objValue['dimension'] = col;\n            if (col.childLevel) {\n                const childValues = this.extractValuesForRow([col.childLevel], recData, pivotKeys);\n                objValue[pivotKeys.children] = childValues;\n            }\n            values.set(value, objValue);\n        }\n\n        return values;\n    }\n\n    public static extractValuesForColumn(dims: IPivotDimension[], recData: any, pivotKeys: IPivotKeys, path = []) {\n        const vals = new Map<string, any>();\n        let lvlCollection = vals;\n        const flattenedDims = this.flatten(dims);\n        for (const col of flattenedDims) {\n            const value = this.extractValueFromDimension(col, recData);\n            path.push(value);\n            const newValue = path.join(pivotKeys.columnDimensionSeparator);\n            const newObj = { value: newValue, expandable: col.expandable, children: null, dimension: col };\n            if (!newObj.children) {\n                newObj.children = new Map<string, any>();\n            }\n            lvlCollection.set(newValue, newObj);\n            lvlCollection = newObj.children;\n        }\n        return vals;\n    }\n\n    public static flatten(arr, lvl = 0) {\n        const newArr = arr.reduce((acc, item) => {\n            item.level = lvl;\n            acc.push(item);\n            if (item.childLevel) {\n                item.expandable = true;\n                acc = acc.concat(this.flatten([item.childLevel], lvl + 1));\n            }\n            return acc;\n        }, []);\n        return newArr;\n    }\n\n    public static applyAggregations(rec: IPivotGridRecord, hierarchies, values, pivotKeys: IPivotKeys) {\n        if (hierarchies.size === 0) {\n            // no column groups\n            const aggregationResult = this.aggregate(rec.records, values);\n            this.applyAggregationRecordData(aggregationResult, undefined, rec, pivotKeys);\n            return;\n        }\n        hierarchies.forEach((hierarchy) => {\n            const children = hierarchy[pivotKeys.children];\n            if (children && children.size > 0) {\n                this.applyAggregations(rec, children, values, pivotKeys);\n                const childRecords = this.collectRecords(children, pivotKeys);\n                hierarchy[pivotKeys.aggregations] = this.aggregate(childRecords, values);\n                this.applyAggregationRecordData(hierarchy[pivotKeys.aggregations], hierarchy.value, rec, pivotKeys);\n            } else if (hierarchy[pivotKeys.records]) {\n                hierarchy[pivotKeys.aggregations] = this.aggregate(hierarchy[pivotKeys.records], values);\n                this.applyAggregationRecordData(hierarchy[pivotKeys.aggregations], hierarchy.value, rec, pivotKeys);\n            }\n        });\n    }\n\n    protected static applyAggregationRecordData(aggregationData: any, groupName: string, rec: IPivotGridRecord, pivotKeys: IPivotKeys) {\n        const aggregationKeys = Object.keys(aggregationData);\n        if (aggregationKeys.length > 1) {\n            aggregationKeys.forEach((key) => {\n                const aggregationKey = groupName ? groupName + pivotKeys.columnDimensionSeparator + key : key;\n                rec.aggregationValues.set(aggregationKey, aggregationData[key]);\n            });\n        } else  if (aggregationKeys.length === 1) {\n            const aggregationKey = aggregationKeys[0];\n            rec.aggregationValues.set(groupName || aggregationKey, aggregationData[aggregationKey]);\n        }\n    }\n\n    public static aggregate(records, values: IPivotValue[]) {\n        const result = {};\n        for (const pivotValue of values) {\n            result[pivotValue.member] = pivotValue.aggregate.aggregator(records.map(r => r[pivotValue.member]), records);\n        }\n\n        return result;\n    }\n\n    public static processHierarchy(hierarchies, pivotKeys, level = 0, rootData = false): IPivotGridRecord[] {\n        const flatData: IPivotGridRecord[] = [];\n        hierarchies.forEach((h, key) => {\n            const field = h.dimension.memberName;\n            const rec: IPivotGridRecord = {\n                dimensionValues: new Map<string, string>(),\n                aggregationValues: new Map<string, string>(),\n                children: new Map<string, IPivotGridRecord[]>(),\n                dimensions: [h.dimension]\n            };\n            rec.dimensionValues.set(field, key);\n            if (h[pivotKeys.records]) {\n                rec.records = this.getDirectLeafs(h[pivotKeys.records]);\n            }\n            rec.level = level;\n            flatData.push(rec);\n            if (h[pivotKeys.children] && h[pivotKeys.children].size > 0) {\n                const nestedData = this.processHierarchy(h[pivotKeys.children],\n                    pivotKeys, level + 1, rootData);\n                rec.records = this.getDirectLeafs(nestedData);\n                rec.children.set(field, nestedData);\n            }\n        });\n\n        return flatData;\n    }\n\n    public static getDirectLeafs(records: IPivotGridRecord[]) {\n        let leafs = [];\n        for (const rec of records) {\n            if (rec.records) {\n                const data = rec.records.filter(x => !x.records && leafs.indexOf(x) === -1);\n                leafs = leafs.concat(data);\n            } else {\n                leafs.push(rec);\n            }\n        }\n        return leafs;\n    }\n\n    public static getRecordKey(rec: IPivotGridRecord, currentDim: IPivotDimension,) {\n        const parentFields = [];\n        const currentDimIndex = rec.dimensions.findIndex(x => x.memberName === currentDim.memberName) + 1;\n        const prevDims = rec.dimensions.slice(0, currentDimIndex);\n        for (const prev of prevDims) {\n            const prevValue = rec.dimensionValues.get(prev.memberName);\n            parentFields.push(prevValue);\n        }\n        return parentFields.join('-');\n    }\n\n    public static buildExpressionTree(config: IPivotConfiguration) {\n        const allDimensions = (config?.rows || []).concat((config?.columns || [])).concat(config?.filters || []).filter(x => x !== null && x !== undefined);\n        const enabledDimensions = allDimensions.filter(x => x && x.enabled);\n\n        const expressionsTree = new FilteringExpressionsTree(FilteringLogic.And);\n        // add expression trees from all filters\n        PivotUtil.flatten(enabledDimensions).forEach((x: IPivotDimension) => {\n            if (x.filter && x.filter.filteringOperands) {\n                expressionsTree.filteringOperands.push(...x.filter.filteringOperands);\n            }\n        });\n\n        return expressionsTree;\n    }\n\n    private static collectRecords(children, pivotKeys: IPivotKeys) {\n        let result = [];\n        children.forEach(value => result = result.concat(value[pivotKeys.records]));\n        return result;\n    }\n\n    private static applyHierarchyChildren(hierarchy, val, rec, pivotKeys: IPivotKeys) {\n        const recordsKey = pivotKeys.records;\n        const childKey = pivotKeys.children;\n        const childCollection = val[childKey];\n        const hierarchyValue = hierarchy.get(val.value);\n        if (Array.isArray(hierarchyValue[childKey])) {\n            hierarchyValue[childKey] = new Map<string, any>();\n        }\n        if (!childCollection || childCollection.size === 0) {\n            const dim = hierarchyValue.dimension;\n            const isValid = this.extractValueFromDimension(dim, rec) === val.value;\n            if (isValid) {\n                if (hierarchyValue[recordsKey]) {\n                    hierarchyValue[recordsKey].push(rec);\n                } else {\n                    hierarchyValue[recordsKey] = [rec];\n                }\n            }\n        } else {\n            const hierarchyChild = hierarchyValue[childKey];\n            for (const [key, child] of childCollection) {\n                let hierarchyChildValue = hierarchyChild.get(child.value);\n                if (!hierarchyChildValue) {\n                    hierarchyChild.set(child.value, child);\n                    hierarchyChildValue = child;\n                }\n\n                if (hierarchyChildValue[recordsKey]) {\n                    const copy = Object.assign({}, rec);\n                    if (rec[recordsKey]) {\n                        // not all nested children are valid\n                        const nestedValue = hierarchyChildValue.value;\n                        const dimension = hierarchyChildValue.dimension;\n                        const validRecs = rec[recordsKey].filter(x => this.extractValueFromDimension(dimension, x) === nestedValue);\n                        copy[recordsKey] = validRecs;\n                    }\n                    hierarchyChildValue[recordsKey].push(copy);\n                } else {\n                    hierarchyChildValue[recordsKey] = [rec];\n                }\n\n                if (child[childKey] && child[childKey].size > 0) {\n                    this.applyHierarchyChildren(hierarchyChild, child, rec, pivotKeys);\n                }\n            }\n        }\n    }\n\n    public static getAggregateList(val: IPivotValue, grid: PivotGridType): IPivotAggregator[] {\n        if (!val.aggregateList) {\n            let defaultAggr = this.getAggregatorsForValue(val, grid);\n            const isDefault = defaultAggr.find(\n                (x) => x.key === val.aggregate.key\n            );\n            // resolve custom aggregations\n            if (!isDefault && grid.data[0][val.member] !== undefined) {\n                // if field exists, then we can apply default aggregations and add the custom one.\n                defaultAggr.unshift(val.aggregate);\n            } else if (!isDefault) {\n                // otherwise this is a custom aggregation that is not compatible\n                // with the defaults, since it operates on field that is not in the data\n                // leave only the custom one.\n                defaultAggr = [val.aggregate];\n            }\n            val.aggregateList = defaultAggr;\n        }\n        return val.aggregateList;\n    }\n\n    public static getAggregatorsForValue(value: IPivotValue, grid: PivotGridType): IPivotAggregator[] {\n        const dataType = value.dataType || grid.resolveDataTypes(grid.data[0][value.member]);\n        switch (dataType) {\n            case GridColumnDataType.Number:\n            case GridColumnDataType.Currency:\n                return IgxPivotNumericAggregate.aggregators();\n            case GridColumnDataType.Date:\n            case GridColumnDataType.DateTime:\n                return IgxPivotDateAggregate.aggregators();\n            case GridColumnDataType.Time:\n                return IgxPivotTimeAggregate.aggregators();\n            default:\n                return IgxPivotAggregate.aggregators();\n        }\n    }\n\n\n}\n"]}
|
|
385
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pivot-util.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/pivot-grid/pivot-util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AACnE,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,kBAAkB,EAAE,MAAM,iCAAiC,CAAC;AAC/E,OAAO,EAAE,cAAc,EAAE,MAAM,sDAAsD,CAAC;AACtF,OAAO,EAAE,wBAAwB,EAAE,MAAM,kDAAkD,CAAC;AAG5F,OAAO,EAAwB,UAAU,EAAE,MAAM,oBAAoB,CAAC;AACtE,OAAO,EAAE,iBAAiB,EAAE,qBAAqB,EAAE,wBAAwB,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AACnI,OAAO,EAAqG,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAE/J,MAAM,OAAO,SAAS;IAElB,kEAAkE;IAC3D,MAAM,CAAC,aAAa,CAAC,IAAwB,EAAE,SAA0B,EAAE,SAAqB;QACnG,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE;YACpB,4BAA4B;YAC5B,IAAI,GAAG,CAAC,QAAQ,IAAI,GAAG,CAAC,QAAQ,CAAC,IAAI,GAAG,CAAC,EAAE;gBACvC,4BAA4B;gBAC5B,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE;oBACjC,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;gBACrD,CAAC,CAAC,CAAC;aACN;YACD,qCAAqC;YACrC,MAAM,eAAe,GAAG,SAAS;iBAC5B,kBAAkB,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,EAAE,kBAAkB,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;YACrF,MAAM,MAAM,GAAG,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,UAAU,KAAK,SAAS,CAAC,UAAU,CAAC,CAAC;YAC/G,MAAM,WAAW,GAAG,SAAS;iBACxB,gBAAgB,CAAC,eAAe,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;YACrD,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;SACvD;IACL,CAAC;IAEM,MAAM,CAAC,aAAa,CAAC,IAAwB,EAAE,SAA0B,EAAE,eAAe,EAAE,aAAsB,EAAE,MAAwB,EAAE,SAA4B;QAC7K,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAClC,MAAM,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;YACpB,MAAM,KAAK,GAAG,SAAS,CAAC,UAAU,CAAC;YACnC,IAAI,CAAC,KAAK,EAAE;gBACR,SAAS;aACZ;YAED,IAAI,WAAW,GAAG,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YAC1C,IAAI,CAAC,WAAW,IAAI,MAAM,EAAE;gBACxB,eAAe;gBACf,WAAW,GAAG,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;gBAClD,IAAI,WAAW,EAAE;oBACb,SAAS,GAAG,MAAM,CAAC;iBACtB;aACJ;YAED,IAAI,SAAS,EAAE;gBACX,SAAS,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;oBAC7C,IAAI,MAAM,CAAC,UAAU,KAAK,GAAG,EAAE;wBAC3B,GAAG,CAAC,eAAe,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;wBACpC,MAAM,GAAG,GAAG,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,KAAK,GAAG,CAAC,CAAC;wBACjE,GAAG,CAAC,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;qBAC/B;gBAEL,CAAC,CAAC,CAAC;aACN;YAGD,MAAM,eAAe,GAAG,SAAS,CAAC,YAAY,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;YAC/D,MAAM,UAAU,GAAG,eAAe,CAAC,GAAG,CAAC,eAAe,CAAC,KAAK,SAAS,CAAC,CAAC;gBACnE,aAAa,CAAC,CAAC;gBACf,eAAe,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;YACzC,MAAM,YAAY,GAAG,UAAU,IAAI,CAAC,SAAS,CAAC,UAAU,IAAI,CAAC,GAAG,CAAC,eAAe,CAAC,GAAG,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;YAC3G,IAAI,YAAY,IAAI,WAAW,EAAE;gBAC7B,IAAI,SAAS,CAAC,UAAU,EAAE;oBACtB,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,SAAS,CAAC,UAAU,EAAE,eAAe,EAAE,aAAa,EAAE,SAAS,EAAE,GAAG,CAAC,CAAC;iBACzG;qBAAM;oBACH,uCAAuC;oBACvC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;wBACpB,GAAG,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;4BACvC,IAAI,SAAS,CAAC,UAAU,KAAK,GAAG,EAAE;gCAC9B,CAAC,CAAC,eAAe,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;gCAClC,MAAM,GAAG,GAAG,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,KAAK,GAAG,CAAC,CAAC;gCAC3D,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;6BAC7B;wBAEL,CAAC,CAAC,CAAC;oBACP,CAAC,CAAC,CAAC;iBACN;gBAED,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,GAAG,WAAW,CAAC,CAAC;gBACtC,CAAC,IAAI,WAAW,CAAC,MAAM,CAAC;aAE3B;SACJ;IACL,CAAC;IACM,MAAM,CAAC,YAAY,CAAC,IAAI;QAC3B,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE;YACpB,IAAI,OAAO,GAAG,GAAG,CAAC;YAClB,IAAI,GAAG,GAAG,CAAC,CAAC;YACZ,OAAO,OAAO,CAAC,UAAU,EAAE;gBACvB,OAAO,CAAC,KAAK,GAAG,GAAG,CAAC;gBACpB,OAAO,GAAG,OAAO,CAAC,UAAU,CAAC;gBAC7B,GAAG,EAAE,CAAC;aACT;YACD,OAAO,CAAC,KAAK,GAAG,GAAG,CAAC;SACvB;IACL,CAAC;IACM,MAAM,CAAC,kBAAkB,CAAC,IAAW,EAAE,UAA6B,EACvE,aAAiC,EAAE,SAAqB;QACxD,MAAM,SAAS,GAAG,IAAI,GAAG,EAAe,CAAC;QACzC,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE;YACpB,MAAM,IAAI,GAAG,aAAa,KAAK,kBAAkB,CAAC,MAAM,CAAC,CAAC;gBACtD,IAAI,CAAC,sBAAsB,CAAC,UAAU,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC,CAAC;gBACzD,IAAI,CAAC,mBAAmB,CAAC,UAAU,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;YACzD,KAAK,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,IAAI,EAAE,EAAE,6CAA6C;gBAC1E,IAAI,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE;oBAClC,IAAI,CAAC,sBAAsB,CAAC,SAAS,EAAE,GAAG,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;iBAC/D;qBAAM;oBACH,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC;oBAC1C,IAAI,CAAC,sBAAsB,CAAC,SAAS,EAAE,GAAG,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;iBAC/D;aACJ;SACJ;QACD,OAAO,SAAS,CAAC;IACrB,CAAC;IAEM,MAAM,CAAC,IAAI,CAAC,IAAwB,EAAE,WAAiC,EAAE,UAAgC,IAAI,UAAU,EAAE;QAC5H,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YACf,MAAM,QAAQ,GAAG,GAAG,CAAC,QAAQ,CAAC;YAC9B,IAAI,QAAQ,EAAE;gBACV,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;oBACjB,IAAI,CAAC,IAAI,CAAC,CAAC,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;gBACvC,CAAC,CAAC,CAAC;aACN;QACL,CAAC,CAAC,CAAC;QACH,OAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;IACrD,CAAC;IAEM,MAAM,CAAC,yBAAyB,CAAC,GAAoB,EAAE,OAAY;QACtE,OAAO,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,GAAG,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IACjG,CAAC;IAEM,MAAM,CAAC,iBAAiB,CAAC,GAAoB;QAChD,IAAI,GAAG,GAAG,CAAC,CAAC;QACZ,OAAO,GAAG,CAAC,UAAU,EAAE;YACnB,GAAG,EAAE,CAAC;YACN,GAAG,GAAG,GAAG,CAAC,UAAU,CAAC;SACxB;QACD,OAAO,GAAG,CAAC;IACf,CAAC;IAEM,MAAM,CAAC,mBAAmB,CAAC,IAAuB,EAAE,OAAY,EAAE,SAAqB;QAC1F,MAAM,MAAM,GAAG,IAAI,GAAG,EAAe,CAAC;QACtC,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE;YACpB,IAAI,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;gBAC1D,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;gBAC7C,OAAO,IAAI,CAAC,kBAAkB,CAAC,SAAS,EAAE,CAAC,GAAG,CAAC,EAAE,kBAAkB,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;aACvF;YAED,MAAM,KAAK,GAAG,IAAI,CAAC,yBAAyB,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;YAC3D,MAAM,QAAQ,GAAG,EAAE,CAAC;YACpB,QAAQ,CAAC,OAAO,CAAC,GAAG,KAAK,CAAC;YAC1B,QAAQ,CAAC,WAAW,CAAC,GAAG,GAAG,CAAC;YAC5B,IAAI,GAAG,CAAC,UAAU,EAAE;gBAChB,MAAM,WAAW,GAAG,IAAI,CAAC,mBAAmB,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,SAAS,CAAC,CAAC;gBACnF,QAAQ,CAAC,SAAS,CAAC,QAAQ,CAAC,GAAG,WAAW,CAAC;aAC9C;YACD,MAAM,CAAC,GAAG,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;SAC/B;QAED,OAAO,MAAM,CAAC;IAClB,CAAC;IAEM,MAAM,CAAC,sBAAsB,CAAC,IAAuB,EAAE,OAAY,EAAE,SAAqB,EAAE,IAAI,GAAG,EAAE;QACxG,MAAM,IAAI,GAAG,IAAI,GAAG,EAAe,CAAC;QACpC,IAAI,aAAa,GAAG,IAAI,CAAC;QACzB,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACzC,KAAK,MAAM,GAAG,IAAI,aAAa,EAAE;YAC7B,MAAM,KAAK,GAAG,IAAI,CAAC,yBAAyB,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;YAC3D,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACjB,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,wBAAwB,CAAC,CAAC;YAC/D,MAAM,MAAM,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAE,UAAU,EAAE,GAAG,CAAC,UAAU,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE,GAAG,EAAE,CAAC;YAC/F,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE;gBAClB,MAAM,CAAC,QAAQ,GAAG,IAAI,GAAG,EAAe,CAAC;aAC5C;YACD,aAAa,CAAC,GAAG,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;YACpC,aAAa,GAAG,MAAM,CAAC,QAAQ,CAAC;SACnC;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAEM,MAAM,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,GAAG,CAAC;QAC9B,MAAM,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE;YACpC,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;YACjB,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACf,IAAI,IAAI,CAAC,UAAU,EAAE;gBACjB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;gBACvB,GAAG,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;aAC9D;YACD,OAAO,GAAG,CAAC;QACf,CAAC,EAAE,EAAE,CAAC,CAAC;QACP,OAAO,MAAM,CAAC;IAClB,CAAC;IAEM,MAAM,CAAC,iBAAiB,CAAC,GAAqB,EAAE,WAAW,EAAE,MAAM,EAAE,SAAqB;QAC7F,IAAI,WAAW,CAAC,IAAI,KAAK,CAAC,EAAE;YACxB,mBAAmB;YACnB,MAAM,iBAAiB,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;YAC9D,IAAI,CAAC,0BAA0B,CAAC,iBAAiB,EAAE,SAAS,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;YAC9E,OAAO;SACV;QACD,WAAW,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE;YAC9B,MAAM,QAAQ,GAAG,SAAS,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;YAC/C,IAAI,QAAQ,IAAI,QAAQ,CAAC,IAAI,GAAG,CAAC,EAAE;gBAC/B,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC;gBACzD,MAAM,YAAY,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;gBAC9D,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;gBACzE,IAAI,CAAC,0BAA0B,CAAC,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,EAAE,SAAS,CAAC,KAAK,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;aACvG;iBAAM,IAAI,SAAS,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE;gBACrC,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC,CAAC;gBACzF,IAAI,CAAC,0BAA0B,CAAC,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,EAAE,SAAS,CAAC,KAAK,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;aACvG;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAES,MAAM,CAAC,0BAA0B,CAAC,eAAoB,EAAE,SAAiB,EAAE,GAAqB,EAAE,SAAqB;QAC7H,MAAM,eAAe,GAAG,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QACrD,IAAI,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE;YAC5B,eAAe,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;gBAC5B,MAAM,cAAc,GAAG,SAAS,CAAC,CAAC,CAAC,SAAS,GAAG,SAAS,CAAC,wBAAwB,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;gBAC9F,GAAG,CAAC,iBAAiB,CAAC,GAAG,CAAC,cAAc,EAAE,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC;YACpE,CAAC,CAAC,CAAC;SACN;aAAO,IAAI,eAAe,CAAC,MAAM,KAAK,CAAC,EAAE;YACtC,MAAM,cAAc,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC;YAC1C,GAAG,CAAC,iBAAiB,CAAC,GAAG,CAAC,SAAS,IAAI,cAAc,EAAE,eAAe,CAAC,cAAc,CAAC,CAAC,CAAC;SAC3F;IACL,CAAC;IAEM,MAAM,CAAC,SAAS,CAAC,OAAO,EAAE,MAAqB;QAClD,MAAM,MAAM,GAAG,EAAE,CAAC;QAClB,KAAK,MAAM,UAAU,IAAI,MAAM,EAAE;YAC7B,MAAM,UAAU,GAAG,SAAS,CAAC,oBAAoB,CAAC,UAAU,CAAC,SAAS,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;YAC7F,IAAI,CAAC,UAAU,EAAE;gBACb,MAAM,sBAAsB,CAAC,cAAc,CAAC,4BAA4B,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC;aAC9G;YACD,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,GAAG,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;SAC3F;QAED,OAAO,MAAM,CAAC;IAClB,CAAC;IAEM,MAAM,CAAC,oBAAoB,CAAC,SAA2B,EAAE,QAA4B;QACxF,IAAI,UAAU,GAAG,SAAS,CAAC,UAAU,CAAC;QACtC,IAAI,SAAS,CAAC,cAAc,EAAE;YAC1B,IAAI,WAAW,GAAG,wBAAwB,CAAC,WAAW,EAAE,CAAC;YACzD,IAAI,CAAC,QAAQ,IAAI,QAAQ,KAAK,MAAM,IAAI,QAAQ,KAAK,UAAU,EAAE;gBAC7D,WAAW,GAAG,WAAW,CAAC,MAAM,CAAC,qBAAqB,CAAC,WAAW,EAAE,CAAC,CAAA;aACxE;iBAAM,IAAI,QAAQ,KAAK,MAAM,EAAE;gBAC5B,WAAW,GAAG,WAAW,CAAC,MAAM,CAAC,qBAAqB,CAAC,WAAW,EAAE,CAAC,CAAC;aACzE;YACD,UAAU,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,SAAS,CAAC,cAAc,CAAC,EAAE,UAAU,CAAC;SACtF;QACD,OAAO,UAAU,CAAC;IACtB,CAAC;IAEM,MAAM,CAAC,gBAAgB,CAAC,WAAW,EAAE,SAAS,EAAE,KAAK,GAAG,CAAC,EAAE,QAAQ,GAAG,KAAK;QAC9E,MAAM,QAAQ,GAAuB,EAAE,CAAC;QACxC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;YAC3B,MAAM,KAAK,GAAG,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC;YACrC,MAAM,GAAG,GAAqB;gBAC1B,eAAe,EAAE,IAAI,GAAG,EAAkB;gBAC1C,iBAAiB,EAAE,IAAI,GAAG,EAAkB;gBAC5C,QAAQ,EAAE,IAAI,GAAG,EAA8B;gBAC/C,UAAU,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;aAC5B,CAAC;YACF,GAAG,CAAC,eAAe,CAAC,GAAG,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;YACpC,IAAI,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE;gBACtB,GAAG,CAAC,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;aAC3D;YACD,GAAG,CAAC,KAAK,GAAG,KAAK,CAAC;YAClB,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACnB,IAAI,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,IAAI,GAAG,CAAC,EAAE;gBACzD,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,EAC1D,SAAS,EAAE,KAAK,GAAG,CAAC,EAAE,QAAQ,CAAC,CAAC;gBACpC,GAAG,CAAC,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;gBAC9C,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;aACvC;QACL,CAAC,CAAC,CAAC;QAEH,OAAO,QAAQ,CAAC;IACpB,CAAC;IAEM,MAAM,CAAC,cAAc,CAAC,OAA2B;QACpD,IAAI,KAAK,GAAG,EAAE,CAAC;QACf,KAAK,MAAM,GAAG,IAAI,OAAO,EAAE;YACvB,IAAI,GAAG,CAAC,OAAO,EAAE;gBACb,MAAM,IAAI,GAAG,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBAC5E,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;aAC9B;iBAAM;gBACH,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;aACnB;SACJ;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;IAEM,MAAM,CAAC,YAAY,CAAC,GAAqB,EAAE,UAA2B;QACzE,MAAM,YAAY,GAAG,EAAE,CAAC;QACxB,MAAM,eAAe,GAAG,GAAG,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,KAAK,UAAU,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;QAClG,MAAM,QAAQ,GAAG,GAAG,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,EAAE,eAAe,CAAC,CAAC;QAC1D,KAAK,MAAM,IAAI,IAAI,QAAQ,EAAE;YACzB,MAAM,SAAS,GAAG,GAAG,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC3D,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SAChC;QACD,OAAO,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAClC,CAAC;IAEM,MAAM,CAAC,mBAAmB,CAAC,MAA2B;QACzD,MAAM,aAAa,GAAG,CAAC,MAAM,EAAE,IAAI,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,OAAO,IAAI,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,SAAS,CAAC,CAAC;QACpJ,MAAM,iBAAiB,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC;QAEpE,MAAM,eAAe,GAAG,IAAI,wBAAwB,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;QACzE,wCAAwC;QACxC,SAAS,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC,OAAO,CAAC,CAAC,CAAkB,EAAE,EAAE;YAChE,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,MAAM,CAAC,iBAAiB,EAAE;gBACxC,eAAe,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;aACzE;QACL,CAAC,CAAC,CAAC;QAEH,OAAO,eAAe,CAAC;IAC3B,CAAC;IAEO,MAAM,CAAC,cAAc,CAAC,QAAQ,EAAE,SAAqB;QACzD,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAC5E,OAAO,MAAM,CAAC;IAClB,CAAC;IAEO,MAAM,CAAC,sBAAsB,CAAC,SAAS,EAAE,GAAG,EAAE,GAAG,EAAE,SAAqB;QAC5E,MAAM,UAAU,GAAG,SAAS,CAAC,OAAO,CAAC;QACrC,MAAM,QAAQ,GAAG,SAAS,CAAC,QAAQ,CAAC;QACpC,MAAM,eAAe,GAAG,GAAG,CAAC,QAAQ,CAAC,CAAC;QACtC,MAAM,cAAc,GAAG,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAChD,IAAI,KAAK,CAAC,OAAO,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,EAAE;YACzC,cAAc,CAAC,QAAQ,CAAC,GAAG,IAAI,GAAG,EAAe,CAAC;SACrD;QACD,IAAI,CAAC,eAAe,IAAI,eAAe,CAAC,IAAI,KAAK,CAAC,EAAE;YAChD,MAAM,GAAG,GAAG,cAAc,CAAC,SAAS,CAAC;YACrC,MAAM,OAAO,GAAG,IAAI,CAAC,yBAAyB,CAAC,GAAG,EAAE,GAAG,CAAC,KAAK,GAAG,CAAC,KAAK,CAAC;YACvE,IAAI,OAAO,EAAE;gBACT,IAAI,cAAc,CAAC,UAAU,CAAC,EAAE;oBAC5B,cAAc,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;iBACxC;qBAAM;oBACH,cAAc,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;iBACtC;aACJ;SACJ;aAAM;YACH,MAAM,cAAc,GAAG,cAAc,CAAC,QAAQ,CAAC,CAAC;YAChD,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,eAAe,EAAE;gBACxC,IAAI,mBAAmB,GAAG,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBAC1D,IAAI,CAAC,mBAAmB,EAAE;oBACtB,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;oBACvC,mBAAmB,GAAG,KAAK,CAAC;iBAC/B;gBAED,IAAI,mBAAmB,CAAC,UAAU,CAAC,EAAE;oBACjC,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC;oBACpC,IAAI,GAAG,CAAC,UAAU,CAAC,EAAE;wBACjB,oCAAoC;wBACpC,MAAM,WAAW,GAAG,mBAAmB,CAAC,KAAK,CAAC;wBAC9C,MAAM,SAAS,GAAG,mBAAmB,CAAC,SAAS,CAAC;wBAChD,MAAM,SAAS,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,yBAAyB,CAAC,SAAS,EAAE,CAAC,CAAC,KAAK,WAAW,CAAC,CAAC;wBAC5G,IAAI,CAAC,UAAU,CAAC,GAAG,SAAS,CAAC;qBAChC;oBACD,mBAAmB,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iBAC9C;qBAAM;oBACH,mBAAmB,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;iBAC3C;gBAED,IAAI,KAAK,CAAC,QAAQ,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,GAAG,CAAC,EAAE;oBAC7C,IAAI,CAAC,sBAAsB,CAAC,cAAc,EAAE,KAAK,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;iBACtE;aACJ;SACJ;IACL,CAAC;IAEM,MAAM,CAAC,gBAAgB,CAAC,GAAgB,EAAE,IAAmB;QAChE,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE;YACpB,IAAI,WAAW,GAAG,IAAI,CAAC,sBAAsB,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;YACzD,MAAM,SAAS,GAAG,WAAW,CAAC,IAAI,CAC9B,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC,SAAS,CAAC,GAAG,CACrC,CAAC;YACF,8BAA8B;YAC9B,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,SAAS,EAAE;gBACtD,kFAAkF;gBAClF,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;aACtC;iBAAM,IAAI,CAAC,SAAS,EAAE;gBACnB,gEAAgE;gBAChE,wEAAwE;gBACxE,6BAA6B;gBAC7B,WAAW,GAAG,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;aACjC;YACD,GAAG,CAAC,aAAa,GAAG,WAAW,CAAC;SACnC;QACD,OAAO,GAAG,CAAC,aAAa,CAAC;IAC7B,CAAC;IAEM,MAAM,CAAC,sBAAsB,CAAC,KAAkB,EAAE,IAAmB;QACxE,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,IAAI,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;QACrF,QAAQ,QAAQ,EAAE;YACd,KAAK,kBAAkB,CAAC,MAAM,CAAC;YAC/B,KAAK,kBAAkB,CAAC,QAAQ;gBAC5B,OAAO,wBAAwB,CAAC,WAAW,EAAE,CAAC;YAClD,KAAK,kBAAkB,CAAC,IAAI,CAAC;YAC7B,KAAK,kBAAkB,CAAC,QAAQ;gBAC5B,OAAO,qBAAqB,CAAC,WAAW,EAAE,CAAC;YAC/C,KAAK,kBAAkB,CAAC,IAAI;gBACxB,OAAO,qBAAqB,CAAC,WAAW,EAAE,CAAC;YAC/C;gBACI,OAAO,iBAAiB,CAAC,WAAW,EAAE,CAAC;SAC9C;IACL,CAAC;CAGJ","sourcesContent":["import { CurrentResourceStrings } from '../../core/i18n/resources';\nimport { cloneValue } from '../../core/utils';\nimport { DataUtil, GridColumnDataType } from '../../data-operations/data-util';\nimport { FilteringLogic } from '../../data-operations/filtering-expression.interface';\nimport { FilteringExpressionsTree } from '../../data-operations/filtering-expressions-tree';\nimport { ISortingExpression } from '../../data-operations/sorting-strategy';\nimport { PivotGridType } from '../common/grid.interface';\nimport { IGridSortingStrategy, IgxSorting } from '../common/strategy';\nimport { IgxPivotAggregate, IgxPivotDateAggregate, IgxPivotNumericAggregate, IgxPivotTimeAggregate } from './pivot-grid-aggregate';\nimport { IPivotAggregator, IPivotConfiguration, IPivotDimension, IPivotGridRecord, IPivotKeys, IPivotValue, PivotDimensionType } from './pivot-grid.interface';\n\nexport class PivotUtil {\n\n    // go through all children and apply new dimension groups as child\n    public static processGroups(recs: IPivotGridRecord[], dimension: IPivotDimension, pivotKeys: IPivotKeys) {\n        for (const rec of recs) {\n            // process existing children\n            if (rec.children && rec.children.size > 0) {\n                // process hierarchy in dept\n                rec.children.forEach((values, key) => {\n                    this.processGroups(values, dimension, pivotKeys);\n                });\n            }\n            // add children for current dimension\n            const hierarchyFields = PivotUtil\n                .getFieldsHierarchy(rec.records, [dimension], PivotDimensionType.Row, pivotKeys);\n            const values = Array.from(hierarchyFields.values()).find(x => x.dimension.memberName === dimension.memberName);\n            const siblingData = PivotUtil\n                .processHierarchy(hierarchyFields, pivotKeys, 0);\n            rec.children.set(dimension.memberName, siblingData);\n        }\n    }\n\n    public static flattenGroups(data: IPivotGridRecord[], dimension: IPivotDimension, expansionStates, defaultExpand: boolean, parent?: IPivotDimension, parentRec?: IPivotGridRecord) {\n        for (let i = 0; i < data.length; i++) {\n            const rec = data[i];\n            const field = dimension.memberName;\n            if (!field) {\n                continue;\n            }\n\n            let recordsData = rec.children.get(field);\n            if (!recordsData && parent) {\n                // check parent\n                recordsData = rec.children.get(parent.memberName);\n                if (recordsData) {\n                    dimension = parent;\n                }\n            }\n\n            if (parentRec) {\n                parentRec.dimensionValues.forEach((value, key) => {\n                    if (parent.memberName !== key) {\n                        rec.dimensionValues.set(key, value);\n                        const dim = parentRec.dimensions.find(x => x.memberName === key);\n                        rec.dimensions.unshift(dim);\n                    }\n\n                });\n            }\n\n\n            const expansionRowKey = PivotUtil.getRecordKey(rec, dimension);\n            const isExpanded = expansionStates.get(expansionRowKey) === undefined ?\n                defaultExpand :\n                expansionStates.get(expansionRowKey);\n            const shouldExpand = isExpanded || !dimension.childLevel || !rec.dimensionValues.get(dimension.memberName);\n            if (shouldExpand && recordsData) {\n                if (dimension.childLevel) {\n                    this.flattenGroups(recordsData, dimension.childLevel, expansionStates, defaultExpand, dimension, rec);\n                } else {\n                    // copy parent values and dims in child\n                    recordsData.forEach(x => {\n                        rec.dimensionValues.forEach((value, key) => {\n                            if (dimension.memberName !== key) {\n                                x.dimensionValues.set(key, value);\n                                const dim = rec.dimensions.find(y => y.memberName === key);\n                                x.dimensions.unshift(dim);\n                            }\n\n                        });\n                    });\n                }\n\n                data.splice(i + 1, 0, ...recordsData);\n                i += recordsData.length;\n\n            }\n        }\n    }\n    public static assignLevels(dims) {\n        for (const dim of dims) {\n            let currDim = dim;\n            let lvl = 0;\n            while (currDim.childLevel) {\n                currDim.level = lvl;\n                currDim = currDim.childLevel;\n                lvl++;\n            }\n            currDim.level = lvl;\n        }\n    }\n    public static getFieldsHierarchy(data: any[], dimensions: IPivotDimension[],\n        dimensionType: PivotDimensionType, pivotKeys: IPivotKeys): Map<string, any> {\n        const hierarchy = new Map<string, any>();\n        for (const rec of data) {\n            const vals = dimensionType === PivotDimensionType.Column ?\n                this.extractValuesForColumn(dimensions, rec, pivotKeys) :\n                this.extractValuesForRow(dimensions, rec, pivotKeys);\n            for (const [key, val] of vals) { // this should go in depth also vals.children\n                if (hierarchy.get(val.value) != null) {\n                    this.applyHierarchyChildren(hierarchy, val, rec, pivotKeys);\n                } else {\n                    hierarchy.set(val.value, cloneValue(val));\n                    this.applyHierarchyChildren(hierarchy, val, rec, pivotKeys);\n                }\n            }\n        }\n        return hierarchy;\n    }\n\n    public static sort(data: IPivotGridRecord[], expressions: ISortingExpression[], sorting: IGridSortingStrategy = new IgxSorting()): any[] {\n        data.forEach(rec => {\n            const children = rec.children;\n            if (children) {\n                children.forEach(x => {\n                    this.sort(x, expressions, sorting);\n                });\n            }\n        });\n        return DataUtil.sort(data, expressions, sorting);\n    }\n\n    public static extractValueFromDimension(dim: IPivotDimension, recData: any) {\n        return dim.memberFunction ? dim.memberFunction.call(null, recData) : recData[dim.memberName];\n    }\n\n    public static getDimensionDepth(dim: IPivotDimension): number {\n        let lvl = 0;\n        while (dim.childLevel) {\n            lvl++;\n            dim = dim.childLevel;\n        }\n        return lvl;\n    }\n\n    public static extractValuesForRow(dims: IPivotDimension[], recData: any, pivotKeys: IPivotKeys) {\n        const values = new Map<string, any>();\n        for (const col of dims) {\n            if (recData[pivotKeys.level] && recData[pivotKeys.level] > 0) {\n                const childData = recData[pivotKeys.records];\n                return this.getFieldsHierarchy(childData, [col], PivotDimensionType.Row, pivotKeys);\n            }\n\n            const value = this.extractValueFromDimension(col, recData);\n            const objValue = {};\n            objValue['value'] = value;\n            objValue['dimension'] = col;\n            if (col.childLevel) {\n                const childValues = this.extractValuesForRow([col.childLevel], recData, pivotKeys);\n                objValue[pivotKeys.children] = childValues;\n            }\n            values.set(value, objValue);\n        }\n\n        return values;\n    }\n\n    public static extractValuesForColumn(dims: IPivotDimension[], recData: any, pivotKeys: IPivotKeys, path = []) {\n        const vals = new Map<string, any>();\n        let lvlCollection = vals;\n        const flattenedDims = this.flatten(dims);\n        for (const col of flattenedDims) {\n            const value = this.extractValueFromDimension(col, recData);\n            path.push(value);\n            const newValue = path.join(pivotKeys.columnDimensionSeparator);\n            const newObj = { value: newValue, expandable: col.expandable, children: null, dimension: col };\n            if (!newObj.children) {\n                newObj.children = new Map<string, any>();\n            }\n            lvlCollection.set(newValue, newObj);\n            lvlCollection = newObj.children;\n        }\n        return vals;\n    }\n\n    public static flatten(arr, lvl = 0) {\n        const newArr = arr.reduce((acc, item) => {\n            item.level = lvl;\n            acc.push(item);\n            if (item.childLevel) {\n                item.expandable = true;\n                acc = acc.concat(this.flatten([item.childLevel], lvl + 1));\n            }\n            return acc;\n        }, []);\n        return newArr;\n    }\n\n    public static applyAggregations(rec: IPivotGridRecord, hierarchies, values, pivotKeys: IPivotKeys) {\n        if (hierarchies.size === 0) {\n            // no column groups\n            const aggregationResult = this.aggregate(rec.records, values);\n            this.applyAggregationRecordData(aggregationResult, undefined, rec, pivotKeys);\n            return;\n        }\n        hierarchies.forEach((hierarchy) => {\n            const children = hierarchy[pivotKeys.children];\n            if (children && children.size > 0) {\n                this.applyAggregations(rec, children, values, pivotKeys);\n                const childRecords = this.collectRecords(children, pivotKeys);\n                hierarchy[pivotKeys.aggregations] = this.aggregate(childRecords, values);\n                this.applyAggregationRecordData(hierarchy[pivotKeys.aggregations], hierarchy.value, rec, pivotKeys);\n            } else if (hierarchy[pivotKeys.records]) {\n                hierarchy[pivotKeys.aggregations] = this.aggregate(hierarchy[pivotKeys.records], values);\n                this.applyAggregationRecordData(hierarchy[pivotKeys.aggregations], hierarchy.value, rec, pivotKeys);\n            }\n        });\n    }\n\n    protected static applyAggregationRecordData(aggregationData: any, groupName: string, rec: IPivotGridRecord, pivotKeys: IPivotKeys) {\n        const aggregationKeys = Object.keys(aggregationData);\n        if (aggregationKeys.length > 1) {\n            aggregationKeys.forEach((key) => {\n                const aggregationKey = groupName ? groupName + pivotKeys.columnDimensionSeparator + key : key;\n                rec.aggregationValues.set(aggregationKey, aggregationData[key]);\n            });\n        } else  if (aggregationKeys.length === 1) {\n            const aggregationKey = aggregationKeys[0];\n            rec.aggregationValues.set(groupName || aggregationKey, aggregationData[aggregationKey]);\n        }\n    }\n\n    public static aggregate(records, values: IPivotValue[]) {\n        const result = {};\n        for (const pivotValue of values) {\n            const aggregator = PivotUtil.getAggregatorForType(pivotValue.aggregate, pivotValue.dataType);\n            if (!aggregator) {\n                throw CurrentResourceStrings.GridResStrings.igx_grid_pivot_no_aggregator.replace(\"{0}\", pivotValue.member);\n            }\n            result[pivotValue.member] = aggregator(records.map(r => r[pivotValue.member]), records);\n        }\n\n        return result;\n    }\n\n    public static getAggregatorForType(aggregate: IPivotAggregator, dataType: GridColumnDataType) {\n        let aggregator = aggregate.aggregator;\n        if (aggregate.aggregatorName) {\n            let aggregators = IgxPivotNumericAggregate.aggregators();\n            if (!dataType || dataType === 'date' || dataType === 'dateTime') {\n                aggregators = aggregators.concat(IgxPivotDateAggregate.aggregators())\n            } else if (dataType === 'time') {\n                aggregators = aggregators.concat(IgxPivotTimeAggregate.aggregators());\n            }\n            aggregator = aggregators.find(x => x.key === aggregate.aggregatorName)?.aggregator;\n        }\n        return aggregator;\n    }\n\n    public static processHierarchy(hierarchies, pivotKeys, level = 0, rootData = false): IPivotGridRecord[] {\n        const flatData: IPivotGridRecord[] = [];\n        hierarchies.forEach((h, key) => {\n            const field = h.dimension.memberName;\n            const rec: IPivotGridRecord = {\n                dimensionValues: new Map<string, string>(),\n                aggregationValues: new Map<string, string>(),\n                children: new Map<string, IPivotGridRecord[]>(),\n                dimensions: [h.dimension]\n            };\n            rec.dimensionValues.set(field, key);\n            if (h[pivotKeys.records]) {\n                rec.records = this.getDirectLeafs(h[pivotKeys.records]);\n            }\n            rec.level = level;\n            flatData.push(rec);\n            if (h[pivotKeys.children] && h[pivotKeys.children].size > 0) {\n                const nestedData = this.processHierarchy(h[pivotKeys.children],\n                    pivotKeys, level + 1, rootData);\n                rec.records = this.getDirectLeafs(nestedData);\n                rec.children.set(field, nestedData);\n            }\n        });\n\n        return flatData;\n    }\n\n    public static getDirectLeafs(records: IPivotGridRecord[]) {\n        let leafs = [];\n        for (const rec of records) {\n            if (rec.records) {\n                const data = rec.records.filter(x => !x.records && leafs.indexOf(x) === -1);\n                leafs = leafs.concat(data);\n            } else {\n                leafs.push(rec);\n            }\n        }\n        return leafs;\n    }\n\n    public static getRecordKey(rec: IPivotGridRecord, currentDim: IPivotDimension,) {\n        const parentFields = [];\n        const currentDimIndex = rec.dimensions.findIndex(x => x.memberName === currentDim.memberName) + 1;\n        const prevDims = rec.dimensions.slice(0, currentDimIndex);\n        for (const prev of prevDims) {\n            const prevValue = rec.dimensionValues.get(prev.memberName);\n            parentFields.push(prevValue);\n        }\n        return parentFields.join('-');\n    }\n\n    public static buildExpressionTree(config: IPivotConfiguration) {\n        const allDimensions = (config?.rows || []).concat((config?.columns || [])).concat(config?.filters || []).filter(x => x !== null && x !== undefined);\n        const enabledDimensions = allDimensions.filter(x => x && x.enabled);\n\n        const expressionsTree = new FilteringExpressionsTree(FilteringLogic.And);\n        // add expression trees from all filters\n        PivotUtil.flatten(enabledDimensions).forEach((x: IPivotDimension) => {\n            if (x.filter && x.filter.filteringOperands) {\n                expressionsTree.filteringOperands.push(...x.filter.filteringOperands);\n            }\n        });\n\n        return expressionsTree;\n    }\n\n    private static collectRecords(children, pivotKeys: IPivotKeys) {\n        let result = [];\n        children.forEach(value => result = result.concat(value[pivotKeys.records]));\n        return result;\n    }\n\n    private static applyHierarchyChildren(hierarchy, val, rec, pivotKeys: IPivotKeys) {\n        const recordsKey = pivotKeys.records;\n        const childKey = pivotKeys.children;\n        const childCollection = val[childKey];\n        const hierarchyValue = hierarchy.get(val.value);\n        if (Array.isArray(hierarchyValue[childKey])) {\n            hierarchyValue[childKey] = new Map<string, any>();\n        }\n        if (!childCollection || childCollection.size === 0) {\n            const dim = hierarchyValue.dimension;\n            const isValid = this.extractValueFromDimension(dim, rec) === val.value;\n            if (isValid) {\n                if (hierarchyValue[recordsKey]) {\n                    hierarchyValue[recordsKey].push(rec);\n                } else {\n                    hierarchyValue[recordsKey] = [rec];\n                }\n            }\n        } else {\n            const hierarchyChild = hierarchyValue[childKey];\n            for (const [key, child] of childCollection) {\n                let hierarchyChildValue = hierarchyChild.get(child.value);\n                if (!hierarchyChildValue) {\n                    hierarchyChild.set(child.value, child);\n                    hierarchyChildValue = child;\n                }\n\n                if (hierarchyChildValue[recordsKey]) {\n                    const copy = Object.assign({}, rec);\n                    if (rec[recordsKey]) {\n                        // not all nested children are valid\n                        const nestedValue = hierarchyChildValue.value;\n                        const dimension = hierarchyChildValue.dimension;\n                        const validRecs = rec[recordsKey].filter(x => this.extractValueFromDimension(dimension, x) === nestedValue);\n                        copy[recordsKey] = validRecs;\n                    }\n                    hierarchyChildValue[recordsKey].push(copy);\n                } else {\n                    hierarchyChildValue[recordsKey] = [rec];\n                }\n\n                if (child[childKey] && child[childKey].size > 0) {\n                    this.applyHierarchyChildren(hierarchyChild, child, rec, pivotKeys);\n                }\n            }\n        }\n    }\n\n    public static getAggregateList(val: IPivotValue, grid: PivotGridType): IPivotAggregator[] {\n        if (!val.aggregateList) {\n            let defaultAggr = this.getAggregatorsForValue(val, grid);\n            const isDefault = defaultAggr.find(\n                (x) => x.key === val.aggregate.key\n            );\n            // resolve custom aggregations\n            if (!isDefault && grid.data[0][val.member] !== undefined) {\n                // if field exists, then we can apply default aggregations and add the custom one.\n                defaultAggr.unshift(val.aggregate);\n            } else if (!isDefault) {\n                // otherwise this is a custom aggregation that is not compatible\n                // with the defaults, since it operates on field that is not in the data\n                // leave only the custom one.\n                defaultAggr = [val.aggregate];\n            }\n            val.aggregateList = defaultAggr;\n        }\n        return val.aggregateList;\n    }\n\n    public static getAggregatorsForValue(value: IPivotValue, grid: PivotGridType): IPivotAggregator[] {\n        const dataType = value.dataType || grid.resolveDataTypes(grid.data[0][value.member]);\n        switch (dataType) {\n            case GridColumnDataType.Number:\n            case GridColumnDataType.Currency:\n                return IgxPivotNumericAggregate.aggregators();\n            case GridColumnDataType.Date:\n            case GridColumnDataType.DateTime:\n                return IgxPivotDateAggregate.aggregators();\n            case GridColumnDataType.Time:\n                return IgxPivotTimeAggregate.aggregators();\n            default:\n                return IgxPivotAggregate.aggregators();\n        }\n    }\n\n\n}\n"]}
|