@garrix82/reactgenie-lib 1.3.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 (85) hide show
  1. package/.env.example +22 -0
  2. package/.github/workflows/publish.yml +20 -0
  3. package/LICENSE.txt +201 -0
  4. package/README.md +621 -0
  5. package/babel.config.js +29 -0
  6. package/dist/adapters/__tests__/expo-router-adapter.test.d.ts +1 -0
  7. package/dist/adapters/expo-router-adapter.d.ts +16 -0
  8. package/dist/adapters/expo-router-adapter.js +521 -0
  9. package/dist/adapters/navigation-adapter.d.ts +20 -0
  10. package/dist/adapters/navigation-adapter.js +137 -0
  11. package/dist/audio-visualizer.d.ts +14 -0
  12. package/dist/audio-visualizer.js +123 -0
  13. package/dist/current-selection.d.ts +27 -0
  14. package/dist/current-selection.js +94 -0
  15. package/dist/errors.d.ts +19 -0
  16. package/dist/errors.js +37 -0
  17. package/dist/genie/DateTime.d.ts +66 -0
  18. package/dist/genie/DateTime.js +399 -0
  19. package/dist/genie/TimeDelta.d.ts +35 -0
  20. package/dist/genie/TimeDelta.js +169 -0
  21. package/dist/genie-view-wrapper.d.ts +1 -0
  22. package/dist/genie-view-wrapper.js +377 -0
  23. package/dist/hooks/__tests__/useSpeechRecognition.test.d.ts +1 -0
  24. package/dist/hooks/useSpeechRecognition.d.ts +28 -0
  25. package/dist/hooks/useSpeechRecognition.js +118 -0
  26. package/dist/index.d.ts +30 -0
  27. package/dist/index.js +469 -0
  28. package/dist/logger.d.ts +23 -0
  29. package/dist/logger.js +597 -0
  30. package/dist/logger.remote.test.d.ts +0 -0
  31. package/dist/modality-provider-v2.d.ts +28 -0
  32. package/dist/modality-provider-v2.js +1321 -0
  33. package/dist/modality-provider.d.ts +22 -0
  34. package/dist/modality-provider.js +373 -0
  35. package/dist/native-visibility.d.ts +28 -0
  36. package/dist/native-visibility.js +50 -0
  37. package/dist/platform/VoiceRecognitionBar.d.ts +17 -0
  38. package/dist/platform/VoiceRecognitionBar.js +332 -0
  39. package/dist/platform/components.d.ts +32 -0
  40. package/dist/platform/components.js +351 -0
  41. package/dist/platform/events.d.ts +31 -0
  42. package/dist/platform/events.js +274 -0
  43. package/dist/platform/index.d.ts +3 -0
  44. package/dist/platform/index.js +39 -0
  45. package/dist/platform/types.d.ts +79 -0
  46. package/dist/platform/types.js +97 -0
  47. package/dist/react-decorators.d.ts +87 -0
  48. package/dist/react-decorators.js +368 -0
  49. package/dist/shared-store.d.ts +74 -0
  50. package/dist/shared-store.js +589 -0
  51. package/dist/speech-recognition/__tests__/speech-recognition-groq-transport.test.d.ts +1 -0
  52. package/dist/speech-recognition/__tests__/speech-recognition-native.test.d.ts +1 -0
  53. package/dist/speech-recognition/__tests__/speech-recognition-openai-native.test.d.ts +1 -0
  54. package/dist/speech-recognition/__tests__/speech-recognition-openai.test.d.ts +1 -0
  55. package/dist/speech-recognition/__tests__/speech-recognition-unified-import.test.d.ts +0 -0
  56. package/dist/speech-recognition/__tests__/speech-recognition-unified.test.d.ts +1 -0
  57. package/dist/speech-recognition/speech-recognition-groq.d.ts +21 -0
  58. package/dist/speech-recognition/speech-recognition-groq.js +409 -0
  59. package/dist/speech-recognition/speech-recognition-mlx.d.ts +15 -0
  60. package/dist/speech-recognition/speech-recognition-mlx.js +393 -0
  61. package/dist/speech-recognition/speech-recognition-native.d.ts +24 -0
  62. package/dist/speech-recognition/speech-recognition-native.js +632 -0
  63. package/dist/speech-recognition/speech-recognition-openai-native.d.ts +40 -0
  64. package/dist/speech-recognition/speech-recognition-openai-native.js +653 -0
  65. package/dist/speech-recognition/speech-recognition-openai.d.ts +39 -0
  66. package/dist/speech-recognition/speech-recognition-openai.js +718 -0
  67. package/dist/speech-recognition/speech-recognition-unified.d.ts +93 -0
  68. package/dist/speech-recognition/speech-recognition-unified.js +589 -0
  69. package/dist/speech-recognition/utils/groq-transcription.d.ts +41 -0
  70. package/dist/speech-recognition/utils/groq-transcription.js +382 -0
  71. package/dist/speech-recognition.d.ts +7 -0
  72. package/dist/speech-recognition.js +61 -0
  73. package/dist/voice-pipeline-telemetry.d.ts +26 -0
  74. package/dist/voice-pipeline-telemetry.js +15 -0
  75. package/garrix82-reactgenie-lib-1.3.0.tgz +0 -0
  76. package/metro/index.js +3 -0
  77. package/metro/with-genie-registry.js +47 -0
  78. package/package.json +111 -0
  79. package/scripts/dry-run.js +23 -0
  80. package/scripts/generate-genie-registry.js +278 -0
  81. package/scripts/log-file-test.js +51 -0
  82. package/scripts/parse.js +26 -0
  83. package/scripts/prompt.js +19 -0
  84. package/scripts/set-script.js +200 -0
  85. package/tsconfig.json +36 -0
