@foxford/logger 1.0.2 → 1.1.0

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 (6) hide show
  1. package/browser.js +292 -400
  2. package/browser.mjs +295 -399
  3. package/index.d.ts +170 -11
  4. package/node.js +257 -373
  5. package/node.mjs +260 -372
  6. package/package.json +5 -4
package/node.js CHANGED
@@ -1,426 +1,310 @@
1
- 'use strict';
2
-
3
- var log = require('loglevel');
4
- var chalk = require('chalk');
5
-
6
- /**
7
- * Генерирует hex-код цвета на основе строки, избегая оттенков красного
8
- * @param {string} str - Строка, для которой нужно сгенерировать цвет
9
- * @returns {string} - Hex-код цвета
10
- */
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const log = require("loglevel");
4
+ const chalk = require("chalk");
11
5
  function generateHexByString(str) {
12
- // Генерируем новый цвет
13
- let hash = 0;
14
- for (let i = 0; i < str.length; i++) {
15
- hash = str.charCodeAt(i) + ((hash << 5) - hash);
16
- }
17
- // Используем HSL для контроля оттенка
18
- const hue = Math.abs(hash) % 300; // Расширяем диапазон, исключая только часть красного (300-360)
19
- const saturation = 60 + (Math.abs(hash) % 40); // От 60% до 100%
20
- const lightness = 30 + (Math.abs(hash) % 40); // От 30% до 70%
21
- // Конвертируем HSL в RGB
22
- const chroma = ((1 - Math.abs((2 * lightness) / 100 - 1)) * saturation) / 100;
23
- const huePrime = hue / 60;
24
- const x = chroma * (1 - Math.abs((huePrime % 2) - 1));
25
- let r1 = 0, g1 = 0, b1 = 0;
26
- if (huePrime >= 0 && huePrime < 1) {
27
- [r1, g1, b1] = [chroma, x, 0];
28
- }
29
- else if (huePrime >= 1 && huePrime < 2) {
30
- [r1, g1, b1] = [x, chroma, 0];
31
- }
32
- else if (huePrime >= 2 && huePrime < 3) {
33
- [r1, g1, b1] = [0, chroma, x];
34
- }
35
- else if (huePrime >= 3 && huePrime < 4) {
36
- [r1, g1, b1] = [0, x, chroma];
37
- }
38
- else if (huePrime >= 4 && huePrime < 5) {
39
- [r1, g1, b1] = [x, 0, chroma];
40
- }
41
- else {
42
- [r1, g1, b1] = [chroma, 0, x];
43
- }
44
- const m = lightness / 100 - chroma / 2;
45
- const [r, g, b] = [r1, g1, b1].map((v) => Math.round((v + m) * 255));
46
- // Добавляем проверку и значения по умолчанию
47
- const rValue = r !== null && r !== void 0 ? r : 0;
48
- const gValue = g !== null && g !== void 0 ? g : 0;
49
- const bValue = b !== null && b !== void 0 ? b : 0;
50
- const color = `#${((rValue << 16) | (gValue << 8) | bValue).toString(16).padStart(6, '0')}`;
51
- return color;
6
+ let hash = 0;
7
+ for (let i = 0; i < str.length; i++) {
8
+ hash = str.charCodeAt(i) + ((hash << 5) - hash);
9
+ }
10
+ const hue = Math.abs(hash) % 300;
11
+ const saturation = 60 + Math.abs(hash) % 40;
12
+ const lightness = 30 + Math.abs(hash) % 40;
13
+ const chroma = (1 - Math.abs(2 * lightness / 100 - 1)) * saturation / 100;
14
+ const huePrime = hue / 60;
15
+ const x = chroma * (1 - Math.abs(huePrime % 2 - 1));
16
+ let r1 = 0, g1 = 0, b1 = 0;
17
+ if (huePrime >= 0 && huePrime < 1) {
18
+ [r1, g1, b1] = [chroma, x, 0];
19
+ } else if (huePrime >= 1 && huePrime < 2) {
20
+ [r1, g1, b1] = [x, chroma, 0];
21
+ } else if (huePrime >= 2 && huePrime < 3) {
22
+ [r1, g1, b1] = [0, chroma, x];
23
+ } else if (huePrime >= 3 && huePrime < 4) {
24
+ [r1, g1, b1] = [0, x, chroma];
25
+ } else if (huePrime >= 4 && huePrime < 5) {
26
+ [r1, g1, b1] = [x, 0, chroma];
27
+ } else {
28
+ [r1, g1, b1] = [chroma, 0, x];
29
+ }
30
+ const m = lightness / 100 - chroma / 2;
31
+ const [r, g, b] = [r1, g1, b1].map((v) => Math.round((v + m) * 255));
32
+ const rValue = r ?? 0;
33
+ const gValue = g ?? 0;
34
+ const bValue = b ?? 0;
35
+ const color = `#${(rValue << 16 | gValue << 8 | bValue).toString(16).padStart(6, "0")}`;
36
+ return color;
52
37
  }
