zek 17.3.86 → 17.3.88

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.
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxhdHRlbi10cmVlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kZWxzL2ZsYXR0ZW4tdHJlZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJRmxhdHRlblRyZWU8VEtleSA9IGFueSwgVFZhbHVlID0gYW55PiB7XHJcbiAgICBrZXk/OiBUS2V5IHwgbnVsbDtcclxuICAgIHZhbHVlPzogVFZhbHVlIHwgbnVsbDtcclxuICAgIGluZGVudDogbnVtYmVyO1xyXG4gICAgY291bnQ6IG51bWJlcjtcclxufVxyXG4iXX0=
@@ -75,54 +75,56 @@ export class ArrayHelper {
75
75
  return array;
76
76
  return array.filter(x => x !== undefined && x !== null && x[key] === filterValue);
77
77
  }
78
- static flattenArray(array) {
78
+ static flatten(array, indent = 0) {
79
79
  let result = [];
80
- if (array) {
81
- array.forEach(tree => {
82
- tree.indent = 0;
83
- result.push(tree);
84
- result = result.concat(this.getChildren(tree));
85
- });
86
- }
87
- return result;
88
- }
89
- static getChildren(tree, indent = 1) {
90
- let result = [];
91
- if (tree.children) {
92
- tree.childrenCount = tree.children.length;
93
- tree.children.forEach(child => {
94
- child.indent = indent;
95
- result.push(child);
96
- result = result.concat(this.getChildren(child, indent + 1));
97
- });
80
+ // If the input is an array of trees, we process each one
81
+ if (Array.isArray(array)) {
82
+ for (const item of array) {
83
+ result = result.concat(this.flatten(item, indent));
84
+ }
98
85
  }
99
86
  else {
100
- tree.childrenCount = 0;
87
+ // Add the current tree node to the result
88
+ const item = Object.assign({}, array);
89
+ item.indent = indent;
90
+ item.count = Array.isArray(array.children)
91
+ ? array.children.length
92
+ : 0;
93
+ delete item.children;
94
+ delete item.childrenIds;
95
+ result.push(item);
96
+ // If there are children, recursively flatten them
97
+ if (Array.isArray(array.children)) {
98
+ for (const child of array.children) {
99
+ result = result.concat(this.flatten(child, indent + 1));
100
+ }
101
+ }
101
102
  }
102
- delete tree.children;
103
- delete tree.childrenIds;
104
- //delete tree.childrenCount;
105
- //delete tree.indent;
106
103
  return result;
107
104
  }
108
- static treeToKeyPairArray(array) {
105
+ static flattenDropDownList(tree, indent = 0) {
109
106
  let result = [];
110
- if (array) {
111
- array.forEach(tree => {
112
- result.push({ key: tree.key, value: tree.value });
113
- result = result.concat(this.getIndentChildren(tree));
114
- });
107
+ // If the input is an array of trees, we process each one
108
+ if (Array.isArray(tree)) {
109
+ for (const item of tree) {
110
+ result = result.concat(this.flattenDropDownList(item, indent));
111
+ }
115
112
  }
116
- return result;
117
- }
118
- static getIndentChildren(tree, indent = 1) {
119
- let result = [];
120
- if (tree.children) {
121
- tree.children.forEach(child => {
122
- //result.push({ key: child.key, value: '└' + '─'.repeat(indent) + child.value });
123
- result.push({ key: child.key, value: ' '.repeat(indent) + child.value });
124
- result = result.concat(this.getChildren(child, indent + 1));
125
- });
113
+ else {
114
+ // Add the current tree node to the result
115
+ let item = {
116
+ key: tree.key,
117
+ value: ' '.repeat(indent) + tree.value,
118
+ indent: indent,
119
+ count: Array.isArray(tree.children) ? tree.children.length : 0
120
+ };
121
+ result.push(item);
122
+ // If there are children, recursively flatten them
123
+ if (Array.isArray(tree.children)) {
124
+ for (const child of tree.children) {
125
+ result = result.concat(this.flattenDropDownList(child, indent + 1));
126
+ }
127
+ }
126
128
  }
127
129
  return result;
128
130
  }
@@ -147,4 +149,4 @@ export class ArrayHelper {
147
149
  return this.enumToKeyPairBaseArray(value);
148
150
  }
149
151
  }
150
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array-helper.js","sourceRoot":"","sources":["../../../../../projects/zek/src/lib/utils/array-helper.ts"],"names":[],"mappings":"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","sourcesContent":["// import { KeyPair } from \"../models/key-pair.model\";\r\n// import { Tree } from \"../models/tree.model\";\r\n\r\nimport { KeyPair, KeyPairEx, Tree } from \"../models\";\r\n\r\n\r\nexport class ArrayHelper {\r\n    static insert(array: any[], index: number, item: any) {\r\n        array.splice(index, 0, item);\r\n    }\r\n\r\n\r\n    /**\r\n     * Remove item from array\r\n     * @param array \r\n     * @param item item to remove\r\n     */\r\n    static remove(array: any[], item: any) {\r\n        const index = array.indexOf(item);\r\n        if (index > -1) { // only splice array when item is found\r\n            array.splice(index, 1); // 2nd parameter means remove one item only\r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * Remove all items from array\r\n     * @param array \r\n     * @param item item to remove\r\n     */\r\n    static removeAll(array: any[], item: any) {\r\n        var i = 0;\r\n        while (i < array.length) {\r\n            if (array[i] === item) {\r\n                array.splice(i, 1);\r\n            } else {\r\n                ++i;\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n    static move(array: any[], fromIndex: number, toIndex: number) {\r\n\r\n        const item = array[fromIndex];\r\n        array.splice(fromIndex, 1);//remove item frrom array\r\n        array.splice(toIndex, 0, item);//insert item into array\r\n        return array;\r\n    }\r\n\r\n    static contains(value: any[], v: any) {\r\n        for (let i = 0; i < value.length; i++) {\r\n            if (value[i] === v) return true;\r\n        }\r\n        return false;\r\n    }\r\n\r\n\r\n    static isArray(value: any) {\r\n        return Array.isArray(value) && value.length > 0;\r\n    }\r\n    // static distinct(value: any[]) {\r\n    //     var arr: any[] = [];\r\n    //     for (var i = 0; i < value.length; i++) {\r\n    //         let val = value[i];\r\n    //         if (!this.contains(arr, val)) {\r\n    //             arr.push(val);\r\n    //         }\r\n    //     }\r\n    //     return arr;\r\n    // }\r\n\r\n    static distinct(array: any[]) {\r\n        const length = array.length;\r\n        const result = []\r\n        const seen = new Set();\r\n\r\n        for (let index = 0; index < length; index++) {\r\n            const value = array[index];\r\n            if (seen.has(value)) continue;\r\n\r\n            seen.add(value);\r\n            result.push(value);\r\n        }\r\n\r\n        return result;\r\n    }\r\n\r\n    static filterByKey(filterValue: any, key: string, array: any[]) {\r\n        if (typeof filterValue === 'undefined' || filterValue == null || (typeof key === 'string' && key.length === 0))\r\n            return array;\r\n\r\n        return array.filter(x => x !== undefined && x !== null && x[key] === filterValue);\r\n    }\r\n\r\n    static flattenArray(array: any[]): any[] {\r\n        let result: any[] = [];\r\n        if (array) {\r\n            array.forEach(tree => {\r\n                tree.indent = 0;\r\n                result.push(tree);\r\n                result = result.concat(this.getChildren(tree));\r\n            });\r\n        }\r\n        return result;\r\n    }\r\n\r\n    private static getChildren(tree: Tree, indent: number = 1): any[] {\r\n        let result: any[] = [];\r\n        if (tree.children) {\r\n            tree.childrenCount = tree.children.length;\r\n            tree.children.forEach(child => {\r\n                child.indent = indent;\r\n                result.push(child);\r\n                result = result.concat(this.getChildren(child, indent + 1));\r\n            });\r\n        } else {\r\n            tree.childrenCount = 0;\r\n        }\r\n\r\n        delete tree.children;\r\n        delete tree.childrenIds;\r\n        //delete tree.childrenCount;\r\n        //delete tree.indent;\r\n        return result;\r\n    }\r\n\r\n\r\n\r\n    static treeToKeyPairArray(array: Tree[]) {\r\n        let result: KeyPair[] = [];\r\n        if (array) {\r\n            array.forEach(tree => {\r\n                result.push({ key: tree.key, value: tree.value });\r\n                result = result.concat(this.getIndentChildren(tree));\r\n            });\r\n        }\r\n\r\n        return result;\r\n    }\r\n\r\n\r\n    private static getIndentChildren(tree: Tree, indent: number = 1): KeyPair[] {\r\n        let result: KeyPair[] = [];\r\n        if (tree.children) {\r\n            tree.children.forEach(child => {\r\n                //result.push({ key: child.key, value: '└' + '─'.repeat(indent) + child.value });\r\n                result.push({ key: child.key, value: '&emsp;'.repeat(indent) + child.value });\r\n                result = result.concat(this.getChildren(child, indent + 1));\r\n            });\r\n        }\r\n        return result;\r\n    }\r\n\r\n\r\n\r\n    private static enumToKeyPairBaseArray<T extends KeyPair<number, string>>(value: any): T[] {\r\n        const keys = Object.keys(value);\r\n        const slice = keys.length / 2;\r\n        const result: T[] = [];\r\n        // for (let i = 0; i < slice; i++) {\r\n        //     result.push({ key: +keys[i], value: keys[i + slice] } as T);\r\n        // }\r\n        for (let i = slice; i < keys.length; i++) {\r\n            const name = keys[i];\r\n            result.push({ key: + value[name], value: name } as T);\r\n        }\r\n        return result;\r\n        //return Array.from(keys.slice(keys.length / 2), x => { key:x, value:'aaa' } as Object);\r\n    }\r\n    static enumToKeyPairArray(value: any): KeyPair<number, string>[] {\r\n        return this.enumToKeyPairBaseArray<KeyPair<number, string>>(value);\r\n    }\r\n    static enumToKeyPairExArray(value: any): KeyPairEx<number, string>[] {\r\n        return this.enumToKeyPairBaseArray<KeyPairEx<number, string>>(value);\r\n    }\r\n}"]}
152
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array-helper.js","sourceRoot":"","sources":["../../../../../projects/zek/src/lib/utils/array-helper.ts"],"names":[],"mappings":"AAAA,sDAAsD;AACtD,+CAA+C;AAM/C,MAAM,OAAO,WAAW;IACpB,MAAM,CAAC,MAAM,CAAC,KAAY,EAAE,KAAa,EAAE,IAAS;QAChD,KAAK,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;IACjC,CAAC;IAGD;;;;OAIG;IACH,MAAM,CAAC,MAAM,CAAC,KAAY,EAAE,IAAS;QACjC,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,uCAAuC;YACrD,KAAK,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,2CAA2C;QACvE,CAAC;IACL,CAAC;IAGD;;;;OAIG;IACH,MAAM,CAAC,SAAS,CAAC,KAAY,EAAE,IAAS;QACpC,IAAI,CAAC,GAAG,CAAC,CAAC;QACV,OAAO,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC;YACtB,IAAI,KAAK,CAAC,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC;gBACpB,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YACvB,CAAC;iBAAM,CAAC;gBACJ,EAAE,CAAC,CAAC;YACR,CAAC;QACL,CAAC;IACL,CAAC;IAGD,MAAM,CAAC,IAAI,CAAC,KAAY,EAAE,SAAiB,EAAE,OAAe;QAExD,MAAM,IAAI,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC;QAC9B,KAAK,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,CAAA,yBAAyB;QACpD,KAAK,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC,CAAA,wBAAwB;QACvD,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,MAAM,CAAC,QAAQ,CAAC,KAAY,EAAE,CAAM;QAChC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACpC,IAAI,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC;gBAAE,OAAO,IAAI,CAAC;QACpC,CAAC;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;IAGD,MAAM,CAAC,OAAO,CAAC,KAAU;QACrB,OAAO,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;IACpD,CAAC;IACD,kCAAkC;IAClC,2BAA2B;IAC3B,+CAA+C;IAC/C,8BAA8B;IAC9B,0CAA0C;IAC1C,6BAA6B;IAC7B,YAAY;IACZ,QAAQ;IACR,kBAAkB;IAClB,IAAI;IAEJ,MAAM,CAAC,QAAQ,CAAC,KAAY;QACxB,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;QAC5B,MAAM,MAAM,GAAG,EAAE,CAAA;QACjB,MAAM,IAAI,GAAG,IAAI,GAAG,EAAE,CAAC;QAEvB,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC;YAC1C,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;YAC3B,IAAI,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC;gBAAE,SAAS;YAE9B,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YAChB,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC;QAED,OAAO,MAAM,CAAC;IAClB,CAAC;IAED,MAAM,CAAC,WAAW,CAAC,WAAgB,EAAE,GAAW,EAAE,KAAY;QAC1D,IAAI,OAAO,WAAW,KAAK,WAAW,IAAI,WAAW,IAAI,IAAI,IAAI,CAAC,OAAO,GAAG,KAAK,QAAQ,IAAI,GAAG,CAAC,MAAM,KAAK,CAAC,CAAC;YAC1G,OAAO,KAAK,CAAC;QAEjB,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,SAAS,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC,GAAG,CAAC,KAAK,WAAW,CAAC,CAAC;IACtF,CAAC;IAGD,MAAM,CAAC,OAAO,CAAC,KAAU,EAAE,SAAiB,CAAC;QACzC,IAAI,MAAM,GAAU,EAAE,CAAC;QACvB,yDAAyD;QACzD,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YACvB,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;gBACvB,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC;YACvD,CAAC;QACL,CAAC;aAAM,CAAC;YACJ,0CAA0C;YAC1C,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;YACtC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;YACrB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC;gBACtC,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM;gBACvB,CAAC,CAAC,CAAC,CAAC;YACR,OAAO,IAAI,CAAC,QAAQ,CAAC;YACrB,OAAO,IAAI,CAAC,WAAW,CAAC;YACxB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAClB,kDAAkD;YAClD,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAChC,KAAK,MAAM,KAAK,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;oBACjC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;gBAC5D,CAAC;YACL,CAAC;QACL,CAAC;QAED,OAAO,MAAM,CAAC;IAClB,CAAC;IAED,MAAM,CAAC,mBAAmB,CAAC,IAAmB,EAAE,SAAiB,CAAC;QAC9D,IAAI,MAAM,GAAmB,EAAE,CAAC;QAChC,yDAAyD;QACzD,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;YACtB,KAAK,MAAM,IAAI,IAAI,IAAI,EAAE,CAAC;gBACtB,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC;YACnE,CAAC;QACL,CAAC;aAAM,CAAC;YACJ,0CAA0C;YAC1C,IAAI,IAAI,GAAG;gBACP,GAAG,EAAE,IAAI,CAAC,GAAG;gBACb,KAAK,EAAE,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK;gBAC3C,MAAM,EAAE,MAAM;gBACd,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;aACjD,CAAC;YAClB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAClB,kDAAkD;YAClD,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC/B,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;oBAChC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,KAAK,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;gBACxE,CAAC;YAEL,CAAC;QACL,CAAC;QAED,OAAO,MAAM,CAAC;IAClB,CAAC;IAIO,MAAM,CAAC,sBAAsB,CAAoC,KAAU;QAC/E,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAChC,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;QAC9B,MAAM,MAAM,GAAQ,EAAE,CAAC;QACvB,oCAAoC;QACpC,mEAAmE;QACnE,IAAI;QACJ,KAAK,IAAI,CAAC,GAAG,KAAK,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACvC,MAAM,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;YACrB,MAAM,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,CAAE,KAAK,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,IAAI,EAAO,CAAC,CAAC;QAC1D,CAAC;QACD,OAAO,MAAM,CAAC;QACd,wFAAwF;IAC5F,CAAC;IACD,MAAM,CAAC,kBAAkB,CAAC,KAAU;QAChC,OAAO,IAAI,CAAC,sBAAsB,CAA0B,KAAK,CAAC,CAAC;IACvE,CAAC;IACD,MAAM,CAAC,oBAAoB,CAAC,KAAU;QAClC,OAAO,IAAI,CAAC,sBAAsB,CAA4B,KAAK,CAAC,CAAC;IACzE,CAAC;CACJ","sourcesContent":["// import { KeyPair } from \"../models/key-pair.model\";\r\n// import { Tree } from \"../models/tree.model\";\r\n\r\nimport { KeyPair, KeyPairEx, Tree } from \"../models\";\r\nimport { IFlattenTree } from \"../models/flatten-tree\";\r\n\r\n\r\nexport class ArrayHelper {\r\n    static insert(array: any[], index: number, item: any) {\r\n        array.splice(index, 0, item);\r\n    }\r\n\r\n\r\n    /**\r\n     * Remove item from array\r\n     * @param array \r\n     * @param item item to remove\r\n     */\r\n    static remove(array: any[], item: any) {\r\n        const index = array.indexOf(item);\r\n        if (index > -1) { // only splice array when item is found\r\n            array.splice(index, 1); // 2nd parameter means remove one item only\r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * Remove all items from array\r\n     * @param array \r\n     * @param item item to remove\r\n     */\r\n    static removeAll(array: any[], item: any) {\r\n        var i = 0;\r\n        while (i < array.length) {\r\n            if (array[i] === item) {\r\n                array.splice(i, 1);\r\n            } else {\r\n                ++i;\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n    static move(array: any[], fromIndex: number, toIndex: number) {\r\n\r\n        const item = array[fromIndex];\r\n        array.splice(fromIndex, 1);//remove item frrom array\r\n        array.splice(toIndex, 0, item);//insert item into array\r\n        return array;\r\n    }\r\n\r\n    static contains(value: any[], v: any) {\r\n        for (let i = 0; i < value.length; i++) {\r\n            if (value[i] === v) return true;\r\n        }\r\n        return false;\r\n    }\r\n\r\n\r\n    static isArray(value: any) {\r\n        return Array.isArray(value) && value.length > 0;\r\n    }\r\n    // static distinct(value: any[]) {\r\n    //     var arr: any[] = [];\r\n    //     for (var i = 0; i < value.length; i++) {\r\n    //         let val = value[i];\r\n    //         if (!this.contains(arr, val)) {\r\n    //             arr.push(val);\r\n    //         }\r\n    //     }\r\n    //     return arr;\r\n    // }\r\n\r\n    static distinct(array: any[]) {\r\n        const length = array.length;\r\n        const result = []\r\n        const seen = new Set();\r\n\r\n        for (let index = 0; index < length; index++) {\r\n            const value = array[index];\r\n            if (seen.has(value)) continue;\r\n\r\n            seen.add(value);\r\n            result.push(value);\r\n        }\r\n\r\n        return result;\r\n    }\r\n\r\n    static filterByKey(filterValue: any, key: string, array: any[]) {\r\n        if (typeof filterValue === 'undefined' || filterValue == null || (typeof key === 'string' && key.length === 0))\r\n            return array;\r\n\r\n        return array.filter(x => x !== undefined && x !== null && x[key] === filterValue);\r\n    }\r\n\r\n\r\n    static flatten(array: any, indent: number = 0) {\r\n        let result: any[] = [];\r\n        // If the input is an array of trees, we process each one\r\n        if (Array.isArray(array)) {\r\n            for (const item of array) {\r\n                result = result.concat(this.flatten(item, indent));\r\n            }\r\n        } else {\r\n            // Add the current tree node to the result\r\n            const item = Object.assign({}, array);\r\n            item.indent = indent;\r\n            item.count = Array.isArray(array.children)\r\n                ? array.children.length\r\n                : 0;\r\n            delete item.children;\r\n            delete item.childrenIds;\r\n            result.push(item);\r\n            // If there are children, recursively flatten them\r\n            if (Array.isArray(array.children)) {\r\n                for (const child of array.children) {\r\n                    result = result.concat(this.flatten(child, indent + 1));\r\n                }\r\n            }\r\n        }\r\n\r\n        return result;\r\n    }\r\n\r\n    static flattenDropDownList(tree: Tree | Tree[], indent: number = 0) {\r\n        let result: IFlattenTree[] = [];\r\n        // If the input is an array of trees, we process each one\r\n        if (Array.isArray(tree)) {\r\n            for (const item of tree) {\r\n                result = result.concat(this.flattenDropDownList(item, indent));\r\n            }\r\n        } else {\r\n            // Add the current tree node to the result\r\n            let item = {\r\n                key: tree.key,\r\n                value: '&emsp;'.repeat(indent) + tree.value,\r\n                indent: indent,\r\n                count: Array.isArray(tree.children) ? tree.children.length : 0\r\n            } as IFlattenTree;\r\n            result.push(item);\r\n            // If there are children, recursively flatten them\r\n            if (Array.isArray(tree.children)) {\r\n                for (const child of tree.children) {\r\n                    result = result.concat(this.flattenDropDownList(child, indent + 1));\r\n                }\r\n\r\n            }\r\n        }\r\n\r\n        return result;\r\n    }\r\n\r\n\r\n\r\n    private static enumToKeyPairBaseArray<T extends KeyPair<number, string>>(value: any): T[] {\r\n        const keys = Object.keys(value);\r\n        const slice = keys.length / 2;\r\n        const result: T[] = [];\r\n        // for (let i = 0; i < slice; i++) {\r\n        //     result.push({ key: +keys[i], value: keys[i + slice] } as T);\r\n        // }\r\n        for (let i = slice; i < keys.length; i++) {\r\n            const name = keys[i];\r\n            result.push({ key: + value[name], value: name } as T);\r\n        }\r\n        return result;\r\n        //return Array.from(keys.slice(keys.length / 2), x => { key:x, value:'aaa' } as Object);\r\n    }\r\n    static enumToKeyPairArray(value: any): KeyPair<number, string>[] {\r\n        return this.enumToKeyPairBaseArray<KeyPair<number, string>>(value);\r\n    }\r\n    static enumToKeyPairExArray(value: any): KeyPairEx<number, string>[] {\r\n        return this.enumToKeyPairBaseArray<KeyPairEx<number, string>>(value);\r\n    }\r\n}"]}
package/fesm2022/zek.mjs CHANGED
@@ -97,54 +97,56 @@ class ArrayHelper {
97
97
  return array;
98
98
  return array.filter(x => x !== undefined && x !== null && x[key] === filterValue);
99
99
  }
100
- static flattenArray(array) {
100
+ static flatten(array, indent = 0) {
101
101
  let result = [];
102
- if (array) {
103
- array.forEach(tree => {
104
- tree.indent = 0;
105
- result.push(tree);
106
- result = result.concat(this.getChildren(tree));
107
- });
108
- }
109
- return result;
110
- }
111
- static getChildren(tree, indent = 1) {
112
- let result = [];
113
- if (tree.children) {
114
- tree.childrenCount = tree.children.length;
115
- tree.children.forEach(child => {
116
- child.indent = indent;
117
- result.push(child);
118
- result = result.concat(this.getChildren(child, indent + 1));
119
- });
102
+ // If the input is an array of trees, we process each one
103
+ if (Array.isArray(array)) {
104
+ for (const item of array) {
105
+ result = result.concat(this.flatten(item, indent));
106
+ }
120
107
  }
121
108
  else {
122
- tree.childrenCount = 0;
109
+ // Add the current tree node to the result
110
+ const item = Object.assign({}, array);
111
+ item.indent = indent;
112
+ item.count = Array.isArray(array.children)
113
+ ? array.children.length
114
+ : 0;
115
+ delete item.children;
116
+ delete item.childrenIds;
117
+ result.push(item);
118
+ // If there are children, recursively flatten them
119
+ if (Array.isArray(array.children)) {
120
+ for (const child of array.children) {
121
+ result = result.concat(this.flatten(child, indent + 1));
122
+ }
123
+ }
123
124
  }
124
- delete tree.children;
125
- delete tree.childrenIds;
126
- //delete tree.childrenCount;
127
- //delete tree.indent;
128
125
  return result;
129
126
  }
130
- static treeToKeyPairArray(array) {
127
+ static flattenDropDownList(tree, indent = 0) {
131
128
  let result = [];
132
- if (array) {
133
- array.forEach(tree => {
134
- result.push({ key: tree.key, value: tree.value });
135
- result = result.concat(this.getIndentChildren(tree));
136
- });
129
+ // If the input is an array of trees, we process each one
130
+ if (Array.isArray(tree)) {
131
+ for (const item of tree) {
132
+ result = result.concat(this.flattenDropDownList(item, indent));
133
+ }
137
134
  }
138
- return result;
139
- }
140
- static getIndentChildren(tree, indent = 1) {
141
- let result = [];
142
- if (tree.children) {
143
- tree.children.forEach(child => {
144
- //result.push({ key: child.key, value: '└' + '─'.repeat(indent) + child.value });
145
- result.push({ key: child.key, value: ' '.repeat(indent) + child.value });
146
- result = result.concat(this.getChildren(child, indent + 1));
147
- });
135
+ else {
136
+ // Add the current tree node to the result
137
+ let item = {
138
+ key: tree.key,
139
+ value: ' '.repeat(indent) + tree.value,
140
+ indent: indent,
141
+ count: Array.isArray(tree.children) ? tree.children.length : 0
142
+ };
143
+ result.push(item);
144
+ // If there are children, recursively flatten them
145
+ if (Array.isArray(tree.children)) {
146
+ for (const child of tree.children) {
147
+ result = result.concat(this.flattenDropDownList(child, indent + 1));
148
+ }
149
+ }
148
150
  }
149
151
  return result;
150
152
  }