ng2-logger 13.1.21 → 13.1.22
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/README.md +192 -192
- package/assets/shared/shared_folder_info.txt +1 -1
- package/browser/README.md +24 -24
- package/browser/esm2020/lib/backend-logging.mjs +93 -93
- package/browser/esm2020/lib/display.mjs +96 -96
- package/browser/esm2020/lib/index.mjs +6 -6
- package/browser/esm2020/lib/level.mjs +32 -32
- package/browser/esm2020/lib/log.mjs +160 -160
- package/browser/esm2020/lib/logger.mjs +236 -236
- package/browser/esm2020/ng2-logger.mjs +4 -4
- package/browser/esm2020/public-api.mjs +1 -1
- package/browser/fesm2015/ng2-logger.mjs +514 -514
- package/browser/fesm2020/ng2-logger.mjs +514 -514
- package/browser/lib/backend-logging.d.ts +3 -3
- package/browser/lib/display.d.ts +3 -3
- package/browser/lib/index.d.ts +3 -3
- package/browser/lib/level.d.ts +20 -20
- package/browser/lib/log.d.ts +24 -24
- package/browser/lib/logger.d.ts +80 -80
- package/browser/ng2-logger.d.ts +4 -4
- package/client/README.md +24 -24
- package/client/esm2020/lib/backend-logging.mjs +93 -93
- package/client/esm2020/lib/display.mjs +96 -96
- package/client/esm2020/lib/index.mjs +6 -6
- package/client/esm2020/lib/level.mjs +32 -32
- package/client/esm2020/lib/log.mjs +160 -160
- package/client/esm2020/lib/logger.mjs +236 -236
- package/client/esm2020/ng2-logger.mjs +4 -4
- package/client/esm2020/public-api.mjs +1 -1
- package/client/fesm2015/ng2-logger.mjs +514 -514
- package/client/fesm2020/ng2-logger.mjs +514 -514
- package/client/lib/backend-logging.d.ts +3 -3
- package/client/lib/display.d.ts +3 -3
- package/client/lib/index.d.ts +3 -3
- package/client/lib/level.d.ts +20 -20
- package/client/lib/log.d.ts +24 -24
- package/client/lib/logger.d.ts +80 -80
- package/client/ng2-logger.d.ts +4 -4
- package/client/package.json +6 -6
- package/index.d.ts +1 -1
- package/lib/backend-logging.d.ts +4 -4
- package/lib/display.d.ts +4 -4
- package/lib/index.d.ts +4 -4
- package/lib/level.d.ts +21 -21
- package/lib/log.d.ts +25 -25
- package/lib/logger.d.ts +81 -81
- package/package.json +3 -3
- package/package.json_devDependencies.json +184 -184
- package/package.json_tnp.json5 +51 -51
- package/tmp-environment.json +9 -9
- package/websql/README.md +24 -24
- package/websql/esm2020/lib/backend-logging.mjs +93 -93
- package/websql/esm2020/lib/display.mjs +96 -96
- package/websql/esm2020/lib/index.mjs +6 -6
- package/websql/esm2020/lib/level.mjs +32 -32
- package/websql/esm2020/lib/log.mjs +160 -160
- package/websql/esm2020/lib/logger.mjs +236 -236
- package/websql/esm2020/ng2-logger.mjs +4 -4
- package/websql/esm2020/public-api.mjs +1 -1
- package/websql/fesm2015/ng2-logger.mjs +514 -514
- package/websql/fesm2020/ng2-logger.mjs +514 -514
- package/websql/lib/backend-logging.d.ts +3 -3
- package/websql/lib/display.d.ts +3 -3
- package/websql/lib/index.d.ts +3 -3
- package/websql/lib/level.d.ts +20 -20
- package/websql/lib/log.d.ts +24 -24
- package/websql/lib/logger.d.ts +80 -80
- package/websql/ng2-logger.d.ts +4 -4
|
@@ -1,97 +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
|
|
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
97
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzcGxheS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3RtcC1saWJzLWZvci1idW5kbGUvbmcyLWxvZ2dlci9wcm9qZWN0cy9uZzItbG9nZ2VyL3NyYy9saWIvZGlzcGxheS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxLQUFLO0FBQ0wsS0FBSztBQUVMLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDaEMsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRzNDLEtBQUs7QUFDTCxLQUFLO0FBR0wsTUFBTSxPQUFPLE9BQU87SUFFbEIsTUFBTSxDQUFDLEdBQUcsQ0FDUixPQUFxQixFQUNyQixNQUFhLEVBQ2IsVUFBa0IsRUFDbEIsV0FBbUIsRUFDbkIsS0FBWSxFQUNaLFdBQStCLEVBQy9CLGdCQUF5QjtRQUV6QixJQUFJLGdCQUFnQixFQUFFO1lBQ3BCLE9BQU87U0FDUjtRQUFBLENBQUM7UUFDRixJQUFJLEtBQUssR0FBRyxNQUFNLENBQUM7UUFDbkIsSUFBSSxLQUFLLEtBQUssS0FBSyxDQUFDLElBQUksRUFBRTtZQUFFLEtBQUssR0FBRyxhQUFhLENBQUM7U0FBRTtRQUNwRCxJQUFJLEtBQUssS0FBSyxLQUFLLENBQUMsS0FBSyxFQUFFO1lBQUUsS0FBSyxHQUFHLEtBQUssQ0FBQztTQUFFO1FBQzdDLElBQUksS0FBSyxLQUFLLEtBQUssQ0FBQyxJQUFJLEVBQUU7WUFBRSxLQUFLLEdBQUcsUUFBUSxDQUFDO1NBQUU7UUFFL0MsSUFBSSxXQUFXLEVBQUU7WUFDZixNQUFNLElBQUksR0FBRyxXQUFXLEdBQUcsVUFBVSxDQUFDLE1BQU0sQ0FBQztZQUM3QyxJQUFJLElBQUksR0FBRyxDQUFDLEVBQUU7Z0JBQ1osS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLElBQUksRUFBRSxDQUFDLEVBQUUsRUFBRTtvQkFDN0IsVUFBVSxJQUFJLEdBQUcs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QUFBLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxzREFBc0QiLCJzb3VyY2VzQ29udGVudCI6WyIvKiAqL1xuLyogKi9cbiAgXG5pbXBvcnQgeyBMZXZlbCB9IGZyb20gJy4vbGV2ZWwnO1xuaW1wb3J0IHsgSGVscGVycyB9IGZyb20gJ3RucC1jb3JlL2Jyb3dzZXInO1xuaW1wb3J0IHsgY29uc29sZUxvZywgZGlzcGxheVBhcmFtcyB9IGZyb20gJy4vYmFja2VuZC1sb2dnaW5nJztcblxuLyogKi9cbi8qICovXG4gIFxuXG5leHBvcnQgY2xhc3MgRGlzcGxheSB7XG5cbiAgc3RhdGljIG1zZyhcbiAgICBtZXNzYWdlOiBzdHJpbmcgfCBhbnksXG4gICAgcGFyYW1zOiBhbnlbXSxcbiAgICBtb2R1bGVOYW1lOiBzdHJpbmcsXG4gICAgbW9kdWxlQ29sb3I6IHN0cmluZyxcbiAgICBsZXZlbDogTGV2ZWwsXG4gICAgbW9kdWxlV2lkdGg6IG51bWJlciB8IHVuZGVmaW5lZCxcbiAgICBpc1Byb2R1Y3Rpb25Nb2RlOiBib29sZWFuXG4gICkge1xuICAgIGlmIChpc1Byb2R1Y3Rpb25Nb2RlKSB7XG4gICAgICByZXR1cm47XG4gICAgfTtcbiAgICBsZXQgY29sb3IgPSAnZ3JheSc7XG4gICAgaWYgKGxldmVsID09PSBMZXZlbC5JTkZPKSB7IGNvbG9yID0gJ2RlZXBza3libHVlJzsgfVxuICAgIGlmIChsZXZlbCA9PT0gTGV2ZWwuRVJST1IpIHsgY29sb3IgPSAncmVkJzsgfVxuICAgIGlmIChsZXZlbCA9PT0gTGV2ZWwuV0FSTikgeyBjb2xvciA9ICdvcmFuZ2UnOyB9XG5cbiAgICBpZiAobW9kdWxlV2lkdGgpIHtcbiAgICAgIGNvbnN0IGRpZmYgPSBtb2R1bGVXaWR0aCAtIG1vZHVsZU5hbWUubGVuZ3RoO1xuICAgICAgaWYgKGRpZmYgPiAwKSB7XG4gICAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgZGlmZjsgaSsrKSB7XG4gICAgICAgICAgbW9kdWxlTmFtZSArPSAnICc7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG5cblxuICAgIGlmIChIZWxwZXJzLmlzQnJvd3NlclxuLyogKi9cbi8qICovXG4gIFxuICAgICkge1xuXG5cbiAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgIGNvbnN0IGlzRWRnZU9ySWU4b3JBYm92ZSA9IChkb2N1bWVudFsnZG9jdW1lbnRNb2RlJ10gfHwgL0VkZ2UvLnRlc3QobmF2aWdhdG9yLnVzZXJBZ2VudCkpO1xuXG4gICAgICBpZiAoaXNFZGdlT3JJZThvckFib3ZlKSB7XG4gICAgICAgIGlmICh0eXBlb2YgbWVzc2FnZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgICBsZXQgYTEgPSAnW1sgJyArIG1vZHVsZU5hbWUgKyAnIF1dICcgKyBtZXNzYWdlICsgJyAnO1xuICAgICAgICAgIHBhcmFtcy51bnNoaWZ0KGExKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBsZXQgYTEgPSAnW1sgJyArIG1vZHVsZU5hbWUgKyAnXV0gJztcbiAgICAgICAgICBwYXJhbXMucHVzaChtZXNzYWdlKTtcbiAgICAgICAgICBwYXJhbXMudW5zaGlmdChhMSk7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKGxldmVsID09PSBMZXZlbC5JTkZPKSB7XG4gICAgICAgICAgY29uc29sZS5pbmZvLmFwcGx5KGNvbnNvbGUsIHBhcmFtcyk7XG4gICAgICAgIH0gZWxzZSBpZiAobGV2ZWwgPT09IExldmVsLkVSUk9SKSB7XG4gICAgICAgICAgY29uc29sZS5lcnJvci5hcHBseShjb25zb2xlLCBwYXJhbXMpO1xuICAgICAgICB9IGVsc2UgaWYgKGxldmVsID09PSBMZXZlbC5XQVJOKSB7XG4gICAgICAgICAgY29uc29sZS53YXJuLmFwcGx5KGNvbnNvbGUsIHBhcmFtcyk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgY29uc29sZS5sb2cuYXBwbHkoY29uc29sZSwgcGFyYW1zKTtcbiAgICAgICAgfVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgaWYgKHR5cGVvZiBtZXNzYWdlID09PSAnc3RyaW5nJykge1xuICAgICAgICAgIGxldCBhMSA9ICclYyAnICsgbW9kdWxlTmFtZSArICcgICVjICcgKyBtZXNzYWdlICsgJyAnO1xuICAgICAgICAgIGxldCBhMiA9ICdiYWNrZ3JvdW5kOiAnICsgbW9kdWxlQ29sb3IgKyAnO2NvbG9yOndoaXRlOyBib3JkZXI6IDFweCBzb2xpZCAnICsgbW9kdWxlQ29sb3IgKyAnOyAnO1xuICAgICAgICAgIGxldCBhMyA9ICdib3JkZXI6IDFweCBzb2xpZCAnICsgY29sb3IgKyAnOyAnO1xuICAgICAgICAgIHBhcmFtcy51bnNoaWZ0KGEzKTtcbiAgICAgICAgICBwYXJhbXMudW5zaGlmdChhMik7XG4gICAgICAgICAgcGFyYW1zLnVuc2hpZnQoYTEpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGxldCBhMSA9ICclYyAnICsgbW9kdWxlTmFtZSArICcgJztcbiAgICAgICAgICBsZXQgYTIgPSAnYmFja2dyb3VuZDogJyArIG1vZHVsZUNvbG9yICsgJztjb2xvcjp3aGl0ZTsgYm9yZGVyOiAxcHggc29saWQgJyArIGNvbG9yICsgJzsgJztcbiAgICAgICAgICBwYXJhbXMucHVzaChtZXNzYWdlKTtcbiAgICAgICAgICBwYXJhbXMudW5zaGlmdChhMik7XG4gICAgICAgICAgcGFyYW1zLnVuc2hpZnQoYTEpO1xuICAgICAgICB9XG4gICAgICAgIGNvbnNvbGUubG9nLmFwcGx5KGNvbnNvbGUsIHBhcmFtcyk7XG4gICAgICB9XG5cbiAgICB9XG5cblxuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4gIFxuXG4gIH1cblxufVxuXG4gOyh7fSk7IC8vIEAtLWVuZC1vZi1maWxlLWZvci1tb2R1bGU9bmcyLWxvZ2dlciBsaWIvZGlzcGxheS50cyJdfQ==
|
|
@@ -1,7 +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
|
|
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
7
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi90bXAtbGlicy1mb3ItYnVuZGxlL25nMi1sb2dnZXIvcHJvamVjdHMvbmcyLWxvZ2dlci9zcmMvbGliL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsT0FBTyxDQUFDO0FBQ3RCLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsV0FBVyxDQUFDO0FBRXpCLENBQUM7QUFBQSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsb0RBQW9EIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9sb2cnO1xuZXhwb3J0ICogZnJvbSAnLi9sZXZlbCc7XG5leHBvcnQgKiBmcm9tICcuL2xvZ2dlcic7XG5leHBvcnQgKiBmcm9tICcuL2Rpc3BsYXknO1xuXG4gOyh7fSk7IC8vIEAtLWVuZC1vZi1maWxlLWZvci1tb2R1bGU9bmcyLWxvZ2dlciBsaWIvaW5kZXgudHMiXX0=
|
|
@@ -1,33 +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
|
|
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
33
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGV2ZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi90bXAtbGlicy1mb3ItYnVuZGxlL25nMi1sb2dnZXIvcHJvamVjdHMvbmcyLWxvZ2dlci9zcmMvbGliL2xldmVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLEtBU1g7QUFURCxXQUFZLEtBQUs7SUFDYixpQ0FBSSxDQUFBO0lBQ0osaUNBQUksQ0FBQTtJQUNKLGlDQUFJLENBQUE7SUFDSixtQ0FBSyxDQUFBO0lBQ0wsdUNBQU8sQ0FBQTtJQUNQLGlEQUFZLENBQUE7SUFDWiwyQ0FBUyxDQUFBO0lBQ1QsMkNBQVMsQ0FBQTtBQUNiLENBQUMsRUFUVyxLQUFLLEtBQUwsS0FBSyxRQVNoQjtBQUVELE1BQU0sQ0FBQyxNQUFNLFFBQVEsR0FBRztJQUN0QixDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsRUFBRyxLQUFLO0lBQ3BCLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxFQUFHLE1BQU07SUFDckIsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUcsTUFBTTtJQUNyQixDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsRUFBRyxPQUFPO0lBQ3ZCLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxFQUFHLFNBQVM7SUFDM0IsQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLEVBQUcsYUFBYTtJQUNwQyxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsRUFBRyxVQUFVO0lBQzlCLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxFQUFHLEVBQUU7Q0FDdkIsQ0FBQTtBQUVELE1BQU0sQ0FBQyxNQUFNLFVBQVUsR0FBRztJQUN4QixRQUFRLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQztJQUNwQixRQUFRLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQztJQUM1QixRQUFRLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQztJQUN6QixRQUFRLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQztJQUNwQixRQUFRLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQztJQUN2QixRQUFRLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQztJQUNwQixRQUFRLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQztDQUN0QixDQUFDO0FBRUQsQ0FBQztBQUFBLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxvREFBb0QiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBMZXZlbCB7XG4gICAgREFUQSxcbiAgICBJTkZPLFxuICAgIFdBUk4sXG4gICAgRVJST1IgLFxuICAgIFNVQ0NFU1MsXG4gICAgVEFTS19TVEFSVEVELFxuICAgIFRBU0tfRE9ORSxcbiAgICBfX05PVEhJTkcgLFxufVxuXG5leHBvcnQgY29uc3QgTGV2ZWxLZXkgPSB7XG4gIFtMZXZlbC5EQVRBXSA6ICdsb2cnLFxuICBbTGV2ZWwuSU5GT10gOiAnaW5mbycsXG4gIFtMZXZlbC5XQVJOXSA6ICd3YXJuJyxcbiAgW0xldmVsLkVSUk9SXSA6ICdlcnJvcicsXG4gIFtMZXZlbC5TVUNDRVNTXSA6ICdzdWNjZXNzJyxcbiAgW0xldmVsLlRBU0tfU1RBUlRFRF0gOiAndGFza3N0YXJ0ZWQnLFxuICBbTGV2ZWwuVEFTS19ET05FXSA6ICd0YXNrZG9uZScsXG4gIFtMZXZlbC5fX05PVEhJTkddIDogJycsXG59XG5cbmV4cG9ydCBjb25zdCBMZXZlbE9yZGVyID0gW1xuICBMZXZlbEtleVtMZXZlbC5EQVRBXSxcbiAgTGV2ZWxLZXlbTGV2ZWwuVEFTS19TVEFSVEVEXSxcbiAgTGV2ZWxLZXlbTGV2ZWwuVEFTS19ET05FXSxcbiAgTGV2ZWxLZXlbTGV2ZWwuSU5GT10sXG4gIExldmVsS2V5W0xldmVsLlNVQ0NFU1NdLFxuICBMZXZlbEtleVtMZXZlbC5XQVJOXSxcbiAgTGV2ZWxLZXlbTGV2ZWwuRVJST1JdLFxuXTtcblxuIDsoe30pOyAvLyBALS1lbmQtb2YtZmlsZS1mb3ItbW9kdWxlPW5nMi1sb2dnZXIgbGliL2xldmVsLnRzIl19
|
|
@@ -1,161 +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 create(name, ...level) {
|
|
31
|
-
return Log.instance.create(name, ...level);
|
|
32
|
-
}
|
|
33
|
-
static disableLogs(level = Level.__NOTHING) {
|
|
34
|
-
/* */
|
|
35
|
-
/* */
|
|
36
|
-
/* */
|
|
37
|
-
/* */
|
|
38
|
-
/* */
|
|
39
|
-
/* */
|
|
40
|
-
/* */
|
|
41
|
-
LevelOrder.reverse().find(a => {
|
|
42
|
-
// @ts-ignore
|
|
43
|
-
if (!this.consolelogfn[a]) {
|
|
44
|
-
// @ts-ignore
|
|
45
|
-
this.consolelogfn[a] = console[a];
|
|
46
|
-
}
|
|
47
|
-
// @ts-ignore
|
|
48
|
-
console[a] = () => { };
|
|
49
|
-
if (a === LevelKey[level]) {
|
|
50
|
-
return true;
|
|
51
|
-
}
|
|
52
|
-
return false;
|
|
53
|
-
});
|
|
54
|
-
}
|
|
55
|
-
static enableLogs() {
|
|
56
|
-
/* */
|
|
57
|
-
/* */
|
|
58
|
-
/* */
|
|
59
|
-
/* */
|
|
60
|
-
LevelOrder.forEach(a => {
|
|
61
|
-
// @ts-ignore
|
|
62
|
-
console[a] = this.consolelogfn[a];
|
|
63
|
-
});
|
|
64
|
-
}
|
|
65
|
-
setProductionMode() {
|
|
66
|
-
if (this.modeIsSet) {
|
|
67
|
-
this.modeIsSet = false;
|
|
68
|
-
throw '[ng2-logger] Production mode is already set';
|
|
69
|
-
}
|
|
70
|
-
else {
|
|
71
|
-
this.modeIsSet = true;
|
|
72
|
-
setTimeout(() => {
|
|
73
|
-
if (this.modeIsSet && console !== void 0 && console.clear !== void 0) {
|
|
74
|
-
console.clear();
|
|
75
|
-
console.log = () => { };
|
|
76
|
-
console.error = () => { };
|
|
77
|
-
console.warn = () => { };
|
|
78
|
-
console.info = () => { };
|
|
79
|
-
}
|
|
80
|
-
});
|
|
81
|
-
this.isDevelopmentMode = false;
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
onlyModules(...modules) {
|
|
85
|
-
if (this._logModules) {
|
|
86
|
-
throw '[ng2-logger] You should use funcion onlyModules only once';
|
|
87
|
-
}
|
|
88
|
-
if (!this._logModules) {
|
|
89
|
-
this._logModules = true;
|
|
90
|
-
}
|
|
91
|
-
if (modules.length === 0)
|
|
92
|
-
return;
|
|
93
|
-
this.modules = modules;
|
|
94
|
-
this.muteAllOtherModules();
|
|
95
|
-
}
|
|
96
|
-
onlyLevel(...level) {
|
|
97
|
-
if (this._logOnly) {
|
|
98
|
-
throw '[ng2-logger] You should use funcion onlyLevel only once';
|
|
99
|
-
}
|
|
100
|
-
if (!this._logOnly) {
|
|
101
|
-
this._logOnly = true;
|
|
102
|
-
}
|
|
103
|
-
this.levels = Array.isArray(level) ? level : [level];
|
|
104
|
-
for (const logName in this.instances) {
|
|
105
|
-
if (this.instances.hasOwnProperty(logName)) {
|
|
106
|
-
const element = this.instances[logName];
|
|
107
|
-
element['allowed'] = this.levels;
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
create(name, ...level) {
|
|
112
|
-
let i;
|
|
113
|
-
if (Array.isArray(this.levels) && this.levels.length > 0) {
|
|
114
|
-
level = this.levels;
|
|
115
|
-
}
|
|
116
|
-
if (this.instances[name] === void 0) {
|
|
117
|
-
i = new (Log.Logger)(name, getRandomColor(), this.isDevelopmentMode, level, this.isMutedModule(name), this.levels.length > 0 ? this.fixedWidth : void 0);
|
|
118
|
-
this.instances[name] = i;
|
|
119
|
-
}
|
|
120
|
-
else {
|
|
121
|
-
i = this.instances[name];
|
|
122
|
-
}
|
|
123
|
-
return i;
|
|
124
|
-
}
|
|
125
|
-
isMutedModule(moduleName) {
|
|
126
|
-
if (this.modules.length == 0)
|
|
127
|
-
return false;
|
|
128
|
-
if (!Helpers.contain(this.modules, moduleName))
|
|
129
|
-
return true;
|
|
130
|
-
return false;
|
|
131
|
-
}
|
|
132
|
-
muteAllOtherModules() {
|
|
133
|
-
for (var moduleName in this.instances) {
|
|
134
|
-
if (!Helpers.contain(this.modules, moduleName))
|
|
135
|
-
this.instances[moduleName].mute();
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
Log.Logger = Logger;
|
|
140
|
-
Log.consolelogfn = {};
|
|
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
|
|
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 create(name, ...level) {
|
|
31
|
+
return Log.instance.create(name, ...level);
|
|
32
|
+
}
|
|
33
|
+
static disableLogs(level = Level.__NOTHING) {
|
|
34
|
+
/* */
|
|
35
|
+
/* */
|
|
36
|
+
/* */
|
|
37
|
+
/* */
|
|
38
|
+
/* */
|
|
39
|
+
/* */
|
|
40
|
+
/* */
|
|
41
|
+
LevelOrder.reverse().find(a => {
|
|
42
|
+
// @ts-ignore
|
|
43
|
+
if (!this.consolelogfn[a]) {
|
|
44
|
+
// @ts-ignore
|
|
45
|
+
this.consolelogfn[a] = console[a];
|
|
46
|
+
}
|
|
47
|
+
// @ts-ignore
|
|
48
|
+
console[a] = () => { };
|
|
49
|
+
if (a === LevelKey[level]) {
|
|
50
|
+
return true;
|
|
51
|
+
}
|
|
52
|
+
return false;
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
static enableLogs() {
|
|
56
|
+
/* */
|
|
57
|
+
/* */
|
|
58
|
+
/* */
|
|
59
|
+
/* */
|
|
60
|
+
LevelOrder.forEach(a => {
|
|
61
|
+
// @ts-ignore
|
|
62
|
+
console[a] = this.consolelogfn[a];
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
setProductionMode() {
|
|
66
|
+
if (this.modeIsSet) {
|
|
67
|
+
this.modeIsSet = false;
|
|
68
|
+
throw '[ng2-logger] Production mode is already set';
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
this.modeIsSet = true;
|
|
72
|
+
setTimeout(() => {
|
|
73
|
+
if (this.modeIsSet && console !== void 0 && console.clear !== void 0) {
|
|
74
|
+
console.clear();
|
|
75
|
+
console.log = () => { };
|
|
76
|
+
console.error = () => { };
|
|
77
|
+
console.warn = () => { };
|
|
78
|
+
console.info = () => { };
|
|
79
|
+
}
|
|
80
|
+
});
|
|
81
|
+
this.isDevelopmentMode = false;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
onlyModules(...modules) {
|
|
85
|
+
if (this._logModules) {
|
|
86
|
+
throw '[ng2-logger] You should use funcion onlyModules only once';
|
|
87
|
+
}
|
|
88
|
+
if (!this._logModules) {
|
|
89
|
+
this._logModules = true;
|
|
90
|
+
}
|
|
91
|
+
if (modules.length === 0)
|
|
92
|
+
return;
|
|
93
|
+
this.modules = modules;
|
|
94
|
+
this.muteAllOtherModules();
|
|
95
|
+
}
|
|
96
|
+
onlyLevel(...level) {
|
|
97
|
+
if (this._logOnly) {
|
|
98
|
+
throw '[ng2-logger] You should use funcion onlyLevel only once';
|
|
99
|
+
}
|
|
100
|
+
if (!this._logOnly) {
|
|
101
|
+
this._logOnly = true;
|
|
102
|
+
}
|
|
103
|
+
this.levels = Array.isArray(level) ? level : [level];
|
|
104
|
+
for (const logName in this.instances) {
|
|
105
|
+
if (this.instances.hasOwnProperty(logName)) {
|
|
106
|
+
const element = this.instances[logName];
|
|
107
|
+
element['allowed'] = this.levels;
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
create(name, ...level) {
|
|
112
|
+
let i;
|
|
113
|
+
if (Array.isArray(this.levels) && this.levels.length > 0) {
|
|
114
|
+
level = this.levels;
|
|
115
|
+
}
|
|
116
|
+
if (this.instances[name] === void 0) {
|
|
117
|
+
i = new (Log.Logger)(name, getRandomColor(), this.isDevelopmentMode, level, this.isMutedModule(name), this.levels.length > 0 ? this.fixedWidth : void 0);
|
|
118
|
+
this.instances[name] = i;
|
|
119
|
+
}
|
|
120
|
+
else {
|
|
121
|
+
i = this.instances[name];
|
|
122
|
+
}
|
|
123
|
+
return i;
|
|
124
|
+
}
|
|
125
|
+
isMutedModule(moduleName) {
|
|
126
|
+
if (this.modules.length == 0)
|
|
127
|
+
return false;
|
|
128
|
+
if (!Helpers.contain(this.modules, moduleName))
|
|
129
|
+
return true;
|
|
130
|
+
return false;
|
|
131
|
+
}
|
|
132
|
+
muteAllOtherModules() {
|
|
133
|
+
for (var moduleName in this.instances) {
|
|
134
|
+
if (!Helpers.contain(this.modules, moduleName))
|
|
135
|
+
this.instances[moduleName].mute();
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
Log.Logger = Logger;
|
|
140
|
+
Log.consolelogfn = {};
|
|
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
161
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vdG1wLWxpYnMtZm9yLWJ1bmRsZS9uZzItbG9nZ2VyL3Byb2plY3RzL25nMi1sb2dnZXIvc3JjL2xpYi9sb2cudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUNsQyxPQUFPLEVBQUUsS0FBSyxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDdEQsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQzNDLEtBQUs7QUFDTCxLQUFLO0FBQ0wsS0FBSztBQUlMLEtBQUs7QUFDTCxLQUFLO0FBSUwsTUFBTSxPQUFPLEdBQUc7SUFFZDtRQXVEUSxhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLGdCQUFXLEdBQUcsS0FBSyxDQUFDO1FBQ3BCLHNCQUFpQixHQUFHLElBQUksQ0FBQztRQUN6QixjQUFTLEdBQVksS0FBSyxDQUFDO1FBQzNCLGVBQVUsR0FBRyxDQUFDLENBQUM7UUFDZixjQUFTLEdBQXFDLEVBQUUsQ0FBQztRQUNqRCxXQUFNLEdBQVksRUFBRSxDQUFDO1FBQ3JCLFlBQU8sR0FBd0IsRUFBRSxDQUFDO0lBOURsQixDQUFDO0lBQ3pCLGFBQWE7SUFDTCxNQUFNLEtBQUssUUFBUTtRQUN6QixhQUFhO1FBQ2IsSUFBSSxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsRUFBRTtZQUNyQixhQUFhO1lBQ2IsR0FBRyxDQUFDLFdBQVcsQ0FBQyxHQUFHLElBQUksR0FBRyxFQUFFLENBQUM7U0FDOUI7UUFDRCxhQUFhO1FBQ2IsT0FBTyxHQUFHLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDMUIsQ0FBQztJQUlELE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBWSxFQUFFLEdBQUcsS0FBYztRQUMzQyxPQUFPLEdBQUcsQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLElBQUks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QUFLLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUM7S0FDbEQ7SUFDRCxJQUFJLEtBQUssS0FBSyxLQUFLLENBQUMsRUFBRTtRQUNwQixPQUFPLGNBQWMsRUFBRSxDQUFBO0tBQ3hCO0lBQUEsQ0FBQztJQUNGLE9BQU8sS0FBSyxDQUFDO0FBQ2YsQ0FBQztBQUVBLENBQUM7QUFBQSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsa0RBQWtEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTG9nZ2VyIH0gZnJvbSAnLi9sb2dnZXInO1xuaW1wb3J0IHsgTGV2ZWwsIExldmVsT3JkZXIsIExldmVsS2V5IH0gZnJvbSAnLi9sZXZlbCc7XG5pbXBvcnQgeyBIZWxwZXJzIH0gZnJvbSAndG5wLWNvcmUvYnJvd3Nlcic7XG4vKiAqL1xuLyogKi9cbi8qICovXG4gIFxuXG5cbi8qICovXG4vKiAqL1xuICBcblxuXG5leHBvcnQgY2xhc3MgTG9nIHtcblxuICBwcml2YXRlIGNvbnN0cnVjdG9yKCkgeyB9XG4gIC8vIEB0cy1pZ25vcmVcbiAgcHJpdmF0ZSBzdGF0aWMgZ2V0IGluc3RhbmNlKCk6IGFueSB7XG4gICAgLy8gQHRzLWlnbm9yZVxuICAgIGlmICghTG9nWydfaW5zdGFuY2UnXSkge1xuICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgTG9nWydfaW5zdGFuY2UnXSA9IG5ldyBMb2coKTtcbiAgICB9XG4gICAgLy8gQHRzLWlnbm9yZVxuICAgIHJldHVybiBMb2dbJ19pbnN0YW5jZSddO1xuICB9XG5cblxuICBzdGF0aWMgTG9nZ2VyOiAodHlwZW9mIExvZ2dlcikgPSBMb2dnZXI7XG4gIHN0YXRpYyBjcmVhdGUobmFtZTogc3RyaW5nLCAuLi5sZXZlbDogTGV2ZWxbXSk6IExvZ2dlciB7XG4gICAgcmV0dXJuIExvZy5pbnN0YW5jZS5jcmVhdGUobmFtZSwgLi4ubGV2ZWwpO1xuICB9XG5cbiAgcHJpdmF0ZSBzdGF0aWMgcmVhZG9ubHkgY29uc29sZWxvZ2ZuID0ge307XG4gIHN0YXRpYyBkaXNhYmxlTG9ncyhsZXZlbCA9IExldmVsLl9fTk9USElORykge1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbiAgXG4gICAgTGV2ZWxPcmRlci5yZXZlcnNlKCkuZmluZChhID0+IHtcbiAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgIGlmICghdGhpcy5jb25zb2xlbG9nZm5bYV0pIHtcbiAgICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgICB0aGlzLmNvbnNvbGVsb2dmblthXSA9IGNvbnNvbGVbYV07XG4gICAgICB9XG4gICAgICAvLyBAdHMtaWdub3JlXG4gICAgICBjb25zb2xlW2FdID0gKCkgPT4geyB9O1xuICAgICAgaWYgKGEgPT09IExldmVsS2V5W2xldmVsXSkge1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgIH1cbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9KTtcbiAgfVxuXG4gIHN0YXRpYyBlbmFibGVMb2dzKCkge1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbiAgXG4gICAgTGV2ZWxPcmRlci5mb3JFYWNoKGEgPT4ge1xuICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgY29uc29sZVthXSA9IHRoaXMuY29uc29sZWxvZ2ZuW2FdXG4gICAgfSk7XG4gIH1cblxuICBwcml2YXRlIF9sb2dPbmx5ID0gZmFsc2U7XG4gIHByaXZhdGUgX2xvZ01vZHVsZXMgPSBmYWxzZTtcbiAgcHJpdmF0ZSBpc0RldmVsb3BtZW50TW9kZSA9IHRydWU7XG4gIHByaXZhdGUgbW9kZUlzU2V0OiBib29sZWFuID0gZmFsc2U7XG4gIHByaXZhdGUgZml4ZWRXaWR0aCA9IDA7XG4gIHByaXZhdGUgaW5zdGFuY2VzOiB7IFttb2R1bGVOYW1lOiBzdHJpbmddOiBMb2dnZXIgfSA9IHt9O1xuICBwcml2YXRlIGxldmVsczogTGV2ZWxbXSA9IFtdO1xuICBwcml2YXRlIG1vZHVsZXM6IChzdHJpbmcgfCBSZWdFeHApW10gPSBbXTtcblxuXG4gIHB1YmxpYyBzZXRQcm9kdWN0aW9uTW9kZSgpIHtcbiAgICBpZiAodGhpcy5tb2RlSXNTZXQpIHtcbiAgICAgIHRoaXMubW9kZUlzU2V0ID0gZmFsc2VcbiAgICAgIHRocm93ICdbbmcyLWxvZ2dlcl0gUHJvZHVjdGlvbiBtb2RlIGlzIGFscmVhZHkgc2V0JztcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5tb2RlSXNTZXQgPSB0cnVlO1xuICAgICAgc2V0VGltZW91dCgoKSA9PiB7XG5cbiAgICAgICAgaWYgKHRoaXMubW9kZUlzU2V0ICYmIGNvbnNvbGUgIT09IHZvaWQgMCAmJiBjb25zb2xlLmNsZWFyICE9PSB2b2lkIDApIHtcblxuICAgICAgICAgIGNvbnNvbGUuY2xlYXIoKTtcbiAgICAgICAgICBjb25zb2xlLmxvZyA9ICgpID0+IHsgfTtcbiAgICAgICAgICBjb25zb2xlLmVycm9yID0gKCkgPT4geyB9O1xuICAgICAgICAgIGNvbnNvbGUud2FybiA9ICgpID0+IHsgfTtcbiAgICAgICAgICBjb25zb2xlLmluZm8gPSAoKSA9PiB7IH07XG4gICAgICAgIH1cbiAgICAgIH0pO1xuXG4gICAgICB0aGlzLmlzRGV2ZWxvcG1lbnRNb2RlID0gZmFsc2U7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIG9ubHlNb2R1bGVzKC4uLm1vZHVsZXM6IChzdHJpbmcgfCBSZWdFeHApW10pIHtcbiAgICBpZiAodGhpcy5fbG9nTW9kdWxlcykge1xuICAgICAgdGhyb3cgJ1tuZzItbG9nZ2VyXSBZb3Ugc2hvdWxkIHVzZSBmdW5jaW9uIG9ubHlNb2R1bGVzIG9ubHkgb25jZSc7XG4gICAgfVxuICAgIGlmICghdGhpcy5fbG9nTW9kdWxlcykge1xuICAgICAgdGhpcy5fbG9nTW9kdWxlcyA9IHRydWU7XG4gICAgfVxuICAgIGlmIChtb2R1bGVzLmxlbmd0aCA9PT0gMCkgcmV0dXJuO1xuICAgIHRoaXMubW9kdWxlcyA9IG1vZHVsZXM7XG5cbiAgICB0aGlzLm11dGVBbGxPdGhlck1vZHVsZXMoKTtcbiAgfVxuXG5cbiAgcHVibGljIG9ubHlMZXZlbCguLi5sZXZlbDogTGV2ZWxbXSkge1xuICAgIGlmICh0aGlzLl9sb2dPbmx5KSB7XG4gICAgICB0aHJvdyAnW25nMi1sb2dnZXJdIFlvdSBzaG91bGQgdXNlIGZ1bmNpb24gb25seUxldmVsIG9ubHkgb25jZSc7XG4gICAgfVxuICAgIGlmICghdGhpcy5fbG9nT25seSkge1xuICAgICAgdGhpcy5fbG9nT25seSA9IHRydWU7XG4gICAgfVxuXG4gICAgdGhpcy5sZXZlbHMgPSBBcnJheS5pc0FycmF5KGxldmVsKSA/IGxldmVsIDogW2xldmVsXTtcblxuXG4gICAgZm9yIChjb25zdCBsb2dOYW1lIGluIHRoaXMuaW5zdGFuY2VzKSB7XG4gICAgICBpZiAodGhpcy5pbnN0YW5jZXMuaGFzT3duUHJvcGVydHkobG9nTmFtZSkpIHtcbiAgICAgICAgY29uc3QgZWxlbWVudCA9IHRoaXMuaW5zdGFuY2VzW2xvZ05hbWVdO1xuICAgICAgICBlbGVtZW50WydhbGxvd2VkJ10gPSB0aGlzLmxldmVscztcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuXG5cbiAgcHJpdmF0ZSBjcmVhdGUobmFtZTogc3RyaW5nLCAuLi5sZXZlbDogTGV2ZWxbXSk6IExvZ2dlciB7XG4gICAgbGV0IGk6IExvZ2dlcjtcbiAgICBpZiAoQXJyYXkuaXNBcnJheSh0aGlzLmxldmVscykgJiYgdGhpcy5sZXZlbHMubGVuZ3RoID4gMCkge1xuICAgICAgbGV2ZWwgPSB0aGlzLmxldmVscztcbiAgICB9XG4gICAgaWYgKHRoaXMuaW5zdGFuY2VzW25hbWVdID09PSB2b2lkIDApIHtcbiAgICAgIGkgPSBuZXcgKExvZy5Mb2dnZXIpKFxuICAgICAgICBuYW1lLFxuICAgICAgICBnZXRSYW5kb21Db2xvcigpLFxuICAgICAgICB0aGlzLmlzRGV2ZWxvcG1lbnRNb2RlLFxuICAgICAgICBsZXZlbCxcbiAgICAgICAgdGhpcy5pc011dGVkTW9kdWxlKG5hbWUpLFxuICAgICAgICB0aGlzLmxldmVscy5sZW5ndGggPiAwID8gdGhpcy5maXhlZFdpZHRoIDogdm9pZCAwLFxuXG4gICAgICApO1xuICAgICAgdGhpcy5pbnN0YW5jZXNbbmFtZV0gPSBpO1xuICAgIH0gZWxzZSB7XG4gICAgICBpID0gdGhpcy5pbnN0YW5jZXNbbmFtZV07XG4gICAgfVxuICAgIHJldHVybiBpO1xuICB9XG5cbiAgcHJpdmF0ZSBpc011dGVkTW9kdWxlKG1vZHVsZU5hbWU6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIGlmICh0aGlzLm1vZHVsZXMubGVuZ3RoID09IDApIHJldHVybiBmYWxzZTtcbiAgICBpZiAoIUhlbHBlcnMuY29udGFpbih0aGlzLm1vZHVsZXMsIG1vZHVsZU5hbWUpKSByZXR1cm4gdHJ1ZTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbiAgcHJpdmF0ZSBtdXRlQWxsT3RoZXJNb2R1bGVzKCkge1xuICAgIGZvciAodmFyIG1vZHVsZU5hbWUgaW4gdGhpcy5pbnN0YW5jZXMpIHtcbiAgICAgIGlmICghSGVscGVycy5jb250YWluKHRoaXMubW9kdWxlcywgbW9kdWxlTmFtZSkpXG4gICAgICAgIHRoaXMuaW5zdGFuY2VzW21vZHVsZU5hbWVdLm11dGUoKVxuICAgIH1cbiAgfVxuXG59XG5cblxuZnVuY3Rpb24gZ2V0UmFuZG9tQ29sb3IoKTogc3RyaW5nIHtcbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4gIFxuXG4gIGxldCBsZXR0ZXJzID0gJzAxMjM0NScuc3BsaXQoJycpO1xuICBsZXQgY29sb3IgPSAnIyc7XG4gIGNvbG9yICs9IGxldHRlcnNbTWF0aC5yb3VuZChNYXRoLnJhbmRvbSgpICogNSldO1xuICBsZXR0ZXJzID0gJzAxMjM0NTY3ODlBQkNERUYnLnNwbGl0KCcnKTtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCA1OyBpKyspIHtcbiAgICBjb2xvciArPSBsZXR0ZXJzW01hdGgucm91bmQoTWF0aC5yYW5kb20oKSAqIDE1KV07XG4gIH1cbiAgaWYgKGNvbG9yID09PSB2b2lkIDApIHtcbiAgICByZXR1cm4gZ2V0UmFuZG9tQ29sb3IoKVxuICB9O1xuICByZXR1cm4gY29sb3I7XG59XG5cbiA7KHt9KTsgLy8gQC0tZW5kLW9mLWZpbGUtZm9yLW1vZHVsZT1uZzItbG9nZ2VyIGxpYi9sb2cudHMiXX0=
|