53
-
54
- /**
55
- * Кеш для хранения сгенерированных цветов
56
- * могут быть заранее предустановлены по имени логгера
57
- **/
58
38
  const colorCache = {};
59
- /** Цвета для различных уровней логирования */
60
39
  const levelColors = {
61
- TRACE: chalk.gray,
62
- LOG: chalk.cyan,
63
- DEBUG: chalk.cyan,
64
- INFO: chalk.green,
65
- WARN: chalk.yellow,
66
- ERROR: chalk.red,
40
+ TRACE: chalk.gray,
41
+ LOG: chalk.cyan,
42
+ DEBUG: chalk.cyan,
43
+ INFO: chalk.green,
44
+ WARN: chalk.yellow,
45
+ ERROR: chalk.red
67
46
  };
68
- // Хранилище для значений debug в памяти
69
- const debugStorage = new Set();
70
- /**
71
- * Генерирует hex-код цвета на основе строки, избегая оттенков красного
72
- * @param {string} str - Строка, для которой нужно сгенерировать цвет
73
- * @returns {string} - Hex-код цвета
74
- */
47
+ const debugStorage = /* @__PURE__ */ new Set();
75
48
  function stringToColorCode(str) {
76
- var _a;
77
- // Если цвет уже есть в кеше, возвращаем его
78
- if (str in colorCache) {
79
- return (_a = colorCache[str]) !== null && _a !== void 0 ? _a : 'inherit';
80
- }
81
- const color = generateHexByString(str);
82
- // Сохраняем цвет в кеш
83
- colorCache[str] = color;
84
- return color;
49
+ if (str in colorCache) {
50
+ return colorCache[str] ?? "inherit";
51
+ }
52
+ const color = generateHexByString(str);
53
+ colorCache[str] = color;
54
+ return color;
85
55
  }
