ng2-logger 13.0.26 → 13.1.1

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.
Files changed (107) hide show
  1. package/README.md +206 -206
  2. package/app/index.d.ts +4 -4
  3. package/app/index.js +19 -19
  4. package/app/index.js.map +1 -1
  5. package/app/ng2-logger.component.d.ts +5 -5
  6. package/app/ng2-logger.component.js +33 -33
  7. package/app/ng2-logger.component.js.map +1 -1
  8. package/app/ng2-logger.module.d.ts +2 -2
  9. package/app/ng2-logger.module.js +30 -30
  10. package/app/ng2-logger.module.js.map +1 -1
  11. package/browser/README.md +24 -24
  12. package/browser/esm2020/lib/backend-logging.mjs +92 -88
  13. package/browser/esm2020/lib/display.mjs +97 -93
  14. package/browser/esm2020/lib/helpers.mjs +1 -1
  15. package/browser/esm2020/lib/index.mjs +5 -5
  16. package/browser/esm2020/lib/level.mjs +31 -22
  17. package/browser/esm2020/lib/log.mjs +164 -165
  18. package/browser/esm2020/lib/logger.mjs +235 -157
  19. package/browser/esm2020/ng2-logger.mjs +4 -4
  20. package/browser/esm2020/public-api.mjs +1 -1
  21. package/browser/fesm2015/ng2-logger.mjs +512 -422
  22. package/browser/fesm2015/ng2-logger.mjs.map +1 -1
  23. package/browser/fesm2020/ng2-logger.mjs +512 -422
  24. package/browser/fesm2020/ng2-logger.mjs.map +1 -1
  25. package/browser/lib/backend-logging.d.ts +4 -4
  26. package/browser/lib/display.d.ts +4 -4
  27. package/browser/lib/helpers.d.ts +1 -1
  28. package/browser/lib/index.d.ts +5 -5
  29. package/browser/lib/level.d.ts +21 -15
  30. package/browser/lib/log.d.ts +25 -25
  31. package/browser/lib/logger.d.ts +81 -60
  32. package/browser/ng2-logger.d.ts +5 -5
  33. package/browser/public-api.d.ts +1 -1
  34. package/client/README.md +24 -24
  35. package/client/esm2020/lib/backend-logging.mjs +92 -88
  36. package/client/esm2020/lib/display.mjs +97 -93
  37. package/client/esm2020/lib/helpers.mjs +1 -1
  38. package/client/esm2020/lib/index.mjs +5 -5
  39. package/client/esm2020/lib/level.mjs +31 -22
  40. package/client/esm2020/lib/log.mjs +164 -165
  41. package/client/esm2020/lib/logger.mjs +235 -157
  42. package/client/esm2020/ng2-logger.mjs +4 -4
  43. package/client/esm2020/public-api.mjs +1 -1
  44. package/client/fesm2015/ng2-logger.mjs +512 -422
  45. package/client/fesm2015/ng2-logger.mjs.map +1 -1
  46. package/client/fesm2020/ng2-logger.mjs +512 -422
  47. package/client/fesm2020/ng2-logger.mjs.map +1 -1
  48. package/client/lib/backend-logging.d.ts +4 -4
  49. package/client/lib/display.d.ts +4 -4
  50. package/client/lib/helpers.d.ts +1 -1
  51. package/client/lib/index.d.ts +5 -5
  52. package/client/lib/level.d.ts +21 -15
  53. package/client/lib/log.d.ts +25 -25
  54. package/client/lib/logger.d.ts +81 -60
  55. package/client/ng2-logger.d.ts +5 -5
  56. package/client/public-api.d.ts +1 -1
  57. package/index.d.ts +1 -1
  58. package/index.js +5 -5
  59. package/index.js.map +1 -1
  60. package/lib/backend-logging.d.ts +4 -4
  61. package/lib/backend-logging.js +115 -108
  62. package/lib/backend-logging.js.map +1 -1
  63. package/lib/display.d.ts +4 -4
  64. package/lib/display.js +104 -104
  65. package/lib/display.js.map +1 -1
  66. package/lib/helpers.d.ts +1 -1
  67. package/lib/helpers.js +6 -6
  68. package/lib/helpers.js.map +1 -1
  69. package/lib/index.d.ts +5 -5
  70. package/lib/index.js +9 -9
  71. package/lib/index.js.map +1 -1
  72. package/lib/level.d.ts +21 -15
  73. package/lib/level.js +35 -26
  74. package/lib/level.js.map +1 -1
  75. package/lib/log.d.ts +25 -25
  76. package/lib/log.js +197 -199
  77. package/lib/log.js.map +1 -1
  78. package/lib/logger.d.ts +81 -60
  79. package/lib/logger.js +340 -232
  80. package/lib/logger.js.map +1 -1
  81. package/package.json +2 -2
  82. package/package.json_devDependencies.json +184 -184
  83. package/package.json_tnp.json5 +47 -47
  84. package/tmp-environment.json +13 -13
  85. package/websql/README.md +24 -24
  86. package/websql/esm2020/lib/backend-logging.mjs +92 -88
  87. package/websql/esm2020/lib/display.mjs +97 -93
  88. package/websql/esm2020/lib/helpers.mjs +1 -1
  89. package/websql/esm2020/lib/index.mjs +5 -5
  90. package/websql/esm2020/lib/level.mjs +31 -22
  91. package/websql/esm2020/lib/log.mjs +164 -165
  92. package/websql/esm2020/lib/logger.mjs +235 -157
  93. package/websql/esm2020/ng2-logger.mjs +4 -4
  94. package/websql/esm2020/public-api.mjs +1 -1
  95. package/websql/fesm2015/ng2-logger.mjs +512 -422
  96. package/websql/fesm2015/ng2-logger.mjs.map +1 -1
  97. package/websql/fesm2020/ng2-logger.mjs +512 -422
  98. package/websql/fesm2020/ng2-logger.mjs.map +1 -1
  99. package/websql/lib/backend-logging.d.ts +4 -4
  100. package/websql/lib/display.d.ts +4 -4
  101. package/websql/lib/helpers.d.ts +1 -1
  102. package/websql/lib/index.d.ts +5 -5
  103. package/websql/lib/level.d.ts +21 -15
  104. package/websql/lib/log.d.ts +25 -25
  105. package/websql/lib/logger.d.ts +81 -60
  106. package/websql/ng2-logger.d.ts +5 -5
  107. package/websql/public-api.d.ts +1 -1