package/dist/logger.js ADDED
@@ -0,0 +1,597 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.configureLogger = configureLogger;
7
+ exports.logger = exports.default = void 0;
8
+ exports.setLogLevel = setLogLevel;
9
+ exports.setLoggerTelemetryBridge = setLoggerTelemetryBridge;
10
+ var _reactNative = require("react-native");
11
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
12
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
13
+ function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
14
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
15
+ function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } // Environment-aware logger utility
16
+ // Uses react-native-logs for React Native, winston for Node.js/web, console as fallback
17
+ // Determine environment first
18
+ // Treat Node as its own runtime even if react-native Platform.OS is ios/android in tests
19
+ const getRuntimeProcess = () => {
20
+ const globalObj = globalThis;
21
+ return globalObj?.process ?? null;
22
+ };
23
+ const isNodeEnvironment = Boolean(getRuntimeProcess()?.versions?.node);
24
+ const isReactNative = _reactNative.Platform.OS !== 'web' && !isNodeEnvironment;
25
+ const isWeb = _reactNative.Platform.OS === 'web';
26
+
27
+ // Try to require libraries based on environment
28
+ let rnLogs = null;
29
+ let winston = null;
30
+
31
+ // Only try to require react-native-logs in React Native environments
32
+ if (isReactNative) {
33
+ try {
34
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
35
+ rnLogs = require('react-native-logs');
36
+ } catch (e) {
37
+ rnLogs = null;
38
+ }
39
+ }
40
+
41
+ // For winston, use runtime detection without static requires
42
+ const getWinston = () => {
43
+ if (winston !== null) return winston;
44
+ if (!isNodeEnvironment) return null;
45
+ try {
46
+ // Use eval to dynamically construct the require call
47
+ // This prevents static analysis from finding 'winston' in require()
48
+ const winstonModule = eval('require')('winston');
49
+ winston = winstonModule;
50
+ return winston;
51
+ } catch (e) {
52
+ winston = null;
53
+ return null;
54
+ }
55
+ };
56
+ // Read desired log level from env/config
57
+ function getDefaultLogLevel() {
58
+ const env = getRuntimeProcess()?.env ?? {};
59
+ const level = env.REACT_APP_LOG_LEVEL || env.EXPO_PUBLIC_LOG_LEVEL || env.LOG_LEVEL;
60
+ if (!level) return isNodeEnvironment || isWeb ? 'info' : 'warn';
61
+ const normalized = level.toLowerCase();
62
+ if (['error', 'warn', 'info', 'debug', 'silent'].includes(normalized)) {
63
+ return normalized;
64
+ }
65
+ return 'info';
66
+ }
67
+ let currentLevel = getDefaultLogLevel();
68
+ let runtimeLoggerConfig = {};
69
+ let loggerTelemetryBridge = null;
70
+ const pad2 = n => String(n).padStart(2, '0');
71
+ const formatLocalDate = (date = new Date()) => `${date.getFullYear()}-${pad2(date.getMonth() + 1)}-${pad2(date.getDate())}`;
72
+ const buildDailyFileName = (date = new Date()) => `logs-${formatLocalDate(date)}.log`;
73
+ const getEnvConfig = () => {
74
+ return getRuntimeProcess()?.env ?? {};
75
+ };
76
+ const isValidLogLevel = level => {
77
+ return typeof level === 'string' && ['error', 'warn', 'info', 'debug', 'silent'].includes(level);
78
+ };
79
+ const isFileLoggingEnabled = () => {
80
+ if (typeof runtimeLoggerConfig.enableFileLogging === 'boolean') {
81
+ return runtimeLoggerConfig.enableFileLogging;
82
+ }
83
+ const env = getEnvConfig();
84
+ const raw = env.REACT_APP_ENABLE_WINSTON_FILE || env.EXPO_PUBLIC_ENABLE_WINSTON_FILE || env.REACT_APP_ENABLE_FILE_LOGS || env.EXPO_PUBLIC_ENABLE_FILE_LOGS || env.LOG_FILE_ENABLED;
85
+ if (raw === undefined) return true;
86
+ return raw === 'true' || raw === '1';
87
+ };
88
+ const getConfiguredLogDir = () => {
89
+ if (runtimeLoggerConfig.logFileDir && runtimeLoggerConfig.logFileDir.trim()) {
90
+ return runtimeLoggerConfig.logFileDir;
91
+ }
92
+ const env = getEnvConfig();
93
+ return env.REACT_APP_LOG_FILE_DIR || env.EXPO_PUBLIC_LOG_FILE_DIR || env.LOG_FILE_DIR || '.';
94
+ };
95
+ const formatLogLine = (level, args) => {
96
+ const ts = new Date().toISOString();
97
+ const serialize = value => {
98
+ if (value instanceof Error) {
99
+ const stack = value.stack ? `\n${value.stack}` : '';
100
+ return `${value.message}${stack}`;
101
+ }
102
+ if (typeof value === 'string') return value;
103
+ try {
104
+ return JSON.stringify(value);
105
+ } catch {
106
+ return String(value);
107
+ }
108
+ };
109
+ const payload = args.map(serialize).join(' ');
110
+ return `${ts} [${level.toUpperCase()}] ${payload}\n`;
111
+ };
112
+ let fileSink = undefined;
113
+ let remoteSink = undefined;
114
+ const getConfiguredRemoteUrl = () => {
115
+ if (runtimeLoggerConfig.remoteUrl && runtimeLoggerConfig.remoteUrl.trim()) {
116
+ return runtimeLoggerConfig.remoteUrl;
117
+ }
118
+ const env = getEnvConfig();
119
+ return env.REACT_APP_LOG_REMOTE_URL || env.EXPO_PUBLIC_LOG_REMOTE_URL || env.LOG_REMOTE_URL || '';
120
+ };
121
+ const getConfiguredRemoteToken = () => {
122
+ if (runtimeLoggerConfig.remoteToken && runtimeLoggerConfig.remoteToken.trim()) {
123
+ return runtimeLoggerConfig.remoteToken;
124
+ }
125
+ const env = getEnvConfig();
126
+ return env.REACT_APP_LOG_INGEST_TOKEN || env.EXPO_PUBLIC_LOG_INGEST_TOKEN || env.LOG_INGEST_TOKEN || '';
127
+ };
128
+ const isRemoteLoggingEnabled = () => {
129
+ if (typeof runtimeLoggerConfig.remoteEnabled === 'boolean') {
130
+ return runtimeLoggerConfig.remoteEnabled && Boolean(getConfiguredRemoteUrl());
131
+ }
132
+ const remoteUrl = getConfiguredRemoteUrl();
133
+ if (!remoteUrl) return false;
134
+ const env = getEnvConfig();
135
+ const raw = env.REACT_APP_ENABLE_REMOTE_LOGS || env.EXPO_PUBLIC_ENABLE_REMOTE_LOGS || env.LOG_REMOTE_ENABLED;
136
+ if (raw === undefined) return true;
137
+ return raw === 'true' || raw === '1';
138
+ };
139
+ const serializeArgForJson = value => {
140
+ if (value instanceof Error) {
141
+ return {
142
+ name: value.name,
143
+ message: value.message,
144
+ stack: value.stack
145
+ };
146
+ }
147
+ if (value === null || value === undefined) return value;
148
+ if (typeof value === 'string' || typeof value === 'number' || typeof value === 'boolean') return value;
149
+ try {
150
+ return JSON.parse(JSON.stringify(value));
151
+ } catch {
152
+ return String(value);
153
+ }
154
+ };
155
+ const buildRemotePayload = (level, args) => {
156
+ const normalizedArgs = args.map(arg => serializeArgForJson(arg));
157
+ const firstArg = normalizedArgs[0];
158
+ const message = typeof firstArg === 'string' ? firstArg : normalizedArgs.map(arg => typeof arg === 'string' ? arg : JSON.stringify(arg)).join(' ');
159
+ return {
160
+ timestamp: new Date().toISOString(),
161
+ level,
162
+ message: message || '[empty]',
163
+ source: isWeb ? 'web' : 'mobile',
164
+ runtime: isNodeEnvironment ? 'node' : 'client',
165
+ args: normalizedArgs
166
+ };
167
+ };
168
+ const buildTelemetryMessage = args => {
169
+ if (!Array.isArray(args) || args.length === 0) return "[empty]";
170
+ const [first] = args;
171
+ if (typeof first === "string" && first.trim()) return first;
172
+ return args.map(arg => {
173
+ if (arg instanceof Error) return arg.message;
174
+ if (typeof arg === "string") return arg;
175
+ try {
176
+ return JSON.stringify(arg);
177
+ } catch {
178
+ return String(arg);
179
+ }
180
+ }).join(" ").trim() || "[empty]";
181
+ };
182
+ const emitTelemetryBridge = (level, args) => {
183
+ if (!loggerTelemetryBridge) return;
184
+ const errorArg = args.find(arg => arg instanceof Error);
185
+ const context = {
186
+ level,
187
+ runtime: isNodeEnvironment ? "node" : isWeb ? "web" : "native"
188
+ };
189
+ if (errorArg && typeof loggerTelemetryBridge.captureException === "function") {
190
+ loggerTelemetryBridge.captureException(errorArg, context);
191
+ return;
192
+ }
193
+ if (typeof loggerTelemetryBridge.captureMessage === "function") {
194
+ loggerTelemetryBridge.captureMessage(buildTelemetryMessage(args), level, context);
195
+ }
196
+ };
197
+ const getRemoteSink = () => {
198
+ if (remoteSink !== undefined) return remoteSink ?? null;
199
+ if (!isRemoteLoggingEnabled()) {
200
+ remoteSink = null;
201
+ return null;
202
+ }
203
+ if (typeof fetch !== 'function') {
204
+ remoteSink = null;
205
+ return null;
206
+ }
207
+ const url = getConfiguredRemoteUrl();
208
+ const token = getConfiguredRemoteToken();
209
+ let sendChain = Promise.resolve();
210
+ const sendOne = async (level, args) => {
211
+ const headers = {
212
+ 'content-type': 'application/json'
213
+ };
214
+ if (token) {
215
+ headers['x-log-token'] = token;
216
+ }
217
+ const payload = buildRemotePayload(level, args);
218
+ await fetch(url, {
219
+ method: 'POST',
220
+ headers,
221
+ body: JSON.stringify(payload)
222
+ });
223
+ };
224
+ remoteSink = {
225
+ write: (level, args) => {
226
+ sendChain = sendChain.then(() => sendOne(level, args)).catch(() => {});
227
+ }
228
+ };
229
+ return remoteSink;
230
+ };
231
+ const invalidateDerivedLoggerState = () => {
232
+ fileSink = undefined;
233
+ remoteSink = undefined;
234
+ };
235
+ const getNodeFileSink = () => {
236
+ if (!isNodeEnvironment) return null;
237
+ let fs = null;
238
+ let path = null;
239
+ try {
240
+ fs = eval('require')('fs');
241
+ path = eval('require')('path');
242
+ } catch {
243
+ return null;
244
+ }
245
+ let currentDate = '';
246
+ let filePath = '';
247
+ const ensureFilePath = () => {
248
+ const today = formatLocalDate(new Date());
249
+ if (today === currentDate && filePath) return;
250
+ currentDate = today;
251
+ const logDir = getConfiguredLogDir() || '.';
252
+ const cwd = getRuntimeProcess()?.cwd?.() ?? '.';
253
+ const resolvedDir = path.resolve(cwd, logDir);
254
+ if (!fs.existsSync(resolvedDir)) {
255
+ try {
256
+ fs.mkdirSync(resolvedDir, {
257
+ recursive: true
258
+ });
259
+ } catch {/* ignore */}
260
+ }
261
+ filePath = path.join(resolvedDir, buildDailyFileName(new Date()));
262
+ };
263
+ return {
264
+ write: (level, args) => {
265
+ try {
266
+ ensureFilePath();
267
+ fs.appendFile(filePath, formatLogLine(level, args), () => {});
268
+ } catch {
269
+ // ignore file logging errors
270
+ }
271
+ }
272
+ };
273
+ };
274
+ const getExpoFileSystem = () => {
275
+ try {
276
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
277
+ return require('expo-file-system/legacy');
278
+ } catch {
279
+ try {
280
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
281
+ return require('expo-file-system');
282
+ } catch {
283
+ return null;
284
+ }
285
+ }
286
+ };
287
+ const getExpoFileSink = () => {
288
+ const FileSystem = getExpoFileSystem();
289
+ if (!FileSystem || typeof FileSystem.writeAsStringAsync !== 'function') return null;
290
+ const baseDir = FileSystem.documentDirectory || FileSystem.cacheDirectory;
291
+ if (!baseDir) return null;
292
+ const encoding = FileSystem.EncodingType?.UTF8 ?? 'utf8';
293
+ const normalizeDir = dir => dir.replace(/\/?$/, '/');
294
+ const logDir = getConfiguredLogDir();
295
+ const subDir = logDir && logDir !== '.' ? logDir.replace(/^\.\/+/, '').replace(/\/+$/, '') : '';
296
+ const basePath = subDir ? `${normalizeDir(baseDir)}${subDir}/` : normalizeDir(baseDir);
297
+ let currentDate = '';
298
+ let fileUri = '';
299
+ let writeChain = Promise.resolve();
300
+ const ensureFileUri = async () => {
301
+ const today = formatLocalDate(new Date());
302
+ if (today === currentDate && fileUri) return;
303
+ currentDate = today;
304
+ fileUri = `${basePath}${buildDailyFileName(new Date())}`;
305
+ if (subDir) {
306
+ try {
307
+ await FileSystem.makeDirectoryAsync(basePath, {
308
+ intermediates: true
309
+ });
310
+ } catch {/* ignore */}
311
+ }
312
+ try {
313
+ const info = await FileSystem.getInfoAsync(fileUri);
314
+ if (!info?.exists) {
315
+ await FileSystem.writeAsStringAsync(fileUri, '', {
316
+ encoding
317
+ });
318
+ }
319
+ } catch {
320
+ try {
321
+ await FileSystem.writeAsStringAsync(fileUri, '', {
322
+ encoding
323
+ });
324
+ } catch {/* ignore */}
325
+ }
326
+ };
327
+ const appendLine = async line => {
328
+ await ensureFileUri();
329
+ try {
330
+ await FileSystem.writeAsStringAsync(fileUri, line, {
331
+ encoding,
332
+ append: true
333
+ });
334
+ return;
335
+ } catch {
336
+ // fall through to read/append fallback
337
+ }
338
+ try {
339
+ const existing = await FileSystem.readAsStringAsync(fileUri, {
340
+ encoding
341
+ });
342
+ await FileSystem.writeAsStringAsync(fileUri, `${existing}${line}`, {
343
+ encoding
344
+ });
345
+ } catch {
346
+ // ignore
347
+ }
348
+ };
349
+ return {
350
+ write: (level, args) => {
351
+ const line = formatLogLine(level, args);
352
+ writeChain = writeChain.then(() => appendLine(line)).catch(() => {});
353
+ }
354
+ };
355
+ };
356
+ const getFileSink = () => {
357
+ if (fileSink !== undefined) return fileSink ?? null;
358
+ if (!isFileLoggingEnabled()) {
359
+ fileSink = null;
360
+ return null;
361
+ }
362
+ const nodeSink = getNodeFileSink();
363
+ if (nodeSink) {
364
+ fileSink = nodeSink;
365
+ return nodeSink;
366
+ }
367
+ const expoSink = getExpoFileSink();
368
+ if (expoSink) {
369
+ fileSink = expoSink;
370
+ return expoSink;
371
+ }
372
+ fileSink = null;
373
+ return null;
374
+ };
375
+
376
+ // Create logger instance based on environment - LAZY LOADING
377
+ let rnLogger = null;
378
+ let winstonLogger = null;
379
+
380
+ // Lazy initialization functions
381
+ const getRnLogger = () => {
382
+ if (rnLogger !== null) return rnLogger;
383
+ if (!isReactNative || !rnLogs) return null;
384
+ try {
385
+ const {
386
+ logger: createLogger
387
+ } = rnLogs;
388
+ const config = {
389
+ severity: currentLevel,
390
+ transport: (msg, level, _options) => {
391
+ const prefix = `[${level.toUpperCase()}]`;
392
+ switch (level) {
393
+ case 'error':
394
+ // eslint-disable-next-line no-console
395
+ console.error(prefix, ...msg);
396
+ break;
397
+ case 'warn':
398
+ // eslint-disable-next-line no-console
399
+ console.warn(prefix, ...msg);
400
+ break;
401
+ case 'info':
402
+ // eslint-disable-next-line no-console
403
+ console.log(prefix, ...msg);
404
+ break;
405
+ case 'debug':
406
+ // eslint-disable-next-line no-console
407
+ console.debug ? console.debug(prefix, ...msg) : console.log(prefix, ...msg);
408
+ break;
409
+ default:
410
+ // eslint-disable-next-line no-console
411
+ console.log(prefix, ...msg);
412
+ }
413
+ },
414
+ transportOptions: {
415
+ colors: {
416
+ error: 'red',
417
+ warn: 'yellow',
418
+ info: 'blue',
419
+ debug: 'gray'
420
+ }
421
+ }
422
+ };
423
+ rnLogger = createLogger(config);
424
+ return rnLogger;
425
+ } catch (e) {
426
+ rnLogger = null;
427
+ return null;
428
+ }
429
+ };
430
+ const getWinstonLogger = () => {
431
+ if (winstonLogger !== null) return winstonLogger;
432
+ if (!isNodeEnvironment) return null;
433
+ const winston = getWinston();
434
+ if (!winston) return null;
435
+ try {
436
+ const {
437
+ createLogger,
438
+ format,
439
+ transports
440
+ } = winston;
441
+ const transportInstances = [new transports.Console({
442
+ level: currentLevel
443
+ })];
444
+ winstonLogger = createLogger({
445
+ level: currentLevel,
446
+ format: format.combine(format.timestamp(), format.errors({
447
+ stack: true
448
+ }), format.splat(), format.json()),
449
+ transports: transportInstances
450
+ });
451
+ return winstonLogger;
452
+ } catch (e) {
453
+ winstonLogger = null;
454
+ return null;
455
+ }
456
+ };
457
+
458
+ // Initialize RN logger immediately if in React Native
459
+ if (isReactNative) {
460
+ getRnLogger();
461
+ }
462
+ function setLogLevel(level) {
463
+ currentLevel = level;
464
+ // Update logger severity if available
465
+ const rnLogger = getRnLogger();
466
+ if (rnLogger && rnLogger.setSeverity) {
467
+ rnLogger.setSeverity(level);
468
+ }
469
+ const winstonLogger = getWinstonLogger();
470
+ if (winstonLogger) {
471
+ winstonLogger.level = level;
472
+ }
473
+ }
474
+ function configureLogger(config = {}) {
475
+ runtimeLoggerConfig = _objectSpread(_objectSpread({}, runtimeLoggerConfig), config);
476
+ if (isValidLogLevel(config.level)) {
477
+ currentLevel = config.level;
478
+ }
479
+ invalidateDerivedLoggerState();
480
+
481
+ // Keep active logger instances aligned with the updated effective level.
482
+ const rnLogger = getRnLogger();
483
+ if (rnLogger && rnLogger.setSeverity) {
484
+ rnLogger.setSeverity(currentLevel);
485
+ }
486
+ const winstonLogger = getWinstonLogger();
487
+ if (winstonLogger) {
488
+ winstonLogger.level = currentLevel;
489
+ }
490
+ }
491
+ function setLoggerTelemetryBridge(bridge) {
492
+ loggerTelemetryBridge = bridge ?? null;
493
+ }
494
+ function levelPriority(l) {
495
+ switch (l) {
496
+ case 'silent':
497
+ return 0;
498
+ case 'error':
499
+ return 1;
500
+ case 'warn':
501
+ return 2;
502
+ case 'info':
503
+ return 3;
504
+ case 'debug':
505
+ return 4;
506
+ default:
507
+ return 3;
508
+ }
509
+ }
510
+
511
+ // Lightweight logger API used across the app
512
+ const logger = exports.logger = {
513
+ error: (...args) => {
514
+ if (levelPriority(currentLevel) >= levelPriority('error')) {
515
+ const rnLogger = getRnLogger();
516
+ if (rnLogger) {
517
+ rnLogger.error(...args);
518
+ } else {
519
+ const winstonLogger = getWinstonLogger();
520
+ if (winstonLogger) {
521
+ winstonLogger.error(...args);
522
+ } else {
523
+ // eslint-disable-next-line no-console
524
+ console.error('[error]', ...args);
525
+ }
526
+ }
527
+ const sink = getFileSink();
528
+ if (sink) sink.write('error', args);
529
+ const remote = getRemoteSink();
530
+ if (remote) remote.write('error', args);
531
+ emitTelemetryBridge("error", args);
532
+ }
533
+ },
534
+ warn: (...args) => {
535
+ if (levelPriority(currentLevel) >= levelPriority('warn')) {
536
+ const rnLogger = getRnLogger();
537
+ if (rnLogger) {
538
+ rnLogger.warn(...args);
539
+ } else {
540
+ const winstonLogger = getWinstonLogger();
541
+ if (winstonLogger) {
542
+ winstonLogger.warn(...args);
543
+ } else {
544
+ // eslint-disable-next-line no-console
545
+ console.warn('[warn]', ...args);
546
+ }
547
+ }
548
+ const sink = getFileSink();
549
+ if (sink) sink.write('warn', args);
550
+ const remote = getRemoteSink();
551
+ if (remote) remote.write('warn', args);
552
+ emitTelemetryBridge("warn", args);
553
+ }
554
+ },
555
+ info: (...args) => {
556
+ if (levelPriority(currentLevel) >= levelPriority('info')) {
557
+ const rnLogger = getRnLogger();
558
+ if (rnLogger) {
559
+ rnLogger.info(...args);
560
+ } else {
561
+ const winstonLogger = getWinstonLogger();
562
+ if (winstonLogger) {
563
+ winstonLogger.info(...args);
564
+ } else {
565
+ // eslint-disable-next-line no-console
566
+ console.log('[info]', ...args);
567
+ }
568
+ }
569
+ const sink = getFileSink();
570
+ if (sink) sink.write('info', args);
571
+ const remote = getRemoteSink();
572
+ if (remote) remote.write('info', args);
573
+ }
574
+ },
575
+ debug: (...args) => {
576
+ if (levelPriority(currentLevel) >= levelPriority('debug')) {
577
+ const rnLogger = getRnLogger();
578
+ if (rnLogger) {
579
+ rnLogger.debug(...args);
580
+ } else {
581
+ const winstonLogger = getWinstonLogger();
582
+ if (winstonLogger) {
583
+ winstonLogger.debug(...args);
584
+ } else {
585
+ // eslint-disable-next-line no-console
586
+ console.debug ? console.debug('[debug]', ...args) : console.log('[debug]', ...args);
587
+ }
588
+ }
589
+ const sink = getFileSink();
590
+ if (sink) sink.write('debug', args);
591
+ const remote = getRemoteSink();
592
+ if (remote) remote.write('debug', args);
593
+ }
594
+ }
595
+ };
596
+ var _default = exports.default = logger;
597
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_reactNative","require","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","_toPropertyKey","value","configurable","writable","i","_toPrimitive","Symbol","toPrimitive","call","TypeError","String","Number","getRuntimeProcess","globalObj","globalThis","process","isNodeEnvironment","Boolean","versions","node","isReactNative","Platform","OS","isWeb","rnLogs","winston","getWinston","winstonModule","eval","getDefaultLogLevel","env","level","REACT_APP_LOG_LEVEL","EXPO_PUBLIC_LOG_LEVEL","LOG_LEVEL","normalized","toLowerCase","includes","currentLevel","runtimeLoggerConfig","loggerTelemetryBridge","pad2","n","padStart","formatLocalDate","date","Date","getFullYear","getMonth","getDate","buildDailyFileName","getEnvConfig","isValidLogLevel","isFileLoggingEnabled","enableFileLogging","raw","REACT_APP_ENABLE_WINSTON_FILE","EXPO_PUBLIC_ENABLE_WINSTON_FILE","REACT_APP_ENABLE_FILE_LOGS","EXPO_PUBLIC_ENABLE_FILE_LOGS","LOG_FILE_ENABLED","undefined","getConfiguredLogDir","logFileDir","trim","REACT_APP_LOG_FILE_DIR","EXPO_PUBLIC_LOG_FILE_DIR","LOG_FILE_DIR","formatLogLine","args","ts","toISOString","serialize","Error","stack","message","JSON","stringify","payload","map","join","toUpperCase","fileSink","remoteSink","getConfiguredRemoteUrl","remoteUrl","REACT_APP_LOG_REMOTE_URL","EXPO_PUBLIC_LOG_REMOTE_URL","LOG_REMOTE_URL","getConfiguredRemoteToken","remoteToken","REACT_APP_LOG_INGEST_TOKEN","EXPO_PUBLIC_LOG_INGEST_TOKEN","LOG_INGEST_TOKEN","isRemoteLoggingEnabled","remoteEnabled","REACT_APP_ENABLE_REMOTE_LOGS","EXPO_PUBLIC_ENABLE_REMOTE_LOGS","LOG_REMOTE_ENABLED","serializeArgForJson","name","parse","buildRemotePayload","normalizedArgs","arg","firstArg","timestamp","source","runtime","buildTelemetryMessage","Array","isArray","first","emitTelemetryBridge","errorArg","find","context","captureException","captureMessage","getRemoteSink","fetch","url","token","sendChain","Promise","resolve","sendOne","headers","method","body","write","then","catch","invalidateDerivedLoggerState","getNodeFileSink","fs","path","currentDate","filePath","ensureFilePath","today","logDir","cwd","resolvedDir","existsSync","mkdirSync","recursive","appendFile","getExpoFileSystem","getExpoFileSink","FileSystem","writeAsStringAsync","baseDir","documentDirectory","cacheDirectory","encoding","EncodingType","UTF8","normalizeDir","dir","replace","subDir","basePath","fileUri","writeChain","ensureFileUri","makeDirectoryAsync","intermediates","info","getInfoAsync","exists","appendLine","line","append","existing","readAsStringAsync","getFileSink","nodeSink","expoSink","rnLogger","winstonLogger","getRnLogger","logger","createLogger","config","severity","transport","msg","_options","prefix","console","error","warn","log","debug","transportOptions","colors","getWinstonLogger","format","transports","transportInstances","Console","combine","errors","splat","json","setLogLevel","setSeverity","configureLogger","setLoggerTelemetryBridge","bridge","levelPriority","l","exports","sink","remote","_default","default"],"sources":["../src/logger.ts"],"sourcesContent":["// Environment-aware logger utility\n// Uses react-native-logs for React Native, winston for Node.js/web, console as fallback\n\nimport { Platform } from 'react-native';\n\n// Determine environment first\n// Treat Node as its own runtime even if react-native Platform.OS is ios/android in tests\nconst getRuntimeProcess = (): {\n  versions?: { node?: string };\n  env?: Record<string, string | undefined>;\n  cwd?: () => string;\n} | null => {\n  const globalObj = globalThis as any;\n  return globalObj?.process ?? null;\n};\n\nconst isNodeEnvironment = Boolean(getRuntimeProcess()?.versions?.node);\nconst isReactNative = Platform.OS !== 'web' && !isNodeEnvironment;\nconst isWeb = Platform.OS === 'web';\n\n// Try to require libraries based on environment\nlet rnLogs: any = null;\nlet winston: any = null;\n\n// Only try to require react-native-logs in React Native environments\nif (isReactNative) {\n  try {\n    // eslint-disable-next-line @typescript-eslint/no-var-requires\n    rnLogs = require('react-native-logs');\n  } catch (e) {\n    rnLogs = null;\n  }\n}\n\n// For winston, use runtime detection without static requires\nconst getWinston = () => {\n  if (winston !== null) return winston;\n  if (!isNodeEnvironment) return null;\n\n  try {\n    // Use eval to dynamically construct the require call\n    // This prevents static analysis from finding 'winston' in require()\n    const winstonModule = eval('require')('winston');\n    winston = winstonModule;\n    return winston;\n  } catch (e) {\n    winston = null;\n    return null;\n  }\n};\n\nexport type LogLevel = 'error' | 'warn' | 'info' | 'debug' | 'silent';\nexport type LoggerRuntimeConfig = {\n  level?: LogLevel;\n  enableFileLogging?: boolean;\n  logFileDir?: string;\n  remoteEnabled?: boolean;\n  remoteUrl?: string;\n  remoteToken?: string;\n};\n\nexport type LoggerTelemetryBridge = {\n  captureException?: (error: Error, context?: Record<string, unknown>) => void;\n  captureMessage?: (\n    message: string,\n    level?: \"error\" | \"warn\" | \"info\" | \"debug\",\n    context?: Record<string, unknown>\n  ) => void;\n};\n\n// Read desired log level from env/config\nfunction getDefaultLogLevel(): LogLevel {\n  const env = getRuntimeProcess()?.env ?? {};\n  const level = env.REACT_APP_LOG_LEVEL || env.EXPO_PUBLIC_LOG_LEVEL || env.LOG_LEVEL;\n  if (!level) return (isNodeEnvironment || isWeb) ? 'info' : 'warn';\n  const normalized = level.toLowerCase();\n  if (['error', 'warn', 'info', 'debug', 'silent'].includes(normalized)) {\n    return normalized as LogLevel;\n  }\n  return 'info';\n}\n\nlet currentLevel: LogLevel = getDefaultLogLevel();\nlet runtimeLoggerConfig: LoggerRuntimeConfig = {};\nlet loggerTelemetryBridge: LoggerTelemetryBridge | null = null;\n\nconst pad2 = (n: number) => String(n).padStart(2, '0');\nconst formatLocalDate = (date = new Date()) =>\n  `${date.getFullYear()}-${pad2(date.getMonth() + 1)}-${pad2(date.getDate())}`;\nconst buildDailyFileName = (date = new Date()) => `logs-${formatLocalDate(date)}.log`;\n\nconst getEnvConfig = () => {\n  return getRuntimeProcess()?.env ?? {};\n};\n\nconst isValidLogLevel = (level: unknown): level is LogLevel => {\n  return typeof level === 'string' && ['error', 'warn', 'info', 'debug', 'silent'].includes(level);\n};\n\nconst isFileLoggingEnabled = () => {\n  if (typeof runtimeLoggerConfig.enableFileLogging === 'boolean') {\n    return runtimeLoggerConfig.enableFileLogging;\n  }\n  const env = getEnvConfig();\n  const raw =\n    env.REACT_APP_ENABLE_WINSTON_FILE ||\n    env.EXPO_PUBLIC_ENABLE_WINSTON_FILE ||\n    env.REACT_APP_ENABLE_FILE_LOGS ||\n    env.EXPO_PUBLIC_ENABLE_FILE_LOGS ||\n    env.LOG_FILE_ENABLED;\n  if (raw === undefined) return true;\n  return raw === 'true' || raw === '1';\n};\n\nconst getConfiguredLogDir = () => {\n  if (runtimeLoggerConfig.logFileDir && runtimeLoggerConfig.logFileDir.trim()) {\n    return runtimeLoggerConfig.logFileDir;\n  }\n  const env = getEnvConfig();\n  return env.REACT_APP_LOG_FILE_DIR || env.EXPO_PUBLIC_LOG_FILE_DIR || env.LOG_FILE_DIR || '.';\n};\n\nconst formatLogLine = (level: LogLevel, args: any[]) => {\n  const ts = new Date().toISOString();\n  const serialize = (value: any) => {\n    if (value instanceof Error) {\n      const stack = value.stack ? `\\n${value.stack}` : '';\n      return `${value.message}${stack}`;\n    }\n    if (typeof value === 'string') return value;\n    try {\n      return JSON.stringify(value);\n    } catch {\n      return String(value);\n    }\n  };\n  const payload = args.map(serialize).join(' ');\n  return `${ts} [${level.toUpperCase()}] ${payload}\\n`;\n};\n\ntype FileSink = { write: (level: LogLevel, args: any[]) => void };\nlet fileSink: FileSink | null | undefined = undefined;\ntype RemoteSink = { write: (level: LogLevel, args: any[]) => void };\nlet remoteSink: RemoteSink | null | undefined = undefined;\n\nconst getConfiguredRemoteUrl = () => {\n  if (runtimeLoggerConfig.remoteUrl && runtimeLoggerConfig.remoteUrl.trim()) {\n    return runtimeLoggerConfig.remoteUrl;\n  }\n  const env = getEnvConfig();\n  return env.REACT_APP_LOG_REMOTE_URL || env.EXPO_PUBLIC_LOG_REMOTE_URL || env.LOG_REMOTE_URL || '';\n};\n\nconst getConfiguredRemoteToken = () => {\n  if (runtimeLoggerConfig.remoteToken && runtimeLoggerConfig.remoteToken.trim()) {\n    return runtimeLoggerConfig.remoteToken;\n  }\n  const env = getEnvConfig();\n  return env.REACT_APP_LOG_INGEST_TOKEN || env.EXPO_PUBLIC_LOG_INGEST_TOKEN || env.LOG_INGEST_TOKEN || '';\n};\n\nconst isRemoteLoggingEnabled = () => {\n  if (typeof runtimeLoggerConfig.remoteEnabled === 'boolean') {\n    return runtimeLoggerConfig.remoteEnabled && Boolean(getConfiguredRemoteUrl());\n  }\n  const remoteUrl = getConfiguredRemoteUrl();\n  if (!remoteUrl) return false;\n  const env = getEnvConfig();\n  const raw =\n    env.REACT_APP_ENABLE_REMOTE_LOGS ||\n    env.EXPO_PUBLIC_ENABLE_REMOTE_LOGS ||\n    env.LOG_REMOTE_ENABLED;\n  if (raw === undefined) return true;\n  return raw === 'true' || raw === '1';\n};\n\nconst serializeArgForJson = (value: any): any => {\n  if (value instanceof Error) {\n    return {\n      name: value.name,\n      message: value.message,\n      stack: value.stack,\n    };\n  }\n  if (value === null || value === undefined) return value;\n  if (typeof value === 'string' || typeof value === 'number' || typeof value === 'boolean') return value;\n  try {\n    return JSON.parse(JSON.stringify(value));\n  } catch {\n    return String(value);\n  }\n};\n\nconst buildRemotePayload = (level: LogLevel, args: any[]) => {\n  const normalizedArgs = args.map((arg) => serializeArgForJson(arg));\n  const firstArg = normalizedArgs[0];\n  const message =\n    typeof firstArg === 'string'\n      ? firstArg\n      : normalizedArgs.map((arg) => (typeof arg === 'string' ? arg : JSON.stringify(arg))).join(' ');\n\n  return {\n    timestamp: new Date().toISOString(),\n    level,\n    message: message || '[empty]',\n    source: isWeb ? 'web' : 'mobile',\n    runtime: isNodeEnvironment ? 'node' : 'client',\n    args: normalizedArgs,\n  };\n};\n\nconst buildTelemetryMessage = (args: any[]): string => {\n  if (!Array.isArray(args) || args.length === 0) return \"[empty]\";\n  const [first] = args;\n  if (typeof first === \"string\" && first.trim()) return first;\n  return args\n    .map((arg) => {\n      if (arg instanceof Error) return arg.message;\n      if (typeof arg === \"string\") return arg;\n      try {\n        return JSON.stringify(arg);\n      } catch {\n        return String(arg);\n      }\n    })\n    .join(\" \")\n    .trim() || \"[empty]\";\n};\n\nconst emitTelemetryBridge = (\n  level: \"error\" | \"warn\" | \"info\" | \"debug\",\n  args: any[]\n) => {\n  if (!loggerTelemetryBridge) return;\n\n  const errorArg = args.find((arg) => arg instanceof Error) as Error | undefined;\n  const context = { level, runtime: isNodeEnvironment ? \"node\" : isWeb ? \"web\" : \"native\" };\n\n  if (errorArg && typeof loggerTelemetryBridge.captureException === \"function\") {\n    loggerTelemetryBridge.captureException(errorArg, context);\n    return;\n  }\n\n  if (typeof loggerTelemetryBridge.captureMessage === \"function\") {\n    loggerTelemetryBridge.captureMessage(buildTelemetryMessage(args), level, context);\n  }\n};\n\nconst getRemoteSink = (): RemoteSink | null => {\n  if (remoteSink !== undefined) return remoteSink ?? null;\n  if (!isRemoteLoggingEnabled()) {\n    remoteSink = null;\n    return null;\n  }\n  if (typeof fetch !== 'function') {\n    remoteSink = null;\n    return null;\n  }\n\n  const url = getConfiguredRemoteUrl();\n  const token = getConfiguredRemoteToken();\n  let sendChain = Promise.resolve();\n\n  const sendOne = async (level: LogLevel, args: any[]) => {\n    const headers: Record<string, string> = {\n      'content-type': 'application/json',\n    };\n    if (token) {\n      headers['x-log-token'] = token;\n    }\n\n    const payload = buildRemotePayload(level, args);\n    await fetch(url, {\n      method: 'POST',\n      headers,\n      body: JSON.stringify(payload),\n    });\n  };\n\n  remoteSink = {\n    write: (level, args) => {\n      sendChain = sendChain.then(() => sendOne(level, args)).catch(() => {});\n    },\n  };\n  return remoteSink;\n};\n\nconst invalidateDerivedLoggerState = () => {\n  fileSink = undefined;\n  remoteSink = undefined;\n};\n\nconst getNodeFileSink = (): FileSink | null => {\n  if (!isNodeEnvironment) return null;\n  let fs: any = null;\n  let path: any = null;\n  try {\n    fs = eval('require')('fs');\n    path = eval('require')('path');\n  } catch {\n    return null;\n  }\n\n  let currentDate = '';\n  let filePath = '';\n  const ensureFilePath = () => {\n    const today = formatLocalDate(new Date());\n    if (today === currentDate && filePath) return;\n    currentDate = today;\n    const logDir = getConfiguredLogDir() || '.';\n    const cwd = getRuntimeProcess()?.cwd?.() ?? '.';\n    const resolvedDir = path.resolve(cwd, logDir);\n    if (!fs.existsSync(resolvedDir)) {\n      try { fs.mkdirSync(resolvedDir, { recursive: true }); } catch { /* ignore */ }\n    }\n    filePath = path.join(resolvedDir, buildDailyFileName(new Date()));\n  };\n\n  return {\n    write: (level, args) => {\n      try {\n        ensureFilePath();\n        fs.appendFile(filePath, formatLogLine(level, args), () => {});\n      } catch {\n        // ignore file logging errors\n      }\n    },\n  };\n};\n\nconst getExpoFileSystem = () => {\n  try {\n    // eslint-disable-next-line @typescript-eslint/no-var-requires\n    return require('expo-file-system/legacy');\n  } catch {\n    try {\n      // eslint-disable-next-line @typescript-eslint/no-var-requires\n      return require('expo-file-system');\n    } catch {\n      return null;\n    }\n  }\n};\n\nconst getExpoFileSink = (): FileSink | null => {\n  const FileSystem = getExpoFileSystem();\n  if (!FileSystem || typeof FileSystem.writeAsStringAsync !== 'function') return null;\n\n  const baseDir = FileSystem.documentDirectory || FileSystem.cacheDirectory;\n  if (!baseDir) return null;\n  const encoding = FileSystem.EncodingType?.UTF8 ?? 'utf8';\n\n  const normalizeDir = (dir: string) => dir.replace(/\\/?$/, '/');\n  const logDir = getConfiguredLogDir();\n  const subDir = logDir && logDir !== '.' ? logDir.replace(/^\\.\\/+/, '').replace(/\\/+$/, '') : '';\n  const basePath = subDir ? `${normalizeDir(baseDir)}${subDir}/` : normalizeDir(baseDir);\n\n  let currentDate = '';\n  let fileUri = '';\n  let writeChain = Promise.resolve();\n\n  const ensureFileUri = async () => {\n    const today = formatLocalDate(new Date());\n    if (today === currentDate && fileUri) return;\n    currentDate = today;\n    fileUri = `${basePath}${buildDailyFileName(new Date())}`;\n    if (subDir) {\n      try { await FileSystem.makeDirectoryAsync(basePath, { intermediates: true }); } catch { /* ignore */ }\n    }\n    try {\n      const info = await FileSystem.getInfoAsync(fileUri);\n      if (!info?.exists) {\n        await FileSystem.writeAsStringAsync(fileUri, '', { encoding });\n      }\n    } catch {\n      try { await FileSystem.writeAsStringAsync(fileUri, '', { encoding }); } catch { /* ignore */ }\n    }\n  };\n\n  const appendLine = async (line: string) => {\n    await ensureFileUri();\n    try {\n      await FileSystem.writeAsStringAsync(fileUri, line, {\n        encoding,\n        append: true,\n      });\n      return;\n    } catch {\n      // fall through to read/append fallback\n    }\n    try {\n      const existing = await FileSystem.readAsStringAsync(fileUri, { encoding });\n      await FileSystem.writeAsStringAsync(fileUri, `${existing}${line}`, { encoding });\n    } catch {\n      // ignore\n    }\n  };\n\n  return {\n    write: (level, args) => {\n      const line = formatLogLine(level, args);\n      writeChain = writeChain.then(() => appendLine(line)).catch(() => {});\n    },\n  };\n};\n\nconst getFileSink = (): FileSink | null => {\n  if (fileSink !== undefined) return fileSink ?? null;\n  if (!isFileLoggingEnabled()) {\n    fileSink = null;\n    return null;\n  }\n  const nodeSink = getNodeFileSink();\n  if (nodeSink) {\n    fileSink = nodeSink;\n    return nodeSink;\n  }\n  const expoSink = getExpoFileSink();\n  if (expoSink) {\n    fileSink = expoSink;\n    return expoSink;\n  }\n  fileSink = null;\n  return null;\n};\n\n// Create logger instance based on environment - LAZY LOADING\nlet rnLogger: any = null;\nlet winstonLogger: any = null;\n\n// Lazy initialization functions\nconst getRnLogger = () => {\n  if (rnLogger !== null) return rnLogger;\n  if (!isReactNative || !rnLogs) return null;\n\n  try {\n    const { logger: createLogger } = rnLogs;\n\n    const config = {\n      severity: currentLevel,\n      transport: (msg: any, level: string, _options: any) => {\n        const prefix = `[${level.toUpperCase()}]`;\n        switch (level) {\n          case 'error':\n            // eslint-disable-next-line no-console\n            console.error(prefix, ...msg);\n            break;\n          case 'warn':\n            // eslint-disable-next-line no-console\n            console.warn(prefix, ...msg);\n            break;\n          case 'info':\n            // eslint-disable-next-line no-console\n            console.log(prefix, ...msg);\n            break;\n          case 'debug':\n            // eslint-disable-next-line no-console\n            console.debug ? console.debug(prefix, ...msg) : console.log(prefix, ...msg);\n            break;\n          default:\n            // eslint-disable-next-line no-console\n            console.log(prefix, ...msg);\n        }\n      },\n      transportOptions: {\n        colors: {\n          error: 'red',\n          warn: 'yellow',\n          info: 'blue',\n          debug: 'gray',\n        },\n      },\n    };\n\n    rnLogger = createLogger(config);\n    return rnLogger;\n  } catch (e) {\n    rnLogger = null;\n    return null;\n  }\n};\n\nconst getWinstonLogger = () => {\n  if (winstonLogger !== null) return winstonLogger;\n  if (!isNodeEnvironment) return null;\n\n  const winston = getWinston();\n  if (!winston) return null;\n\n  try {\n    const { createLogger, format, transports } = winston;\n    const transportInstances: any[] = [new transports.Console({ level: currentLevel })];\n\n    winstonLogger = createLogger({\n      level: currentLevel,\n      format: format.combine(\n        format.timestamp(),\n        format.errors({ stack: true }),\n        format.splat(),\n        format.json()\n      ),\n      transports: transportInstances,\n    });\n    return winstonLogger;\n  } catch (e) {\n    winstonLogger = null;\n    return null;\n  }\n};\n\n// Initialize RN logger immediately if in React Native\nif (isReactNative) {\n  getRnLogger();\n}\n\nexport function setLogLevel(level: LogLevel) {\n  currentLevel = level;\n  // Update logger severity if available\n  const rnLogger = getRnLogger();\n  if (rnLogger && rnLogger.setSeverity) {\n    rnLogger.setSeverity(level);\n  }\n  const winstonLogger = getWinstonLogger();\n  if (winstonLogger) {\n    winstonLogger.level = level;\n  }\n}\n\nexport function configureLogger(config: LoggerRuntimeConfig = {}) {\n  runtimeLoggerConfig = {\n    ...runtimeLoggerConfig,\n    ...config,\n  };\n\n  if (isValidLogLevel(config.level)) {\n    currentLevel = config.level;\n  }\n\n  invalidateDerivedLoggerState();\n\n  // Keep active logger instances aligned with the updated effective level.\n  const rnLogger = getRnLogger();\n  if (rnLogger && rnLogger.setSeverity) {\n    rnLogger.setSeverity(currentLevel);\n  }\n  const winstonLogger = getWinstonLogger();\n  if (winstonLogger) {\n    winstonLogger.level = currentLevel;\n  }\n}\n\nexport function setLoggerTelemetryBridge(bridge?: LoggerTelemetryBridge | null) {\n  loggerTelemetryBridge = bridge ?? null;\n}\n\nfunction levelPriority(l: LogLevel) {\n  switch (l) {\n    case 'silent': return 0;\n    case 'error': return 1;\n    case 'warn': return 2;\n    case 'info': return 3;\n    case 'debug': return 4;\n    default: return 3;\n  }\n}\n\n// Lightweight logger API used across the app\nexport const logger = {\n  error: (...args: any[]) => {\n    if (levelPriority(currentLevel) >= levelPriority('error')) {\n      const rnLogger = getRnLogger();\n      if (rnLogger) {\n        rnLogger.error(...args);\n      } else {\n        const winstonLogger = getWinstonLogger();\n        if (winstonLogger) {\n          winstonLogger.error(...args);\n        } else {\n          // eslint-disable-next-line no-console\n          console.error('[error]', ...args);\n        }\n      }\n      const sink = getFileSink();\n      if (sink) sink.write('error', args);\n      const remote = getRemoteSink();\n      if (remote) remote.write('error', args);\n      emitTelemetryBridge(\"error\", args);\n    }\n  },\n  warn: (...args: any[]) => {\n    if (levelPriority(currentLevel) >= levelPriority('warn')) {\n      const rnLogger = getRnLogger();\n      if (rnLogger) {\n        rnLogger.warn(...args);\n      } else {\n        const winstonLogger = getWinstonLogger();\n        if (winstonLogger) {\n          winstonLogger.warn(...args);\n        } else {\n          // eslint-disable-next-line no-console\n          console.warn('[warn]', ...args);\n        }\n      }\n      const sink = getFileSink();\n      if (sink) sink.write('warn', args);\n      const remote = getRemoteSink();\n      if (remote) remote.write('warn', args);\n      emitTelemetryBridge(\"warn\", args);\n    }\n  },\n  info: (...args: any[]) => {\n    if (levelPriority(currentLevel) >= levelPriority('info')) {\n      const rnLogger = getRnLogger();\n      if (rnLogger) {\n        rnLogger.info(...args);\n      } else {\n        const winstonLogger = getWinstonLogger();\n        if (winstonLogger) {\n          winstonLogger.info(...args);\n        } else {\n          // eslint-disable-next-line no-console\n          console.log('[info]', ...args);\n        }\n      }\n      const sink = getFileSink();\n      if (sink) sink.write('info', args);\n      const remote = getRemoteSink();\n      if (remote) remote.write('info', args);\n    }\n  },\n  debug: (...args: any[]) => {\n    if (levelPriority(currentLevel) >= levelPriority('debug')) {\n      const rnLogger = getRnLogger();\n      if (rnLogger) {\n        rnLogger.debug(...args);\n      } else {\n        const winstonLogger = getWinstonLogger();\n        if (winstonLogger) {\n          winstonLogger.debug(...args);\n        } else {\n          // eslint-disable-next-line no-console\n          console.debug ? console.debug('[debug]', ...args) : console.log('[debug]', ...args);\n        }\n      }\n      const sink = getFileSink();\n      if (sink) sink.write('debug', args);\n      const remote = getRemoteSink();\n      if (remote) remote.write('debug', args);\n    }\n  }\n};\n\nexport default logger;\n"],"mappings":"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","ignoreList":[]}