86
- /**
87
- * Форматирует сообщение лога
88
- * @param {string} level - Уровень лога
89
- * @param {string} name - Имя логгера
90
- * @param {Date} timestamp - Временная метка
91
- * @returns {string} Отформатированное сообщение
92
- */
93
56
  function formatter(level, name, timestamp) {
94
- const levelColor = levelColors[level.toUpperCase()] || chalk.gray;
95
- let date;
96
- let nameHex;
97
- let loggerName;
98
- let loggerLevel;
99
- switch (name) {
100
- // предустановленнный цветовой шаблон по имени логгера
101
- case 'critical':
102
- date = chalk.red(`[${timestamp.toISOString()}]`);
103
- loggerName = chalk.red(`[${name}]`);
104
- loggerLevel = chalk.red(`[${level}]`);
105
- break;
106
- default:
107
- date = chalk.gray(`[${timestamp.toISOString()}]`);
108
- nameHex = stringToColorCode(name);
109
- loggerName = chalk.hex(nameHex)(`[${name}]`);
110
- loggerLevel = levelColor(`[${level}]`);
111
- break;
112
- }
113
- return `${date} ${loggerLevel} ${loggerName} ${chalk.cyan('')}`;
57
+ const levelColor = levelColors[level.toUpperCase()] || chalk.gray;
58
+ let date;
59
+ let nameHex;
60
+ let loggerName;
61
+ let loggerLevel;
62
+ switch (name) {
63
+ // предустановленнный цветовой шаблон по имени логгера
64
+ case "critical":
65
+ date = chalk.red(`[${timestamp.toISOString()}]`);
66
+ loggerName = chalk.red(`[${name}]`);
67
+ loggerLevel = chalk.red(`[${level}]`);
68
+ break;
69
+ default:
70
+ date = chalk.gray(`[${timestamp.toISOString()}]`);
71
+ nameHex = stringToColorCode(name);
72
+ loggerName = chalk.hex(nameHex)(`[${name}]`);
73
+ loggerLevel = levelColor(`[${level}]`);
74
+ break;
75
+ }
76
+ return `${date} ${loggerLevel} ${loggerName} ${chalk.cyan("")}`;
114
77
  }
115
- /**
116
- * Получает текущее значение debug
117
- * @returns {string | undefined} Строка с debug значениями или undefined, если значений нет
118
- */
119
78
  function getDebugValue() {
120
- const value = Array.from(debugStorage).join(',');
121
- return value.length ? value : undefined;
79
+ const value = Array.from(debugStorage).join(",");
80
+ return value.length ? value : void 0;
122
81
  }
123
- /**
124
- * Устанавливает значение debug
125
- * @param {string | null} value - Новое значение debug
126
- */
127
82
  function setDebugValue(value) {
128
- if (value === null || value === undefined) {
129
- debugStorage.clear();
130
- }
131
- else {
132
- debugStorage.add(value.trim());
133
- }
83
+ if (value === null || value === void 0) {
84
+ debugStorage.clear();
85
+ } else {
86
+ debugStorage.add(value.trim());
87
+ }
134
88
  }
135
- /**
136
- * Функция для подписки на изменения значения debug
137
- * @param {function} callback - Функция, вызываемая при изменении значения debug
138
- * @returns {function} Функция для отписки от изменений
139
- */
140
89
  function onDebugValueChange(_callback) {
141
- // TODO: Implement debug value change listener
142
- return () => { };
90
+ return () => {
91
+ };
143
92
  }
144
93
  if (process.env.DEBUG) {
145
- setDebugValue(process.env.DEBUG);
94
+ setDebugValue(process.env.DEBUG);
146
95
  }
147
96
  const environment = {
148
- getDebugValue,
149
- setDebugValue,
150
- formatter,
151
- onDebugValueChange,
97
+ getDebugValue,
98
+ setDebugValue,
99
+ formatter,
100
+ onDebugValueChange
152
101
  };
153
-
154
- /**
155
- * Генерирует UUID версии 4.
156
- * @returns {string} Строка, представляющая UUID версии 4.
157
- */
158
102
  function generateUUIDv4() {
159
- return '10000000-1000-4000-8000-100000000000'.replace(/[018]/g, (char) => (parseInt(char, 10) ^ (crypto.getRandomValues(new Uint8Array(1))[0] & (15 >> (parseInt(char, 10) / 4)))).toString(16));
103
+ return "10000000-1000-4000-8000-100000000000".replace(
104
+ /[018]/g,
105
+ (char) => (parseInt(char, 10) ^ crypto.getRandomValues(new Uint8Array(1))[0] & 15 >> parseInt(char, 10) / 4).toString(
106
+ 16
107
+ )
108
+ );
160
109
  }
