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
|
|
78
|
+
static flatten(array, indent = 0) {
|
|
79
79
|
let result = [];
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
result.
|
|
84
|
-
|
|
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
|
|
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
|
|
105
|
+
static flattenDropDownList(tree, indent = 0) {
|
|
109
106
|
let result = [];
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
result = result.concat(this.
|
|
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
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
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":"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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\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
|
|
100
|
+
static flatten(array, indent = 0) {
|
|
101
101
|
let result = [];
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
result.
|
|
106
|
-
|
|
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
|
|
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
|
|
127
|
+
static flattenDropDownList(tree, indent = 0) {
|
|
131
128
|
let result = [];
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
result = result.concat(this.
|
|
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
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
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
|
}
|