@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.
- package/.env.example +22 -0
- package/.github/workflows/publish.yml +20 -0
- package/LICENSE.txt +201 -0
- package/README.md +621 -0
- package/babel.config.js +29 -0
- package/dist/adapters/__tests__/expo-router-adapter.test.d.ts +1 -0
- package/dist/adapters/expo-router-adapter.d.ts +16 -0
- package/dist/adapters/expo-router-adapter.js +521 -0
- package/dist/adapters/navigation-adapter.d.ts +20 -0
- package/dist/adapters/navigation-adapter.js +137 -0
- package/dist/audio-visualizer.d.ts +14 -0
- package/dist/audio-visualizer.js +123 -0
- package/dist/current-selection.d.ts +27 -0
- package/dist/current-selection.js +94 -0
- package/dist/errors.d.ts +19 -0
- package/dist/errors.js +37 -0
- package/dist/genie/DateTime.d.ts +66 -0
- package/dist/genie/DateTime.js +399 -0
- package/dist/genie/TimeDelta.d.ts +35 -0
- package/dist/genie/TimeDelta.js +169 -0
- package/dist/genie-view-wrapper.d.ts +1 -0
- package/dist/genie-view-wrapper.js +377 -0
- package/dist/hooks/__tests__/useSpeechRecognition.test.d.ts +1 -0
- package/dist/hooks/useSpeechRecognition.d.ts +28 -0
- package/dist/hooks/useSpeechRecognition.js +118 -0
- package/dist/index.d.ts +30 -0
- package/dist/index.js +469 -0
- package/dist/logger.d.ts +23 -0
- package/dist/logger.js +597 -0
- package/dist/logger.remote.test.d.ts +0 -0
- package/dist/modality-provider-v2.d.ts +28 -0
- package/dist/modality-provider-v2.js +1321 -0
- package/dist/modality-provider.d.ts +22 -0
- package/dist/modality-provider.js +373 -0
- package/dist/native-visibility.d.ts +28 -0
- package/dist/native-visibility.js +50 -0
- package/dist/platform/VoiceRecognitionBar.d.ts +17 -0
- package/dist/platform/VoiceRecognitionBar.js +332 -0
- package/dist/platform/components.d.ts +32 -0
- package/dist/platform/components.js +351 -0
- package/dist/platform/events.d.ts +31 -0
- package/dist/platform/events.js +274 -0
- package/dist/platform/index.d.ts +3 -0
- package/dist/platform/index.js +39 -0
- package/dist/platform/types.d.ts +79 -0
- package/dist/platform/types.js +97 -0
- package/dist/react-decorators.d.ts +87 -0
- package/dist/react-decorators.js +368 -0
- package/dist/shared-store.d.ts +74 -0
- package/dist/shared-store.js +589 -0
- package/dist/speech-recognition/__tests__/speech-recognition-groq-transport.test.d.ts +1 -0
- package/dist/speech-recognition/__tests__/speech-recognition-native.test.d.ts +1 -0
- package/dist/speech-recognition/__tests__/speech-recognition-openai-native.test.d.ts +1 -0
- package/dist/speech-recognition/__tests__/speech-recognition-openai.test.d.ts +1 -0
- package/dist/speech-recognition/__tests__/speech-recognition-unified-import.test.d.ts +0 -0
- package/dist/speech-recognition/__tests__/speech-recognition-unified.test.d.ts +1 -0
- package/dist/speech-recognition/speech-recognition-groq.d.ts +21 -0
- package/dist/speech-recognition/speech-recognition-groq.js +409 -0
- package/dist/speech-recognition/speech-recognition-mlx.d.ts +15 -0
- package/dist/speech-recognition/speech-recognition-mlx.js +393 -0
- package/dist/speech-recognition/speech-recognition-native.d.ts +24 -0
- package/dist/speech-recognition/speech-recognition-native.js +632 -0
- package/dist/speech-recognition/speech-recognition-openai-native.d.ts +40 -0
- package/dist/speech-recognition/speech-recognition-openai-native.js +653 -0
- package/dist/speech-recognition/speech-recognition-openai.d.ts +39 -0
- package/dist/speech-recognition/speech-recognition-openai.js +718 -0
- package/dist/speech-recognition/speech-recognition-unified.d.ts +93 -0
- package/dist/speech-recognition/speech-recognition-unified.js +589 -0
- package/dist/speech-recognition/utils/groq-transcription.d.ts +41 -0
- package/dist/speech-recognition/utils/groq-transcription.js +382 -0
- package/dist/speech-recognition.d.ts +7 -0
- package/dist/speech-recognition.js +61 -0
- package/dist/voice-pipeline-telemetry.d.ts +26 -0
- package/dist/voice-pipeline-telemetry.js +15 -0
- package/garrix82-reactgenie-lib-1.3.0.tgz +0 -0
- package/metro/index.js +3 -0
- package/metro/with-genie-registry.js +47 -0
- package/package.json +111 -0
- package/scripts/dry-run.js +23 -0
- package/scripts/generate-genie-registry.js +278 -0
- package/scripts/log-file-test.js +51 -0
- package/scripts/parse.js +26 -0
- package/scripts/prompt.js +19 -0
- package/scripts/set-script.js +200 -0
- 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":";;;;;;;;;AAGA,IAAAA,YAAA,GAAAC,OAAA;AAAwC,SAAAC,QAAAC,CAAA,EAAAC,CAAA,QAAAC,CAAA,GAAAC,MAAA,CAAAC,IAAA,CAAAJ,CAAA,OAAAG,MAAA,CAAAE,qBAAA,QAAAC,CAAA,GAAAH,MAAA,CAAAE,qBAAA,CAAAL,CAAA,GAAAC,CAAA,KAAAK,CAAA,GAAAA,CAAA,CAAAC,MAAA,WAAAN,CAAA,WAAAE,MAAA,CAAAK,wBAAA,CAAAR,CAAA,EAAAC,CAAA,EAAAQ,UAAA,OAAAP,CAAA,CAAAQ,IAAA,CAAAC,KAAA,CAAAT,CAAA,EAAAI,CAAA,YAAAJ,CAAA;AAAA,SAAAU,cAAAZ,CAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAY,SAAA,CAAAC,MAAA,EAAAb,CAAA,UAAAC,CAAA,WAAAW,SAAA,CAAAZ,CAAA,IAAAY,SAAA,CAAAZ,CAAA,QAAAA,CAAA,OAAAF,OAAA,CAAAI,MAAA,CAAAD,CAAA,OAAAa,OAAA,WAAAd,CAAA,IAAAe,eAAA,CAAAhB,CAAA,EAAAC,CAAA,EAAAC,CAAA,CAAAD,CAAA,SAAAE,MAAA,CAAAc,yBAAA,GAAAd,MAAA,CAAAe,gBAAA,CAAAlB,CAAA,EAAAG,MAAA,CAAAc,yBAAA,CAAAf,CAAA,KAAAH,OAAA,CAAAI,MAAA,CAAAD,CAAA,GAAAa,OAAA,WAAAd,CAAA,IAAAE,MAAA,CAAAgB,cAAA,CAAAnB,CAAA,EAAAC,CAAA,EAAAE,MAAA,CAAAK,wBAAA,CAAAN,CAAA,EAAAD,CAAA,iBAAAD,CAAA;AAAA,SAAAgB,gBAAAhB,CAAA,EAAAC,CAAA,EAAAC,CAAA,YAAAD,CAAA,GAAAmB,cAAA,CAAAnB,CAAA,MAAAD,CAAA,GAAAG,MAAA,CAAAgB,cAAA,CAAAnB,CAAA,EAAAC,CAAA,IAAAoB,KAAA,EAAAnB,CAAA,EAAAO,UAAA,MAAAa,YAAA,MAAAC,QAAA,UAAAvB,CAAA,CAAAC,CAAA,IAAAC,CAAA,EAAAF,CAAA;AAAA,SAAAoB,eAAAlB,CAAA,QAAAsB,CAAA,GAAAC,YAAA,CAAAvB,CAAA,uCAAAsB,CAAA,GAAAA,CAAA,GAAAA,CAAA;AAAA,SAAAC,aAAAvB,CAAA,EAAAD,CAAA,2BAAAC,CAAA,KAAAA,CAAA,SAAAA,CAAA,MAAAF,CAAA,GAAAE,CAAA,CAAAwB,MAAA,CAAAC,WAAA,kBAAA3B,CAAA,QAAAwB,CAAA,GAAAxB,CAAA,CAAA4B,IAAA,CAAA1B,CAAA,EAAAD,CAAA,uCAAAuB,CAAA,SAAAA,CAAA,YAAAK,SAAA,yEAAA5B,CAAA,GAAA6B,MAAA,GAAAC,MAAA,EAAA7B,CAAA,KAHxC;AACA;AAIA;AACA;AACA,MAAM8B,iBAAiB,GAAGA,CAAA,KAId;EACV,MAAMC,SAAS,GAAGC,UAAiB;EACnC,OAAOD,SAAS,EAAEE,OAAO,IAAI,IAAI;AACnC,CAAC;AAED,MAAMC,iBAAiB,GAAGC,OAAO,CAACL,iBAAiB,CAAC,CAAC,EAAEM,QAAQ,EAAEC,IAAI,CAAC;AACtE,MAAMC,aAAa,GAAGC,qBAAQ,CAACC,EAAE,KAAK,KAAK,IAAI,CAACN,iBAAiB;AACjE,MAAMO,KAAK,GAAGF,qBAAQ,CAACC,EAAE,KAAK,KAAK;;AAEnC;AACA,IAAIE,MAAW,GAAG,IAAI;AACtB,IAAIC,OAAY,GAAG,IAAI;;AAEvB;AACA,IAAIL,aAAa,EAAE;EACjB,IAAI;IACF;IACAI,MAAM,GAAG9C,OAAO,CAAC,mBAAmB,CAAC;EACvC,CAAC,CAAC,OAAOE,CAAC,EAAE;IACV4C,MAAM,GAAG,IAAI;EACf;AACF;;AAEA;AACA,MAAME,UAAU,GAAGA,CAAA,KAAM;EACvB,IAAID,OAAO,KAAK,IAAI,EAAE,OAAOA,OAAO;EACpC,IAAI,CAACT,iBAAiB,EAAE,OAAO,IAAI;EAEnC,IAAI;IACF;IACA;IACA,MAAMW,aAAa,GAAGC,IAAI,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC;IAChDH,OAAO,GAAGE,aAAa;IACvB,OAAOF,OAAO;EAChB,CAAC,CAAC,OAAO7C,CAAC,EAAE;IACV6C,OAAO,GAAG,IAAI;IACd,OAAO,IAAI;EACb;AACF,CAAC;AAqBD;AACA,SAASI,kBAAkBA,CAAA,EAAa;EACtC,MAAMC,GAAG,GAAGlB,iBAAiB,CAAC,CAAC,EAAEkB,GAAG,IAAI,CAAC,CAAC;EAC1C,MAAMC,KAAK,GAAGD,GAAG,CAACE,mBAAmB,IAAIF,GAAG,CAACG,qBAAqB,IAAIH,GAAG,CAACI,SAAS;EACnF,IAAI,CAACH,KAAK,EAAE,OAAQf,iBAAiB,IAAIO,KAAK,GAAI,MAAM,GAAG,MAAM;EACjE,MAAMY,UAAU,GAAGJ,KAAK,CAACK,WAAW,CAAC,CAAC;EACtC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,CAACC,QAAQ,CAACF,UAAU,CAAC,EAAE;IACrE,OAAOA,UAAU;EACnB;EACA,OAAO,MAAM;AACf;AAEA,IAAIG,YAAsB,GAAGT,kBAAkB,CAAC,CAAC;AACjD,IAAIU,mBAAwC,GAAG,CAAC,CAAC;AACjD,IAAIC,qBAAmD,GAAG,IAAI;AAE9D,MAAMC,IAAI,GAAIC,CAAS,IAAKhC,MAAM,CAACgC,CAAC,CAAC,CAACC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC;AACtD,MAAMC,eAAe,GAAGA,CAACC,IAAI,GAAG,IAAIC,IAAI,CAAC,CAAC,KACxC,GAAGD,IAAI,CAACE,WAAW,CAAC,CAAC,IAAIN,IAAI,CAACI,IAAI,CAACG,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,IAAIP,IAAI,CAACI,IAAI,CAACI,OAAO,CAAC,CAAC,CAAC,EAAE;AAC9E,MAAMC,kBAAkB,GAAGA,CAACL,IAAI,GAAG,IAAIC,IAAI,CAAC,CAAC,KAAK,QAAQF,eAAe,CAACC,IAAI,CAAC,MAAM;AAErF,MAAMM,YAAY,GAAGA,CAAA,KAAM;EACzB,OAAOvC,iBAAiB,CAAC,CAAC,EAAEkB,GAAG,IAAI,CAAC,CAAC;AACvC,CAAC;AAED,MAAMsB,eAAe,GAAIrB,KAAc,IAAwB;EAC7D,OAAO,OAAOA,KAAK,KAAK,QAAQ,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,CAACM,QAAQ,CAACN,KAAK,CAAC;AAClG,CAAC;AAED,MAAMsB,oBAAoB,GAAGA,CAAA,KAAM;EACjC,IAAI,OAAOd,mBAAmB,CAACe,iBAAiB,KAAK,SAAS,EAAE;IAC9D,OAAOf,mBAAmB,CAACe,iBAAiB;EAC9C;EACA,MAAMxB,GAAG,GAAGqB,YAAY,CAAC,CAAC;EAC1B,MAAMI,GAAG,GACPzB,GAAG,CAAC0B,6BAA6B,IACjC1B,GAAG,CAAC2B,+BAA+B,IACnC3B,GAAG,CAAC4B,0BAA0B,IAC9B5B,GAAG,CAAC6B,4BAA4B,IAChC7B,GAAG,CAAC8B,gBAAgB;EACtB,IAAIL,GAAG,KAAKM,SAAS,EAAE,OAAO,IAAI;EAClC,OAAON,GAAG,KAAK,MAAM,IAAIA,GAAG,KAAK,GAAG;AACtC,CAAC;AAED,MAAMO,mBAAmB,GAAGA,CAAA,KAAM;EAChC,IAAIvB,mBAAmB,CAACwB,UAAU,IAAIxB,mBAAmB,CAACwB,UAAU,CAACC,IAAI,CAAC,CAAC,EAAE;IAC3E,OAAOzB,mBAAmB,CAACwB,UAAU;EACvC;EACA,MAAMjC,GAAG,GAAGqB,YAAY,CAAC,CAAC;EAC1B,OAAOrB,GAAG,CAACmC,sBAAsB,IAAInC,GAAG,CAACoC,wBAAwB,IAAIpC,GAAG,CAACqC,YAAY,IAAI,GAAG;AAC9F,CAAC;AAED,MAAMC,aAAa,GAAGA,CAACrC,KAAe,EAAEsC,IAAW,KAAK;EACtD,MAAMC,EAAE,GAAG,IAAIxB,IAAI,CAAC,CAAC,CAACyB,WAAW,CAAC,CAAC;EACnC,MAAMC,SAAS,GAAIvE,KAAU,IAAK;IAChC,IAAIA,KAAK,YAAYwE,KAAK,EAAE;MAC1B,MAAMC,KAAK,GAAGzE,KAAK,CAACyE,KAAK,GAAG,KAAKzE,KAAK,CAACyE,KAAK,EAAE,GAAG,EAAE;MACnD,OAAO,GAAGzE,KAAK,CAAC0E,OAAO,GAAGD,KAAK,EAAE;IACnC;IACA,IAAI,OAAOzE,KAAK,KAAK,QAAQ,EAAE,OAAOA,KAAK;IAC3C,IAAI;MACF,OAAO2E,IAAI,CAACC,SAAS,CAAC5E,KAAK,CAAC;IAC9B,CAAC,CAAC,MAAM;MACN,OAAOS,MAAM,CAACT,KAAK,CAAC;IACtB;EACF,CAAC;EACD,MAAM6E,OAAO,GAAGT,IAAI,CAACU,GAAG,CAACP,SAAS,CAAC,CAACQ,IAAI,CAAC,GAAG,CAAC;EAC7C,OAAO,GAAGV,EAAE,KAAKvC,KAAK,CAACkD,WAAW,CAAC,CAAC,KAAKH,OAAO,IAAI;AACtD,CAAC;AAGD,IAAII,QAAqC,GAAGrB,SAAS;AAErD,IAAIsB,UAAyC,GAAGtB,SAAS;AAEzD,MAAMuB,sBAAsB,GAAGA,CAAA,KAAM;EACnC,IAAI7C,mBAAmB,CAAC8C,SAAS,IAAI9C,mBAAmB,CAAC8C,SAAS,CAACrB,IAAI,CAAC,CAAC,EAAE;IACzE,OAAOzB,mBAAmB,CAAC8C,SAAS;EACtC;EACA,MAAMvD,GAAG,GAAGqB,YAAY,CAAC,CAAC;EAC1B,OAAOrB,GAAG,CAACwD,wBAAwB,IAAIxD,GAAG,CAACyD,0BAA0B,IAAIzD,GAAG,CAAC0D,cAAc,IAAI,EAAE;AACnG,CAAC;AAED,MAAMC,wBAAwB,GAAGA,CAAA,KAAM;EACrC,IAAIlD,mBAAmB,CAACmD,WAAW,IAAInD,mBAAmB,CAACmD,WAAW,CAAC1B,IAAI,CAAC,CAAC,EAAE;IAC7E,OAAOzB,mBAAmB,CAACmD,WAAW;EACxC;EACA,MAAM5D,GAAG,GAAGqB,YAAY,CAAC,CAAC;EAC1B,OAAOrB,GAAG,CAAC6D,0BAA0B,IAAI7D,GAAG,CAAC8D,4BAA4B,IAAI9D,GAAG,CAAC+D,gBAAgB,IAAI,EAAE;AACzG,CAAC;AAED,MAAMC,sBAAsB,GAAGA,CAAA,KAAM;EACnC,IAAI,OAAOvD,mBAAmB,CAACwD,aAAa,KAAK,SAAS,EAAE;IAC1D,OAAOxD,mBAAmB,CAACwD,aAAa,IAAI9E,OAAO,CAACmE,sBAAsB,CAAC,CAAC,CAAC;EAC/E;EACA,MAAMC,SAAS,GAAGD,sBAAsB,CAAC,CAAC;EAC1C,IAAI,CAACC,SAAS,EAAE,OAAO,KAAK;EAC5B,MAAMvD,GAAG,GAAGqB,YAAY,CAAC,CAAC;EAC1B,MAAMI,GAAG,GACPzB,GAAG,CAACkE,4BAA4B,IAChClE,GAAG,CAACmE,8BAA8B,IAClCnE,GAAG,CAACoE,kBAAkB;EACxB,IAAI3C,GAAG,KAAKM,SAAS,EAAE,OAAO,IAAI;EAClC,OAAON,GAAG,KAAK,MAAM,IAAIA,GAAG,KAAK,GAAG;AACtC,CAAC;AAED,MAAM4C,mBAAmB,GAAIlG,KAAU,IAAU;EAC/C,IAAIA,KAAK,YAAYwE,KAAK,EAAE;IAC1B,OAAO;MACL2B,IAAI,EAAEnG,KAAK,CAACmG,IAAI;MAChBzB,OAAO,EAAE1E,KAAK,CAAC0E,OAAO;MACtBD,KAAK,EAAEzE,KAAK,CAACyE;IACf,CAAC;EACH;EACA,IAAIzE,KAAK,KAAK,IAAI,IAAIA,KAAK,KAAK4D,SAAS,EAAE,OAAO5D,KAAK;EACvD,IAAI,OAAOA,KAAK,KAAK,QAAQ,IAAI,OAAOA,KAAK,KAAK,QAAQ,IAAI,OAAOA,KAAK,KAAK,SAAS,EAAE,OAAOA,KAAK;EACtG,IAAI;IACF,OAAO2E,IAAI,CAACyB,KAAK,CAACzB,IAAI,CAACC,SAAS,CAAC5E,KAAK,CAAC,CAAC;EAC1C,CAAC,CAAC,MAAM;IACN,OAAOS,MAAM,CAACT,KAAK,CAAC;EACtB;AACF,CAAC;AAED,MAAMqG,kBAAkB,GAAGA,CAACvE,KAAe,EAAEsC,IAAW,KAAK;EAC3D,MAAMkC,cAAc,GAAGlC,IAAI,CAACU,GAAG,CAAEyB,GAAG,IAAKL,mBAAmB,CAACK,GAAG,CAAC,CAAC;EAClE,MAAMC,QAAQ,GAAGF,cAAc,CAAC,CAAC,CAAC;EAClC,MAAM5B,OAAO,GACX,OAAO8B,QAAQ,KAAK,QAAQ,GACxBA,QAAQ,GACRF,cAAc,CAACxB,GAAG,CAAEyB,GAAG,IAAM,OAAOA,GAAG,KAAK,QAAQ,GAAGA,GAAG,GAAG5B,IAAI,CAACC,SAAS,CAAC2B,GAAG,CAAE,CAAC,CAACxB,IAAI,CAAC,GAAG,CAAC;EAElG,OAAO;IACL0B,SAAS,EAAE,IAAI5D,IAAI,CAAC,CAAC,CAACyB,WAAW,CAAC,CAAC;IACnCxC,KAAK;IACL4C,OAAO,EAAEA,OAAO,IAAI,SAAS;IAC7BgC,MAAM,EAAEpF,KAAK,GAAG,KAAK,GAAG,QAAQ;IAChCqF,OAAO,EAAE5F,iBAAiB,GAAG,MAAM,GAAG,QAAQ;IAC9CqD,IAAI,EAAEkC;EACR,CAAC;AACH,CAAC;AAED,MAAMM,qBAAqB,GAAIxC,IAAW,IAAa;EACrD,IAAI,CAACyC,KAAK,CAACC,OAAO,CAAC1C,IAAI,CAAC,IAAIA,IAAI,CAAC3E,MAAM,KAAK,CAAC,EAAE,OAAO,SAAS;EAC/D,MAAM,CAACsH,KAAK,CAAC,GAAG3C,IAAI;EACpB,IAAI,OAAO2C,KAAK,KAAK,QAAQ,IAAIA,KAAK,CAAChD,IAAI,CAAC,CAAC,EAAE,OAAOgD,KAAK;EAC3D,OAAO3C,IAAI,CACRU,GAAG,CAAEyB,GAAG,IAAK;IACZ,IAAIA,GAAG,YAAY/B,KAAK,EAAE,OAAO+B,GAAG,CAAC7B,OAAO;IAC5C,IAAI,OAAO6B,GAAG,KAAK,QAAQ,EAAE,OAAOA,GAAG;IACvC,IAAI;MACF,OAAO5B,IAAI,CAACC,SAAS,CAAC2B,GAAG,CAAC;IAC5B,CAAC,CAAC,MAAM;MACN,OAAO9F,MAAM,CAAC8F,GAAG,CAAC;IACpB;EACF,CAAC,CAAC,CACDxB,IAAI,CAAC,GAAG,CAAC,CACThB,IAAI,CAAC,CAAC,IAAI,SAAS;AACxB,CAAC;AAED,MAAMiD,mBAAmB,GAAGA,CAC1BlF,KAA0C,EAC1CsC,IAAW,KACR;EACH,IAAI,CAAC7B,qBAAqB,EAAE;EAE5B,MAAM0E,QAAQ,GAAG7C,IAAI,CAAC8C,IAAI,CAAEX,GAAG,IAAKA,GAAG,YAAY/B,KAAK,CAAsB;EAC9E,MAAM2C,OAAO,GAAG;IAAErF,KAAK;IAAE6E,OAAO,EAAE5F,iBAAiB,GAAG,MAAM,GAAGO,KAAK,GAAG,KAAK,GAAG;EAAS,CAAC;EAEzF,IAAI2F,QAAQ,IAAI,OAAO1E,qBAAqB,CAAC6E,gBAAgB,KAAK,UAAU,EAAE;IAC5E7E,qBAAqB,CAAC6E,gBAAgB,CAACH,QAAQ,EAAEE,OAAO,CAAC;IACzD;EACF;EAEA,IAAI,OAAO5E,qBAAqB,CAAC8E,cAAc,KAAK,UAAU,EAAE;IAC9D9E,qBAAqB,CAAC8E,cAAc,CAACT,qBAAqB,CAACxC,IAAI,CAAC,EAAEtC,KAAK,EAAEqF,OAAO,CAAC;EACnF;AACF,CAAC;AAED,MAAMG,aAAa,GAAGA,CAAA,KAAyB;EAC7C,IAAIpC,UAAU,KAAKtB,SAAS,EAAE,OAAOsB,UAAU,IAAI,IAAI;EACvD,IAAI,CAACW,sBAAsB,CAAC,CAAC,EAAE;IAC7BX,UAAU,GAAG,IAAI;IACjB,OAAO,IAAI;EACb;EACA,IAAI,OAAOqC,KAAK,KAAK,UAAU,EAAE;IAC/BrC,UAAU,GAAG,IAAI;IACjB,OAAO,IAAI;EACb;EAEA,MAAMsC,GAAG,GAAGrC,sBAAsB,CAAC,CAAC;EACpC,MAAMsC,KAAK,GAAGjC,wBAAwB,CAAC,CAAC;EACxC,IAAIkC,SAAS,GAAGC,OAAO,CAACC,OAAO,CAAC,CAAC;EAEjC,MAAMC,OAAO,GAAG,MAAAA,CAAO/F,KAAe,EAAEsC,IAAW,KAAK;IACtD,MAAM0D,OAA+B,GAAG;MACtC,cAAc,EAAE;IAClB,CAAC;IACD,IAAIL,KAAK,EAAE;MACTK,OAAO,CAAC,aAAa,CAAC,GAAGL,KAAK;IAChC;IAEA,MAAM5C,OAAO,GAAGwB,kBAAkB,CAACvE,KAAK,EAAEsC,IAAI,CAAC;IAC/C,MAAMmD,KAAK,CAACC,GAAG,EAAE;MACfO,MAAM,EAAE,MAAM;MACdD,OAAO;MACPE,IAAI,EAAErD,IAAI,CAACC,SAAS,CAACC,OAAO;IAC9B,CAAC,CAAC;EACJ,CAAC;EAEDK,UAAU,GAAG;IACX+C,KAAK,EAAEA,CAACnG,KAAK,EAAEsC,IAAI,KAAK;MACtBsD,SAAS,GAAGA,SAAS,CAACQ,IAAI,CAAC,MAAML,OAAO,CAAC/F,KAAK,EAAEsC,IAAI,CAAC,CAAC,CAAC+D,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;IACxE;EACF,CAAC;EACD,OAAOjD,UAAU;AACnB,CAAC;AAED,MAAMkD,4BAA4B,GAAGA,CAAA,KAAM;EACzCnD,QAAQ,GAAGrB,SAAS;EACpBsB,UAAU,GAAGtB,SAAS;AACxB,CAAC;AAED,MAAMyE,eAAe,GAAGA,CAAA,KAAuB;EAC7C,IAAI,CAACtH,iBAAiB,EAAE,OAAO,IAAI;EACnC,IAAIuH,EAAO,GAAG,IAAI;EAClB,IAAIC,IAAS,GAAG,IAAI;EACpB,IAAI;IACFD,EAAE,GAAG3G,IAAI,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC;IAC1B4G,IAAI,GAAG5G,IAAI,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC;EAChC,CAAC,CAAC,MAAM;IACN,OAAO,IAAI;EACb;EAEA,IAAI6G,WAAW,GAAG,EAAE;EACpB,IAAIC,QAAQ,GAAG,EAAE;EACjB,MAAMC,cAAc,GAAGA,CAAA,KAAM;IAC3B,MAAMC,KAAK,GAAGhG,eAAe,CAAC,IAAIE,IAAI,CAAC,CAAC,CAAC;IACzC,IAAI8F,KAAK,KAAKH,WAAW,IAAIC,QAAQ,EAAE;IACvCD,WAAW,GAAGG,KAAK;IACnB,MAAMC,MAAM,GAAG/E,mBAAmB,CAAC,CAAC,IAAI,GAAG;IAC3C,MAAMgF,GAAG,GAAGlI,iBAAiB,CAAC,CAAC,EAAEkI,GAAG,GAAG,CAAC,IAAI,GAAG;IAC/C,MAAMC,WAAW,GAAGP,IAAI,CAACX,OAAO,CAACiB,GAAG,EAAED,MAAM,CAAC;IAC7C,IAAI,CAACN,EAAE,CAACS,UAAU,CAACD,WAAW,CAAC,EAAE;MAC/B,IAAI;QAAER,EAAE,CAACU,SAAS,CAACF,WAAW,EAAE;UAAEG,SAAS,EAAE;QAAK,CAAC,CAAC;MAAE,CAAC,CAAC,MAAM,CAAE;IAClE;IACAR,QAAQ,GAAGF,IAAI,CAACxD,IAAI,CAAC+D,WAAW,EAAE7F,kBAAkB,CAAC,IAAIJ,IAAI,CAAC,CAAC,CAAC,CAAC;EACnE,CAAC;EAED,OAAO;IACLoF,KAAK,EAAEA,CAACnG,KAAK,EAAEsC,IAAI,KAAK;MACtB,IAAI;QACFsE,cAAc,CAAC,CAAC;QAChBJ,EAAE,CAACY,UAAU,CAACT,QAAQ,EAAEtE,aAAa,CAACrC,KAAK,EAAEsC,IAAI,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC;MAC/D,CAAC,CAAC,MAAM;QACN;MAAA;IAEJ;EACF,CAAC;AACH,CAAC;AAED,MAAM+E,iBAAiB,GAAGA,CAAA,KAAM;EAC9B,IAAI;IACF;IACA,OAAO1K,OAAO,CAAC,yBAAyB,CAAC;EAC3C,CAAC,CAAC,MAAM;IACN,IAAI;MACF;MACA,OAAOA,OAAO,CAAC,kBAAkB,CAAC;IACpC,CAAC,CAAC,MAAM;MACN,OAAO,IAAI;IACb;EACF;AACF,CAAC;AAED,MAAM2K,eAAe,GAAGA,CAAA,KAAuB;EAC7C,MAAMC,UAAU,GAAGF,iBAAiB,CAAC,CAAC;EACtC,IAAI,CAACE,UAAU,IAAI,OAAOA,UAAU,CAACC,kBAAkB,KAAK,UAAU,EAAE,OAAO,IAAI;EAEnF,MAAMC,OAAO,GAAGF,UAAU,CAACG,iBAAiB,IAAIH,UAAU,CAACI,cAAc;EACzE,IAAI,CAACF,OAAO,EAAE,OAAO,IAAI;EACzB,MAAMG,QAAQ,GAAGL,UAAU,CAACM,YAAY,EAAEC,IAAI,IAAI,MAAM;EAExD,MAAMC,YAAY,GAAIC,GAAW,IAAKA,GAAG,CAACC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC;EAC9D,MAAMnB,MAAM,GAAG/E,mBAAmB,CAAC,CAAC;EACpC,MAAMmG,MAAM,GAAGpB,MAAM,IAAIA,MAAM,KAAK,GAAG,GAAGA,MAAM,CAACmB,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,CAACA,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,GAAG,EAAE;EAC/F,MAAME,QAAQ,GAAGD,MAAM,GAAG,GAAGH,YAAY,CAACN,OAAO,CAAC,GAAGS,MAAM,GAAG,GAAGH,YAAY,CAACN,OAAO,CAAC;EAEtF,IAAIf,WAAW,GAAG,EAAE;EACpB,IAAI0B,OAAO,GAAG,EAAE;EAChB,IAAIC,UAAU,GAAGxC,OAAO,CAACC,OAAO,CAAC,CAAC;EAElC,MAAMwC,aAAa,GAAG,MAAAA,CAAA,KAAY;IAChC,MAAMzB,KAAK,GAAGhG,eAAe,CAAC,IAAIE,IAAI,CAAC,CAAC,CAAC;IACzC,IAAI8F,KAAK,KAAKH,WAAW,IAAI0B,OAAO,EAAE;IACtC1B,WAAW,GAAGG,KAAK;IACnBuB,OAAO,GAAG,GAAGD,QAAQ,GAAGhH,kBAAkB,CAAC,IAAIJ,IAAI,CAAC,CAAC,CAAC,EAAE;IACxD,IAAImH,MAAM,EAAE;MACV,IAAI;QAAE,MAAMX,UAAU,CAACgB,kBAAkB,CAACJ,QAAQ,EAAE;UAAEK,aAAa,EAAE;QAAK,CAAC,CAAC;MAAE,CAAC,CAAC,MAAM,CAAE;IAC1F;IACA,IAAI;MACF,MAAMC,IAAI,GAAG,MAAMlB,UAAU,CAACmB,YAAY,CAACN,OAAO,CAAC;MACnD,IAAI,CAACK,IAAI,EAAEE,MAAM,EAAE;QACjB,MAAMpB,UAAU,CAACC,kBAAkB,CAACY,OAAO,EAAE,EAAE,EAAE;UAAER;QAAS,CAAC,CAAC;MAChE;IACF,CAAC,CAAC,MAAM;MACN,IAAI;QAAE,MAAML,UAAU,CAACC,kBAAkB,CAACY,OAAO,EAAE,EAAE,EAAE;UAAER;QAAS,CAAC,CAAC;MAAE,CAAC,CAAC,MAAM,CAAE;IAClF;EACF,CAAC;EAED,MAAMgB,UAAU,GAAG,MAAOC,IAAY,IAAK;IACzC,MAAMP,aAAa,CAAC,CAAC;IACrB,IAAI;MACF,MAAMf,UAAU,CAACC,kBAAkB,CAACY,OAAO,EAAES,IAAI,EAAE;QACjDjB,QAAQ;QACRkB,MAAM,EAAE;MACV,CAAC,CAAC;MACF;IACF,CAAC,CAAC,MAAM;MACN;IAAA;IAEF,IAAI;MACF,MAAMC,QAAQ,GAAG,MAAMxB,UAAU,CAACyB,iBAAiB,CAACZ,OAAO,EAAE;QAAER;MAAS,CAAC,CAAC;MAC1E,MAAML,UAAU,CAACC,kBAAkB,CAACY,OAAO,EAAE,GAAGW,QAAQ,GAAGF,IAAI,EAAE,EAAE;QAAEjB;MAAS,CAAC,CAAC;IAClF,CAAC,CAAC,MAAM;MACN;IAAA;EAEJ,CAAC;EAED,OAAO;IACLzB,KAAK,EAAEA,CAACnG,KAAK,EAAEsC,IAAI,KAAK;MACtB,MAAMuG,IAAI,GAAGxG,aAAa,CAACrC,KAAK,EAAEsC,IAAI,CAAC;MACvC+F,UAAU,GAAGA,UAAU,CAACjC,IAAI,CAAC,MAAMwC,UAAU,CAACC,IAAI,CAAC,CAAC,CAACxC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;IACtE;EACF,CAAC;AACH,CAAC;AAED,MAAM4C,WAAW,GAAGA,CAAA,KAAuB;EACzC,IAAI9F,QAAQ,KAAKrB,SAAS,EAAE,OAAOqB,QAAQ,IAAI,IAAI;EACnD,IAAI,CAAC7B,oBAAoB,CAAC,CAAC,EAAE;IAC3B6B,QAAQ,GAAG,IAAI;IACf,OAAO,IAAI;EACb;EACA,MAAM+F,QAAQ,GAAG3C,eAAe,CAAC,CAAC;EAClC,IAAI2C,QAAQ,EAAE;IACZ/F,QAAQ,GAAG+F,QAAQ;IACnB,OAAOA,QAAQ;EACjB;EACA,MAAMC,QAAQ,GAAG7B,eAAe,CAAC,CAAC;EAClC,IAAI6B,QAAQ,EAAE;IACZhG,QAAQ,GAAGgG,QAAQ;IACnB,OAAOA,QAAQ;EACjB;EACAhG,QAAQ,GAAG,IAAI;EACf,OAAO,IAAI;AACb,CAAC;;AAED;AACA,IAAIiG,QAAa,GAAG,IAAI;AACxB,IAAIC,aAAkB,GAAG,IAAI;;AAE7B;AACA,MAAMC,WAAW,GAAGA,CAAA,KAAM;EACxB,IAAIF,QAAQ,KAAK,IAAI,EAAE,OAAOA,QAAQ;EACtC,IAAI,CAAC/J,aAAa,IAAI,CAACI,MAAM,EAAE,OAAO,IAAI;EAE1C,IAAI;IACF,MAAM;MAAE8J,MAAM,EAAEC;IAAa,CAAC,GAAG/J,MAAM;IAEvC,MAAMgK,MAAM,GAAG;MACbC,QAAQ,EAAEnJ,YAAY;MACtBoJ,SAAS,EAAEA,CAACC,GAAQ,EAAE5J,KAAa,EAAE6J,QAAa,KAAK;QACrD,MAAMC,MAAM,GAAG,IAAI9J,KAAK,CAACkD,WAAW,CAAC,CAAC,GAAG;QACzC,QAAQlD,KAAK;UACX,KAAK,OAAO;YACV;YACA+J,OAAO,CAACC,KAAK,CAACF,MAAM,EAAE,GAAGF,GAAG,CAAC;YAC7B;UACF,KAAK,MAAM;YACT;YACAG,OAAO,CAACE,IAAI,CAACH,MAAM,EAAE,GAAGF,GAAG,CAAC;YAC5B;UACF,KAAK,MAAM;YACT;YACAG,OAAO,CAACG,GAAG,CAACJ,MAAM,EAAE,GAAGF,GAAG,CAAC;YAC3B;UACF,KAAK,OAAO;YACV;YACAG,OAAO,CAACI,KAAK,GAAGJ,OAAO,CAACI,KAAK,CAACL,MAAM,EAAE,GAAGF,GAAG,CAAC,GAAGG,OAAO,CAACG,GAAG,CAACJ,MAAM,EAAE,GAAGF,GAAG,CAAC;YAC3E;UACF;YACE;YACAG,OAAO,CAACG,GAAG,CAACJ,MAAM,EAAE,GAAGF,GAAG,CAAC;QAC/B;MACF,CAAC;MACDQ,gBAAgB,EAAE;QAChBC,MAAM,EAAE;UACNL,KAAK,EAAE,KAAK;UACZC,IAAI,EAAE,QAAQ;UACdxB,IAAI,EAAE,MAAM;UACZ0B,KAAK,EAAE;QACT;MACF;IACF,CAAC;IAEDf,QAAQ,GAAGI,YAAY,CAACC,MAAM,CAAC;IAC/B,OAAOL,QAAQ;EACjB,CAAC,CAAC,OAAOvM,CAAC,EAAE;IACVuM,QAAQ,GAAG,IAAI;IACf,OAAO,IAAI;EACb;AACF,CAAC;AAED,MAAMkB,gBAAgB,GAAGA,CAAA,KAAM;EAC7B,IAAIjB,aAAa,KAAK,IAAI,EAAE,OAAOA,aAAa;EAChD,IAAI,CAACpK,iBAAiB,EAAE,OAAO,IAAI;EAEnC,MAAMS,OAAO,GAAGC,UAAU,CAAC,CAAC;EAC5B,IAAI,CAACD,OAAO,EAAE,OAAO,IAAI;EAEzB,IAAI;IACF,MAAM;MAAE8J,YAAY;MAAEe,MAAM;MAAEC;IAAW,CAAC,GAAG9K,OAAO;IACpD,MAAM+K,kBAAyB,GAAG,CAAC,IAAID,UAAU,CAACE,OAAO,CAAC;MAAE1K,KAAK,EAAEO;IAAa,CAAC,CAAC,CAAC;IAEnF8I,aAAa,GAAGG,YAAY,CAAC;MAC3BxJ,KAAK,EAAEO,YAAY;MACnBgK,MAAM,EAAEA,MAAM,CAACI,OAAO,CACpBJ,MAAM,CAAC5F,SAAS,CAAC,CAAC,EAClB4F,MAAM,CAACK,MAAM,CAAC;QAAEjI,KAAK,EAAE;MAAK,CAAC,CAAC,EAC9B4H,MAAM,CAACM,KAAK,CAAC,CAAC,EACdN,MAAM,CAACO,IAAI,CAAC,CACd,CAAC;MACDN,UAAU,EAAEC;IACd,CAAC,CAAC;IACF,OAAOpB,aAAa;EACtB,CAAC,CAAC,OAAOxM,CAAC,EAAE;IACVwM,aAAa,GAAG,IAAI;IACpB,OAAO,IAAI;EACb;AACF,CAAC;;AAED;AACA,IAAIhK,aAAa,EAAE;EACjBiK,WAAW,CAAC,CAAC;AACf;AAEO,SAASyB,WAAWA,CAAC/K,KAAe,EAAE;EAC3CO,YAAY,GAAGP,KAAK;EACpB;EACA,MAAMoJ,QAAQ,GAAGE,WAAW,CAAC,CAAC;EAC9B,IAAIF,QAAQ,IAAIA,QAAQ,CAAC4B,WAAW,EAAE;IACpC5B,QAAQ,CAAC4B,WAAW,CAAChL,KAAK,CAAC;EAC7B;EACA,MAAMqJ,aAAa,GAAGiB,gBAAgB,CAAC,CAAC;EACxC,IAAIjB,aAAa,EAAE;IACjBA,aAAa,CAACrJ,KAAK,GAAGA,KAAK;EAC7B;AACF;AAEO,SAASiL,eAAeA,CAACxB,MAA2B,GAAG,CAAC,CAAC,EAAE;EAChEjJ,mBAAmB,GAAA/C,aAAA,CAAAA,aAAA,KACd+C,mBAAmB,GACnBiJ,MAAM,CACV;EAED,IAAIpI,eAAe,CAACoI,MAAM,CAACzJ,KAAK,CAAC,EAAE;IACjCO,YAAY,GAAGkJ,MAAM,CAACzJ,KAAK;EAC7B;EAEAsG,4BAA4B,CAAC,CAAC;;EAE9B;EACA,MAAM8C,QAAQ,GAAGE,WAAW,CAAC,CAAC;EAC9B,IAAIF,QAAQ,IAAIA,QAAQ,CAAC4B,WAAW,EAAE;IACpC5B,QAAQ,CAAC4B,WAAW,CAACzK,YAAY,CAAC;EACpC;EACA,MAAM8I,aAAa,GAAGiB,gBAAgB,CAAC,CAAC;EACxC,IAAIjB,aAAa,EAAE;IACjBA,aAAa,CAACrJ,KAAK,GAAGO,YAAY;EACpC;AACF;AAEO,SAAS2K,wBAAwBA,CAACC,MAAqC,EAAE;EAC9E1K,qBAAqB,GAAG0K,MAAM,IAAI,IAAI;AACxC;AAEA,SAASC,aAAaA,CAACC,CAAW,EAAE;EAClC,QAAQA,CAAC;IACP,KAAK,QAAQ;MAAE,OAAO,CAAC;IACvB,KAAK,OAAO;MAAE,OAAO,CAAC;IACtB,KAAK,MAAM;MAAE,OAAO,CAAC;IACrB,KAAK,MAAM;MAAE,OAAO,CAAC;IACrB,KAAK,OAAO;MAAE,OAAO,CAAC;IACtB;MAAS,OAAO,CAAC;EACnB;AACF;;AAEA;AACO,MAAM9B,MAAM,GAAA+B,OAAA,CAAA/B,MAAA,GAAG;EACpBS,KAAK,EAAEA,CAAC,GAAG1H,IAAW,KAAK;IACzB,IAAI8I,aAAa,CAAC7K,YAAY,CAAC,IAAI6K,aAAa,CAAC,OAAO,CAAC,EAAE;MACzD,MAAMhC,QAAQ,GAAGE,WAAW,CAAC,CAAC;MAC9B,IAAIF,QAAQ,EAAE;QACZA,QAAQ,CAACY,KAAK,CAAC,GAAG1H,IAAI,CAAC;MACzB,CAAC,MAAM;QACL,MAAM+G,aAAa,GAAGiB,gBAAgB,CAAC,CAAC;QACxC,IAAIjB,aAAa,EAAE;UACjBA,aAAa,CAACW,KAAK,CAAC,GAAG1H,IAAI,CAAC;QAC9B,CAAC,MAAM;UACL;UACAyH,OAAO,CAACC,KAAK,CAAC,SAAS,EAAE,GAAG1H,IAAI,CAAC;QACnC;MACF;MACA,MAAMiJ,IAAI,GAAGtC,WAAW,CAAC,CAAC;MAC1B,IAAIsC,IAAI,EAAEA,IAAI,CAACpF,KAAK,CAAC,OAAO,EAAE7D,IAAI,CAAC;MACnC,MAAMkJ,MAAM,GAAGhG,aAAa,CAAC,CAAC;MAC9B,IAAIgG,MAAM,EAAEA,MAAM,CAACrF,KAAK,CAAC,OAAO,EAAE7D,IAAI,CAAC;MACvC4C,mBAAmB,CAAC,OAAO,EAAE5C,IAAI,CAAC;IACpC;EACF,CAAC;EACD2H,IAAI,EAAEA,CAAC,GAAG3H,IAAW,KAAK;IACxB,IAAI8I,aAAa,CAAC7K,YAAY,CAAC,IAAI6K,aAAa,CAAC,MAAM,CAAC,EAAE;MACxD,MAAMhC,QAAQ,GAAGE,WAAW,CAAC,CAAC;MAC9B,IAAIF,QAAQ,EAAE;QACZA,QAAQ,CAACa,IAAI,CAAC,GAAG3H,IAAI,CAAC;MACxB,CAAC,MAAM;QACL,MAAM+G,aAAa,GAAGiB,gBAAgB,CAAC,CAAC;QACxC,IAAIjB,aAAa,EAAE;UACjBA,aAAa,CAACY,IAAI,CAAC,GAAG3H,IAAI,CAAC;QAC7B,CAAC,MAAM;UACL;UACAyH,OAAO,CAACE,IAAI,CAAC,QAAQ,EAAE,GAAG3H,IAAI,CAAC;QACjC;MACF;MACA,MAAMiJ,IAAI,GAAGtC,WAAW,CAAC,CAAC;MAC1B,IAAIsC,IAAI,EAAEA,IAAI,CAACpF,KAAK,CAAC,MAAM,EAAE7D,IAAI,CAAC;MAClC,MAAMkJ,MAAM,GAAGhG,aAAa,CAAC,CAAC;MAC9B,IAAIgG,MAAM,EAAEA,MAAM,CAACrF,KAAK,CAAC,MAAM,EAAE7D,IAAI,CAAC;MACtC4C,mBAAmB,CAAC,MAAM,EAAE5C,IAAI,CAAC;IACnC;EACF,CAAC;EACDmG,IAAI,EAAEA,CAAC,GAAGnG,IAAW,KAAK;IACxB,IAAI8I,aAAa,CAAC7K,YAAY,CAAC,IAAI6K,aAAa,CAAC,MAAM,CAAC,EAAE;MACxD,MAAMhC,QAAQ,GAAGE,WAAW,CAAC,CAAC;MAC9B,IAAIF,QAAQ,EAAE;QACZA,QAAQ,CAACX,IAAI,CAAC,GAAGnG,IAAI,CAAC;MACxB,CAAC,MAAM;QACL,MAAM+G,aAAa,GAAGiB,gBAAgB,CAAC,CAAC;QACxC,IAAIjB,aAAa,EAAE;UACjBA,aAAa,CAACZ,IAAI,CAAC,GAAGnG,IAAI,CAAC;QAC7B,CAAC,MAAM;UACL;UACAyH,OAAO,CAACG,GAAG,CAAC,QAAQ,EAAE,GAAG5H,IAAI,CAAC;QAChC;MACF;MACA,MAAMiJ,IAAI,GAAGtC,WAAW,CAAC,CAAC;MAC1B,IAAIsC,IAAI,EAAEA,IAAI,CAACpF,KAAK,CAAC,MAAM,EAAE7D,IAAI,CAAC;MAClC,MAAMkJ,MAAM,GAAGhG,aAAa,CAAC,CAAC;MAC9B,IAAIgG,MAAM,EAAEA,MAAM,CAACrF,KAAK,CAAC,MAAM,EAAE7D,IAAI,CAAC;IACxC;EACF,CAAC;EACD6H,KAAK,EAAEA,CAAC,GAAG7H,IAAW,KAAK;IACzB,IAAI8I,aAAa,CAAC7K,YAAY,CAAC,IAAI6K,aAAa,CAAC,OAAO,CAAC,EAAE;MACzD,MAAMhC,QAAQ,GAAGE,WAAW,CAAC,CAAC;MAC9B,IAAIF,QAAQ,EAAE;QACZA,QAAQ,CAACe,KAAK,CAAC,GAAG7H,IAAI,CAAC;MACzB,CAAC,MAAM;QACL,MAAM+G,aAAa,GAAGiB,gBAAgB,CAAC,CAAC;QACxC,IAAIjB,aAAa,EAAE;UACjBA,aAAa,CAACc,KAAK,CAAC,GAAG7H,IAAI,CAAC;QAC9B,CAAC,MAAM;UACL;UACAyH,OAAO,CAACI,KAAK,GAAGJ,OAAO,CAACI,KAAK,CAAC,SAAS,EAAE,GAAG7H,IAAI,CAAC,GAAGyH,OAAO,CAACG,GAAG,CAAC,SAAS,EAAE,GAAG5H,IAAI,CAAC;QACrF;MACF;MACA,MAAMiJ,IAAI,GAAGtC,WAAW,CAAC,CAAC;MAC1B,IAAIsC,IAAI,EAAEA,IAAI,CAACpF,KAAK,CAAC,OAAO,EAAE7D,IAAI,CAAC;MACnC,MAAMkJ,MAAM,GAAGhG,aAAa,CAAC,CAAC;MAC9B,IAAIgG,MAAM,EAAEA,MAAM,CAACrF,KAAK,CAAC,OAAO,EAAE7D,IAAI,CAAC;IACzC;EACF;AACF,CAAC;AAAC,IAAAmJ,QAAA,GAAAH,OAAA,CAAAI,OAAA,GAEanC,MAAM","ignoreList":[]}
|