161
-
162
- /* eslint-disable @typescript-eslint/no-unsafe-function-type */
163
- const loggerCache = new Map();
164
- const previousLevels = new Map();
110
+ const loggerCache = /* @__PURE__ */ new Map();
111
+ const previousLevels = /* @__PURE__ */ new Map();
165
112
  let isInitialized = false;
166
- /**
167
- * Создает экземпляр HierarchicalLogger
168
- * @param fullName Имя логгера
169
- * @param parent Родительский логгер (если есть)
170
- */
171
113
  function createHierarchicalLogger(originalGetLogger, fullName, parent) {
172
- const loggerId = generateUUIDv4();
173
- const baseLogger = originalGetLogger(fullName);
174
- const name = parent ? fullName.slice(parent.getFullName().length + 1) : fullName;
175
- const hierarchicalLogger = Object.assign(Object.assign({}, baseLogger), { id: loggerId, parent: parent !== null && parent !== void 0 ? parent : null, children: new Set(), name: name, debugEnabled: false, isDebugEnabled() {
176
- return this.debugEnabled;
177
- },
178
- getDebugPattern() {
179
- var _a;
180
- return (_a = environment.getDebugValue()) !== null && _a !== void 0 ? _a : null;
181
- },
182
- // Добавим вспомогательный метод для получения полного имени логгера
183
- getFullName() {
184
- if (!this.parent) {
185
- return this.name;
186
- }
187
- const parentFullName = this.parent.getFullName();
188
- return parentFullName ? `${parentFullName}:${this.name}` : this.name;
189
- },
190
- setDebug(enabled) {
191
- this.debugEnabled = enabled;
192
- const parentLevel = this.parent ? this.parent.getLevel() : undefined;
193
- const currentPatterns = (environment.getDebugValue() || '').split(',').filter(Boolean);
194
- const fullName = this.getFullName();
195
- if (enabled) {
196
- if (!previousLevels.has(this.id)) {
197
- previousLevels.set(this.id, baseLogger.getLevel());
198
- }
199
- baseLogger.setLevel(log.levels.TRACE, false);
200
- // Если включаем отладку
201
- if (!currentPatterns.some((pattern) => fullName === pattern || `${fullName}:*` === pattern)) {
202
- // Удаляем все дочерние паттерны, если они есть
203
- const childrenPatterns = currentPatterns.filter((pattern) => pattern.startsWith(`${fullName}:`));
204
- childrenPatterns.forEach((pattern) => {
205
- const index = currentPatterns.indexOf(pattern);
206
- if (index !== -1) {
207
- currentPatterns.splice(index, 1);
208
- }
209
- });
210
- // Добавляем новый паттерн без ':*'
211
- currentPatterns.push(fullName);
212
- }
213
- }
214
- else {
215
- let newLevel;
216
- if (parentLevel !== undefined) {
217
- // Используем уровень родительского логгера, если он существует
218
- newLevel = parentLevel;
219
- }
220
- else {
221
- // Если родительского логгера нет, используем предыдущий сохраненный уровень или уровень по умолчанию
222
- newLevel = previousLevels.get(this.id) || log.levels.WARN;
223
- }
224
- baseLogger.setLevel(newLevel, false);
225
- previousLevels.delete(this.id);
226
- // Если выключаем отладку
227
- const index = currentPatterns.findIndex((pattern) => pattern === fullName || pattern === `${fullName}:*`);
228
- if (index !== -1) {
229
- currentPatterns.splice(index, 1);
230
- }
231
- }
232
- // Оптимизируем паттерны
233
- const optimizedPatterns = optimizePatterns(currentPatterns);
234
- // Сохраняем оптимизированные паттерны
235
- environment.setDebugValue(optimizedPatterns.join(',') || null);
236
- },
237
- getLogger(name) {
238
- const childLogger = createHierarchicalLogger(originalGetLogger, `${fullName}:${name}`, this);
239
- this.children.add(childLogger);
240
- return childLogger;
241
- },
242
- setLevel(level) {
243
- baseLogger.setLevel(level, false);
244
- // Обновляем уровень для всех дочерних логгеров
245
- this.children.forEach((child) => child.setLevel(level, false));
246
- // Если логгер в режиме отладки, сохраняем новый уровень
247
- if (this.isDebugEnabled()) {
248
- previousLevels.set(loggerId, level);
249
- }
250
- } });
251
- const originalFactory = baseLogger.methodFactory;
252
- // Переопределяем методы логирования для учета режима отладки
253
- const logMethods = ['trace', 'debug', 'info', 'warn', 'error', 'log'];
254
- logMethods.forEach((method) => {
255
- const originalMethod = originalFactory(method, baseLogger.getLevel(), fullName);
256
- hierarchicalLogger[method] = function (...args) {
257
- var _a;
258
- const debugEnabled = this.isDebugEnabled();
259
- const messageLevel = (_a = log.levels[method.toUpperCase()]) !== null && _a !== void 0 ? _a : 0;
260
- const currentLevel = baseLogger.getLevel();
261
- if (debugEnabled || messageLevel >= currentLevel) {
262
- return originalMethod.apply(baseLogger, args);
114
+ const loggerId = generateUUIDv4();
115
+ const baseLogger = originalGetLogger(fullName);
116
+ const name = parent ? fullName.slice(parent.getFullName().length + 1) : fullName;
117
+ const hierarchicalLogger = {
118
+ ...baseLogger,
119
+ id: loggerId,
120
+ parent: parent ?? null,
121
+ children: /* @__PURE__ */ new Set(),
122
+ name,
123
+ debugEnabled: false,
124
+ isDebugEnabled() {
125
+ return this.debugEnabled;
126
+ },
127
+ getDebugPattern() {
128
+ return environment.getDebugValue() ?? null;
129
+ },
130
+ // Добавим вспомогательный метод для получения полного имени логгера
131
+ getFullName() {
132
+ if (!this.parent) {
133
+ return this.name;
134
+ }
135
+ const parentFullName = this.parent.getFullName();
136
+ return parentFullName ? `${parentFullName}:${this.name}` : this.name;
137
+ },
138
+ setDebug(enabled) {
139
+ this.debugEnabled = enabled;
140
+ const parentLevel = this.parent ? this.parent.getLevel() : void 0;
141
+ const currentPatterns = (environment.getDebugValue() || "").split(",").filter(Boolean);
142
+ const fullName2 = this.getFullName();
143
+ if (enabled) {
144
+ if (!previousLevels.has(this.id)) {
145
+ previousLevels.set(this.id, baseLogger.getLevel());
146
+ }
147
+ baseLogger.setLevel(log.levels.TRACE, false);
148
+ if (!currentPatterns.some((pattern) => fullName2 === pattern || `${fullName2}:*` === pattern)) {
149
+ const childrenPatterns = currentPatterns.filter((pattern) => pattern.startsWith(`${fullName2}:`));
150
+ childrenPatterns.forEach((pattern) => {
151
+ const index = currentPatterns.indexOf(pattern);
152
+ if (index !== -1) {
153
+ currentPatterns.splice(index, 1);
263
154
  }
264
- };
265
- });
266
- loggerCache.set(loggerId, hierarchicalLogger);
267
- if (!isInitialized) {
268
- isInitialized = true;
269
- initializeDebugPatterns();
270
- }
271
- else {
272
- const debugPattern = environment.getDebugValue() || '';
273
- const patterns = debugPattern
274
- .split(',')
275
- .map((p) => p.trim())
276
- .filter(Boolean);
277
- configureLogger(hierarchicalLogger, patterns);
155
+ });
156
+ currentPatterns.push(fullName2);
157
+ }
158
+ } else {
159
+ let newLevel;
160
+ if (parentLevel !== void 0) {
161
+ newLevel = parentLevel;
162
+ } else {
163
+ newLevel = previousLevels.get(this.id) || log.levels.WARN;
164
+ }
165
+ baseLogger.setLevel(newLevel, false);
166
+ previousLevels.delete(this.id);
167
+ const index = currentPatterns.findIndex((pattern) => pattern === fullName2 || pattern === `${fullName2}:*`);
168
+ if (index !== -1) {
169
+ currentPatterns.splice(index, 1);
170
+ }
171
+ }
172
+ const optimizedPatterns = optimizePatterns(currentPatterns);
173
+ environment.setDebugValue(optimizedPatterns.join(",") || null);
174
+ },
175
+ getLogger(name2) {
176
+ const childLogger = createHierarchicalLogger(originalGetLogger, `${fullName}:${name2}`, this);
177
+ this.children.add(childLogger);
178
+ return childLogger;
179
+ },
180
+ setLevel(level) {
181
+ baseLogger.setLevel(level, false);
182
+ this.children.forEach((child) => child.setLevel(level, false));
183
+ if (this.isDebugEnabled()) {
184
+ previousLevels.set(loggerId, level);
185
+ }
278
186
  }
279
- return hierarchicalLogger;
187
+ };
188
+ const originalFactory = baseLogger.methodFactory;
189
+ const logMethods = ["trace", "debug", "info", "warn", "error", "log"];
190
+ logMethods.forEach((method) => {
191
+ const originalMethod = originalFactory(method, baseLogger.getLevel(), fullName);
192
+ hierarchicalLogger[method] = function(...args) {
193
+ const debugEnabled = this.isDebugEnabled();
194
+ const messageLevel = log.levels[method.toUpperCase()] ?? 0;
195
+ const currentLevel = baseLogger.getLevel();
196
+ if (debugEnabled || messageLevel >= currentLevel) {
197
+ return originalMethod.apply(baseLogger, args);
198
+ }
199
+ };
200
+ });
201
+ loggerCache.set(loggerId, hierarchicalLogger);
202
+ if (!isInitialized) {
203
+ isInitialized = true;
204
+ initializeDebugPatterns();
205
+ } else {
206
+ const debugPattern = environment.getDebugValue() || "";
207
+ const patterns = debugPattern.split(",").map((p) => p.trim()).filter(Boolean);
208
+ configureLogger(hierarchicalLogger, patterns);
209
+ }
210
+ return hierarchicalLogger;
280
211
  }
281
- /**
282
- * Оптимизирует паттерны отладки
283
- * @param patterns Массив паттернов отладки
284
- * @returns Оптимизированный массив паттернов
285
- */
286
212
  function optimizePatterns(patterns) {
287
- const optimized = new Set();
288
- // Сортируем паттерны от более общих к более конкретным
289
- patterns.sort((a, b) => a.split(':').length - b.split(':').length);
290
- for (const pattern of patterns) {
291
- let isRedundant = false;
292
- for (const existingPattern of optimized) {
293
- if (pattern === existingPattern || pattern.startsWith(existingPattern + ':')) {
294
- isRedundant = true;
295
- break;
296
- }
297
- }
298
- if (!isRedundant) {
299
- optimized.add(pattern);
300
- }
213
+ const optimized = /* @__PURE__ */ new Set();
214
+ patterns.sort((a, b) => a.split(":").length - b.split(":").length);
215
+ for (const pattern of patterns) {
216
+ let isRedundant = false;
217
+ for (const existingPattern of optimized) {
218
+ if (pattern === existingPattern || pattern.startsWith(existingPattern + ":")) {
219
+ isRedundant = true;
220
+ break;
221
+ }
301
222
  }
302
- return Array.from(optimized);
223
+ if (!isRedundant) {
224
+ optimized.add(pattern);
225
+ }
226
+ }
227
+ return Array.from(optimized);
303
228
  }
304
- /**
305
- * Проверяет, должен ли логгер быть в режиме отладки
306
- * @param fullName Полное имя логгера
307
- * @param patterns Массив паттернов отладки
308
- * @returns true, если логгер должен быть в режиме отладки
309
- */
310
229
  function shouldEnableDebug(fullName, patterns) {
311
- return patterns.some((pattern) => {
312
- if (pattern === '*')
313
- return true;
314
- if (fullName === pattern)
315
- return true;
316
- if (pattern.endsWith(':*')) {
317
- const patternPrefix = pattern.slice(0, -2);
318
- return fullName.startsWith(patternPrefix + ':');
319
- }
320
- return false;
321
- });
230
+ return patterns.some((pattern) => {
231
+ if (pattern === "*") return true;
232
+ if (fullName === pattern) return true;
233
+ if (pattern.endsWith(":*")) {
234
+ const patternPrefix = pattern.slice(0, -2);
235
+ return fullName.startsWith(patternPrefix + ":");
236
+ }
237
+ return false;
238
+ });
322
239
  }
323
- /**
324
- * Настраивает логгер в соответствии с текущими паттернами отладки
325
- * @param logger Логгер для настройки
326
- * @param patterns Массив паттернов отладки
327
- */
328
240
  function configureLogger(logger, patterns) {
329
- const fullName = logger.getFullName();
330
- const debugEnabled = shouldEnableDebug(fullName, patterns);
331
- logger.debugEnabled = debugEnabled;
332
- if (debugEnabled) {
333
- logger.setLevel(previousLevels.get(logger.id) || log.levels.TRACE);
334
- }
335
- else {
336
- logger.setLevel(previousLevels.get(logger.id) || log.levels.WARN);
337
- }
241
+ const fullName = logger.getFullName();
242
+ const debugEnabled = shouldEnableDebug(fullName, patterns);
243
+ logger.debugEnabled = debugEnabled;
244
+ if (debugEnabled) {
245
+ logger.setLevel(previousLevels.get(logger.id) || log.levels.TRACE);
246
+ } else {
247
+ logger.setLevel(previousLevels.get(logger.id) || log.levels.WARN);
248
+ }
338
249
  }
339
- /**
340
- * Инициализирует паттерны отладки из environment
341
- */
342
250
  function initializeDebugPatterns() {
343
- const debugPattern = environment.getDebugValue() || '';
344
- const patterns = debugPattern
345
- .split(',')
346
- .map((p) => p.trim())
347
- .filter(Boolean);
348
- // Создаем Set для отслеживания уже обработанных логгеров
349
- const processedLoggers = new Set();
350
- function processLogger(logger) {
351
- if (processedLoggers.has(logger.id))
352
- return;
353
- processedLoggers.add(logger.id);
354
- configureLogger(logger, patterns);
355
- // Обрабатываем дочерние логгеры
356
- logger.children.forEach(processLogger);
357
- }
358
- // Обрабатываем все существующие логгеры
359
- loggerCache.forEach(processLogger);
360
- // Обрабатываем все существующие логгеры
361
- Array.from(loggerCache).forEach(([, logger]) => {
362
- processLogger(logger);
363
- });
251
+ const debugPattern = environment.getDebugValue() || "";
252
+ const patterns = debugPattern.split(",").map((p) => p.trim()).filter(Boolean);
253
+ const processedLoggers = /* @__PURE__ */ new Set();
254
+ function processLogger(logger) {
255
+ if (processedLoggers.has(logger.id)) return;
256
+ processedLoggers.add(logger.id);
257
+ configureLogger(logger, patterns);
258
+ logger.children.forEach(processLogger);
259
+ }
260
+ loggerCache.forEach(processLogger);
261
+ Array.from(loggerCache).forEach(([, logger]) => {
262
+ processLogger(logger);
263
+ });
364
264
  }
365
- /**
366
- * Плагин иерархического логгера для loglevel
367
- */
368
265
  const hierarchicalPlugin = {
369
- apply(rootLogger) {
370
- // Переопределяем метод getLogger корневого логгера
371
- const originalGetLogger = rootLogger.getLogger.bind(rootLogger);
372
- rootLogger.getLogger = (name) => {
373
- return createHierarchicalLogger(originalGetLogger, name);
374
- };
375
- },
266
+ apply(rootLogger) {
267
+ const originalGetLogger = rootLogger.getLogger.bind(rootLogger);
268
+ rootLogger.getLogger = (name) => {
269
+ return createHierarchicalLogger(originalGetLogger, name);
270
+ };
271
+ }
376
272
  };
377
-
378
273
  const defaultOptions = {
379
- format: (level, name, timestamp) => `[${timestamp.toISOString()}] [${level}] [${name}]`,
274
+ format: (level, name, timestamp) => `[${timestamp.toISOString()}] [${level}] [${name}]`
380
275
  };
381
- /**
382
- * Плагин для добавления префикса к логам
383
- * @param logger Инстанс логгера
384
- * @param options Опции плагина
385
- */
386
276
  function prefix(logger, options = {}) {
387
- const mergedOptions = Object.assign(Object.assign({}, defaultOptions), options);
388
- const originalFactory = logger.methodFactory;
389
- logger.methodFactory = function (methodName, logLevel, loggerName) {
390
- const rawMethod = originalFactory(methodName, logLevel, loggerName);
391
- return function (...args) {
392
- const level = methodName.toUpperCase();
393
- const timestamp = new Date();
394
- const prefix = mergedOptions.format(level, typeof loggerName === 'string' ? loggerName : '', timestamp);
395
- if (Array.isArray(prefix)) {
396
- rawMethod.apply(this, [...prefix, ...args]);
397
- }
398
- else {
399
- rawMethod.apply(this, [prefix, ...args]);
400
- }
401
- };
277
+ const mergedOptions = { ...defaultOptions, ...options };
278
+ const originalFactory = logger.methodFactory;
279
+ logger.methodFactory = function(methodName, logLevel, loggerName) {
280
+ const rawMethod = originalFactory(methodName, logLevel, loggerName);
281
+ return function(...args) {
282
+ const level = methodName.toUpperCase();
283
+ const timestamp = /* @__PURE__ */ new Date();
284
+ const prefix2 = mergedOptions.format(level, typeof loggerName === "string" ? loggerName : "", timestamp);
285
+ if (Array.isArray(prefix2)) {
286
+ rawMethod.apply(this, [...prefix2, ...args]);
287
+ } else {
288
+ rawMethod.apply(this, [prefix2, ...args]);
289
+ }
402
290
  };
403
- return logger;
291
+ };
292
+ return logger;
404
293
  }
405
294
  const prefixPlugin = {
406
- apply(rootLogger, options = {}) {
407
- prefix(rootLogger, options);
408
- },
295
+ apply(rootLogger, options = {}) {
296
+ prefix(rootLogger, options);
297
+ }
409
298
  };
410
-
411
- // Применяем плагины
412
299
  hierarchicalPlugin.apply(log);
413
300
  prefixPlugin.apply(log, {
414
- format: (level, name, timestamp) => {
415
- return environment.formatter(level, name, timestamp);
416
- },
301
+ format: (level, name, timestamp) => {
302
+ return environment.formatter(level, name, timestamp);
303
+ }
417
304
  });
418
- // сброс левела чтобы игнорировать запись в сторадже в браузерной имплементации
419
305
  log.resetLevel();
420
- // Пересоздаем методы логгера
421
306
  log.rebuild();
422
307
  const extendedLog = Object.assign(log, {});
423
-
424
308
  exports.hierarchicalPlugin = hierarchicalPlugin;
425
309
  exports.log = extendedLog;
426
310
  exports.prefixPlugin = prefixPlugin;