@@ -1,165 +1,164 @@
1
- import { Logger } from './logger';
2
- import { Level, LevelOrder, LevelKey } from './level';
3
- import { Helpers } from 'tnp-core/websql';
4
- /* */
5
- /* */
6
- /* */
7
- /* */
8
- /* */
9
- /* */
10
- export class Log {
11
- //#region singleton
12
- constructor() {
13
- this._logOnly = false;
14
- this._logModules = false;
15
- this.isDevelopmentMode = true;
16
- this.modeIsSet = false;
17
- this.fixedWidth = 0;
18
- this.instances = {};
19
- this.levels = [];
20
- this.modules = [];
21
- }
22
- // @ts-ignore
23
- static get instance() {
24
- // @ts-ignore
25
- if (!Log['_instance']) {
26
- // @ts-ignore
27
- Log['_instance'] = new Log();
28
- }
29
- // @ts-ignore
30
- return Log['_instance'];
31
- }
32
- static create(name, ...level) {
33
- return Log.instance.create(name, ...level);
34
- }
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
- //#region public api
68
- setProductionMode() {
69
- if (this.modeIsSet) {
70
- this.modeIsSet = false;
71
- throw '[ng2-logger] Production mode is already set';
72
- }
73
- else {
74
- this.modeIsSet = true;
75
- setTimeout(() => {
76
- if (this.modeIsSet && console !== void 0 && console.clear !== void 0) {
77
- console.clear();
78
- console.log = () => { };
79
- console.error = () => { };
80
- console.warn = () => { };
81
- console.info = () => { };
82
- }
83
- });
84
- this.isDevelopmentMode = false;
85
- }
86
- }
87
- onlyModules(...modules) {
88
- if (this._logModules) {
89
- throw '[ng2-logger] You should use funcion onlyModules only once';
90
- }
91
- if (!this._logModules) {
92
- this._logModules = true;
93
- }
94
- if (modules.length === 0)
95
- return;
96
- this.modules = modules;
97
- // console.log('only log this', Log.modules)
98
- this.muteAllOtherModules();
99
- }
100
- onlyLevel(...level) {
101
- if (this._logOnly) {
102
- throw '[ng2-logger] You should use funcion onlyLevel only once';
103
- }
104
- if (!this._logOnly) {
105
- this._logOnly = true;
106
- }
107
- this.levels = Array.isArray(level) ? level : [level];
108
- for (const logName in this.instances) {
109
- if (this.instances.hasOwnProperty(logName)) {
110
- const element = this.instances[logName];
111
- element['allowed'] = this.levels;
112
- }
113
- }
114
- }
115
- //#endregion
116
- create(name, ...level) {
117
- let i;
118
- if (Array.isArray(this.levels) && this.levels.length > 0) {
119
- level = this.levels;
120
- }
121
- if (this.instances[name] === void 0) {
122
- i = new (Log.Logger)(name, getRandomColor(), this.isDevelopmentMode, level, this.isMutedModule(name), this.levels.length > 0 ? this.fixedWidth : void 0);
123
- this.instances[name] = i;
124
- }
125
- else {
126
- i = this.instances[name];
127
- }
128
- return i;
129
- }
130
- isMutedModule(moduleName) {
131
- if (this.modules.length == 0)
132
- return false;
133
- if (!Helpers.contain(this.modules, moduleName))
134
- return true;
135
- return false;
136
- }
137
- muteAllOtherModules() {
138
- for (var moduleName in this.instances) {
139
- if (!Helpers.contain(this.modules, moduleName))
140
- this.instances[moduleName].mute();
141
- }
142
- }
143
- }
144
- //#endregion
145
- Log.Logger = Logger;
146
- Log.consolelogfn = {};
147
- function getRandomColor() {
148
- /* */
149
- /* */
150
- /* */
151
- /* */
152
- let letters = '012345'.split('');
153
- let color = '#';
154
- color += letters[Math.round(Math.random() * 5)];
155
- letters = '0123456789ABCDEF'.split('');
156
- for (let i = 0; i < 5; i++) {
157
- color += letters[Math.round(Math.random() * 15)];
158
- }
159
- if (color === void 0) {
160
- return getRandomColor();
161
- }
162
- ;
163
- return color;
164
- }
165
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vdG1wLWxpYnMtZm9yLWJ1bmRsZS13ZWJzcWwvbmcyLWxvZ2dlci9wcm9qZWN0cy9uZzItbG9nZ2VyL3NyYy9saWIvbG9nLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDbEMsT0FBTyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQ3RELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMxQyxLQUFLO0FBQ0wsS0FBSztBQUlMLEtBQUs7QUFDTCxLQUFLO0FBQ0wsS0FBSztBQUNMLEtBQUs7QUFJTCxNQUFNLE9BQU8sR0FBRztJQUNkLG1CQUFtQjtJQUNuQjtRQXVEUSxhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLGdCQUFXLEdBQUcsS0FBSyxDQUFDO1FBQ3BCLHNCQUFpQixHQUFHLElBQUksQ0FBQztRQUN6QixjQUFTLEdBQVksS0FBSyxDQUFDO1FBQzNCLGVBQVUsR0FBRyxDQUFDLENBQUM7UUFDZixjQUFTLEdBQXFDLEVBQUUsQ0FBQztRQUNqRCxXQUFNLEdBQVksRUFBRSxDQUFDO1FBQ3JCLFlBQU8sR0FBd0IsRUFBRSxDQUFDO0lBOURsQixDQUFDO0lBQ3pCLGFBQWE7SUFDTCxNQUFNLEtBQUssUUFBUTtRQUN6QixhQUFhO1FBQ2IsSUFBSSxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsRUFBRTtZQUNyQixhQUFhO1lBQ2IsR0FBRyxDQUFDLFdBQVcsQ0FBQyxHQUFHLElBQUksR0FBRyxFQUFFLENBQUM7U0FDOUI7UUFDRCxhQUFhO1FBQ2IsT0FBTyxHQUFHLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDMUIsQ0FBQztJQUlELE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBWSxFQUFFLEdBQUcsS0FBYztRQUMzQyxPQUFPLEdBQUcs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dkMsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRTtRQUMxQixLQUFLLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUM7S0FDbEQ7SUFDRCxJQUFJLEtBQUssS0FBSyxLQUFLLENBQUMsRUFBRTtRQUNwQixPQUFPLGNBQWMsRUFBRSxDQUFBO0tBQ3hCO0lBQUEsQ0FBQztJQUNGLE9BQU8sS0FBSyxDQUFDO0FBQ2YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IExvZ2dlciB9IGZyb20gJy4vbG9nZ2VyJztcbmltcG9ydCB7IExldmVsLCBMZXZlbE9yZGVyLCBMZXZlbEtleSB9IGZyb20gJy4vbGV2ZWwnO1xuaW1wb3J0IHsgSGVscGVycyB9IGZyb20gJ3RucC1jb3JlL3dlYnNxbCc7XG4vKiAqL1xuLyogKi9cbiAgXG5cblxuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbiAgXG5cblxuZXhwb3J0IGNsYXNzIExvZyB7XG4gIC8vI3JlZ2lvbiBzaW5nbGV0b25cbiAgcHJpdmF0ZSBjb25zdHJ1Y3RvcigpIHsgfVxuICAvLyBAdHMtaWdub3JlXG4gIHByaXZhdGUgc3RhdGljIGdldCBpbnN0YW5jZSgpOiBhbnkge1xuICAgIC8vIEB0cy1pZ25vcmVcbiAgICBpZiAoIUxvZ1snX2luc3RhbmNlJ10pIHtcbiAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgIExvZ1snX2luc3RhbmNlJ10gPSBuZXcgTG9nKCk7XG4gICAgfVxuICAgIC8vIEB0cy1pZ25vcmVcbiAgICByZXR1cm4gTG9nWydfaW5zdGFuY2UnXTtcbiAgfVxuICAvLyNlbmRyZWdpb25cblxuICBzdGF0aWMgTG9nZ2VyOiAodHlwZW9mIExvZ2dlcikgPSBMb2dnZXI7XG4gIHN0YXRpYyBjcmVhdGUobmFtZTogc3RyaW5nLCAuLi5sZXZlbDogTGV2ZWxbXSk6IExvZ2dlciB7XG4gICAgcmV0dXJuIExvZy5pbnN0YW5jZS5jcmVhdGUobmFtZSwgLi4ubGV2ZWwpO1xuICB9XG5cbiAgcHJpdmF0ZSBzdGF0aWMgcmVhZG9ubHkgY29uc29sZWxvZ2ZuID0ge307XG4gIHN0YXRpYyBkaXNhYmxlTG9ncyhsZXZlbCA9IExldmVsLl9fTk9USElORykge1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbiAgXG4gICAgTGV2ZWxPcmRlci5yZXZlcnNlKCkuZmluZChhID0+IHtcbiAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgIGlmICghdGhpcy5jb25zb2xlbG9nZm5bYV0pIHtcbiAgICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgICB0aGlzLmNvbnNvbGVsb2dmblthXSA9IGNvbnNvbGVbYV07XG4gICAgICB9XG4gICAgICAvLyBAdHMtaWdub3JlXG4gICAgICBjb25zb2xlW2FdID0gKCkgPT4geyB9O1xuICAgICAgaWYgKGEgPT09IExldmVsS2V5W2xldmVsXSkge1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgIH1cbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9KTtcbiAgfVxuXG4gIHN0YXRpYyBlbmFibGVMb2dzKCkge1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbiAgXG4gICAgTGV2ZWxPcmRlci5mb3JFYWNoKGEgPT4ge1xuICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgY29uc29sZVthXSA9IHRoaXMuY29uc29sZWxvZ2ZuW2FdXG4gICAgfSk7XG4gIH1cblxuICBwcml2YXRlIF9sb2dPbmx5ID0gZmFsc2U7XG4gIHByaXZhdGUgX2xvZ01vZHVsZXMgPSBmYWxzZTtcbiAgcHJpdmF0ZSBpc0RldmVsb3BtZW50TW9kZSA9IHRydWU7XG4gIHByaXZhdGUgbW9kZUlzU2V0OiBib29sZWFuID0gZmFsc2U7XG4gIHByaXZhdGUgZml4ZWRXaWR0aCA9IDA7XG4gIHByaXZhdGUgaW5zdGFuY2VzOiB7IFttb2R1bGVOYW1lOiBzdHJpbmddOiBMb2dnZXIgfSA9IHt9O1xuICBwcml2YXRlIGxldmVsczogTGV2ZWxbXSA9IFtdO1xuICBwcml2YXRlIG1vZHVsZXM6IChzdHJpbmcgfCBSZWdFeHApW10gPSBbXTtcblxuICAvLyNyZWdpb24gcHVibGljIGFwaVxuICBwdWJsaWMgc2V0UHJvZHVjdGlvbk1vZGUoKSB7XG4gICAgaWYgKHRoaXMubW9kZUlzU2V0KSB7XG4gICAgICB0aGlzLm1vZGVJc1NldCA9IGZhbHNlXG4gICAgICB0aHJvdyAnW25nMi1sb2dnZXJdIFByb2R1Y3Rpb24gbW9kZSBpcyBhbHJlYWR5IHNldCc7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMubW9kZUlzU2V0ID0gdHJ1ZTtcbiAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuXG4gICAgICAgIGlmICh0aGlzLm1vZGVJc1NldCAmJiBjb25zb2xlICE9PSB2b2lkIDAgJiYgY29uc29sZS5jbGVhciAhPT0gdm9pZCAwKSB7XG5cbiAgICAgICAgICBjb25zb2xlLmNsZWFyKCk7XG4gICAgICAgICAgY29uc29sZS5sb2cgPSAoKSA9PiB7IH07XG4gICAgICAgICAgY29uc29sZS5lcnJvciA9ICgpID0+IHsgfTtcbiAgICAgICAgICBjb25zb2xlLndhcm4gPSAoKSA9PiB7IH07XG4gICAgICAgICAgY29uc29sZS5pbmZvID0gKCkgPT4geyB9O1xuICAgICAgICB9XG4gICAgICB9KTtcblxuICAgICAgdGhpcy5pc0RldmVsb3BtZW50TW9kZSA9IGZhbHNlO1xuICAgIH1cbiAgfVxuXG4gIHB1YmxpYyBvbmx5TW9kdWxlcyguLi5tb2R1bGVzOiAoc3RyaW5nIHwgUmVnRXhwKVtdKSB7XG4gICAgaWYgKHRoaXMuX2xvZ01vZHVsZXMpIHtcbiAgICAgIHRocm93ICdbbmcyLWxvZ2dlcl0gWW91IHNob3VsZCB1c2UgZnVuY2lvbiBvbmx5TW9kdWxlcyBvbmx5IG9uY2UnO1xuICAgIH1cbiAgICBpZiAoIXRoaXMuX2xvZ01vZHVsZXMpIHtcbiAgICAgIHRoaXMuX2xvZ01vZHVsZXMgPSB0cnVlO1xuICAgIH1cbiAgICBpZiAobW9kdWxlcy5sZW5ndGggPT09IDApIHJldHVybjtcbiAgICB0aGlzLm1vZHVsZXMgPSBtb2R1bGVzO1xuICAgIC8vIGNvbnNvbGUubG9nKCdvbmx5IGxvZyB0aGlzJywgTG9nLm1vZHVsZXMpXG4gICAgdGhpcy5tdXRlQWxsT3RoZXJNb2R1bGVzKCk7XG4gIH1cblxuXG4gIHB1YmxpYyBvbmx5TGV2ZWwoLi4ubGV2ZWw6IExldmVsW10pIHtcbiAgICBpZiAodGhpcy5fbG9nT25seSkge1xuICAgICAgdGhyb3cgJ1tuZzItbG9nZ2VyXSBZb3Ugc2hvdWxkIHVzZSBmdW5jaW9uIG9ubHlMZXZlbCBvbmx5IG9uY2UnO1xuICAgIH1cbiAgICBpZiAoIXRoaXMuX2xvZ09ubHkpIHtcbiAgICAgIHRoaXMuX2xvZ09ubHkgPSB0cnVlO1xuICAgIH1cblxuICAgIHRoaXMubGV2ZWxzID0gQXJyYXkuaXNBcnJheShsZXZlbCkgPyBsZXZlbCA6IFtsZXZlbF07XG5cblxuICAgIGZvciAoY29uc3QgbG9nTmFtZSBpbiB0aGlzLmluc3RhbmNlcykge1xuICAgICAgaWYgKHRoaXMuaW5zdGFuY2VzLmhhc093blByb3BlcnR5KGxvZ05hbWUpKSB7XG4gICAgICAgIGNvbnN0IGVsZW1lbnQgPSB0aGlzLmluc3RhbmNlc1tsb2dOYW1lXTtcbiAgICAgICAgZWxlbWVudFsnYWxsb3dlZCddID0gdGhpcy5sZXZlbHM7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgLy8jZW5kcmVnaW9uXG5cbiAgcHJpdmF0ZSBjcmVhdGUobmFtZTogc3RyaW5nLCAuLi5sZXZlbDogTGV2ZWxbXSk6IExvZ2dlciB7XG4gICAgbGV0IGk6IExvZ2dlcjtcbiAgICBpZiAoQXJyYXkuaXNBcnJheSh0aGlzLmxldmVscykgJiYgdGhpcy5sZXZlbHMubGVuZ3RoID4gMCkge1xuICAgICAgbGV2ZWwgPSB0aGlzLmxldmVscztcbiAgICB9XG4gICAgaWYgKHRoaXMuaW5zdGFuY2VzW25hbWVdID09PSB2b2lkIDApIHtcbiAgICAgIGkgPSBuZXcgKExvZy5Mb2dnZXIpKFxuICAgICAgICBuYW1lLFxuICAgICAgICBnZXRSYW5kb21Db2xvcigpLFxuICAgICAgICB0aGlzLmlzRGV2ZWxvcG1lbnRNb2RlLFxuICAgICAgICBsZXZlbCxcbiAgICAgICAgdGhpcy5pc011dGVkTW9kdWxlKG5hbWUpLFxuICAgICAgICB0aGlzLmxldmVscy5sZW5ndGggPiAwID8gdGhpcy5maXhlZFdpZHRoIDogdm9pZCAwLFxuICAgICAgICAvLyBMb2cubGV2ZWxzLmxlbmd0aCA+IDAgPyBMb2cuZGlzcGxheSA6IHVuZGVmaW5lZCxcbiAgICAgICk7XG4gICAgICB0aGlzLmluc3RhbmNlc1tuYW1lXSA9IGk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGkgPSB0aGlzLmluc3RhbmNlc1tuYW1lXTtcbiAgICB9XG4gICAgcmV0dXJuIGk7XG4gIH1cblxuICBwcml2YXRlIGlzTXV0ZWRNb2R1bGUobW9kdWxlTmFtZTogc3RyaW5nKTogYm9vbGVhbiB7XG4gICAgaWYgKHRoaXMubW9kdWxlcy5sZW5ndGggPT0gMCkgcmV0dXJuIGZhbHNlO1xuICAgIGlmICghSGVscGVycy5jb250YWluKHRoaXMubW9kdWxlcywgbW9kdWxlTmFtZSkpIHJldHVybiB0cnVlO1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuICBwcml2YXRlIG11dGVBbGxPdGhlck1vZHVsZXMoKSB7XG4gICAgZm9yICh2YXIgbW9kdWxlTmFtZSBpbiB0aGlzLmluc3RhbmNlcykge1xuICAgICAgaWYgKCFIZWxwZXJzLmNvbnRhaW4odGhpcy5tb2R1bGVzLCBtb2R1bGVOYW1lKSlcbiAgICAgICAgdGhpcy5pbnN0YW5jZXNbbW9kdWxlTmFtZV0ubXV0ZSgpXG4gICAgfVxuICB9XG5cbn1cblxuXG5mdW5jdGlvbiBnZXRSYW5kb21Db2xvcigpOiBzdHJpbmcge1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbiAgXG5cbiAgbGV0IGxldHRlcnMgPSAnMDEyMzQ1Jy5zcGxpdCgnJyk7XG4gIGxldCBjb2xvciA9ICcjJztcbiAgY29sb3IgKz0gbGV0dGVyc1tNYXRoLnJvdW5kKE1hdGgucmFuZG9tKCkgKiA1KV07XG4gIGxldHRlcnMgPSAnMDEyMzQ1Njc4OUFCQ0RFRicuc3BsaXQoJycpO1xuICBmb3IgKGxldCBpID0gMDsgaSA8IDU7IGkrKykge1xuICAgIGNvbG9yICs9IGxldHRlcnNbTWF0aC5yb3VuZChNYXRoLnJhbmRvbSgpICogMTUpXTtcbiAgfVxuICBpZiAoY29sb3IgPT09IHZvaWQgMCkge1xuICAgIHJldHVybiBnZXRSYW5kb21Db2xvcigpXG4gIH07XG4gIHJldHVybiBjb2xvcjtcbn1cbiJdfQ==
1
+ import { Logger } from './logger';
2
+ import { Level, LevelOrder, LevelKey } from './level';
3
+ import { Helpers } from 'tnp-core/websql';
4
+ /* */
5
+ /* */
6
+ /* */
7
+ /* */
8
+ /* */
9
+ export class Log {
10
+ //#region singleton
11
+ constructor() {
12
+ this._logOnly = false;
13
+ this._logModules = false;
14
+ this.isDevelopmentMode = true;
15
+ this.modeIsSet = false;
16
+ this.fixedWidth = 0;
17
+ this.instances = {};
18
+ this.levels = [];
19
+ this.modules = [];
20
+ }
21
+ // @ts-ignore
22
+ static get instance() {
23
+ // @ts-ignore
24
+ if (!Log['_instance']) {
25
+ // @ts-ignore
26
+ Log['_instance'] = new Log();
27
+ }
28
+ // @ts-ignore
29
+ return Log['_instance'];
30
+ }
31
+ static create(name, ...level) {
32
+ return Log.instance.create(name, ...level);
33
+ }
34
+ static disableLogs(level = Level.__NOTHING) {
35
+ /* */
36
+ /* */
37
+ /* */
38
+ /* */
39
+ /* */
40
+ /* */
41
+ /* */
42
+ LevelOrder.reverse().find(a => {
43
+ // @ts-ignore
44
+ if (!this.consolelogfn[a]) {
45
+ // @ts-ignore
46
+ this.consolelogfn[a] = console[a];
47
+ }
48
+ // @ts-ignore
49
+ console[a] = () => { };
50
+ if (a === LevelKey[level]) {
51
+ return true;
52
+ }
53
+ return false;
54
+ });
55
+ }
56
+ static enableLogs() {
57
+ /* */
58
+ /* */
59
+ /* */
60
+ /* */
61
+ LevelOrder.forEach(a => {
62
+ // @ts-ignore
63
+ console[a] = this.consolelogfn[a];
64
+ });
65
+ }
66
+ //#region public api
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
+ // console.log('only log this', Log.modules)
97
+ this.muteAllOtherModules();
98
+ }
99
+ onlyLevel(...level) {
100
+ if (this._logOnly) {
101
+ throw '[ng2-logger] You should use funcion onlyLevel only once';
102
+ }
103
+ if (!this._logOnly) {
104
+ this._logOnly = true;
105
+ }
106
+ this.levels = Array.isArray(level) ? level : [level];
107
+ for (const logName in this.instances) {
108
+ if (this.instances.hasOwnProperty(logName)) {
109
+ const element = this.instances[logName];
110
+ element['allowed'] = this.levels;
111
+ }
112
+ }
113
+ }
114
+ //#endregion
115
+ create(name, ...level) {
116
+ let i;
117
+ if (Array.isArray(this.levels) && this.levels.length > 0) {
118
+ level = this.levels;
119
+ }
120
+ if (this.instances[name] === void 0) {
121
+ i = new (Log.Logger)(name, getRandomColor(), this.isDevelopmentMode, level, this.isMutedModule(name), this.levels.length > 0 ? this.fixedWidth : void 0);
122
+ this.instances[name] = i;
123
+ }
124
+ else {
125
+ i = this.instances[name];
126
+ }
127
+ return i;
128
+ }
129
+ isMutedModule(moduleName) {
130
+ if (this.modules.length == 0)
131
+ return false;
132
+ if (!Helpers.contain(this.modules, moduleName))
133
+ return true;
134
+ return false;
135
+ }
136
+ muteAllOtherModules() {
137
+ for (var moduleName in this.instances) {
138
+ if (!Helpers.contain(this.modules, moduleName))
139
+ this.instances[moduleName].mute();
140
+ }
141
+ }
142
+ }
143
+ //#endregion
144
+ Log.Logger = Logger;
145
+ Log.consolelogfn = {};
146
+ function getRandomColor() {
147
+ /* */
148
+ /* */
149
+ /* */
150
+ /* */
151
+ let letters = '012345'.split('');
152
+ let color = '#';
153
+ color += letters[Math.round(Math.random() * 5)];
154
+ letters = '0123456789ABCDEF'.split('');
155
+ for (let i = 0; i < 5; i++) {
156
+ color += letters[Math.round(Math.random() * 15)];
157
+ }
158
+ if (color === void 0) {
159
+ return getRandomColor();
160
+ }
161
+ ;
162
+ return color;
163
+ }
164
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vdG1wLWxpYnMtZm9yLWJ1bmRsZS13ZWJzcWwvbmcyLWxvZ2dlci9wcm9qZWN0cy9uZzItbG9nZ2VyL3NyYy9saWIvbG9nLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDbEMsT0FBTyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQ3RELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMxQyxLQUFLO0FBQ0wsS0FBSztBQUNMLEtBQUs7QUFJTCxLQUFLO0FBQ0wsS0FBSztBQUlMLE1BQU0sT0FBTyxHQUFHO0lBQ2QsbUJBQW1CO0lBQ25CO1FBdURRLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFDakIsZ0JBQVcsR0FBRyxLQUFLLENBQUM7UUFDcEIsc0JBQWlCLEdBQUcsSUFBSSxDQUFDO1FBQ3pCLGNBQVMsR0FBWSxLQUFLLENBQUM7UUFDM0IsZUFBVSxHQUFHLENBQUMsQ0FBQztRQUNmLGNBQVMsR0FBcUMsRUFBRSxDQUFDO1FBQ2pELFdBQU0sR0FBWSxFQUFFLENBQUM7UUFDckIsWUFBTyxHQUF3QixFQUFFLENBQUM7SUE5RGxCLENBQUM7SUFDekIsYUFBYTtJQUNMLE1BQU0sS0FBSyxRQUFRO1FBQ3pCLGFBQWE7UUFDYixJQUFJLENBQUMsR0FBRyxDQUFDLFdBQVcsQ0FBQyxFQUFFO1lBQ3JCLGFBQWE7WUFDYixHQUFHLENBQUMsV0FBVyxDQUFDLEdBQUcsSUFBSSxHQUFHLEVBQUUsQ0FBQztTQUM5QjtRQUNELGFBQWE7UUFDYixPQUFPLEdBQUcsQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUMxQixDQUFDO0lBSUQsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFZLEVBQUUsR0FBRyxLQUFjO1FBQzNDLE9BQU8sR0FBRyxDQUFDLFFBQVEs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QUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFO1FBQzFCLEtBQUssSUFBSSxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQztLQUNsRDtJQUNELElBQUksS0FBSyxLQUFLLEtBQUssQ0FBQyxFQUFFO1FBQ3BCLE9BQU8sY0FBYyxFQUFFLENBQUE7S0FDeEI7SUFBQSxDQUFDO0lBQ0YsT0FBTyxLQUFLLENBQUM7QUFDZixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTG9nZ2VyIH0gZnJvbSAnLi9sb2dnZXInO1xuaW1wb3J0IHsgTGV2ZWwsIExldmVsT3JkZXIsIExldmVsS2V5IH0gZnJvbSAnLi9sZXZlbCc7XG5pbXBvcnQgeyBIZWxwZXJzIH0gZnJvbSAndG5wLWNvcmUvd2Vic3FsJztcbi8qICovXG4vKiAqL1xuLyogKi9cbiAgXG5cblxuLyogKi9cbi8qICovXG4gIFxuXG5cbmV4cG9ydCBjbGFzcyBMb2cge1xuICAvLyNyZWdpb24gc2luZ2xldG9uXG4gIHByaXZhdGUgY29uc3RydWN0b3IoKSB7IH1cbiAgLy8gQHRzLWlnbm9yZVxuICBwcml2YXRlIHN0YXRpYyBnZXQgaW5zdGFuY2UoKTogYW55IHtcbiAgICAvLyBAdHMtaWdub3JlXG4gICAgaWYgKCFMb2dbJ19pbnN0YW5jZSddKSB7XG4gICAgICAvLyBAdHMtaWdub3JlXG4gICAgICBMb2dbJ19pbnN0YW5jZSddID0gbmV3IExvZygpO1xuICAgIH1cbiAgICAvLyBAdHMtaWdub3JlXG4gICAgcmV0dXJuIExvZ1snX2luc3RhbmNlJ107XG4gIH1cbiAgLy8jZW5kcmVnaW9uXG5cbiAgc3RhdGljIExvZ2dlcjogKHR5cGVvZiBMb2dnZXIpID0gTG9nZ2VyO1xuICBzdGF0aWMgY3JlYXRlKG5hbWU6IHN0cmluZywgLi4ubGV2ZWw6IExldmVsW10pOiBMb2dnZXIge1xuICAgIHJldHVybiBMb2cuaW5zdGFuY2UuY3JlYXRlKG5hbWUsIC4uLmxldmVsKTtcbiAgfVxuXG4gIHByaXZhdGUgc3RhdGljIHJlYWRvbmx5IGNvbnNvbGVsb2dmbiA9IHt9O1xuICBzdGF0aWMgZGlzYWJsZUxvZ3MobGV2ZWwgPSBMZXZlbC5fX05PVEhJTkcpIHtcbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4gIFxuICAgIExldmVsT3JkZXIucmV2ZXJzZSgpLmZpbmQoYSA9PiB7XG4gICAgICAvLyBAdHMtaWdub3JlXG4gICAgICBpZiAoIXRoaXMuY29uc29sZWxvZ2ZuW2FdKSB7XG4gICAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgICAgdGhpcy5jb25zb2xlbG9nZm5bYV0gPSBjb25zb2xlW2FdO1xuICAgICAgfVxuICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgY29uc29sZVthXSA9ICgpID0+IHsgfTtcbiAgICAgIGlmIChhID09PSBMZXZlbEtleVtsZXZlbF0pIHtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICB9XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfSk7XG4gIH1cblxuICBzdGF0aWMgZW5hYmxlTG9ncygpIHtcbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4gIFxuICAgIExldmVsT3JkZXIuZm9yRWFjaChhID0+IHtcbiAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgIGNvbnNvbGVbYV0gPSB0aGlzLmNvbnNvbGVsb2dmblthXVxuICAgIH0pO1xuICB9XG5cbiAgcHJpdmF0ZSBfbG9nT25seSA9IGZhbHNlO1xuICBwcml2YXRlIF9sb2dNb2R1bGVzID0gZmFsc2U7XG4gIHByaXZhdGUgaXNEZXZlbG9wbWVudE1vZGUgPSB0cnVlO1xuICBwcml2YXRlIG1vZGVJc1NldDogYm9vbGVhbiA9IGZhbHNlO1xuICBwcml2YXRlIGZpeGVkV2lkdGggPSAwO1xuICBwcml2YXRlIGluc3RhbmNlczogeyBbbW9kdWxlTmFtZTogc3RyaW5nXTogTG9nZ2VyIH0gPSB7fTtcbiAgcHJpdmF0ZSBsZXZlbHM6IExldmVsW10gPSBbXTtcbiAgcHJpdmF0ZSBtb2R1bGVzOiAoc3RyaW5nIHwgUmVnRXhwKVtdID0gW107XG5cbiAgLy8jcmVnaW9uIHB1YmxpYyBhcGlcbiAgcHVibGljIHNldFByb2R1Y3Rpb25Nb2RlKCkge1xuICAgIGlmICh0aGlzLm1vZGVJc1NldCkge1xuICAgICAgdGhpcy5tb2RlSXNTZXQgPSBmYWxzZVxuICAgICAgdGhyb3cgJ1tuZzItbG9nZ2VyXSBQcm9kdWN0aW9uIG1vZGUgaXMgYWxyZWFkeSBzZXQnO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLm1vZGVJc1NldCA9IHRydWU7XG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHtcblxuICAgICAgICBpZiAodGhpcy5tb2RlSXNTZXQgJiYgY29uc29sZSAhPT0gdm9pZCAwICYmIGNvbnNvbGUuY2xlYXIgIT09IHZvaWQgMCkge1xuXG4gICAgICAgICAgY29uc29sZS5jbGVhcigpO1xuICAgICAgICAgIGNvbnNvbGUubG9nID0gKCkgPT4geyB9O1xuICAgICAgICAgIGNvbnNvbGUuZXJyb3IgPSAoKSA9PiB7IH07XG4gICAgICAgICAgY29uc29sZS53YXJuID0gKCkgPT4geyB9O1xuICAgICAgICAgIGNvbnNvbGUuaW5mbyA9ICgpID0+IHsgfTtcbiAgICAgICAgfVxuICAgICAgfSk7XG5cbiAgICAgIHRoaXMuaXNEZXZlbG9wbWVudE1vZGUgPSBmYWxzZTtcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgb25seU1vZHVsZXMoLi4ubW9kdWxlczogKHN0cmluZyB8IFJlZ0V4cClbXSkge1xuICAgIGlmICh0aGlzLl9sb2dNb2R1bGVzKSB7XG4gICAgICB0aHJvdyAnW25nMi1sb2dnZXJdIFlvdSBzaG91bGQgdXNlIGZ1bmNpb24gb25seU1vZHVsZXMgb25seSBvbmNlJztcbiAgICB9XG4gICAgaWYgKCF0aGlzLl9sb2dNb2R1bGVzKSB7XG4gICAgICB0aGlzLl9sb2dNb2R1bGVzID0gdHJ1ZTtcbiAgICB9XG4gICAgaWYgKG1vZHVsZXMubGVuZ3RoID09PSAwKSByZXR1cm47XG4gICAgdGhpcy5tb2R1bGVzID0gbW9kdWxlcztcbiAgICAvLyBjb25zb2xlLmxvZygnb25seSBsb2cgdGhpcycsIExvZy5tb2R1bGVzKVxuICAgIHRoaXMubXV0ZUFsbE90aGVyTW9kdWxlcygpO1xuICB9XG5cblxuICBwdWJsaWMgb25seUxldmVsKC4uLmxldmVsOiBMZXZlbFtdKSB7XG4gICAgaWYgKHRoaXMuX2xvZ09ubHkpIHtcbiAgICAgIHRocm93ICdbbmcyLWxvZ2dlcl0gWW91IHNob3VsZCB1c2UgZnVuY2lvbiBvbmx5TGV2ZWwgb25seSBvbmNlJztcbiAgICB9XG4gICAgaWYgKCF0aGlzLl9sb2dPbmx5KSB7XG4gICAgICB0aGlzLl9sb2dPbmx5ID0gdHJ1ZTtcbiAgICB9XG5cbiAgICB0aGlzLmxldmVscyA9IEFycmF5LmlzQXJyYXkobGV2ZWwpID8gbGV2ZWwgOiBbbGV2ZWxdO1xuXG5cbiAgICBmb3IgKGNvbnN0IGxvZ05hbWUgaW4gdGhpcy5pbnN0YW5jZXMpIHtcbiAgICAgIGlmICh0aGlzLmluc3RhbmNlcy5oYXNPd25Qcm9wZXJ0eShsb2dOYW1lKSkge1xuICAgICAgICBjb25zdCBlbGVtZW50ID0gdGhpcy5pbnN0YW5jZXNbbG9nTmFtZV07XG4gICAgICAgIGVsZW1lbnRbJ2FsbG93ZWQnXSA9IHRoaXMubGV2ZWxzO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIC8vI2VuZHJlZ2lvblxuXG4gIHByaXZhdGUgY3JlYXRlKG5hbWU6IHN0cmluZywgLi4ubGV2ZWw6IExldmVsW10pOiBMb2dnZXIge1xuICAgIGxldCBpOiBMb2dnZXI7XG4gICAgaWYgKEFycmF5LmlzQXJyYXkodGhpcy5sZXZlbHMpICYmIHRoaXMubGV2ZWxzLmxlbmd0aCA+IDApIHtcbiAgICAgIGxldmVsID0gdGhpcy5sZXZlbHM7XG4gICAgfVxuICAgIGlmICh0aGlzLmluc3RhbmNlc1tuYW1lXSA9PT0gdm9pZCAwKSB7XG4gICAgICBpID0gbmV3IChMb2cuTG9nZ2VyKShcbiAgICAgICAgbmFtZSxcbiAgICAgICAgZ2V0UmFuZG9tQ29sb3IoKSxcbiAgICAgICAgdGhpcy5pc0RldmVsb3BtZW50TW9kZSxcbiAgICAgICAgbGV2ZWwsXG4gICAgICAgIHRoaXMuaXNNdXRlZE1vZHVsZShuYW1lKSxcbiAgICAgICAgdGhpcy5sZXZlbHMubGVuZ3RoID4gMCA/IHRoaXMuZml4ZWRXaWR0aCA6IHZvaWQgMCxcbiAgICAgICAgLy8gTG9nLmxldmVscy5sZW5ndGggPiAwID8gTG9nLmRpc3BsYXkgOiB1bmRlZmluZWQsXG4gICAgICApO1xuICAgICAgdGhpcy5pbnN0YW5jZXNbbmFtZV0gPSBpO1xuICAgIH0gZWxzZSB7XG4gICAgICBpID0gdGhpcy5pbnN0YW5jZXNbbmFtZV07XG4gICAgfVxuICAgIHJldHVybiBpO1xuICB9XG5cbiAgcHJpdmF0ZSBpc011dGVkTW9kdWxlKG1vZHVsZU5hbWU6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIGlmICh0aGlzLm1vZHVsZXMubGVuZ3RoID09IDApIHJldHVybiBmYWxzZTtcbiAgICBpZiAoIUhlbHBlcnMuY29udGFpbih0aGlzLm1vZHVsZXMsIG1vZHVsZU5hbWUpKSByZXR1cm4gdHJ1ZTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbiAgcHJpdmF0ZSBtdXRlQWxsT3RoZXJNb2R1bGVzKCkge1xuICAgIGZvciAodmFyIG1vZHVsZU5hbWUgaW4gdGhpcy5pbnN0YW5jZXMpIHtcbiAgICAgIGlmICghSGVscGVycy5jb250YWluKHRoaXMubW9kdWxlcywgbW9kdWxlTmFtZSkpXG4gICAgICAgIHRoaXMuaW5zdGFuY2VzW21vZHVsZU5hbWVdLm11dGUoKVxuICAgIH1cbiAgfVxuXG59XG5cblxuZnVuY3Rpb24gZ2V0UmFuZG9tQ29sb3IoKTogc3RyaW5nIHtcbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4gIFxuXG4gIGxldCBsZXR0ZXJzID0gJzAxMjM0NScuc3BsaXQoJycpO1xuICBsZXQgY29sb3IgPSAnIyc7XG4gIGNvbG9yICs9IGxldHRlcnNbTWF0aC5yb3VuZChNYXRoLnJhbmRvbSgpICogNSldO1xuICBsZXR0ZXJzID0gJzAxMjM0NTY3ODlBQkNERUYnLnNwbGl0KCcnKTtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCA1OyBpKyspIHtcbiAgICBjb2xvciArPSBsZXR0ZXJzW01hdGgucm91bmQoTWF0aC5yYW5kb20oKSAqIDE1KV07XG4gIH1cbiAgaWYgKGNvbG9yID09PSB2b2lkIDApIHtcbiAgICByZXR1cm4gZ2V0UmFuZG9tQ29sb3IoKVxuICB9O1xuICByZXR1cm4gY29sb3I7XG59XG4iXX0=