zek 17.3.92 → 17.3.118

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.
@@ -77,53 +77,74 @@ export class ArrayHelper {
77
77
  }
78
78
  static flatten(array, indent = 0) {
79
79
  let result = [];
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));
80
+ if (!Array.isArray(array)) {
81
+ const flattenedItem = {
82
+ ...array, // shallow copy the current item
83
+ indent, // add the current indent level
84
+ count: Array.isArray(array.children) ? array.children.length : 0 // set count based on children
85
+ };
86
+ delete flattenedItem.children;
87
+ delete flattenedItem.childrenIds;
88
+ result.push(flattenedItem);
89
+ if (flattenedItem.count) {
90
+ result.push(...this.flatten(array.children, indent + 1)); // Use spread operator for efficiency
84
91
  }
92
+ return result;
85
93
  }
86
94
  else {
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
- }
95
+ for (const item of array) {
96
+ result.push(...this.flatten(item, indent));
101
97
  }
102
98
  }
103
99
  return result;
104
100
  }
101
+ /**
102
+ * @deprecated use flattenDropDownList2
103
+ */
105
104
  static flattenDropDownList(tree, indent = 0) {
106
105
  let result = [];
107
106
  // 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));
107
+ if (!Array.isArray(tree)) {
108
+ // Add the current tree node to the result
109
+ let item = {
110
+ key: tree.key,
111
+ value: ' '.repeat(indent) + tree.value,
112
+ indent: indent,
113
+ count: Array.isArray(tree.children) ? tree.children.length : 0
114
+ };
115
+ result.push(item);
116
+ // If there are children, recursively flatten them
117
+ if (Array.isArray(tree.children)) {
118
+ result.push(...this.flattenDropDownList(tree.children, indent + 1)); // Use spread operator for efficiency
111
119
  }
112
120
  }
113
121
  else {
122
+ for (const item of tree) {
123
+ result.push(...this.flattenDropDownList(item, indent));
124
+ }
125
+ }
126
+ return result;
127
+ }
128
+ static flattenTreeNodeDropDownList(tree, indent = 0) {
129
+ let result = [];
130
+ // If the input is an array of trees, we process each one
131
+ if (!Array.isArray(tree)) {
114
132
  // Add the current tree node to the result
115
133
  let item = {
116
- key: tree.key,
117
- value: ' '.repeat(indent) + tree.value,
134
+ id: tree.id,
135
+ name: ' '.repeat(indent) + tree.name,
118
136
  indent: indent,
119
137
  count: Array.isArray(tree.children) ? tree.children.length : 0
120
138
  };
121
139
  result.push(item);
122
140
  // If there are children, recursively flatten them
123
141
  if (Array.isArray(tree.children)) {
124
- for (const child of tree.children) {
125
- result = result.concat(this.flattenDropDownList(child, indent + 1));
126
- }
142
+ result.push(...this.flattenTreeNodeDropDownList(tree.children, indent + 1)); // Use spread operator for efficiency
143
+ }
144
+ }
145
+ else {
146
+ for (const item of tree) {
147
+ result.push(...this.flattenTreeNodeDropDownList(item, indent));
127
148
  }
128
149
  }
129
150
  return result;
@@ -148,5 +169,48 @@ export class ArrayHelper {
148
169
  static enumToKeyPairExArray(value) {
149
170
  return this.enumToKeyPairBaseArray(value);
150
171
  }
172
+ /**
173
+ * Method to create a tree from a flat array of nodes
174
+ * @param array
175
+ * @param safe if tue and some nodes not have parent thand adds as a root node. if false than thoose nodes skipped.
176
+ * @returns
177
+ */
178
+ static createTree(array, safe = true) {
179
+ const tree = [];
180
+ // Map to store nodes by their id for easy access
181
+ const map = {};
182
+ // Step 1: Loop over the array to build the nodes
183
+ for (const item of array) {
184
+ const node = {
185
+ id: item.id,
186
+ parentId: item.parentId ?? null,
187
+ name: item.name ?? null,
188
+ children: null
189
+ };
190
+ map[node.id] = node;
191
+ }
192
+ for (const item of array) {
193
+ const node = map[item.id];
194
+ // Step 2: Check if it's a root or child and assign to parent or tree
195
+ if (typeof node.parentId === 'undefined' || node.parentId === null) {
196
+ // Root node, add directly to the tree
197
+ tree.push(node);
198
+ }
199
+ else {
200
+ // Non-root node, find its parent and add to its children
201
+ let parentNode = map[node.parentId];
202
+ if (parentNode) {
203
+ if (!Array.isArray(parentNode.children))
204
+ parentNode.children = [];
205
+ parentNode.children.push(node);
206
+ }
207
+ else if (safe) {
208
+ //if save=true and parent node not exists, then we add as a root node
209
+ tree.push(node);
210
+ }
211
+ }
212
+ }
213
+ return tree;
214
+ }
151
215
  }
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}"]}
216
+ //# 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, IFlattenTreeNode, INode, ITreeNode } from \"../models/tree\";\r\n\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\r\n    static flatten(array: any, indent: number = 0) {\r\n        let result: any[] = [];\r\n        if (!Array.isArray(array)) {\r\n            const flattenedItem = {\r\n                ...array, // shallow copy the current item\r\n                indent, // add the current indent level\r\n                count: Array.isArray(array.children) ? array.children.length : 0 // set count based on children\r\n            };\r\n\r\n            delete flattenedItem.children;\r\n            delete flattenedItem.childrenIds;\r\n            result.push(flattenedItem);\r\n\r\n            if (flattenedItem.count) {\r\n                result.push(...this.flatten(array.children, indent + 1)); // Use spread operator for efficiency\r\n            }\r\n\r\n            return result;\r\n        } else {\r\n\r\n            for (const item of array) {\r\n                result.push(...this.flatten(item, indent));\r\n            }\r\n        }\r\n\r\n        return result;\r\n    }\r\n\r\n    /**\r\n    * @deprecated use flattenDropDownList2\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            // Add the current tree node to the result\r\n            let item: IFlattenTree = {\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                result.push(...this.flattenDropDownList(tree.children, indent + 1)); // Use spread operator for efficiency\r\n            }\r\n        } else {\r\n            for (const item of tree) {\r\n                result.push(...this.flattenDropDownList(item, indent));\r\n            }\r\n        }\r\n\r\n        return result;\r\n    }\r\n\r\n    static flattenTreeNodeDropDownList(tree: ITreeNode | ITreeNode[], indent: number = 0) {\r\n        let result: IFlattenTreeNode[] = [];\r\n        // If the input is an array of trees, we process each one\r\n        if (!Array.isArray(tree)) {\r\n            // Add the current tree node to the result\r\n            let item: IFlattenTreeNode = {\r\n                id: tree.id,\r\n                name: '&emsp;'.repeat(indent) + tree.name,\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                result.push(...this.flattenTreeNodeDropDownList(tree.children, indent + 1)); // Use spread operator for efficiency\r\n            }\r\n        } else {\r\n            for (const item of tree) {\r\n                result.push(...this.flattenTreeNodeDropDownList(item, indent));\r\n            }\r\n        }\r\n\r\n        return result;\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\r\n\r\n\r\n\r\n\r\n    /**\r\n     * Method to create a tree from a flat array of nodes\r\n     * @param array \r\n     * @param safe if tue and some nodes not have parent thand adds as a root node. if false than thoose nodes skipped.\r\n     * @returns \r\n     */\r\n    static createTree(array: INode[], safe = true): ITreeNode[] {\r\n        const tree: ITreeNode[] = [];\r\n\r\n        // Map to store nodes by their id for easy access\r\n        const map: { [key: number]: ITreeNode } = {};\r\n\r\n        // Step 1: Loop over the array to build the nodes\r\n        for (const item of array) {\r\n            const node: ITreeNode = {\r\n                id: item.id,\r\n                parentId: item.parentId ?? null,\r\n                name: item.name ?? null,\r\n                children: null\r\n            };\r\n            map[node.id] = node;\r\n        }\r\n\r\n        for (const item of array) {\r\n            const node = map[item.id];\r\n\r\n            // Step 2: Check if it's a root or child and assign to parent or tree\r\n            if (typeof node.parentId === 'undefined' || node.parentId === null) {\r\n                // Root node, add directly to the tree\r\n                tree.push(node);\r\n            } else {\r\n                // Non-root node, find its parent and add to its children\r\n                let parentNode = map[node.parentId];\r\n                if (parentNode) {\r\n                    if (!Array.isArray(parentNode.children))\r\n                        parentNode.children = [];\r\n                    parentNode.children.push(node);\r\n                } else if (safe) {\r\n                    //if save=true and parent node not exists, then we add as a root node\r\n                    tree.push(node);\r\n                }\r\n            }\r\n        }\r\n\r\n        return tree;\r\n    }\r\n\r\n}"]}
@@ -21,7 +21,8 @@ export * from './storage-helper';
21
21
  export * from './string-helper';
