ng2-logger 19.0.1 → 19.0.3
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/assets/shared/shared_folder_info.txt +1 -1
- package/browser/esm2022/lib/backend-logging.mjs +94 -0
- package/browser/esm2022/lib/display.mjs +97 -0
- package/browser/esm2022/lib/index.mjs +7 -0
- package/browser/esm2022/lib/level.mjs +33 -0
- package/browser/esm2022/lib/log.mjs +161 -0
- package/browser/esm2022/lib/logger.mjs +237 -0
- package/browser/esm2022/ng2-logger.mjs +5 -0
- package/browser/esm2022/public-api.mjs +2 -0
- package/browser/fesm2022/ng2-logger.mjs.map +1 -1
- package/browser/package.json +13 -0
- package/client/esm2022/lib/backend-logging.mjs +94 -0
- package/client/esm2022/lib/display.mjs +97 -0
- package/client/esm2022/lib/index.mjs +7 -0
- package/client/esm2022/lib/level.mjs +33 -0
- package/client/esm2022/lib/log.mjs +161 -0
- package/client/esm2022/lib/logger.mjs +237 -0
- package/client/esm2022/ng2-logger.mjs +5 -0
- package/client/esm2022/public-api.mjs +2 -0
- package/client/fesm2022/ng2-logger.mjs.map +1 -1
- package/client/package.json +13 -0
- package/lib/build-info._auto-generated_.d.ts +1 -1
- package/lib/build-info._auto-generated_.js +1 -1
- package/package.json +1 -1
- package/tmp-environment.json +4 -3
- package/websql/esm2022/lib/backend-logging.mjs +94 -0
- package/websql/esm2022/lib/display.mjs +97 -0
- package/websql/esm2022/lib/index.mjs +7 -0
- package/websql/esm2022/lib/level.mjs +33 -0
- package/websql/esm2022/lib/log.mjs +161 -0
- package/websql/esm2022/lib/logger.mjs +237 -0
- package/websql/esm2022/ng2-logger.mjs +5 -0
- package/websql/esm2022/public-api.mjs +2 -0
- package/websql/fesm2022/ng2-logger.mjs.map +1 -1
- package/websql/package.json +13 -0
- package/taon.jsonc +0 -28
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
THIS FILE IS GENERATED - DO NOT MODIFY
|
|
2
2
|
|
|
3
|
-
Assets from this folder are being shipped with this npm package (ng2-logger
|
|
3
|
+
Assets from this folder are being shipped with this npm package (ng2-logger)
|
|
4
4
|
created from this project.
|
|
5
5
|
|
|
6
6
|
THIS FILE IS GENERATED - DO NOT MODIFY
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
/* */
|
|
2
|
+
/* */
|
|
3
|
+
/* */
|
|
4
|
+
/* */
|
|
5
|
+
/* */
|
|
6
|
+
/* */
|
|
7
|
+
/* */
|
|
8
|
+
export function consoleLog(data, level) {
|
|
9
|
+
/* */
|
|
10
|
+
/* */
|
|
11
|
+
/* */
|
|
12
|
+
/* */
|
|
13
|
+
/* */
|
|
14
|
+
/* */
|
|
15
|
+
/* */
|
|
16
|
+
/* */
|
|
17
|
+
}
|
|
18
|
+
export function displayParams(params = [], level) {
|
|
19
|
+
/* */
|
|
20
|
+
/* */
|
|
21
|
+
/* */
|
|
22
|
+
/* */
|
|
23
|
+
/* */
|
|
24
|
+
/* */
|
|
25
|
+
/* */
|
|
26
|
+
/* */
|
|
27
|
+
/* */
|
|
28
|
+
/* */
|
|
29
|
+
}
|
|
30
|
+
function replace(out, match, char, color) {
|
|
31
|
+
/* */
|
|
32
|
+
/* */
|
|
33
|
+
/* */
|
|
34
|
+
/* */
|
|
35
|
+
/* */
|
|
36
|
+
/* */
|
|
37
|
+
/* */
|
|
38
|
+
/* */
|
|
39
|
+
/* */
|
|
40
|
+
/* */
|
|
41
|
+
}
|
|
42
|
+
function handleObjectData(param, level) {
|
|
43
|
+
/* */
|
|
44
|
+
/* */
|
|
45
|
+
/* */
|
|
46
|
+
/* */
|
|
47
|
+
/* */
|
|
48
|
+
/* */
|
|
49
|
+
/* */
|
|
50
|
+
/* */
|
|
51
|
+
/* */
|
|
52
|
+
/* */
|
|
53
|
+
/* */
|
|
54
|
+
/* */
|
|
55
|
+
/* */
|
|
56
|
+
/* */
|
|
57
|
+
/* */
|
|
58
|
+
/* */
|
|
59
|
+
/* */
|
|
60
|
+
/* */
|
|
61
|
+
/* */
|
|
62
|
+
/* */
|
|
63
|
+
/* */
|
|
64
|
+
/* */
|
|
65
|
+
/* */
|
|
66
|
+
/* */
|
|
67
|
+
/* */
|
|
68
|
+
/* */
|
|
69
|
+
}
|
|
70
|
+
export function istartedInVscode() {
|
|
71
|
+
/* */
|
|
72
|
+
/* */
|
|
73
|
+
/* */
|
|
74
|
+
/* */
|
|
75
|
+
/* */
|
|
76
|
+
/* */
|
|
77
|
+
/* */
|
|
78
|
+
/* */
|
|
79
|
+
/* */
|
|
80
|
+
/* */
|
|
81
|
+
/* */
|
|
82
|
+
}
|
|
83
|
+
function isObjectAfterStringify(s) {
|
|
84
|
+
/* */
|
|
85
|
+
/* */
|
|
86
|
+
/* */
|
|
87
|
+
/* */
|
|
88
|
+
/* */
|
|
89
|
+
/* */
|
|
90
|
+
/* */
|
|
91
|
+
}
|
|
92
|
+
;
|
|
93
|
+
({}); // @--end-of-file-for-module=ng2-logger lib/backend-logging.ts
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFja2VuZC1sb2dnaW5nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vdG1wLWxpYnMtZm9yLWRpc3QvbmcyLWxvZ2dlci9wcm9qZWN0cy9uZzItbG9nZ2VyL3NyYy9saWIvYmFja2VuZC1sb2dnaW5nLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLEtBQUs7QUFDTCxLQUFLO0FBS0wsS0FBSztBQUNMLEtBQUs7QUFDTCxLQUFLO0FBQ0wsS0FBSztBQUNMLEtBQUs7QUFHTCxNQUFNLFVBQVUsVUFBVSxDQUFDLElBQVksRUFBRSxLQUFZO0lBQ3JELEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0FBRUwsQ0FBQztBQUdELE1BQU0sVUFBVSxhQUFhLENBQUMsU0FBZ0IsRUFBRSxFQUFFLEtBQVk7SUFDOUQsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztBQUVMLENBQUM7QUFFRCxTQUFTLE9BQU8sQ0FBQyxHQUFXLEVBQUUsS0FBYSxFQUFFLElBQVksRUFBRSxLQUFVO0lBQ3JFLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7QUFFTCxDQUFDO0FBR0QsU0FBUyxnQkFBZ0IsQ0FBQyxLQUFhLEVBQUUsS0FBWTtJQUNyRCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztBQUVMLENBQUM7QUFHRCxNQUFNLFVBQVUsZ0JBQWdCO0lBQ2hDLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0FBRUwsQ0FBQztBQUVELFNBQVMsc0JBQXNCLENBQUMsQ0FBUztJQUN6QyxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0lBQ0wsS0FBSztJQUNMLEtBQUs7SUFDTCxLQUFLO0FBRUwsQ0FBQztBQUVBLENBQUM7QUFBQSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsOERBQThEIiwic291cmNlc0NvbnRlbnQiOlsiXG5cbi8qICovXG4vKiAqL1xuICBcblxuaW1wb3J0IHsgTGV2ZWwgfSBmcm9tICcuL2xldmVsJztcblxuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4gIFxuXG5leHBvcnQgZnVuY3Rpb24gY29uc29sZUxvZyhkYXRhOiBzdHJpbmcsIGxldmVsOiBMZXZlbCkge1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4gIFxufVxuXG5cbmV4cG9ydCBmdW5jdGlvbiBkaXNwbGF5UGFyYW1zKHBhcmFtczogYW55W10gPSBbXSwgbGV2ZWw6IExldmVsKSB7XG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuICBcbn1cblxuZnVuY3Rpb24gcmVwbGFjZShvdXQ6IHN0cmluZywgbWF0Y2g6IFJlZ0V4cCwgY2hhcjogUmVnRXhwLCBjb2xvcjogYW55KSB7XG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuICBcbn1cblxuXG5mdW5jdGlvbiBoYW5kbGVPYmplY3REYXRhKHBhcmFtOiBzdHJpbmcsIGxldmVsOiBMZXZlbCkge1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4gIFxufVxuXG5cbmV4cG9ydCBmdW5jdGlvbiBpc3RhcnRlZEluVnNjb2RlKCkge1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4gIFxufVxuXG5mdW5jdGlvbiBpc09iamVjdEFmdGVyU3RyaW5naWZ5KHM6IHN0cmluZykge1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbiAgXG59XG5cbiA7KHt9KTsgLy8gQC0tZW5kLW9mLWZpbGUtZm9yLW1vZHVsZT1uZzItbG9nZ2VyIGxpYi9iYWNrZW5kLWxvZ2dpbmcudHMiXX0=
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
/* */
|
|
2
|
+
/* */
|
|
3
|
+
import { Level } from './level';
|
|
4
|
+
import { Helpers } from 'tnp-core/browser';
|
|
5
|
+
/* */
|
|
6
|
+
/* */
|
|
7
|
+
export class Display {
|
|
8
|
+
static msg(message, params, moduleName, moduleColor, level, moduleWidth, isProductionMode) {
|
|
9
|
+
if (isProductionMode) {
|
|
10
|
+
return;
|
|
11
|
+
}
|
|
12
|
+
;
|
|
13
|
+
let color = 'gray';
|
|
14
|
+
if (level === Level.INFO) {
|
|
15
|
+
color = 'deepskyblue';
|
|
16
|
+
}
|
|
17
|
+
if (level === Level.ERROR) {
|
|
18
|
+
color = 'red';
|
|
19
|
+
}
|
|
20
|
+
if (level === Level.WARN) {
|
|
21
|
+
color = 'orange';
|
|
22
|
+
}
|
|
23
|
+
if (moduleWidth) {
|
|
24
|
+
const diff = moduleWidth - moduleName.length;
|
|
25
|
+
if (diff > 0) {
|
|
26
|
+
for (let i = 0; i < diff; i++) {
|
|
27
|
+
moduleName += ' ';
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
if (Helpers.isBrowser
|
|
32
|
+
/* */
|
|
33
|
+
/* */
|
|
34
|
+
) {
|
|
35
|
+
// @ts-ignore
|
|
36
|
+
const isEdgeOrIe8orAbove = (document['documentMode'] || /Edge/.test(navigator.userAgent));
|
|
37
|
+
if (isEdgeOrIe8orAbove) {
|
|
38
|
+
if (typeof message === 'string') {
|
|
39
|
+
let a1 = '[[ ' + moduleName + ' ]] ' + message + ' ';
|
|
40
|
+
params.unshift(a1);
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
let a1 = '[[ ' + moduleName + ']] ';
|
|
44
|
+
params.push(message);
|
|
45
|
+
params.unshift(a1);
|
|
46
|
+
}
|
|
47
|
+
if (level === Level.INFO) {
|
|
48
|
+
console.info.apply(console, params);
|
|
49
|
+
}
|
|
50
|
+
else if (level === Level.ERROR) {
|
|
51
|
+
console.error.apply(console, params);
|
|
52
|
+
}
|
|
53
|
+
else if (level === Level.WARN) {
|
|
54
|
+
console.warn.apply(console, params);
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
console.log.apply(console, params);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
if (typeof message === 'string') {
|
|
62
|
+
let a1 = '%c ' + moduleName + ' %c ' + message + ' ';
|
|
63
|
+
let a2 = 'background: ' + moduleColor + ';color:white; border: 1px solid ' + moduleColor + '; ';
|
|
64
|
+
let a3 = 'border: 1px solid ' + color + '; ';
|
|
65
|
+
params.unshift(a3);
|
|
66
|
+
params.unshift(a2);
|
|
67
|
+
params.unshift(a1);
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
let a1 = '%c ' + moduleName + ' ';
|
|
71
|
+
let a2 = 'background: ' + moduleColor + ';color:white; border: 1px solid ' + color + '; ';
|
|
72
|
+
params.push(message);
|
|
73
|
+
params.unshift(a2);
|
|
74
|
+
params.unshift(a1);
|
|
75
|
+
}
|
|
76
|
+
console.log.apply(console, params);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
/* */
|
|
80
|
+
/* */
|
|
81
|
+
/* */
|
|
82
|
+
/* */
|
|
83
|
+
/* */
|
|
84
|
+
/* */
|
|
85
|
+
/* */
|
|
86
|
+
/* */
|
|
87
|
+
/* */
|
|
88
|
+
/* */
|
|
89
|
+
/* */
|
|
90
|
+
/* */
|
|
91
|
+
/* */
|
|
92
|
+
/* */
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
;
|
|
96
|
+
({}); // @--end-of-file-for-module=ng2-logger lib/display.ts
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzcGxheS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3RtcC1saWJzLWZvci1kaXN0L25nMi1sb2dnZXIvcHJvamVjdHMvbmcyLWxvZ2dlci9zcmMvbGliL2Rpc3BsYXkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsS0FBSztBQUNMLEtBQUs7QUFFTCxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQ2hDLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUczQyxLQUFLO0FBQ0wsS0FBSztBQUdMLE1BQU0sT0FBTyxPQUFPO0lBRWxCLE1BQU0sQ0FBQyxHQUFHLENBQ1IsT0FBcUIsRUFDckIsTUFBYSxFQUNiLFVBQWtCLEVBQ2xCLFdBQW1CLEVBQ25CLEtBQVksRUFDWixXQUErQixFQUMvQixnQkFBeUI7UUFFekIsSUFBSSxnQkFBZ0IsRUFBRSxDQUFDO1lBQ3JCLE9BQU87UUFDVCxDQUFDO1FBQUEsQ0FBQztRQUNGLElBQUksS0FBSyxHQUFHLE1BQU0sQ0FBQztRQUNuQixJQUFJLEtBQUssS0FBSyxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUM7WUFBQyxLQUFLLEdBQUcsYUFBYSxDQUFDO1FBQUMsQ0FBQztRQUNwRCxJQUFJLEtBQUssS0FBSyxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUM7WUFBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQUMsQ0FBQztRQUM3QyxJQUFJLEtBQUssS0FBSyxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUM7WUFBQyxLQUFLLEdBQUcsUUFBUSxDQUFDO1FBQUMsQ0FBQztRQUUvQyxJQUFJLFdBQVcsRUFBRSxDQUFDO1lBQ2hCLE1BQU0sSUFBSSxHQUFHLFdBQVcsR0FBRyxVQUFVLENBQUMsTUFBTSxDQUFDO1lBQzdDLElBQUksSUFBSSxHQUFHLENBQUMsRUFBRSxDQUFDO2dCQUNiLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FB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QUM7UUFFSCxDQUFDO1FBR0wsS0FBSztRQUNMLEtBQUs7UUFDTCxLQUFLO1FBQ0wsS0FBSztRQUNMLEtBQUs7UUFDTCxLQUFLO1FBQ0wsS0FBSztRQUNMLEtBQUs7UUFDTCxLQUFLO1FBQ0wsS0FBSztRQUNMLEtBQUs7UUFDTCxLQUFLO1FBQ0wsS0FBSztRQUNMLEtBQUs7SUFHSCxDQUFDO0NBRUY7QUFFQSxDQUFDO0FBQUEsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLHNEQUFzRCIsInNvdXJjZXNDb250ZW50IjpbIlxuXG4vKiAqL1xuLyogKi9cbiAgXG5pbXBvcnQgeyBMZXZlbCB9IGZyb20gJy4vbGV2ZWwnO1xuaW1wb3J0IHsgSGVscGVycyB9IGZyb20gJ3RucC1jb3JlL2Jyb3dzZXInO1xuaW1wb3J0IHsgY29uc29sZUxvZywgZGlzcGxheVBhcmFtcyB9IGZyb20gJy4vYmFja2VuZC1sb2dnaW5nJztcblxuLyogKi9cbi8qICovXG4gIFxuXG5leHBvcnQgY2xhc3MgRGlzcGxheSB7XG5cbiAgc3RhdGljIG1zZyhcbiAgICBtZXNzYWdlOiBzdHJpbmcgfCBhbnksXG4gICAgcGFyYW1zOiBhbnlbXSxcbiAgICBtb2R1bGVOYW1lOiBzdHJpbmcsXG4gICAgbW9kdWxlQ29sb3I6IHN0cmluZyxcbiAgICBsZXZlbDogTGV2ZWwsXG4gICAgbW9kdWxlV2lkdGg6IG51bWJlciB8IHVuZGVmaW5lZCxcbiAgICBpc1Byb2R1Y3Rpb25Nb2RlOiBib29sZWFuXG4gICkge1xuICAgIGlmIChpc1Byb2R1Y3Rpb25Nb2RlKSB7XG4gICAgICByZXR1cm47XG4gICAgfTtcbiAgICBsZXQgY29sb3IgPSAnZ3JheSc7XG4gICAgaWYgKGxldmVsID09PSBMZXZlbC5JTkZPKSB7IGNvbG9yID0gJ2RlZXBza3libHVlJzsgfVxuICAgIGlmIChsZXZlbCA9PT0gTGV2ZWwuRVJST1IpIHsgY29sb3IgPSAncmVkJzsgfVxuICAgIGlmIChsZXZlbCA9PT0gTGV2ZWwuV0FSTikgeyBjb2xvciA9ICdvcmFuZ2UnOyB9XG5cbiAgICBpZiAobW9kdWxlV2lkdGgpIHtcbiAgICAgIGNvbnN0IGRpZmYgPSBtb2R1bGVXaWR0aCAtIG1vZHVsZU5hbWUubGVuZ3RoO1xuICAgICAgaWYgKGRpZmYgPiAwKSB7XG4gICAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgZGlmZjsgaSsrKSB7XG4gICAgICAgICAgbW9kdWxlTmFtZSArPSAnICc7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG5cblxuICAgIGlmIChIZWxwZXJzLmlzQnJvd3NlclxuLyogKi9cbi8qICovXG4gIFxuICAgICkge1xuXG5cbiAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgIGNvbnN0IGlzRWRnZU9ySWU4b3JBYm92ZSA9IChkb2N1bWVudFsnZG9jdW1lbnRNb2RlJ10gfHwgL0VkZ2UvLnRlc3QobmF2aWdhdG9yLnVzZXJBZ2VudCkpO1xuXG4gICAgICBpZiAoaXNFZGdlT3JJZThvckFib3ZlKSB7XG4gICAgICAgIGlmICh0eXBlb2YgbWVzc2FnZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgICBsZXQgYTEgPSAnW1sgJyArIG1vZHVsZU5hbWUgKyAnIF1dICcgKyBtZXNzYWdlICsgJyAnO1xuICAgICAgICAgIHBhcmFtcy51bnNoaWZ0KGExKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBsZXQgYTEgPSAnW1sgJyArIG1vZHVsZU5hbWUgKyAnXV0gJztcbiAgICAgICAgICBwYXJhbXMucHVzaChtZXNzYWdlKTtcbiAgICAgICAgICBwYXJhbXMudW5zaGlmdChhMSk7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKGxldmVsID09PSBMZXZlbC5JTkZPKSB7XG4gICAgICAgICAgY29uc29sZS5pbmZvLmFwcGx5KGNvbnNvbGUsIHBhcmFtcyk7XG4gICAgICAgIH0gZWxzZSBpZiAobGV2ZWwgPT09IExldmVsLkVSUk9SKSB7XG4gICAgICAgICAgY29uc29sZS5lcnJvci5hcHBseShjb25zb2xlLCBwYXJhbXMpO1xuICAgICAgICB9IGVsc2UgaWYgKGxldmVsID09PSBMZXZlbC5XQVJOKSB7XG4gICAgICAgICAgY29uc29sZS53YXJuLmFwcGx5KGNvbnNvbGUsIHBhcmFtcyk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgY29uc29sZS5sb2cuYXBwbHkoY29uc29sZSwgcGFyYW1zKTtcbiAgICAgICAgfVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgaWYgKHR5cGVvZiBtZXNzYWdlID09PSAnc3RyaW5nJykge1xuICAgICAgICAgIGxldCBhMSA9ICclYyAnICsgbW9kdWxlTmFtZSArICcgICVjICcgKyBtZXNzYWdlICsgJyAnO1xuICAgICAgICAgIGxldCBhMiA9ICdiYWNrZ3JvdW5kOiAnICsgbW9kdWxlQ29sb3IgKyAnO2NvbG9yOndoaXRlOyBib3JkZXI6IDFweCBzb2xpZCAnICsgbW9kdWxlQ29sb3IgKyAnOyAnO1xuICAgICAgICAgIGxldCBhMyA9ICdib3JkZXI6IDFweCBzb2xpZCAnICsgY29sb3IgKyAnOyAnO1xuICAgICAgICAgIHBhcmFtcy51bnNoaWZ0KGEzKTtcbiAgICAgICAgICBwYXJhbXMudW5zaGlmdChhMik7XG4gICAgICAgICAgcGFyYW1zLnVuc2hpZnQoYTEpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGxldCBhMSA9ICclYyAnICsgbW9kdWxlTmFtZSArICcgJztcbiAgICAgICAgICBsZXQgYTIgPSAnYmFja2dyb3VuZDogJyArIG1vZHVsZUNvbG9yICsgJztjb2xvcjp3aGl0ZTsgYm9yZGVyOiAxcHggc29saWQgJyArIGNvbG9yICsgJzsgJztcbiAgICAgICAgICBwYXJhbXMucHVzaChtZXNzYWdlKTtcbiAgICAgICAgICBwYXJhbXMudW5zaGlmdChhMik7XG4gICAgICAgICAgcGFyYW1zLnVuc2hpZnQoYTEpO1xuICAgICAgICB9XG4gICAgICAgIGNvbnNvbGUubG9nLmFwcGx5KGNvbnNvbGUsIHBhcmFtcyk7XG4gICAgICB9XG5cbiAgICB9XG5cblxuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4gIFxuXG4gIH1cblxufVxuXG4gOyh7fSk7IC8vIEAtLWVuZC1vZi1maWxlLWZvci1tb2R1bGU9bmcyLWxvZ2dlciBsaWIvZGlzcGxheS50cyJdfQ==
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from './log';
|
|
2
|
+
export * from './level';
|
|
3
|
+
export * from './logger';
|
|
4
|
+
export * from './display';
|
|
5
|
+
;
|
|
6
|
+
({}); // @--end-of-file-for-module=ng2-logger lib/index.ts
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi90bXAtbGlicy1mb3ItZGlzdC9uZzItbG9nZ2VyL3Byb2plY3RzL25nMi1sb2dnZXIvc3JjL2xpYi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxjQUFjLE9BQU8sQ0FBQztBQUN0QixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLFdBQVcsQ0FBQztBQUV6QixDQUFDO0FBQUEsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLG9EQUFvRCIsInNvdXJjZXNDb250ZW50IjpbIlxuXG5leHBvcnQgKiBmcm9tICcuL2xvZyc7XG5leHBvcnQgKiBmcm9tICcuL2xldmVsJztcbmV4cG9ydCAqIGZyb20gJy4vbG9nZ2VyJztcbmV4cG9ydCAqIGZyb20gJy4vZGlzcGxheSc7XG5cbiA7KHt9KTsgLy8gQC0tZW5kLW9mLWZpbGUtZm9yLW1vZHVsZT1uZzItbG9nZ2VyIGxpYi9pbmRleC50cyJdfQ==
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
export var Level;
|
|
2
|
+
(function (Level) {
|
|
3
|
+
Level[Level["DATA"] = 0] = "DATA";
|
|
4
|
+
Level[Level["INFO"] = 1] = "INFO";
|
|
5
|
+
Level[Level["WARN"] = 2] = "WARN";
|
|
6
|
+
Level[Level["ERROR"] = 3] = "ERROR";
|
|
7
|
+
Level[Level["SUCCESS"] = 4] = "SUCCESS";
|
|
8
|
+
Level[Level["TASK_STARTED"] = 5] = "TASK_STARTED";
|
|
9
|
+
Level[Level["TASK_DONE"] = 6] = "TASK_DONE";
|
|
10
|
+
Level[Level["__NOTHING"] = 7] = "__NOTHING";
|
|
11
|
+
})(Level || (Level = {}));
|
|
12
|
+
export const LevelKey = {
|
|
13
|
+
[Level.DATA]: 'log',
|
|
14
|
+
[Level.INFO]: 'info',
|
|
15
|
+
[Level.WARN]: 'warn',
|
|
16
|
+
[Level.ERROR]: 'error',
|
|
17
|
+
[Level.SUCCESS]: 'success',
|
|
18
|
+
[Level.TASK_STARTED]: 'taskstarted',
|
|
19
|
+
[Level.TASK_DONE]: 'taskdone',
|
|
20
|
+
[Level.__NOTHING]: '',
|
|
21
|
+
};
|
|
22
|
+
export const LevelOrder = [
|
|
23
|
+
LevelKey[Level.DATA],
|
|
24
|
+
LevelKey[Level.TASK_STARTED],
|
|
25
|
+
LevelKey[Level.TASK_DONE],
|
|
26
|
+
LevelKey[Level.INFO],
|
|
27
|
+
LevelKey[Level.SUCCESS],
|
|
28
|
+
LevelKey[Level.WARN],
|
|
29
|
+
LevelKey[Level.ERROR],
|
|
30
|
+
];
|
|
31
|
+
;
|
|
32
|
+
({}); // @--end-of-file-for-module=ng2-logger lib/level.ts
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGV2ZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi90bXAtbGlicy1mb3ItZGlzdC9uZzItbG9nZ2VyL3Byb2plY3RzL25nMi1sb2dnZXIvc3JjL2xpYi9sZXZlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLENBQU4sSUFBWSxLQVNYO0FBVEQsV0FBWSxLQUFLO0lBQ2IsaUNBQUksQ0FBQTtJQUNKLGlDQUFJLENBQUE7SUFDSixpQ0FBSSxDQUFBO0lBQ0osbUNBQUssQ0FBQTtJQUNMLHVDQUFPLENBQUE7SUFDUCxpREFBWSxDQUFBO0lBQ1osMkNBQVMsQ0FBQTtJQUNULDJDQUFTLENBQUE7QUFDYixDQUFDLEVBVFcsS0FBSyxLQUFMLEtBQUssUUFTaEI7QUFFRCxNQUFNLENBQUMsTUFBTSxRQUFRLEdBQUc7SUFDdEIsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUcsS0FBSztJQUNwQixDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsRUFBRyxNQUFNO0lBQ3JCLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxFQUFHLE1BQU07SUFDckIsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLEVBQUcsT0FBTztJQUN2QixDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsRUFBRyxTQUFTO0lBQzNCLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxFQUFHLGFBQWE7SUFDcEMsQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLEVBQUcsVUFBVTtJQUM5QixDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsRUFBRyxFQUFFO0NBQ3ZCLENBQUE7QUFFRCxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUc7SUFDeEIsUUFBUSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUM7SUFDcEIsUUFBUSxDQUFDLEtBQUssQ0FBQyxZQUFZLENBQUM7SUFDNUIsUUFBUSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUM7SUFDekIsUUFBUSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUM7SUFDcEIsUUFBUSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUM7SUFDdkIsUUFBUSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUM7SUFDcEIsUUFBUSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUM7Q0FDdEIsQ0FBQztBQUVELENBQUM7QUFBQSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsb0RBQW9EIiwic291cmNlc0NvbnRlbnQiOlsiXG5cbmV4cG9ydCBlbnVtIExldmVsIHtcbiAgICBEQVRBLFxuICAgIElORk8sXG4gICAgV0FSTixcbiAgICBFUlJPUiAsXG4gICAgU1VDQ0VTUyxcbiAgICBUQVNLX1NUQVJURUQsXG4gICAgVEFTS19ET05FLFxuICAgIF9fTk9USElORyAsXG59XG5cbmV4cG9ydCBjb25zdCBMZXZlbEtleSA9IHtcbiAgW0xldmVsLkRBVEFdIDogJ2xvZycsXG4gIFtMZXZlbC5JTkZPXSA6ICdpbmZvJyxcbiAgW0xldmVsLldBUk5dIDogJ3dhcm4nLFxuICBbTGV2ZWwuRVJST1JdIDogJ2Vycm9yJyxcbiAgW0xldmVsLlNVQ0NFU1NdIDogJ3N1Y2Nlc3MnLFxuICBbTGV2ZWwuVEFTS19TVEFSVEVEXSA6ICd0YXNrc3RhcnRlZCcsXG4gIFtMZXZlbC5UQVNLX0RPTkVdIDogJ3Rhc2tkb25lJyxcbiAgW0xldmVsLl9fTk9USElOR10gOiAnJyxcbn1cblxuZXhwb3J0IGNvbnN0IExldmVsT3JkZXIgPSBbXG4gIExldmVsS2V5W0xldmVsLkRBVEFdLFxuICBMZXZlbEtleVtMZXZlbC5UQVNLX1NUQVJURURdLFxuICBMZXZlbEtleVtMZXZlbC5UQVNLX0RPTkVdLFxuICBMZXZlbEtleVtMZXZlbC5JTkZPXSxcbiAgTGV2ZWxLZXlbTGV2ZWwuU1VDQ0VTU10sXG4gIExldmVsS2V5W0xldmVsLldBUk5dLFxuICBMZXZlbEtleVtMZXZlbC5FUlJPUl0sXG5dO1xuXG4gOyh7fSk7IC8vIEAtLWVuZC1vZi1maWxlLWZvci1tb2R1bGU9bmcyLWxvZ2dlciBsaWIvbGV2ZWwudHMiXX0=
|
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
import { Logger } from './logger';
|
|
2
|
+
import { Level, LevelOrder, LevelKey } from './level';
|
|
3
|
+
import { Helpers } from 'tnp-core/browser';
|
|
4
|
+
/* */
|
|
5
|
+
/* */
|
|
6
|
+
/* */
|
|
7
|
+
/* */
|
|
8
|
+
/* */
|
|
9
|
+
export class Log {
|
|
10
|
+
constructor() {
|
|
11
|
+
this._logOnly = false;
|
|
12
|
+
this._logModules = false;
|
|
13
|
+
this.isDevelopmentMode = true;
|
|
14
|
+
this.modeIsSet = false;
|
|
15
|
+
this.fixedWidth = 0;
|
|
16
|
+
this.instances = {};
|
|
17
|
+
this.levels = [];
|
|
18
|
+
this.modules = [];
|
|
19
|
+
}
|
|
20
|
+
// @ts-ignore
|
|
21
|
+
static get instance() {
|
|
22
|
+
// @ts-ignore
|
|
23
|
+
if (!Log['_instance']) {
|
|
24
|
+
// @ts-ignore
|
|
25
|
+
Log['_instance'] = new Log();
|
|
26
|
+
}
|
|
27
|
+
// @ts-ignore
|
|
28
|
+
return Log['_instance'];
|
|
29
|
+
}
|
|
30
|
+
static { this.Logger = Logger; }
|
|
31
|
+
static create(name, ...level) {
|
|
32
|
+
return Log.instance.create(name, ...level);
|
|
33
|
+
}
|
|
34
|
+
static { this.consolelogfn = {}; }
|
|
35
|
+
static disableLogs(level = Level.__NOTHING) {
|
|
36
|
+
/* */
|
|
37
|
+
/* */
|
|
38
|
+
/* */
|
|
39
|
+
/* */
|
|
40
|
+
/* */
|
|
41
|
+
/* */
|
|
42
|
+
/* */
|
|
43
|
+
LevelOrder.reverse().find(a => {
|
|
44
|
+
// @ts-ignore
|
|
45
|
+
if (!this.consolelogfn[a]) {
|
|
46
|
+
// @ts-ignore
|
|
47
|
+
this.consolelogfn[a] = console[a];
|
|
48
|
+
}
|
|
49
|
+
// @ts-ignore
|
|
50
|
+
console[a] = () => { };
|
|
51
|
+
if (a === LevelKey[level]) {
|
|
52
|
+
return true;
|
|
53
|
+
}
|
|
54
|
+
return false;
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
static enableLogs() {
|
|
58
|
+
/* */
|
|
59
|
+
/* */
|
|
60
|
+
/* */
|
|
61
|
+
/* */
|
|
62
|
+
LevelOrder.forEach(a => {
|
|
63
|
+
// @ts-ignore
|
|
64
|
+
console[a] = this.consolelogfn[a];
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
setProductionMode() {
|
|
68
|
+
if (this.modeIsSet) {
|
|
69
|
+
this.modeIsSet = false;
|
|
70
|
+
throw '[ng2-logger] Production mode is already set';
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
this.modeIsSet = true;
|
|
74
|
+
setTimeout(() => {
|
|
75
|
+
if (this.modeIsSet && console !== void 0 && console.clear !== void 0) {
|
|
76
|
+
console.clear();
|
|
77
|
+
console.log = () => { };
|
|
78
|
+
console.error = () => { };
|
|
79
|
+
console.warn = () => { };
|
|
80
|
+
console.info = () => { };
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
this.isDevelopmentMode = false;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
onlyModules(...modules) {
|
|
87
|
+
if (this._logModules) {
|
|
88
|
+
throw '[ng2-logger] You should use funcion onlyModules only once';
|
|
89
|
+
}
|
|
90
|
+
if (!this._logModules) {
|
|
91
|
+
this._logModules = true;
|
|
92
|
+
}
|
|
93
|
+
if (modules.length === 0)
|
|
94
|
+
return;
|
|
95
|
+
this.modules = modules;
|
|
96
|
+
this.muteAllOtherModules();
|
|
97
|
+
}
|
|
98
|
+
onlyLevel(...level) {
|
|
99
|
+
if (this._logOnly) {
|
|
100
|
+
throw '[ng2-logger] You should use funcion onlyLevel only once';
|
|
101
|
+
}
|
|
102
|
+
if (!this._logOnly) {
|
|
103
|
+
this._logOnly = true;
|
|
104
|
+
}
|
|
105
|
+
this.levels = Array.isArray(level) ? level : [level];
|
|
106
|
+
for (const logName in this.instances) {
|
|
107
|
+
if (this.instances.hasOwnProperty(logName)) {
|
|
108
|
+
const element = this.instances[logName];
|
|
109
|
+
element['allowed'] = this.levels;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
create(name, ...level) {
|
|
114
|
+
let i;
|
|
115
|
+
if (Array.isArray(this.levels) && this.levels.length > 0) {
|
|
116
|
+
level = this.levels;
|
|
117
|
+
}
|
|
118
|
+
if (this.instances[name] === void 0) {
|
|
119
|
+
i = new (Log.Logger)(name, getRandomColor(), this.isDevelopmentMode, level, this.isMutedModule(name), this.levels.length > 0 ? this.fixedWidth : void 0);
|
|
120
|
+
this.instances[name] = i;
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
i = this.instances[name];
|
|
124
|
+
}
|
|
125
|
+
return i;
|
|
126
|
+
}
|
|
127
|
+
isMutedModule(moduleName) {
|
|
128
|
+
if (this.modules.length == 0)
|
|
129
|
+
return false;
|
|
130
|
+
if (!Helpers.contain(this.modules, moduleName))
|
|
131
|
+
return true;
|
|
132
|
+
return false;
|
|
133
|
+
}
|
|
134
|
+
muteAllOtherModules() {
|
|
135
|
+
for (var moduleName in this.instances) {
|
|
136
|
+
if (!Helpers.contain(this.modules, moduleName))
|
|
137
|
+
this.instances[moduleName].mute();
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
function getRandomColor() {
|
|
142
|
+
/* */
|
|
143
|
+
/* */
|
|
144
|
+
/* */
|
|
145
|
+
/* */
|
|
146
|
+
let letters = '012345'.split('');
|
|
147
|
+
let color = '#';
|
|
148
|
+
color += letters[Math.round(Math.random() * 5)];
|
|
149
|
+
letters = '0123456789ABCDEF'.split('');
|
|
150
|
+
for (let i = 0; i < 5; i++) {
|
|
151
|
+
color += letters[Math.round(Math.random() * 15)];
|
|
152
|
+
}
|
|
153
|
+
if (color === void 0) {
|
|
154
|
+
return getRandomColor();
|
|
155
|
+
}
|
|
156
|
+
;
|
|
157
|
+
return color;
|
|
158
|
+
}
|
|
159
|
+
;
|
|
160
|
+
({}); // @--end-of-file-for-module=ng2-logger lib/log.ts
|
|
161
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vdG1wLWxpYnMtZm9yLWRpc3QvbmcyLWxvZ2dlci9wcm9qZWN0cy9uZzItbG9nZ2VyL3NyYy9saWIvbG9nLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDbEMsT0FBTyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQ3RELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUMzQyxLQUFLO0FBQ0wsS0FBSztBQUNMLEtBQUs7QUFJTCxLQUFLO0FBQ0wsS0FBSztBQUlMLE1BQU0sT0FBTyxHQUFHO0lBRWQ7UUF1RFEsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUNqQixnQkFBVyxHQUFHLEtBQUssQ0FBQztRQUNwQixzQkFBaUIsR0FBRyxJQUFJLENBQUM7UUFDekIsY0FBUyxHQUFZLEtBQUssQ0FBQztRQUMzQixlQUFVLEdBQUcsQ0FBQyxDQUFDO1FBQ2YsY0FBUyxHQUFxQyxFQUFFLENBQUM7UUFDakQsV0FBTSxHQUFZLEVBQUUsQ0FBQztRQUNyQixZQUFPLEdBQXdCLEVBQUUsQ0FBQztJQTlEbEIsQ0FBQztJQUN6QixhQUFhO0lBQ0wsTUFBTSxLQUFLLFFBQVE7UUFDekIsYUFBYTtRQUNiLElBQUksQ0FBQyxHQUFHLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQztZQUN0QixhQUFhO1lBQ2IsR0FBRyxDQUFDLFdBQVcsQ0FBQyxHQUFHLElBQUksR0FBRyxFQUFFLENBQUM7UUFDL0IsQ0FBQztRQUNELGFBQWE7UUFDYixPQUFPLEdBQUcsQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUMxQixDQUFDO2FBR00sV0FBTSxHQUFvQixNQUFNLEFBQTFCLENBQTJCO0lBQ3hDLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBWSxFQUFFLEdBQUcsS0FBYztRQUMz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QUMsTUFBTSxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNoRCxPQUFPLEdBQUcsa0JBQWtCLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3ZDLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztRQUMzQixLQUFLLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDbkQsQ0FBQztJQUNELElBQUksS0FBSyxLQUFLLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDckIsT0FBTyxjQUFjLEVBQUUsQ0FBQTtJQUN6QixDQUFDO0lBQUEsQ0FBQztJQUNGLE9BQU8sS0FBSyxDQUFDO0FBQ2YsQ0FBQztBQUVBLENBQUM7QUFBQSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsa0RBQWtEIiwic291cmNlc0NvbnRlbnQiOlsiXG5cbmltcG9ydCB7IExvZ2dlciB9IGZyb20gJy4vbG9nZ2VyJztcbmltcG9ydCB7IExldmVsLCBMZXZlbE9yZGVyLCBMZXZlbEtleSB9IGZyb20gJy4vbGV2ZWwnO1xuaW1wb3J0IHsgSGVscGVycyB9IGZyb20gJ3RucC1jb3JlL2Jyb3dzZXInO1xuLyogKi9cbi8qICovXG4vKiAqL1xuICBcblxuXG4vKiAqL1xuLyogKi9cbiAgXG5cblxuZXhwb3J0IGNsYXNzIExvZyB7XG5cbiAgcHJpdmF0ZSBjb25zdHJ1Y3RvcigpIHsgfVxuICAvLyBAdHMtaWdub3JlXG4gIHByaXZhdGUgc3RhdGljIGdldCBpbnN0YW5jZSgpOiBhbnkge1xuICAgIC8vIEB0cy1pZ25vcmVcbiAgICBpZiAoIUxvZ1snX2luc3RhbmNlJ10pIHtcbiAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgIExvZ1snX2luc3RhbmNlJ10gPSBuZXcgTG9nKCk7XG4gICAgfVxuICAgIC8vIEB0cy1pZ25vcmVcbiAgICByZXR1cm4gTG9nWydfaW5zdGFuY2UnXTtcbiAgfVxuXG5cbiAgc3RhdGljIExvZ2dlcjogKHR5cGVvZiBMb2dnZXIpID0gTG9nZ2VyO1xuICBzdGF0aWMgY3JlYXRlKG5hbWU6IHN0cmluZywgLi4ubGV2ZWw6IExldmVsW10pOiBMb2dnZXIge1xuICAgIHJldHVybiBMb2cuaW5zdGFuY2UuY3JlYXRlKG5hbWUsIC4uLmxldmVsKTtcbiAgfVxuXG4gIHByaXZhdGUgc3RhdGljIHJlYWRvbmx5IGNvbnNvbGVsb2dmbiA9IHt9O1xuICBzdGF0aWMgZGlzYWJsZUxvZ3MobGV2ZWwgPSBMZXZlbC5fX05PVEhJTkcpIHtcbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4gIFxuICAgIExldmVsT3JkZXIucmV2ZXJzZSgpLmZpbmQoYSA9PiB7XG4gICAgICAvLyBAdHMtaWdub3JlXG4gICAgICBpZiAoIXRoaXMuY29uc29sZWxvZ2ZuW2FdKSB7XG4gICAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgICAgdGhpcy5jb25zb2xlbG9nZm5bYV0gPSBjb25zb2xlW2FdO1xuICAgICAgfVxuICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgY29uc29sZVthXSA9ICgpID0+IHsgfTtcbiAgICAgIGlmIChhID09PSBMZXZlbEtleVtsZXZlbF0pIHtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICB9XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfSk7XG4gIH1cblxuICBzdGF0aWMgZW5hYmxlTG9ncygpIHtcbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4gIFxuICAgIExldmVsT3JkZXIuZm9yRWFjaChhID0+IHtcbiAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgIGNvbnNvbGVbYV0gPSB0aGlzLmNvbnNvbGVsb2dmblthXVxuICAgIH0pO1xuICB9XG5cbiAgcHJpdmF0ZSBfbG9nT25seSA9IGZhbHNlO1xuICBwcml2YXRlIF9sb2dNb2R1bGVzID0gZmFsc2U7XG4gIHByaXZhdGUgaXNEZXZlbG9wbWVudE1vZGUgPSB0cnVlO1xuICBwcml2YXRlIG1vZGVJc1NldDogYm9vbGVhbiA9IGZhbHNlO1xuICBwcml2YXRlIGZpeGVkV2lkdGggPSAwO1xuICBwcml2YXRlIGluc3RhbmNlczogeyBbbW9kdWxlTmFtZTogc3RyaW5nXTogTG9nZ2VyIH0gPSB7fTtcbiAgcHJpdmF0ZSBsZXZlbHM6IExldmVsW10gPSBbXTtcbiAgcHJpdmF0ZSBtb2R1bGVzOiAoc3RyaW5nIHwgUmVnRXhwKVtdID0gW107XG5cblxuICBwdWJsaWMgc2V0UHJvZHVjdGlvbk1vZGUoKSB7XG4gICAgaWYgKHRoaXMubW9kZUlzU2V0KSB7XG4gICAgICB0aGlzLm1vZGVJc1NldCA9IGZhbHNlXG4gICAgICB0aHJvdyAnW25nMi1sb2dnZXJdIFByb2R1Y3Rpb24gbW9kZSBpcyBhbHJlYWR5IHNldCc7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMubW9kZUlzU2V0ID0gdHJ1ZTtcbiAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuXG4gICAgICAgIGlmICh0aGlzLm1vZGVJc1NldCAmJiBjb25zb2xlICE9PSB2b2lkIDAgJiYgY29uc29sZS5jbGVhciAhPT0gdm9pZCAwKSB7XG5cbiAgICAgICAgICBjb25zb2xlLmNsZWFyKCk7XG4gICAgICAgICAgY29uc29sZS5sb2cgPSAoKSA9PiB7IH07XG4gICAgICAgICAgY29uc29sZS5lcnJvciA9ICgpID0+IHsgfTtcbiAgICAgICAgICBjb25zb2xlLndhcm4gPSAoKSA9PiB7IH07XG4gICAgICAgICAgY29uc29sZS5pbmZvID0gKCkgPT4geyB9O1xuICAgICAgICB9XG4gICAgICB9KTtcblxuICAgICAgdGhpcy5pc0RldmVsb3BtZW50TW9kZSA9IGZhbHNlO1xuICAgIH1cbiAgfVxuXG4gIHB1YmxpYyBvbmx5TW9kdWxlcyguLi5tb2R1bGVzOiAoc3RyaW5nIHwgUmVnRXhwKVtdKSB7XG4gICAgaWYgKHRoaXMuX2xvZ01vZHVsZXMpIHtcbiAgICAgIHRocm93ICdbbmcyLWxvZ2dlcl0gWW91IHNob3VsZCB1c2UgZnVuY2lvbiBvbmx5TW9kdWxlcyBvbmx5IG9uY2UnO1xuICAgIH1cbiAgICBpZiAoIXRoaXMuX2xvZ01vZHVsZXMpIHtcbiAgICAgIHRoaXMuX2xvZ01vZHVsZXMgPSB0cnVlO1xuICAgIH1cbiAgICBpZiAobW9kdWxlcy5sZW5ndGggPT09IDApIHJldHVybjtcbiAgICB0aGlzLm1vZHVsZXMgPSBtb2R1bGVzO1xuXG4gICAgdGhpcy5tdXRlQWxsT3RoZXJNb2R1bGVzKCk7XG4gIH1cblxuXG4gIHB1YmxpYyBvbmx5TGV2ZWwoLi4ubGV2ZWw6IExldmVsW10pIHtcbiAgICBpZiAodGhpcy5fbG9nT25seSkge1xuICAgICAgdGhyb3cgJ1tuZzItbG9nZ2VyXSBZb3Ugc2hvdWxkIHVzZSBmdW5jaW9uIG9ubHlMZXZlbCBvbmx5IG9uY2UnO1xuICAgIH1cbiAgICBpZiAoIXRoaXMuX2xvZ09ubHkpIHtcbiAgICAgIHRoaXMuX2xvZ09ubHkgPSB0cnVlO1xuICAgIH1cblxuICAgIHRoaXMubGV2ZWxzID0gQXJyYXkuaXNBcnJheShsZXZlbCkgPyBsZXZlbCA6IFtsZXZlbF07XG5cblxuICAgIGZvciAoY29uc3QgbG9nTmFtZSBpbiB0aGlzLmluc3RhbmNlcykge1xuICAgICAgaWYgKHRoaXMuaW5zdGFuY2VzLmhhc093blByb3BlcnR5KGxvZ05hbWUpKSB7XG4gICAgICAgIGNvbnN0IGVsZW1lbnQgPSB0aGlzLmluc3RhbmNlc1tsb2dOYW1lXTtcbiAgICAgICAgZWxlbWVudFsnYWxsb3dlZCddID0gdGhpcy5sZXZlbHM7XG4gICAgICB9XG4gICAgfVxuICB9XG5cblxuXG4gIHByaXZhdGUgY3JlYXRlKG5hbWU6IHN0cmluZywgLi4ubGV2ZWw6IExldmVsW10pOiBMb2dnZXIge1xuICAgIGxldCBpOiBMb2dnZXI7XG4gICAgaWYgKEFycmF5LmlzQXJyYXkodGhpcy5sZXZlbHMpICYmIHRoaXMubGV2ZWxzLmxlbmd0aCA+IDApIHtcbiAgICAgIGxldmVsID0gdGhpcy5sZXZlbHM7XG4gICAgfVxuICAgIGlmICh0aGlzLmluc3RhbmNlc1tuYW1lXSA9PT0gdm9pZCAwKSB7XG4gICAgICBpID0gbmV3IChMb2cuTG9nZ2VyKShcbiAgICAgICAgbmFtZSxcbiAgICAgICAgZ2V0UmFuZG9tQ29sb3IoKSxcbiAgICAgICAgdGhpcy5pc0RldmVsb3BtZW50TW9kZSxcbiAgICAgICAgbGV2ZWwsXG4gICAgICAgIHRoaXMuaXNNdXRlZE1vZHVsZShuYW1lKSxcbiAgICAgICAgdGhpcy5sZXZlbHMubGVuZ3RoID4gMCA/IHRoaXMuZml4ZWRXaWR0aCA6IHZvaWQgMCxcblxuICAgICAgKTtcbiAgICAgIHRoaXMuaW5zdGFuY2VzW25hbWVdID0gaTtcbiAgICB9IGVsc2Uge1xuICAgICAgaSA9IHRoaXMuaW5zdGFuY2VzW25hbWVdO1xuICAgIH1cbiAgICByZXR1cm4gaTtcbiAgfVxuXG4gIHByaXZhdGUgaXNNdXRlZE1vZHVsZShtb2R1bGVOYW1lOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICBpZiAodGhpcy5tb2R1bGVzLmxlbmd0aCA9PSAwKSByZXR1cm4gZmFsc2U7XG4gICAgaWYgKCFIZWxwZXJzLmNvbnRhaW4odGhpcy5tb2R1bGVzLCBtb2R1bGVOYW1lKSkgcmV0dXJuIHRydWU7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG4gIHByaXZhdGUgbXV0ZUFsbE90aGVyTW9kdWxlcygpIHtcbiAgICBmb3IgKHZhciBtb2R1bGVOYW1lIGluIHRoaXMuaW5zdGFuY2VzKSB7XG4gICAgICBpZiAoIUhlbHBlcnMuY29udGFpbih0aGlzLm1vZHVsZXMsIG1vZHVsZU5hbWUpKVxuICAgICAgICB0aGlzLmluc3RhbmNlc1ttb2R1bGVOYW1lXS5tdXRlKClcbiAgICB9XG4gIH1cblxufVxuXG5cbmZ1bmN0aW9uIGdldFJhbmRvbUNvbG9yKCk6IHN0cmluZyB7XG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuICBcblxuICBsZXQgbGV0dGVycyA9ICcwMTIzNDUnLnNwbGl0KCcnKTtcbiAgbGV0IGNvbG9yID0gJyMnO1xuICBjb2xvciArPSBsZXR0ZXJzW01hdGgucm91bmQoTWF0aC5yYW5kb20oKSAqIDUpXTtcbiAgbGV0dGVycyA9ICcwMTIzNDU2Nzg5QUJDREVGJy5zcGxpdCgnJyk7XG4gIGZvciAobGV0IGkgPSAwOyBpIDwgNTsgaSsrKSB7XG4gICAgY29sb3IgKz0gbGV0dGVyc1tNYXRoLnJvdW5kKE1hdGgucmFuZG9tKCkgKiAxNSldO1xuICB9XG4gIGlmIChjb2xvciA9PT0gdm9pZCAwKSB7XG4gICAgcmV0dXJuIGdldFJhbmRvbUNvbG9yKClcbiAgfTtcbiAgcmV0dXJuIGNvbG9yO1xufVxuXG4gOyh7fSk7IC8vIEAtLWVuZC1vZi1maWxlLWZvci1tb2R1bGU9bmcyLWxvZ2dlciBsaWIvbG9nLnRzIl19
|