22
22
  export * from './thenBy';
23
23
  export * from './time-helper';
24
+ export * from './interval-helper';
24
25
  export * from './tmp-helper';
25
26
  export * from './url-helper';
26
27
  export * from './validation-helper';
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi91dGlscy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMscUJBQXFCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2FycmF5LWhlbHBlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vYmFzZTY0LWhlbHBlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vYml0d2lzZS1oZWxwZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL2Jvb3RzdHJhcC5oZWxwZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL2NvbnZlcnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2Nzcy1oZWxwZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL2RhdGUtaGVscGVyJztcclxuZXhwb3J0ICogZnJvbSAnLi9lcnJvci1oZWxwZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL2V4Y2VsLWhlbHBlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vZmlsZS5oZWxwZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL2ZpbHRlci1oZWxwZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL2hhbmRsZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL2h0bWwtaGVscGVyJztcclxuZXhwb3J0ICogZnJvbSAnLi9qd3QtaGVscGVyJztcclxuZXhwb3J0ICogZnJvbSAnLi9tYXRoLWhlbHBlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vb2JqZWN0LWhlbHBlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vb3ZlcmxhcC1oZWxwZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL3BhZ2VyLWhlbHBlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vcmFuZG9tLWhlbHBlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vc3RvcmFnZS1oZWxwZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL3N0cmluZy1oZWxwZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL3RoZW5CeSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vdGltZS1oZWxwZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL3RtcC1oZWxwZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL3VybC1oZWxwZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL3ZhbGlkYXRpb24taGVscGVyJzsiXX0=
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi91dGlscy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxxQkFBcUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYXJyYXktaGVscGVyJztcclxuZXhwb3J0ICogZnJvbSAnLi9iYXNlNjQtaGVscGVyJztcclxuZXhwb3J0ICogZnJvbSAnLi9iaXR3aXNlLWhlbHBlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vYm9vdHN0cmFwLmhlbHBlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vY29udmVydCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY3NzLWhlbHBlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vZGF0ZS1oZWxwZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL2Vycm9yLWhlbHBlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vZXhjZWwtaGVscGVyJztcclxuZXhwb3J0ICogZnJvbSAnLi9maWxlLmhlbHBlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vZmlsdGVyLWhlbHBlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vaGFuZGxlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vaHRtbC1oZWxwZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL2p3dC1oZWxwZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL21hdGgtaGVscGVyJztcclxuZXhwb3J0ICogZnJvbSAnLi9vYmplY3QtaGVscGVyJztcclxuZXhwb3J0ICogZnJvbSAnLi9vdmVybGFwLWhlbHBlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vcGFnZXItaGVscGVyJztcclxuZXhwb3J0ICogZnJvbSAnLi9yYW5kb20taGVscGVyJztcclxuZXhwb3J0ICogZnJvbSAnLi9zdG9yYWdlLWhlbHBlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vc3RyaW5nLWhlbHBlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vdGhlbkJ5JztcclxuZXhwb3J0ICogZnJvbSAnLi90aW1lLWhlbHBlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vaW50ZXJ2YWwtaGVscGVyJztcclxuZXhwb3J0ICogZnJvbSAnLi90bXAtaGVscGVyJztcclxuZXhwb3J0ICogZnJvbSAnLi91cmwtaGVscGVyJztcclxuZXhwb3J0ICogZnJvbSAnLi92YWxpZGF0aW9uLWhlbHBlcic7Il19
@@ -0,0 +1,32 @@
1
+ export class IntervalHelper {
2
+ static { this._timeouts = []; }
3
+ static create(callback, ms) {
4
+ const id = setInterval(() => {
5
+ callback();
6
+ }, ms);
7
+ const timeout = {
8
+ id: +id,
9
+ callback: callback.toString(),
10
+ interval: ms,
11
+ createdAt: new Date()
12
+ };
13
+ this._timeouts.push(timeout);
14
+ return timeout;
15
+ }
16
+ static clear(id) {
17
+ const index = this._timeouts.findIndex(x => x.id === id);
18
+ if (index !== -1) {
19
+ clearInterval(id);
20
+ this._timeouts.splice(index, 1);
21
+ return true;
22
+ }
23
+ return false;
24
+ }
25
+ static clearAll() {
26
+ for (const timeout of this._timeouts) {
27
+ this.clear(timeout.id);
28
+ }
29
+ this._timeouts = [];
30
+ }
31
+ }
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJ2YWwtaGVscGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvdXRpbHMvaW50ZXJ2YWwtaGVscGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFBLE1BQU0sT0FBTyxjQUFjO2FBQ1YsY0FBUyxHQUFlLEVBQUUsQ0FBQztJQUUxQyxNQUFNLENBQUMsTUFBTSxDQUFDLFFBQWtCLEVBQUUsRUFBVTtRQUMxQyxNQUFNLEVBQUUsR0FBRyxXQUFXLENBQUMsR0FBRyxFQUFFO1lBQzFCLFFBQVEsRUFBRSxDQUFDO1FBQ2IsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRVAsTUFBTSxPQUFPLEdBQUc7WUFDZCxFQUFFLEVBQUUsQ0FBQyxFQUFFO1lBQ1AsUUFBUSxFQUFFLFFBQVEsQ0FBQyxRQUFRLEVBQUU7WUFDN0IsUUFBUSxFQUFFLEVBQUU7WUFDWixTQUFTLEVBQUUsSUFBSSxJQUFJLEVBQUU7U0FDVixDQUFDO1FBQ2QsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDN0IsT0FBTyxPQUFPLENBQUM7SUFDakIsQ0FBQztJQUVELE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBVTtRQUNyQixNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7UUFDekQsSUFBSSxLQUFLLEtBQUssQ0FBQyxDQUFDLEVBQUUsQ0FBQztZQUNqQixhQUFhLENBQUMsRUFBRSxDQUFDLENBQUM7WUFDbEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQ2hDLE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQztRQUNELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVELE1BQU0sQ0FBQyxRQUFRO1FBQ2IsS0FBSyxNQUFNLE9BQU8sSUFBSSxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7WUFDckMsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDekIsQ0FBQztRQUNELElBQUksQ0FBQyxTQUFTLEdBQUcsRUFBRSxDQUFDO0lBQ3RCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJcclxuZXhwb3J0IGludGVyZmFjZSBJVGltZW91dCB7XHJcbiAgaWQ6IG51bWJlcjtcclxuICBjYWxsYmFjazogc3RyaW5nO1xyXG4gIGludGVydmFsOiBudW1iZXI7XHJcbiAgY3JlYXRlZEF0OiBEYXRlO1xyXG59XHJcblxyXG5leHBvcnQgY2xhc3MgSW50ZXJ2YWxIZWxwZXIge1xyXG4gIHByaXZhdGUgc3RhdGljIF90aW1lb3V0czogSVRpbWVvdXRbXSA9IFtdO1xyXG5cclxuICBzdGF0aWMgY3JlYXRlKGNhbGxiYWNrOiBGdW5jdGlvbiwgbXM6IG51bWJlcikge1xyXG4gICAgY29uc3QgaWQgPSBzZXRJbnRlcnZhbCgoKSA9PiB7XHJcbiAgICAgIGNhbGxiYWNrKCk7XHJcbiAgICB9LCBtcyk7XHJcblxyXG4gICAgY29uc3QgdGltZW91dCA9IHtcclxuICAgICAgaWQ6ICtpZCxcclxuICAgICAgY2FsbGJhY2s6IGNhbGxiYWNrLnRvU3RyaW5nKCksXHJcbiAgICAgIGludGVydmFsOiBtcyxcclxuICAgICAgY3JlYXRlZEF0OiBuZXcgRGF0ZSgpXHJcbiAgICB9IGFzIElUaW1lb3V0O1xyXG4gICAgdGhpcy5fdGltZW91dHMucHVzaCh0aW1lb3V0KTtcclxuICAgIHJldHVybiB0aW1lb3V0O1xyXG4gIH1cclxuXHJcbiAgc3RhdGljIGNsZWFyKGlkOiBudW1iZXIpIHtcclxuICAgIGNvbnN0IGluZGV4ID0gdGhpcy5fdGltZW91dHMuZmluZEluZGV4KHggPT4geC5pZCA9PT0gaWQpO1xyXG4gICAgaWYgKGluZGV4ICE9PSAtMSkge1xyXG4gICAgICBjbGVhckludGVydmFsKGlkKTtcclxuICAgICAgdGhpcy5fdGltZW91dHMuc3BsaWNlKGluZGV4LCAxKTtcclxuICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gZmFsc2U7XHJcbiAgfVxyXG5cclxuICBzdGF0aWMgY2xlYXJBbGwoKSB7XHJcbiAgICBmb3IgKGNvbnN0IHRpbWVvdXQgb2YgdGhpcy5fdGltZW91dHMpIHtcclxuICAgICAgdGhpcy5jbGVhcih0aW1lb3V0LmlkKTtcclxuICAgIH1cclxuICAgIHRoaXMuX3RpbWVvdXRzID0gW107XHJcbiAgfVxyXG59Il19
@@ -2,10 +2,11 @@
2
2
  * Public API Surface of zek
3
3
  */
4
4
  export * from "./lib/components";
5
+ export * from "./lib/directives";
5
6
  export * from "./lib/models";
6
7
  export * from "./lib/modules";
7
8
  export * from "./lib/services";
8
9
  export * from "./lib/utils";
9
10
  export * from "./lib/tokens";
10
11
  export * from "./lib/zek.module";
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3play9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGFBQWEsQ0FBQztBQUU1QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGtCQUFrQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIHpla1xyXG4gKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb21wb25lbnRzXCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9tb2RlbHNcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL21vZHVsZXNcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL3NlcnZpY2VzXCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi91dGlsc1wiO1xyXG5cclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL3Rva2Vuc1wiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvemVrLm1vZHVsZVwiOyJdfQ==
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3play9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsYUFBYSxDQUFDO0FBRTVCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsa0JBQWtCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgemVrXHJcbiAqL1xyXG5cclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbXBvbmVudHNcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL2RpcmVjdGl2ZXNcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL21vZGVsc1wiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvbW9kdWxlc1wiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvc2VydmljZXNcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL3V0aWxzXCI7XHJcblxyXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvdG9rZW5zXCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi96ZWsubW9kdWxlXCI7Il19