@qontinui/ui-bridge 0.3.0 → 0.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/ai/index.d.mts +312 -155
- package/dist/ai/index.d.ts +312 -155
- package/dist/ai/index.js +2363 -67
- package/dist/ai/index.js.map +1 -1
- package/dist/ai/index.mjs +2328 -68
- package/dist/ai/index.mjs.map +1 -1
- package/dist/annotations/index.d.mts +218 -0
- package/dist/annotations/index.d.ts +218 -0
- package/dist/annotations/index.js +246 -0
- package/dist/annotations/index.js.map +1 -0
- package/dist/annotations/index.mjs +241 -0
- package/dist/annotations/index.mjs.map +1 -0
- package/dist/assertions-BSR3afVr.d.ts +161 -0
- package/dist/assertions-CTw1hfOx.d.mts +161 -0
- package/dist/babel-plugin/index.js +23 -34
- package/dist/babel-plugin/index.js.map +1 -1
- package/dist/babel-plugin/index.mjs +23 -34
- package/dist/babel-plugin/index.mjs.map +1 -1
- package/dist/browser-capture-Bms60T6f.d.mts +47 -0
- package/dist/browser-capture-CsTU29mb.d.ts +47 -0
- package/dist/control/index.d.mts +26 -7
- package/dist/control/index.d.ts +26 -7
- package/dist/control/index.js +276 -48
- package/dist/control/index.js.map +1 -1
- package/dist/control/index.mjs +276 -48
- package/dist/control/index.mjs.map +1 -1
- package/dist/core/index.d.mts +2 -2
- package/dist/core/index.d.ts +2 -2
- package/dist/core/index.js.map +1 -1
- package/dist/core/index.mjs.map +1 -1
- package/dist/debug/index.d.mts +5 -3
- package/dist/debug/index.d.ts +5 -3
- package/dist/debug/index.js +925 -1
- package/dist/debug/index.js.map +1 -1
- package/dist/debug/index.mjs +924 -2
- package/dist/debug/index.mjs.map +1 -1
- package/dist/index.d.mts +12 -7
- package/dist/index.d.ts +12 -7
- package/dist/index.js +4720 -173
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +4656 -174
- package/dist/index.mjs.map +1 -1
- package/dist/{metrics-DTA2bwG7.d.mts → metrics-DuA2qIIz.d.mts} +2 -2
- package/dist/{metrics-BfiT_rhZ.d.ts → metrics-KFAAKNEB.d.ts} +2 -2
- package/dist/native/control/index.js +2 -7
- package/dist/native/control/index.js.map +1 -1
- package/dist/native/control/index.mjs +2 -7
- package/dist/native/control/index.mjs.map +1 -1
- package/dist/native/core/index.js.map +1 -1
- package/dist/native/core/index.mjs.map +1 -1
- package/dist/native/debug/index.js +23 -66
- package/dist/native/debug/index.js.map +1 -1
- package/dist/native/debug/index.mjs +23 -66
- package/dist/native/debug/index.mjs.map +1 -1
- package/dist/native/index.js +89 -131
- package/dist/native/index.js.map +1 -1
- package/dist/native/index.mjs +89 -131
- package/dist/native/index.mjs.map +1 -1
- package/dist/native/react/index.js +28 -52
- package/dist/native/react/index.js.map +1 -1
- package/dist/native/react/index.mjs +28 -52
- package/dist/native/react/index.mjs.map +1 -1
- package/dist/native/server/index.js +38 -13
- package/dist/native/server/index.js.map +1 -1
- package/dist/native/server/index.mjs +38 -13
- package/dist/native/server/index.mjs.map +1 -1
- package/dist/react/index.d.mts +107 -8
- package/dist/react/index.d.ts +107 -8
- package/dist/react/index.js +2194 -84
- package/dist/react/index.js.map +1 -1
- package/dist/react/index.mjs +2194 -85
- package/dist/react/index.mjs.map +1 -1
- package/dist/{registry-BKLEm-yk.d.ts → registry-C6dDtn1v.d.ts} +27 -2
- package/dist/{registry-BmZgyCz8.d.mts → registry-POtcxnal.d.mts} +27 -2
- package/dist/render-log/index.d.mts +1 -1
- package/dist/render-log/index.d.ts +1 -1
- package/dist/server/express.d.mts +5 -4
- package/dist/server/express.d.ts +5 -4
- package/dist/server/express.js +104 -2
- package/dist/server/express.js.map +1 -1
- package/dist/server/express.mjs +104 -2
- package/dist/server/express.mjs.map +1 -1
- package/dist/server/handlers.d.mts +36 -5
- package/dist/server/handlers.d.ts +36 -5
- package/dist/server/handlers.js +3129 -224
- package/dist/server/handlers.js.map +1 -1
- package/dist/server/handlers.mjs +3129 -224
- package/dist/server/handlers.mjs.map +1 -1
- package/dist/server/index.d.mts +7 -5
- package/dist/server/index.d.ts +7 -5
- package/dist/server/index.js +3215 -183
- package/dist/server/index.js.map +1 -1
- package/dist/server/index.mjs +3215 -183
- package/dist/server/index.mjs.map +1 -1
- package/dist/server/nextjs.d.mts +6 -4
- package/dist/server/nextjs.d.ts +6 -4
- package/dist/server/nextjs.js +106 -3
- package/dist/server/nextjs.js.map +1 -1
- package/dist/server/nextjs.mjs +106 -3
- package/dist/server/nextjs.mjs.map +1 -1
- package/dist/server/standalone.d.mts +6 -5
- package/dist/server/standalone.d.ts +6 -5
- package/dist/server/standalone.js +131 -5
- package/dist/server/standalone.js.map +1 -1
- package/dist/server/standalone.mjs +131 -5
- package/dist/server/standalone.mjs.map +1 -1
- package/dist/specs/index.d.mts +365 -0
- package/dist/specs/index.d.ts +365 -0
- package/dist/specs/index.js +2809 -0
- package/dist/specs/index.js.map +1 -0
- package/dist/specs/index.mjs +2786 -0
- package/dist/specs/index.mjs.map +1 -0
- package/dist/{standalone-BURj8J3G.d.ts → standalone-B6GLIEmR.d.ts} +6 -2
- package/dist/{standalone-Dwmel29d.d.mts → standalone-CjdYqj3P.d.mts} +6 -2
- package/dist/{types-CHnlwiTK.d.ts → types-B2EfvEaq.d.ts} +83 -3
- package/dist/{types-B7J7noLK.d.mts → types-C7gVYRnF.d.ts} +72 -2
- package/dist/{types-BkNRILUa.d.ts → types-CJGrBEhC.d.mts} +72 -2
- package/dist/types-CebMQj76.d.ts +1275 -0
- package/dist/types-D_ypYl3T.d.mts +1275 -0
- package/dist/types-UBtp7R0u.d.mts +132 -0
- package/dist/types-UBtp7R0u.d.ts +132 -0
- package/dist/{types-CEQLnFMv.d.mts → types-gO696T_t.d.mts} +83 -3
- package/dist/{types-jKVgTI6_.d.mts → types-suaYwWWg.d.mts} +173 -2
- package/dist/{types-jKVgTI6_.d.ts → types-suaYwWWg.d.ts} +173 -2
- package/package.json +18 -2
- package/dist/types-B5Q0GVo0.d.mts +0 -646
- package/dist/types-DfPqwU-i.d.ts +0 -646
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/ai/fuzzy-matcher.ts","../../src/ai/alias-generator.ts","../../src/ai/search-engine.ts","../../src/ai/summary-generator.ts","../../src/ai/nl-action-parser.ts","../../src/ai/error-context.ts","../../src/ai/nl-action-executor.ts","../../src/ai/assertions.ts","../../src/ai/semantic-snapshot.ts","../../src/ai/semantic-diff.ts","../../src/server/handlers.ts"],"names":["aliases","error"],"mappings":"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","file":"handlers.js","sourcesContent":["/**\n * Fuzzy Matcher\n *\n * Provides fuzzy text matching utilities for finding elements by natural language descriptions.\n * Implements multiple matching algorithms with configurable thresholds.\n */\n\n/**\n * Configuration for fuzzy matching\n */\nexport interface FuzzyMatchConfig {\n /** Minimum similarity threshold (0-1) */\n threshold: number;\n /** Weight for Levenshtein distance */\n levenshteinWeight: number;\n /** Weight for Jaro-Winkler similarity */\n jaroWinklerWeight: number;\n /** Weight for N-gram matching */\n ngramWeight: number;\n /** N-gram size */\n ngramSize: number;\n /** Case sensitive matching */\n caseSensitive: boolean;\n /** Ignore whitespace differences */\n ignoreWhitespace: boolean;\n}\n\n/**\n * Default fuzzy match configuration\n */\nexport const DEFAULT_FUZZY_CONFIG: FuzzyMatchConfig = {\n threshold: 0.7,\n levenshteinWeight: 0.3,\n jaroWinklerWeight: 0.4,\n ngramWeight: 0.3,\n ngramSize: 2,\n caseSensitive: false,\n ignoreWhitespace: true,\n};\n\n/**\n * Result from a fuzzy match operation\n */\nexport interface FuzzyMatchResult {\n /** Overall similarity score (0-1) */\n similarity: number;\n /** Whether the match passes the threshold */\n isMatch: boolean;\n /** Individual algorithm scores */\n scores: {\n levenshtein: number;\n jaroWinkler: number;\n ngram: number;\n };\n /** Normalized source string */\n normalizedSource: string;\n /** Normalized target string */\n normalizedTarget: string;\n}\n\n/**\n * Calculate Levenshtein distance between two strings\n */\nexport function levenshteinDistance(s1: string, s2: string): number {\n const len1 = s1.length;\n const len2 = s2.length;\n\n // Create distance matrix\n const matrix: number[][] = Array(len1 + 1)\n .fill(null)\n .map(() => Array(len2 + 1).fill(0));\n\n // Initialize first column and row\n for (let i = 0; i <= len1; i++) matrix[i][0] = i;\n for (let j = 0; j <= len2; j++) matrix[0][j] = j;\n\n // Fill in the rest of the matrix\n for (let i = 1; i <= len1; i++) {\n for (let j = 1; j <= len2; j++) {\n const cost = s1[i - 1] === s2[j - 1] ? 0 : 1;\n matrix[i][j] = Math.min(\n matrix[i - 1][j] + 1, // deletion\n matrix[i][j - 1] + 1, // insertion\n matrix[i - 1][j - 1] + cost // substitution\n );\n }\n }\n\n return matrix[len1][len2];\n}\n\n/**\n * Calculate Levenshtein similarity (0-1)\n */\nexport function levenshteinSimilarity(s1: string, s2: string): number {\n if (s1.length === 0 && s2.length === 0) return 1;\n if (s1.length === 0 || s2.length === 0) return 0;\n\n const distance = levenshteinDistance(s1, s2);\n const maxLength = Math.max(s1.length, s2.length);\n\n return 1 - distance / maxLength;\n}\n\n/**\n * Calculate Jaro similarity between two strings\n */\nexport function jaroSimilarity(s1: string, s2: string): number {\n if (s1.length === 0 && s2.length === 0) return 1;\n if (s1.length === 0 || s2.length === 0) return 0;\n\n const matchDistance = Math.floor(Math.max(s1.length, s2.length) / 2) - 1;\n const s1Matches = new Array(s1.length).fill(false);\n const s2Matches = new Array(s2.length).fill(false);\n\n let matches = 0;\n let transpositions = 0;\n\n // Find matches\n for (let i = 0; i < s1.length; i++) {\n const start = Math.max(0, i - matchDistance);\n const end = Math.min(i + matchDistance + 1, s2.length);\n\n for (let j = start; j < end; j++) {\n if (s2Matches[j] || s1[i] !== s2[j]) continue;\n s1Matches[i] = true;\n s2Matches[j] = true;\n matches++;\n break;\n }\n }\n\n if (matches === 0) return 0;\n\n // Count transpositions\n let k = 0;\n for (let i = 0; i < s1.length; i++) {\n if (!s1Matches[i]) continue;\n while (!s2Matches[k]) k++;\n if (s1[i] !== s2[k]) transpositions++;\n k++;\n }\n\n return (matches / s1.length + matches / s2.length + (matches - transpositions / 2) / matches) / 3;\n}\n\n/**\n * Calculate Jaro-Winkler similarity\n * Gives more weight to strings that match from the beginning\n */\nexport function jaroWinklerSimilarity(s1: string, s2: string, prefixScale: number = 0.1): number {\n const jaroSim = jaroSimilarity(s1, s2);\n\n // Find common prefix (up to 4 characters)\n let prefixLength = 0;\n const maxPrefix = Math.min(4, Math.min(s1.length, s2.length));\n\n for (let i = 0; i < maxPrefix; i++) {\n if (s1[i] === s2[i]) {\n prefixLength++;\n } else {\n break;\n }\n }\n\n return jaroSim + prefixLength * prefixScale * (1 - jaroSim);\n}\n\n/**\n * Generate N-grams from a string\n */\nexport function generateNgrams(s: string, n: number): Set<string> {\n const ngrams = new Set<string>();\n\n if (s.length < n) {\n ngrams.add(s);\n return ngrams;\n }\n\n for (let i = 0; i <= s.length - n; i++) {\n ngrams.add(s.substring(i, i + n));\n }\n\n return ngrams;\n}\n\n/**\n * Calculate N-gram similarity (Jaccard coefficient)\n */\nexport function ngramSimilarity(s1: string, s2: string, n: number = 2): number {\n if (s1.length === 0 && s2.length === 0) return 1;\n if (s1.length === 0 || s2.length === 0) return 0;\n\n const ngrams1 = generateNgrams(s1, n);\n const ngrams2 = generateNgrams(s2, n);\n\n // Calculate intersection\n let intersection = 0;\n for (const ngram of ngrams1) {\n if (ngrams2.has(ngram)) {\n intersection++;\n }\n }\n\n // Jaccard coefficient: |A ∩ B| / |A ∪ B|\n const union = ngrams1.size + ngrams2.size - intersection;\n\n return union === 0 ? 0 : intersection / union;\n}\n\n/**\n * Normalize a string for comparison\n */\nexport function normalizeString(s: string, config: Partial<FuzzyMatchConfig> = {}): string {\n let normalized = s;\n\n // Handle case sensitivity\n if (!config.caseSensitive) {\n normalized = normalized.toLowerCase();\n }\n\n // Handle whitespace\n if (config.ignoreWhitespace !== false) {\n normalized = normalized.replace(/\\s+/g, ' ').trim();\n }\n\n return normalized;\n}\n\n/**\n * Main fuzzy match function\n * Combines multiple algorithms for robust matching\n */\nexport function fuzzyMatch(\n source: string,\n target: string,\n config: Partial<FuzzyMatchConfig> = {}\n): FuzzyMatchResult {\n const finalConfig = { ...DEFAULT_FUZZY_CONFIG, ...config };\n\n // Normalize strings\n const normalizedSource = normalizeString(source, finalConfig);\n const normalizedTarget = normalizeString(target, finalConfig);\n\n // Calculate individual scores\n const levenshteinScore = levenshteinSimilarity(normalizedSource, normalizedTarget);\n const jaroWinklerScore = jaroWinklerSimilarity(normalizedSource, normalizedTarget);\n const ngramScore = ngramSimilarity(normalizedSource, normalizedTarget, finalConfig.ngramSize);\n\n // Weighted combination\n const similarity =\n levenshteinScore * finalConfig.levenshteinWeight +\n jaroWinklerScore * finalConfig.jaroWinklerWeight +\n ngramScore * finalConfig.ngramWeight;\n\n return {\n similarity,\n isMatch: similarity >= finalConfig.threshold,\n scores: {\n levenshtein: levenshteinScore,\n jaroWinkler: jaroWinklerScore,\n ngram: ngramScore,\n },\n normalizedSource,\n normalizedTarget,\n };\n}\n\n/**\n * Find the best match from a list of candidates\n */\nexport function findBestMatch(\n source: string,\n candidates: string[],\n config: Partial<FuzzyMatchConfig> = {}\n): { match: string | null; index: number; result: FuzzyMatchResult | null } {\n if (candidates.length === 0) {\n return { match: null, index: -1, result: null };\n }\n\n let bestMatch: string | null = null;\n let bestIndex = -1;\n let bestResult: FuzzyMatchResult | null = null;\n\n for (let i = 0; i < candidates.length; i++) {\n const result = fuzzyMatch(source, candidates[i], config);\n\n if (result.isMatch && (!bestResult || result.similarity > bestResult.similarity)) {\n bestMatch = candidates[i];\n bestIndex = i;\n bestResult = result;\n }\n }\n\n return { match: bestMatch, index: bestIndex, result: bestResult };\n}\n\n/**\n * Find all matches above threshold\n */\nexport function findAllMatches(\n source: string,\n candidates: string[],\n config: Partial<FuzzyMatchConfig> = {}\n): Array<{ candidate: string; index: number; result: FuzzyMatchResult }> {\n const matches: Array<{ candidate: string; index: number; result: FuzzyMatchResult }> = [];\n\n for (let i = 0; i < candidates.length; i++) {\n const result = fuzzyMatch(source, candidates[i], config);\n\n if (result.isMatch) {\n matches.push({ candidate: candidates[i], index: i, result });\n }\n }\n\n // Sort by similarity descending\n matches.sort((a, b) => b.result.similarity - a.result.similarity);\n\n return matches;\n}\n\n/**\n * Check if source contains target (fuzzy)\n */\nexport function fuzzyContains(\n source: string,\n target: string,\n config: Partial<FuzzyMatchConfig> = {}\n): boolean {\n const finalConfig = { ...DEFAULT_FUZZY_CONFIG, ...config };\n const normalizedSource = normalizeString(source, finalConfig);\n const normalizedTarget = normalizeString(target, finalConfig);\n\n // Exact contains check\n if (normalizedSource.includes(normalizedTarget)) {\n return true;\n }\n\n // Word-by-word fuzzy check\n const sourceWords = normalizedSource.split(/\\s+/);\n const targetWords = normalizedTarget.split(/\\s+/);\n\n // All target words must have a fuzzy match in source\n for (const targetWord of targetWords) {\n const hasMatch = sourceWords.some((sourceWord) => {\n const result = fuzzyMatch(sourceWord, targetWord, { ...finalConfig, threshold: 0.8 });\n return result.isMatch;\n });\n\n if (!hasMatch) {\n return false;\n }\n }\n\n return true;\n}\n\n/**\n * Calculate word-level similarity\n * Useful for comparing phrases\n */\nexport function wordSimilarity(\n s1: string,\n s2: string,\n config: Partial<FuzzyMatchConfig> = {}\n): number {\n const finalConfig = { ...DEFAULT_FUZZY_CONFIG, ...config };\n const words1 = normalizeString(s1, finalConfig).split(/\\s+/);\n const words2 = normalizeString(s2, finalConfig).split(/\\s+/);\n\n if (words1.length === 0 && words2.length === 0) return 1;\n if (words1.length === 0 || words2.length === 0) return 0;\n\n let totalSimilarity = 0;\n let matchCount = 0;\n\n // For each word in s1, find best match in s2\n for (const word1 of words1) {\n let bestSim = 0;\n for (const word2 of words2) {\n const result = fuzzyMatch(word1, word2, finalConfig);\n if (result.similarity > bestSim) {\n bestSim = result.similarity;\n }\n }\n totalSimilarity += bestSim;\n if (bestSim >= finalConfig.threshold) {\n matchCount++;\n }\n }\n\n // Return combination of average similarity and match ratio\n const avgSimilarity = totalSimilarity / words1.length;\n const matchRatio = matchCount / Math.max(words1.length, words2.length);\n\n return avgSimilarity * 0.5 + matchRatio * 0.5;\n}\n\n/**\n * Tokenize a string for matching\n * Handles camelCase, PascalCase, snake_case, kebab-case\n */\nexport function tokenize(s: string): string[] {\n return s\n // Split camelCase and PascalCase\n .replace(/([a-z])([A-Z])/g, '$1 $2')\n // Split snake_case and kebab-case\n .replace(/[_-]/g, ' ')\n // Normalize whitespace\n .replace(/\\s+/g, ' ')\n .trim()\n .toLowerCase()\n .split(' ')\n .filter((token) => token.length > 0);\n}\n\n/**\n * Calculate token-based similarity\n * Better for matching identifiers and labels\n */\nexport function tokenSimilarity(s1: string, s2: string): number {\n const tokens1 = tokenize(s1);\n const tokens2 = tokenize(s2);\n\n if (tokens1.length === 0 && tokens2.length === 0) return 1;\n if (tokens1.length === 0 || tokens2.length === 0) return 0;\n\n const set1 = new Set(tokens1);\n const set2 = new Set(tokens2);\n\n // Calculate Jaccard similarity on tokens\n let intersection = 0;\n for (const token of set1) {\n if (set2.has(token)) {\n intersection++;\n }\n }\n\n const union = set1.size + set2.size - intersection;\n return union === 0 ? 0 : intersection / union;\n}\n","/**\n * Alias Generator\n *\n * Auto-generates element aliases from visible text, aria-label, placeholders,\n * titles, and common synonyms for natural language matching.\n */\n\nimport { tokenize } from './fuzzy-matcher';\n\n/**\n * Configuration for alias generation\n */\nexport interface AliasGeneratorConfig {\n /** Include text content as alias */\n includeText: boolean;\n /** Include aria-label as alias */\n includeAriaLabel: boolean;\n /** Include placeholder text as alias */\n includePlaceholder: boolean;\n /** Include title attribute as alias */\n includeTitle: boolean;\n /** Include common synonyms */\n includeSynonyms: boolean;\n /** Maximum number of aliases to generate */\n maxAliases: number;\n /** Minimum alias length */\n minLength: number;\n /** Maximum alias length */\n maxLength: number;\n}\n\n/**\n * Default alias generator configuration\n */\nexport const DEFAULT_ALIAS_CONFIG: AliasGeneratorConfig = {\n includeText: true,\n includeAriaLabel: true,\n includePlaceholder: true,\n includeTitle: true,\n includeSynonyms: true,\n maxAliases: 20,\n minLength: 2,\n maxLength: 50,\n};\n\n/**\n * Common synonyms for UI actions and elements\n */\nconst SYNONYMS: Record<string, string[]> = {\n // Submit-related\n submit: ['send', 'go', 'confirm', 'ok', 'apply', 'save', 'done', 'finish'],\n send: ['submit', 'deliver', 'post'],\n save: ['submit', 'store', 'keep', 'apply'],\n cancel: ['close', 'dismiss', 'abort', 'back', 'exit', 'quit', 'nevermind'],\n close: ['cancel', 'dismiss', 'exit', 'x'],\n delete: ['remove', 'trash', 'erase', 'clear', 'destroy'],\n remove: ['delete', 'clear', 'discard'],\n edit: ['modify', 'change', 'update', 'alter'],\n update: ['edit', 'modify', 'save', 'refresh'],\n add: ['create', 'new', 'plus', 'insert'],\n create: ['add', 'new', 'make'],\n search: ['find', 'lookup', 'query', 'filter'],\n find: ['search', 'locate', 'lookup'],\n login: ['signin', 'sign in', 'log in', 'authenticate', 'enter'],\n logout: ['signout', 'sign out', 'log out', 'exit'],\n register: ['signup', 'sign up', 'join', 'create account'],\n next: ['continue', 'forward', 'proceed', 'advance'],\n previous: ['back', 'backward', 'return', 'prior'],\n back: ['previous', 'return', 'backward'],\n start: ['begin', 'launch', 'initiate', 'run', 'execute'],\n stop: ['end', 'halt', 'pause', 'terminate'],\n enable: ['activate', 'turn on', 'switch on'],\n disable: ['deactivate', 'turn off', 'switch off'],\n show: ['display', 'reveal', 'view', 'open'],\n hide: ['conceal', 'collapse', 'close'],\n expand: ['open', 'show', 'unfold', 'reveal'],\n collapse: ['close', 'hide', 'fold', 'minimize'],\n yes: ['ok', 'confirm', 'agree', 'accept'],\n no: ['cancel', 'decline', 'reject', 'deny'],\n help: ['support', 'assistance', 'info', 'information', 'faq'],\n settings: ['preferences', 'options', 'config', 'configuration'],\n profile: ['account', 'user', 'me'],\n download: ['export', 'save', 'get'],\n upload: ['import', 'load', 'attach'],\n refresh: ['reload', 'update', 'sync'],\n copy: ['duplicate', 'clone'],\n paste: ['insert'],\n select: ['choose', 'pick'],\n toggle: ['switch', 'flip'],\n\n // Form fields\n email: ['e-mail', 'mail'],\n password: ['pass', 'pwd', 'secret'],\n username: ['user', 'login', 'account', 'name'],\n firstname: ['first name', 'given name', 'forename'],\n lastname: ['last name', 'surname', 'family name'],\n fullname: ['full name', 'name', 'complete name'],\n phone: ['telephone', 'tel', 'mobile', 'cell'],\n address: ['location', 'street'],\n city: ['town'],\n country: ['nation'],\n zip: ['zipcode', 'postal', 'postal code', 'postcode'],\n\n // Navigation\n home: ['main', 'start', 'dashboard'],\n menu: ['navigation', 'nav'],\n sidebar: ['side bar', 'side panel', 'side menu'],\n};\n\n/**\n * Element type to action word mappings\n */\nconst ELEMENT_ACTION_WORDS: Record<string, string[]> = {\n button: ['button', 'btn', 'click'],\n input: ['input', 'field', 'textbox', 'box'],\n textarea: ['textarea', 'text area', 'text field', 'multiline'],\n select: ['select', 'dropdown', 'combo', 'picker', 'chooser'],\n checkbox: ['checkbox', 'check', 'tick'],\n radio: ['radio', 'option', 'choice'],\n link: ['link', 'anchor', 'href'],\n form: ['form'],\n menu: ['menu'],\n menuitem: ['menu item', 'option'],\n tab: ['tab'],\n dialog: ['dialog', 'modal', 'popup'],\n switch: ['switch', 'toggle'],\n slider: ['slider', 'range'],\n};\n\n/**\n * Normalize text for alias comparison\n */\nfunction normalizeAlias(text: string): string {\n return text\n .toLowerCase()\n .replace(/[^\\w\\s]/g, ' ')\n .replace(/\\s+/g, ' ')\n .trim();\n}\n\n/**\n * Extract words from text, handling various naming conventions\n */\nfunction extractWords(text: string): string[] {\n const tokens = tokenize(text);\n return tokens.filter((t) => t.length >= 2);\n}\n\n/**\n * Generate aliases from text content\n */\nfunction generateTextAliases(text: string | null | undefined, config: AliasGeneratorConfig): string[] {\n if (!text || !config.includeText) return [];\n\n const aliases: string[] = [];\n const normalized = normalizeAlias(text);\n\n // Add full normalized text\n if (normalized.length >= config.minLength && normalized.length <= config.maxLength) {\n aliases.push(normalized);\n }\n\n // Add individual words\n const words = extractWords(text);\n for (const word of words) {\n if (word.length >= config.minLength) {\n aliases.push(word);\n }\n }\n\n // Add word combinations\n if (words.length >= 2 && words.length <= 4) {\n // First two words\n const twoWords = words.slice(0, 2).join(' ');\n if (twoWords.length <= config.maxLength) {\n aliases.push(twoWords);\n }\n\n // Last two words\n if (words.length > 2) {\n const lastTwo = words.slice(-2).join(' ');\n if (lastTwo.length <= config.maxLength) {\n aliases.push(lastTwo);\n }\n }\n }\n\n return aliases;\n}\n\n/**\n * Generate synonyms for given aliases\n */\nfunction generateSynonyms(aliases: string[], config: AliasGeneratorConfig): string[] {\n if (!config.includeSynonyms) return [];\n\n const synonyms: string[] = [];\n\n for (const alias of aliases) {\n const words = alias.toLowerCase().split(/\\s+/);\n\n for (const word of words) {\n if (SYNONYMS[word]) {\n for (const synonym of SYNONYMS[word]) {\n // Replace word with synonym in the alias\n const newAlias = alias.toLowerCase().replace(word, synonym);\n if (newAlias !== alias.toLowerCase()) {\n synonyms.push(newAlias);\n }\n\n // Also add standalone synonym\n if (synonym.length >= config.minLength) {\n synonyms.push(synonym);\n }\n }\n }\n }\n }\n\n return synonyms;\n}\n\n/**\n * Generate element type aliases\n */\nfunction generateTypeAliases(elementType: string): string[] {\n const type = elementType.toLowerCase();\n return ELEMENT_ACTION_WORDS[type] || [type];\n}\n\n/**\n * Interface for element information used in alias generation\n */\nexport interface AliasGeneratorInput {\n /** Element text content */\n textContent?: string | null;\n /** ARIA label */\n ariaLabel?: string | null;\n /** ARIA labelledby resolved text */\n ariaLabelledBy?: string | null;\n /** Placeholder text */\n placeholder?: string | null;\n /** Title attribute */\n title?: string | null;\n /** Element type */\n elementType?: string;\n /** Element tag name */\n tagName?: string;\n /** Input type */\n inputType?: string;\n /** Element ID */\n id?: string | null;\n /** Element name attribute */\n name?: string | null;\n /** Associated label text */\n labelText?: string | null;\n /** Value attribute */\n value?: string | null;\n}\n\n/**\n * Generate aliases for an element\n */\nexport function generateAliases(\n input: AliasGeneratorInput,\n config: Partial<AliasGeneratorConfig> = {}\n): string[] {\n const finalConfig = { ...DEFAULT_ALIAS_CONFIG, ...config };\n const aliasSet = new Set<string>();\n\n // Helper to add alias with deduplication and length checks\n const addAlias = (alias: string) => {\n const normalized = normalizeAlias(alias);\n if (\n normalized.length >= finalConfig.minLength &&\n normalized.length <= finalConfig.maxLength\n ) {\n aliasSet.add(normalized);\n }\n };\n\n // Helper to add multiple aliases\n const addAliases = (aliases: string[]) => {\n for (const alias of aliases) {\n addAlias(alias);\n }\n };\n\n // Generate from text content\n if (finalConfig.includeText && input.textContent) {\n addAliases(generateTextAliases(input.textContent, finalConfig));\n }\n\n // Generate from ARIA label\n if (finalConfig.includeAriaLabel && input.ariaLabel) {\n addAliases(generateTextAliases(input.ariaLabel, finalConfig));\n }\n\n // Generate from ARIA labelledby\n if (finalConfig.includeAriaLabel && input.ariaLabelledBy) {\n addAliases(generateTextAliases(input.ariaLabelledBy, finalConfig));\n }\n\n // Generate from placeholder\n if (finalConfig.includePlaceholder && input.placeholder) {\n addAliases(generateTextAliases(input.placeholder, finalConfig));\n }\n\n // Generate from title\n if (finalConfig.includeTitle && input.title) {\n addAliases(generateTextAliases(input.title, finalConfig));\n }\n\n // Generate from label text\n if (input.labelText) {\n addAliases(generateTextAliases(input.labelText, finalConfig));\n }\n\n // Generate from element ID (often meaningful)\n if (input.id) {\n addAliases(extractWords(input.id));\n }\n\n // Generate from name attribute\n if (input.name) {\n addAliases(extractWords(input.name));\n }\n\n // Generate from value for buttons/submit inputs\n if (\n input.value &&\n (input.elementType === 'button' || input.inputType === 'submit' || input.inputType === 'button')\n ) {\n addAliases(generateTextAliases(input.value, finalConfig));\n }\n\n // Generate type aliases\n if (input.elementType) {\n addAliases(generateTypeAliases(input.elementType));\n }\n\n // Generate input type aliases\n if (input.inputType) {\n addAlias(input.inputType);\n\n // Common input type patterns\n if (input.inputType === 'email') {\n addAliases(['email', 'e-mail', 'email address']);\n } else if (input.inputType === 'password') {\n addAliases(['password', 'pass', 'pwd']);\n } else if (input.inputType === 'tel') {\n addAliases(['phone', 'telephone', 'mobile']);\n } else if (input.inputType === 'url') {\n addAliases(['url', 'website', 'link', 'address']);\n } else if (input.inputType === 'search') {\n addAliases(['search', 'find', 'query']);\n }\n }\n\n // Generate synonyms for all collected aliases\n if (finalConfig.includeSynonyms) {\n const currentAliases = Array.from(aliasSet);\n addAliases(generateSynonyms(currentAliases, finalConfig));\n }\n\n // Convert to array and limit\n let aliases = Array.from(aliasSet);\n\n // Sort by length (shorter = more likely to be useful)\n aliases.sort((a, b) => a.length - b.length);\n\n // Limit number of aliases\n if (aliases.length > finalConfig.maxAliases) {\n aliases = aliases.slice(0, finalConfig.maxAliases);\n }\n\n return aliases;\n}\n\n/**\n * Generate a human-readable description for an element\n */\nexport function generateDescription(input: AliasGeneratorInput): string {\n const parts: string[] = [];\n\n // Determine the best name for the element\n let name =\n input.ariaLabel ||\n input.labelText ||\n input.textContent ||\n input.placeholder ||\n input.title ||\n input.id ||\n input.name;\n\n if (name) {\n name = name.trim();\n // Truncate if too long\n if (name.length > 30) {\n name = name.substring(0, 27) + '...';\n }\n parts.push(`\"${name}\"`);\n }\n\n // Add element type\n const typeWords = ELEMENT_ACTION_WORDS[input.elementType || ''] || [input.elementType || 'element'];\n parts.push(typeWords[0]);\n\n // Add input type for inputs\n if (input.inputType && input.inputType !== 'text') {\n parts.push(`(${input.inputType})`);\n }\n\n return parts.join(' ');\n}\n\n/**\n * Generate a purpose statement for an element\n */\nexport function generatePurpose(input: AliasGeneratorInput): string | undefined {\n const text = (input.textContent || input.ariaLabel || input.title || '').toLowerCase();\n const type = input.elementType?.toLowerCase() || '';\n const inputType = input.inputType?.toLowerCase() || '';\n\n // Check for common patterns\n if (type === 'button' || inputType === 'submit') {\n if (text.match(/submit|send|save|confirm|ok|done|finish|apply/)) {\n return 'Submits the form';\n }\n if (text.match(/cancel|close|dismiss|back|exit/)) {\n return 'Cancels or closes the current action';\n }\n if (text.match(/delete|remove|trash|clear/)) {\n return 'Deletes or removes an item';\n }\n if (text.match(/edit|modify|change|update/)) {\n return 'Edits or modifies an item';\n }\n if (text.match(/add|create|new|\\+/)) {\n return 'Creates or adds a new item';\n }\n if (text.match(/search|find|lookup/)) {\n return 'Performs a search';\n }\n if (text.match(/login|sign.?in/)) {\n return 'Signs the user in';\n }\n if (text.match(/logout|sign.?out/)) {\n return 'Signs the user out';\n }\n if (text.match(/register|sign.?up|join/)) {\n return 'Creates a new account';\n }\n if (text.match(/next|continue|proceed/)) {\n return 'Proceeds to the next step';\n }\n if (text.match(/previous|back|return/)) {\n return 'Returns to the previous step';\n }\n }\n\n if (type === 'input' || type === 'textarea') {\n if (inputType === 'email') return 'Accepts email address input';\n if (inputType === 'password') return 'Accepts password input';\n if (inputType === 'search') return 'Accepts search query input';\n if (inputType === 'tel') return 'Accepts phone number input';\n if (inputType === 'url') return 'Accepts URL input';\n if (inputType === 'number') return 'Accepts numeric input';\n if (inputType === 'date') return 'Accepts date input';\n if (inputType === 'file') return 'Accepts file upload';\n }\n\n if (type === 'checkbox') {\n return 'Toggles an option on or off';\n }\n\n if (type === 'radio') {\n return 'Selects one option from a group';\n }\n\n if (type === 'select') {\n return 'Selects an option from a dropdown';\n }\n\n if (type === 'link') {\n return 'Navigates to another page';\n }\n\n return undefined;\n}\n\n/**\n * Generate suggested actions for an element\n */\nexport function generateSuggestedActions(input: AliasGeneratorInput): string[] {\n const type = input.elementType?.toLowerCase() || '';\n const inputType = input.inputType?.toLowerCase() || '';\n const text = (input.textContent || input.ariaLabel || '').toLowerCase();\n const actions: string[] = [];\n\n switch (type) {\n case 'button':\n actions.push(`click \"${text || 'this button'}\"`);\n break;\n case 'input':\n if (inputType === 'checkbox') {\n actions.push('check to enable', 'uncheck to disable');\n } else if (inputType === 'radio') {\n actions.push('select this option');\n } else {\n actions.push(`type into \"${text || 'this field'}\"`);\n actions.push('clear the field');\n }\n break;\n case 'textarea':\n actions.push(`type into \"${text || 'this text area'}\"`);\n actions.push('clear the content');\n break;\n case 'select':\n actions.push(`select an option from \"${text || 'this dropdown'}\"`);\n break;\n case 'checkbox':\n actions.push('check to enable', 'uncheck to disable');\n break;\n case 'radio':\n actions.push('select this option');\n break;\n case 'link':\n actions.push(`click to navigate to \"${text || 'the linked page'}\"`);\n break;\n case 'switch':\n actions.push('toggle on', 'toggle off');\n break;\n default:\n actions.push('click');\n }\n\n return actions;\n}\n\n/**\n * Get synonyms for a word\n */\nexport function getSynonyms(word: string): string[] {\n const normalized = word.toLowerCase().trim();\n return SYNONYMS[normalized] || [];\n}\n\n/**\n * Check if two words are synonyms\n */\nexport function areSynonyms(word1: string, word2: string): boolean {\n const w1 = word1.toLowerCase().trim();\n const w2 = word2.toLowerCase().trim();\n\n if (w1 === w2) return true;\n\n const synonyms1 = SYNONYMS[w1] || [];\n const synonyms2 = SYNONYMS[w2] || [];\n\n return synonyms1.includes(w2) || synonyms2.includes(w1);\n}\n","/**\n * Search Engine\n *\n * Multi-strategy element search using text, role, accessibility,\n * spatial proximity, and fuzzy matching.\n */\n\nimport type { RegisteredElement, ElementState } from '../core/types';\nimport type { DiscoveredElement } from '../control/types';\nimport type {\n SearchCriteria,\n SearchResult,\n SearchResponse,\n AIDiscoveredElement,\n} from './types';\nimport {\n fuzzyMatch,\n fuzzyContains,\n wordSimilarity,\n tokenSimilarity,\n DEFAULT_FUZZY_CONFIG,\n} from './fuzzy-matcher';\nimport {\n generateAliases,\n generateDescription,\n generatePurpose,\n generateSuggestedActions,\n areSynonyms,\n} from './alias-generator';\n\n/**\n * Configuration for the search engine\n */\nexport interface SearchEngineConfig {\n /** Default fuzzy threshold */\n fuzzyThreshold: number;\n /** Weight for text matching */\n textWeight: number;\n /** Weight for accessibility matching */\n accessibilityWeight: number;\n /** Weight for role matching */\n roleWeight: number;\n /** Weight for spatial matching */\n spatialWeight: number;\n /** Weight for alias matching */\n aliasWeight: number;\n /** Maximum results to return */\n maxResults: number;\n /** Include hidden elements */\n includeHidden: boolean;\n}\n\n/**\n * Default search engine configuration\n */\nexport const DEFAULT_SEARCH_CONFIG: SearchEngineConfig = {\n fuzzyThreshold: 0.7,\n textWeight: 0.35,\n accessibilityWeight: 0.25,\n roleWeight: 0.15,\n spatialWeight: 0.1,\n aliasWeight: 0.15,\n maxResults: 20,\n includeHidden: false,\n};\n\n/**\n * Internal element representation for search\n */\ninterface SearchableElement {\n id: string;\n element: DiscoveredElement | RegisteredElement;\n state: ElementState;\n textContent?: string;\n ariaLabel?: string;\n ariaLabelledBy?: string;\n placeholder?: string;\n title?: string;\n role?: string;\n tagName: string;\n type: string;\n aliases: string[];\n description: string;\n rect: ElementState['rect'];\n labelText?: string;\n value?: string;\n}\n\n/**\n * Search Engine class\n */\nexport class SearchEngine {\n private config: SearchEngineConfig;\n private cachedElements: SearchableElement[] = [];\n private cacheTimestamp: number = 0;\n private readonly cacheValidityMs = 100; // Cache valid for 100ms\n\n constructor(config: Partial<SearchEngineConfig> = {}) {\n this.config = { ...DEFAULT_SEARCH_CONFIG, ...config };\n }\n\n /**\n * Update cached elements from various sources\n */\n updateElements(\n elements: Array<DiscoveredElement | RegisteredElement>,\n getState?: (el: RegisteredElement) => ElementState\n ): void {\n this.cachedElements = elements.map((el) => this.toSearchable(el, getState));\n this.cacheTimestamp = Date.now();\n }\n\n /**\n * Convert an element to searchable format\n */\n private toSearchable(\n element: DiscoveredElement | RegisteredElement,\n getState?: (el: RegisteredElement) => ElementState\n ): SearchableElement {\n // Get state depending on element type\n let state: ElementState;\n let textContent: string | undefined;\n let tagName: string;\n let role: string | undefined;\n let ariaLabel: string | undefined;\n let placeholder: string | undefined;\n let title: string | undefined;\n let labelText: string | undefined;\n let value: string | undefined;\n\n if ('getState' in element && typeof element.getState === 'function') {\n // RegisteredElement\n state = getState ? getState(element) : element.getState();\n textContent = state.textContent || undefined;\n tagName = element.element.tagName.toLowerCase();\n role = element.element.getAttribute('role') || undefined;\n ariaLabel = element.element.getAttribute('aria-label') || undefined;\n placeholder = element.element.getAttribute('placeholder') || undefined;\n title = element.element.getAttribute('title') || undefined;\n\n // Get associated label\n if (element.element.id) {\n const labelEl = document.querySelector(`label[for=\"${element.element.id}\"]`);\n labelText = labelEl?.textContent?.trim() || undefined;\n }\n\n // Get value for inputs\n if (element.element instanceof HTMLInputElement ||\n element.element instanceof HTMLTextAreaElement ||\n element.element instanceof HTMLSelectElement) {\n value = (element.element as HTMLInputElement).value || undefined;\n }\n } else {\n // DiscoveredElement\n const discovered = element as DiscoveredElement;\n state = discovered.state;\n textContent = state.textContent || undefined;\n tagName = discovered.tagName;\n role = discovered.role || undefined;\n ariaLabel = discovered.accessibleName || undefined;\n }\n\n // Generate aliases and description\n const aliases = generateAliases({\n textContent,\n ariaLabel,\n placeholder,\n title,\n elementType: element.type,\n tagName,\n id: element.id,\n labelText,\n value,\n });\n\n const description = generateDescription({\n textContent,\n ariaLabel,\n placeholder,\n title,\n elementType: element.type,\n tagName,\n id: element.id,\n labelText,\n });\n\n return {\n id: element.id,\n element,\n state,\n textContent,\n ariaLabel,\n placeholder,\n title,\n role,\n tagName,\n type: element.type,\n aliases,\n description,\n rect: state.rect,\n labelText,\n value,\n };\n }\n\n /**\n * Search for elements matching the criteria\n */\n search(\n criteria: SearchCriteria,\n elements?: Array<DiscoveredElement | RegisteredElement>\n ): SearchResponse {\n const startTime = performance.now();\n\n // Update cache if elements provided or cache expired\n if (elements) {\n this.updateElements(elements);\n }\n\n // Filter visible elements if needed\n let searchableElements = this.cachedElements;\n if (!this.config.includeHidden && !criteria.fuzzy) {\n searchableElements = searchableElements.filter((el) => el.state.visible);\n }\n\n // Score each element\n const results: SearchResult[] = [];\n\n for (const searchable of searchableElements) {\n const result = this.scoreElement(searchable, criteria);\n if (result.confidence >= (criteria.fuzzyThreshold ?? this.config.fuzzyThreshold)) {\n results.push(result);\n }\n }\n\n // Sort by confidence\n results.sort((a, b) => b.confidence - a.confidence);\n\n // Limit results\n const limitedResults = results.slice(0, this.config.maxResults);\n\n return {\n results: limitedResults,\n bestMatch: limitedResults.length > 0 ? limitedResults[0] : null,\n scannedCount: searchableElements.length,\n durationMs: performance.now() - startTime,\n criteria,\n timestamp: Date.now(),\n };\n }\n\n /**\n * Find the best matching element\n */\n findBest(\n criteria: SearchCriteria,\n elements?: Array<DiscoveredElement | RegisteredElement>\n ): SearchResult | null {\n const response = this.search(criteria, elements);\n return response.bestMatch;\n }\n\n /**\n * Find elements by text content\n */\n findByText(\n text: string,\n fuzzy: boolean = true,\n elements?: Array<DiscoveredElement | RegisteredElement>\n ): SearchResult[] {\n return this.search({ text, fuzzy }, elements).results;\n }\n\n /**\n * Find elements by role\n */\n findByRole(\n role: string,\n name?: string,\n elements?: Array<DiscoveredElement | RegisteredElement>\n ): SearchResult[] {\n const criteria: SearchCriteria = { role };\n if (name) {\n criteria.accessibleName = name;\n }\n return this.search(criteria, elements).results;\n }\n\n /**\n * Find elements by accessible name\n */\n findByAccessibleName(\n name: string,\n elements?: Array<DiscoveredElement | RegisteredElement>\n ): SearchResult[] {\n return this.search({ accessibleName: name, fuzzy: true }, elements).results;\n }\n\n /**\n * Find elements near another element\n */\n findNear(\n referenceId: string,\n criteria?: SearchCriteria,\n elements?: Array<DiscoveredElement | RegisteredElement>\n ): SearchResult[] {\n return this.search({ ...criteria, near: referenceId }, elements).results;\n }\n\n /**\n * Find elements within a container\n */\n findWithin(\n containerId: string,\n criteria?: SearchCriteria,\n elements?: Array<DiscoveredElement | RegisteredElement>\n ): SearchResult[] {\n return this.search({ ...criteria, within: containerId }, elements).results;\n }\n\n /**\n * Score an element against search criteria\n */\n private scoreElement(\n searchable: SearchableElement,\n criteria: SearchCriteria\n ): SearchResult {\n const scores: SearchResult['scores'] = {};\n const matchReasons: string[] = [];\n let totalWeight = 0;\n let weightedScore = 0;\n\n const fuzzyConfig = {\n ...DEFAULT_FUZZY_CONFIG,\n threshold: criteria.fuzzyThreshold ?? this.config.fuzzyThreshold,\n };\n\n // Text matching\n if (criteria.text) {\n const textScore = this.scoreTextMatch(searchable, criteria.text, criteria.fuzzy !== false, fuzzyConfig.threshold);\n scores.text = textScore.score;\n if (textScore.score > 0) {\n matchReasons.push(...textScore.reasons);\n }\n weightedScore += textScore.score * this.config.textWeight;\n totalWeight += this.config.textWeight;\n }\n\n // Partial text matching (contains)\n if (criteria.textContains) {\n const containsScore = this.scoreContainsMatch(searchable, criteria.textContains, criteria.fuzzy !== false);\n scores.text = Math.max(scores.text || 0, containsScore.score);\n if (containsScore.score > 0 && containsScore.reasons.length > 0) {\n matchReasons.push(...containsScore.reasons);\n }\n weightedScore += containsScore.score * this.config.textWeight;\n totalWeight += this.config.textWeight;\n }\n\n // Accessible name matching\n if (criteria.accessibleName) {\n const accessibilityScore = this.scoreAccessibilityMatch(\n searchable,\n criteria.accessibleName,\n criteria.fuzzy !== false,\n fuzzyConfig.threshold\n );\n scores.accessibility = accessibilityScore.score;\n if (accessibilityScore.score > 0) {\n matchReasons.push(...accessibilityScore.reasons);\n }\n weightedScore += accessibilityScore.score * this.config.accessibilityWeight;\n totalWeight += this.config.accessibilityWeight;\n }\n\n // Role matching\n if (criteria.role) {\n const roleScore = this.scoreRoleMatch(searchable, criteria.role);\n scores.role = roleScore.score;\n if (roleScore.score > 0) {\n matchReasons.push(...roleScore.reasons);\n }\n weightedScore += roleScore.score * this.config.roleWeight;\n totalWeight += this.config.roleWeight;\n }\n\n // Type matching\n if (criteria.type) {\n const typeMatch = searchable.type.toLowerCase() === criteria.type.toLowerCase();\n if (typeMatch) {\n matchReasons.push(`type: ${criteria.type}`);\n weightedScore += 1.0 * this.config.roleWeight;\n totalWeight += this.config.roleWeight;\n }\n }\n\n // Spatial matching (near)\n if (criteria.near) {\n const spatialScore = this.scoreSpatialMatch(searchable, criteria.near);\n scores.spatial = spatialScore.score;\n if (spatialScore.score > 0) {\n matchReasons.push(...spatialScore.reasons);\n }\n weightedScore += spatialScore.score * this.config.spatialWeight;\n totalWeight += this.config.spatialWeight;\n }\n\n // Placeholder matching\n if (criteria.placeholder && searchable.placeholder) {\n const placeholderResult = fuzzyMatch(searchable.placeholder, criteria.placeholder, fuzzyConfig);\n if (placeholderResult.isMatch) {\n matchReasons.push(`placeholder matches`);\n weightedScore += placeholderResult.similarity * this.config.textWeight;\n totalWeight += this.config.textWeight;\n }\n }\n\n // Title matching\n if (criteria.title && searchable.title) {\n const titleResult = fuzzyMatch(searchable.title, criteria.title, fuzzyConfig);\n if (titleResult.isMatch) {\n matchReasons.push(`title matches`);\n weightedScore += titleResult.similarity * this.config.textWeight;\n totalWeight += this.config.textWeight;\n }\n }\n\n // ID pattern matching\n if (criteria.idPattern) {\n const idMatch = this.matchPattern(searchable.id, criteria.idPattern);\n if (idMatch) {\n matchReasons.push(`id matches pattern`);\n weightedScore += 1.0 * this.config.textWeight;\n totalWeight += this.config.textWeight;\n }\n }\n\n // Alias matching (always applied as a bonus)\n const aliasScore = this.scoreAliasMatch(searchable, criteria, fuzzyConfig.threshold);\n if (aliasScore.score > 0) {\n scores.fuzzy = aliasScore.score;\n matchReasons.push(...aliasScore.reasons);\n weightedScore += aliasScore.score * this.config.aliasWeight;\n totalWeight += this.config.aliasWeight;\n }\n\n // Calculate final confidence\n const confidence = totalWeight > 0 ? weightedScore / totalWeight : 0;\n\n // Convert to AIDiscoveredElement\n const aiElement = this.toAIDiscoveredElement(searchable);\n\n return {\n element: aiElement,\n confidence,\n matchReasons,\n scores,\n };\n }\n\n /**\n * Score text match\n */\n private scoreTextMatch(\n searchable: SearchableElement,\n text: string,\n fuzzy: boolean,\n threshold: number\n ): { score: number; reasons: string[] } {\n const reasons: string[] = [];\n let maxScore = 0;\n\n const textsToMatch = [\n searchable.textContent,\n searchable.labelText,\n searchable.value,\n ].filter(Boolean) as string[];\n\n for (const targetText of textsToMatch) {\n // Exact match\n if (targetText.toLowerCase() === text.toLowerCase()) {\n maxScore = Math.max(maxScore, 1.0);\n reasons.push('exact text match');\n continue;\n }\n\n // Fuzzy match\n if (fuzzy) {\n const result = fuzzyMatch(targetText, text, { threshold });\n if (result.isMatch && result.similarity > maxScore) {\n maxScore = result.similarity;\n reasons.push(`text similarity: ${(result.similarity * 100).toFixed(0)}%`);\n }\n\n // Word-level match\n const wordSim = wordSimilarity(targetText, text, { threshold });\n if (wordSim > maxScore && wordSim >= threshold) {\n maxScore = wordSim;\n reasons.push(`word match: ${(wordSim * 100).toFixed(0)}%`);\n }\n }\n }\n\n return { score: maxScore, reasons };\n }\n\n /**\n * Score contains match\n */\n private scoreContainsMatch(\n searchable: SearchableElement,\n text: string,\n fuzzy: boolean\n ): { score: number; reasons: string[] } {\n const reasons: string[] = [];\n let maxScore = 0;\n\n const textsToMatch = [\n searchable.textContent,\n searchable.labelText,\n searchable.ariaLabel,\n ].filter(Boolean) as string[];\n\n for (const targetText of textsToMatch) {\n // Exact contains\n if (targetText.toLowerCase().includes(text.toLowerCase())) {\n maxScore = Math.max(maxScore, 0.9);\n reasons.push('text contains match');\n continue;\n }\n\n // Fuzzy contains\n if (fuzzy && fuzzyContains(targetText, text)) {\n maxScore = Math.max(maxScore, 0.7);\n reasons.push('fuzzy contains match');\n }\n }\n\n return { score: maxScore, reasons };\n }\n\n /**\n * Score accessibility match\n */\n private scoreAccessibilityMatch(\n searchable: SearchableElement,\n name: string,\n fuzzy: boolean,\n threshold: number\n ): { score: number; reasons: string[] } {\n const reasons: string[] = [];\n let maxScore = 0;\n\n const accessibleNames = [\n searchable.ariaLabel,\n searchable.ariaLabelledBy,\n searchable.labelText,\n searchable.title,\n ].filter(Boolean) as string[];\n\n for (const accessibleName of accessibleNames) {\n // Exact match\n if (accessibleName.toLowerCase() === name.toLowerCase()) {\n maxScore = Math.max(maxScore, 1.0);\n reasons.push('exact accessible name match');\n continue;\n }\n\n // Fuzzy match\n if (fuzzy) {\n const result = fuzzyMatch(accessibleName, name, { threshold });\n if (result.isMatch && result.similarity > maxScore) {\n maxScore = result.similarity;\n reasons.push(`accessible name similarity: ${(result.similarity * 100).toFixed(0)}%`);\n }\n }\n }\n\n return { score: maxScore, reasons };\n }\n\n /**\n * Score role match\n */\n private scoreRoleMatch(\n searchable: SearchableElement,\n role: string\n ): { score: number; reasons: string[] } {\n const reasons: string[] = [];\n const normalizedRole = role.toLowerCase();\n\n // Direct role match\n if (searchable.role?.toLowerCase() === normalizedRole) {\n return { score: 1.0, reasons: [`role: ${role}`] };\n }\n\n // Tag-based role inference\n const tagRoleMap: Record<string, string[]> = {\n button: ['button', 'input[type=button]', 'input[type=submit]'],\n textbox: ['input', 'textarea'],\n checkbox: ['input[type=checkbox]'],\n radio: ['input[type=radio]'],\n link: ['a'],\n listbox: ['select'],\n combobox: ['select', 'input[list]'],\n navigation: ['nav'],\n main: ['main'],\n heading: ['h1', 'h2', 'h3', 'h4', 'h5', 'h6'],\n };\n\n const inferredRoles = tagRoleMap[normalizedRole] || [];\n if (inferredRoles.some((r) => searchable.tagName === r || searchable.type.toLowerCase() === normalizedRole)) {\n return { score: 0.8, reasons: [`inferred role: ${role}`] };\n }\n\n return { score: 0, reasons };\n }\n\n /**\n * Score spatial match (proximity to another element)\n */\n private scoreSpatialMatch(\n searchable: SearchableElement,\n nearId: string\n ): { score: number; reasons: string[] } {\n // Find the reference element\n const reference = this.cachedElements.find((el) => el.id === nearId);\n if (!reference) {\n return { score: 0, reasons: [] };\n }\n\n // Calculate distance between elements\n const distance = this.calculateDistance(searchable.rect, reference.rect);\n\n // Score based on distance (closer = higher score)\n // Assuming 200px as \"near\" threshold\n const nearThreshold = 200;\n if (distance > nearThreshold * 3) {\n return { score: 0, reasons: [] };\n }\n\n const score = Math.max(0, 1 - distance / (nearThreshold * 3));\n return {\n score,\n reasons: [`${distance.toFixed(0)}px from ${nearId}`],\n };\n }\n\n /**\n * Calculate distance between two element rectangles\n */\n private calculateDistance(rect1: ElementState['rect'], rect2: ElementState['rect']): number {\n const center1 = {\n x: rect1.x + rect1.width / 2,\n y: rect1.y + rect1.height / 2,\n };\n const center2 = {\n x: rect2.x + rect2.width / 2,\n y: rect2.y + rect2.height / 2,\n };\n\n return Math.sqrt(Math.pow(center1.x - center2.x, 2) + Math.pow(center1.y - center2.y, 2));\n }\n\n /**\n * Score alias match\n */\n private scoreAliasMatch(\n searchable: SearchableElement,\n criteria: SearchCriteria,\n threshold: number\n ): { score: number; reasons: string[] } {\n const reasons: string[] = [];\n let maxScore = 0;\n\n // Build search terms from criteria\n const searchTerms: string[] = [];\n if (criteria.text) searchTerms.push(criteria.text);\n if (criteria.textContains) searchTerms.push(criteria.textContains);\n if (criteria.accessibleName) searchTerms.push(criteria.accessibleName);\n\n for (const searchTerm of searchTerms) {\n const termLower = searchTerm.toLowerCase();\n\n for (const alias of searchable.aliases) {\n // Exact alias match\n if (alias === termLower) {\n maxScore = Math.max(maxScore, 1.0);\n reasons.push(`alias match: \"${alias}\"`);\n continue;\n }\n\n // Synonym match\n const searchWords = termLower.split(/\\s+/);\n const aliasWords = alias.split(/\\s+/);\n\n for (const searchWord of searchWords) {\n for (const aliasWord of aliasWords) {\n if (areSynonyms(searchWord, aliasWord)) {\n maxScore = Math.max(maxScore, 0.85);\n reasons.push(`synonym match: \"${searchWord}\" ~ \"${aliasWord}\"`);\n }\n }\n }\n\n // Fuzzy alias match\n const result = fuzzyMatch(alias, termLower, { threshold });\n if (result.isMatch && result.similarity > maxScore) {\n maxScore = result.similarity;\n reasons.push(`fuzzy alias: \"${alias}\" (${(result.similarity * 100).toFixed(0)}%)`);\n }\n\n // Token similarity\n const tokenSim = tokenSimilarity(alias, termLower);\n if (tokenSim > maxScore && tokenSim >= threshold) {\n maxScore = tokenSim;\n reasons.push(`token match: \"${alias}\"`);\n }\n }\n }\n\n return { score: maxScore, reasons };\n }\n\n /**\n * Match a string against a pattern (supports * wildcard)\n */\n private matchPattern(str: string, pattern: string): boolean {\n const regexPattern = pattern\n .replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&')\n .replace(/\\\\\\*/g, '.*');\n return new RegExp(`^${regexPattern}$`, 'i').test(str);\n }\n\n /**\n * Convert searchable element to AI discovered element\n */\n private toAIDiscoveredElement(searchable: SearchableElement): AIDiscoveredElement {\n const discoveredBase: DiscoveredElement =\n 'getState' in searchable.element\n ? {\n id: searchable.id,\n type: searchable.type,\n label: (searchable.element as RegisteredElement).label,\n tagName: searchable.tagName,\n role: searchable.role,\n accessibleName: searchable.ariaLabel,\n actions: (searchable.element as RegisteredElement).actions,\n state: searchable.state,\n registered: true,\n }\n : (searchable.element as DiscoveredElement);\n\n return {\n ...discoveredBase,\n description: searchable.description,\n aliases: searchable.aliases,\n purpose: generatePurpose({\n textContent: searchable.textContent,\n ariaLabel: searchable.ariaLabel,\n elementType: searchable.type,\n tagName: searchable.tagName,\n }),\n parentContext: undefined, // Would need DOM traversal\n suggestedActions: generateSuggestedActions({\n textContent: searchable.textContent,\n ariaLabel: searchable.ariaLabel,\n elementType: searchable.type,\n tagName: searchable.tagName,\n }),\n semanticType: this.inferSemanticType(searchable),\n labelText: searchable.labelText,\n placeholder: searchable.placeholder,\n title: searchable.title,\n };\n }\n\n /**\n * Infer a semantic type for the element\n */\n private inferSemanticType(searchable: SearchableElement): string {\n const text = (searchable.textContent || searchable.ariaLabel || '').toLowerCase();\n const type = searchable.type.toLowerCase();\n\n // Form-related\n if (type === 'input' || type === 'textarea') {\n if (searchable.placeholder?.toLowerCase().includes('email') || text.includes('email')) {\n return 'email-input';\n }\n if (searchable.placeholder?.toLowerCase().includes('password') || text.includes('password')) {\n return 'password-input';\n }\n if (searchable.placeholder?.toLowerCase().includes('search') || text.includes('search')) {\n return 'search-input';\n }\n return 'text-input';\n }\n\n // Button types\n if (type === 'button') {\n if (text.match(/submit|save|confirm|ok|done|apply/)) return 'submit-button';\n if (text.match(/cancel|close|dismiss/)) return 'cancel-button';\n if (text.match(/delete|remove|trash/)) return 'delete-button';\n if (text.match(/add|create|new|\\+/)) return 'add-button';\n if (text.match(/edit|modify/)) return 'edit-button';\n if (text.match(/next|continue/)) return 'next-button';\n if (text.match(/back|previous/)) return 'back-button';\n return 'action-button';\n }\n\n // Navigation\n if (type === 'link') {\n if (text.match(/home|dashboard/)) return 'home-link';\n if (text.match(/login|sign.?in/)) return 'login-link';\n if (text.match(/logout|sign.?out/)) return 'logout-link';\n return 'navigation-link';\n }\n\n return type;\n }\n}\n\n/**\n * Create a default search engine instance\n */\nexport function createSearchEngine(config?: Partial<SearchEngineConfig>): SearchEngine {\n return new SearchEngine(config);\n}\n","/**\n * Summary Generator\n *\n * Generates LLM-friendly text summaries of pages and elements\n * for AI agents to understand the current UI state.\n */\n\nimport type { ElementState } from '../core/types';\nimport type { ControlSnapshot } from '../control/types';\nimport type {\n AIDiscoveredElement,\n FormAnalysis,\n FormState,\n PageContext,\n SemanticSnapshot,\n ModalState,\n} from './types';\n\n/**\n * Configuration for summary generation\n */\nexport interface SummaryConfig {\n /** Maximum summary length in characters */\n maxLength: number;\n /** Include form details */\n includeForms: boolean;\n /** Include element counts */\n includeElementCounts: boolean;\n /** Include active modals */\n includeModals: boolean;\n /** Include focused element */\n includeFocused: boolean;\n /** Verbosity level */\n verbosity: 'brief' | 'normal' | 'detailed';\n}\n\n/**\n * Default summary configuration\n */\nexport const DEFAULT_SUMMARY_CONFIG: SummaryConfig = {\n maxLength: 2000,\n includeForms: true,\n includeElementCounts: true,\n includeModals: true,\n includeFocused: true,\n verbosity: 'normal',\n};\n\n/**\n * Generate a page summary from elements\n */\nexport function generatePageSummary(\n elements: AIDiscoveredElement[],\n pageContext?: Partial<PageContext>,\n config: Partial<SummaryConfig> = {}\n): string {\n const finalConfig = { ...DEFAULT_SUMMARY_CONFIG, ...config };\n const lines: string[] = [];\n\n // Page context\n if (pageContext) {\n if (pageContext.title) {\n lines.push(`Page: \"${pageContext.title}\"`);\n }\n if (pageContext.pageType && pageContext.pageType !== 'unknown') {\n lines.push(`Type: ${formatPageType(pageContext.pageType)}`);\n }\n }\n\n // Element counts\n if (finalConfig.includeElementCounts) {\n const counts = countElementTypes(elements);\n const countParts: string[] = [];\n\n if (counts.button > 0) countParts.push(`${counts.button} button${counts.button > 1 ? 's' : ''}`);\n if (counts.input > 0) countParts.push(`${counts.input} input${counts.input > 1 ? 's' : ''}`);\n if (counts.link > 0) countParts.push(`${counts.link} link${counts.link > 1 ? 's' : ''}`);\n if (counts.select > 0) countParts.push(`${counts.select} dropdown${counts.select > 1 ? 's' : ''}`);\n if (counts.checkbox > 0) countParts.push(`${counts.checkbox} checkbox${counts.checkbox > 1 ? 'es' : ''}`);\n\n if (countParts.length > 0) {\n lines.push(`Contains: ${countParts.join(', ')}`);\n }\n }\n\n // Forms\n if (finalConfig.includeForms) {\n const forms = detectForms(elements);\n if (forms.length > 0) {\n lines.push('');\n lines.push('Forms:');\n for (const form of forms) {\n lines.push(generateFormSummary(form, finalConfig.verbosity));\n }\n }\n }\n\n // Active modals\n if (finalConfig.includeModals && pageContext?.activeModals && pageContext.activeModals.length > 0) {\n lines.push('');\n lines.push(`Active modals: ${pageContext.activeModals.join(', ')}`);\n }\n\n // Focused element\n if (finalConfig.includeFocused && pageContext?.focusedElement) {\n lines.push(`Focus: ${pageContext.focusedElement}`);\n }\n\n // Key interactive elements\n const keyElements = getKeyElements(elements);\n if (keyElements.length > 0) {\n lines.push('');\n lines.push('Key elements:');\n for (const el of keyElements) {\n lines.push(` - ${el.description}${el.state.enabled ? '' : ' (disabled)'}`);\n }\n }\n\n // Build final summary\n let summary = lines.join('\\n');\n\n // Truncate if needed\n if (summary.length > finalConfig.maxLength) {\n summary = summary.substring(0, finalConfig.maxLength - 3) + '...';\n }\n\n return summary;\n}\n\n/**\n * Generate an element description\n */\nexport function generateElementDescription(element: AIDiscoveredElement): string {\n const parts: string[] = [];\n\n // Element type and name\n const name = element.accessibleName || element.label || element.state.textContent?.trim();\n if (name) {\n parts.push(`\"${truncate(name, 30)}\"`);\n }\n\n // Type\n parts.push(formatElementType(element.type));\n\n // State indicators\n const stateIndicators: string[] = [];\n if (!element.state.visible) stateIndicators.push('hidden');\n if (!element.state.enabled) stateIndicators.push('disabled');\n if (element.state.focused) stateIndicators.push('focused');\n if (element.state.checked) stateIndicators.push('checked');\n\n if (stateIndicators.length > 0) {\n parts.push(`(${stateIndicators.join(', ')})`);\n }\n\n // Value for inputs\n if (element.state.value && element.type !== 'button') {\n const valuePreview = truncate(element.state.value, 20);\n parts.push(`value: \"${valuePreview}\"`);\n }\n\n return parts.join(' ');\n}\n\n/**\n * Generate a form summary\n */\nfunction generateFormSummary(form: FormAnalysis, verbosity: SummaryConfig['verbosity']): string {\n const lines: string[] = [];\n const formName = form.name || form.purpose || form.id;\n\n lines.push(` ${formName}:`);\n\n if (verbosity === 'brief') {\n const fieldCount = form.fields.length;\n const filledCount = form.fields.filter((f) => f.value).length;\n lines.push(` ${filledCount}/${fieldCount} fields filled, ${form.isValid ? 'valid' : 'has errors'}`);\n } else {\n // List fields\n for (const field of form.fields) {\n let fieldLine = ` - ${field.label || field.id}`;\n\n if (field.value) {\n fieldLine += ` = \"${truncate(field.value, 15)}\"`;\n } else if (field.placeholder) {\n fieldLine += ` (${field.placeholder})`;\n } else {\n fieldLine += ' (empty)';\n }\n\n if (!field.valid && field.error) {\n fieldLine += ` [ERROR: ${field.error}]`;\n } else if (field.required && !field.value) {\n fieldLine += ' [required]';\n }\n\n lines.push(fieldLine);\n }\n\n // Submit button\n if (form.submitButton) {\n lines.push(` Submit: ${form.submitButton}`);\n }\n }\n\n return lines.join('\\n');\n}\n\n/**\n * Generate a snapshot summary\n */\nexport function generateSnapshotSummary(\n snapshot: SemanticSnapshot,\n config: Partial<SummaryConfig> = {}\n): string {\n const finalConfig = { ...DEFAULT_SUMMARY_CONFIG, ...config };\n const lines: string[] = [];\n\n // Page info\n lines.push(`Page: \"${snapshot.page.title}\"`);\n lines.push(`URL: ${snapshot.page.url}`);\n if (snapshot.page.pageType) {\n lines.push(`Type: ${formatPageType(snapshot.page.pageType)}`);\n }\n\n // Element counts\n if (finalConfig.includeElementCounts) {\n const countParts: string[] = [];\n for (const [type, count] of Object.entries(snapshot.elementCounts)) {\n if (count > 0) {\n countParts.push(`${count} ${type}${count > 1 ? 's' : ''}`);\n }\n }\n if (countParts.length > 0) {\n lines.push(`Elements: ${countParts.join(', ')}`);\n }\n }\n\n // Forms\n if (finalConfig.includeForms && snapshot.forms.length > 0) {\n lines.push('');\n lines.push('Forms:');\n for (const form of snapshot.forms) {\n lines.push(generateFormStateSummary(form));\n }\n }\n\n // Modals\n if (finalConfig.includeModals && snapshot.activeModals.length > 0) {\n lines.push('');\n lines.push('Active dialogs:');\n for (const modal of snapshot.activeModals) {\n lines.push(` - ${modal.title || modal.id} (${modal.type})`);\n }\n }\n\n // Focused element\n if (finalConfig.includeFocused && snapshot.focusedElement) {\n const focused = snapshot.elements.find((e) => e.id === snapshot.focusedElement);\n if (focused) {\n lines.push(`Focused: ${generateElementDescription(focused)}`);\n }\n }\n\n return lines.join('\\n');\n}\n\n/**\n * Generate form state summary\n */\nfunction generateFormStateSummary(form: FormState): string {\n const lines: string[] = [];\n const formName = form.name || form.purpose || form.id;\n\n const filledCount = form.fields.filter((f) => f.value).length;\n const errorCount = form.fields.filter((f) => !f.valid).length;\n\n let statusLine = ` ${formName}: ${filledCount}/${form.fields.length} filled`;\n if (errorCount > 0) {\n statusLine += `, ${errorCount} error${errorCount > 1 ? 's' : ''}`;\n }\n if (form.isDirty) {\n statusLine += ' (modified)';\n }\n\n lines.push(statusLine);\n\n // List errors\n for (const field of form.fields) {\n if (!field.valid && field.error) {\n lines.push(` ERROR: ${field.label}: ${field.error}`);\n }\n }\n\n return lines.join('\\n');\n}\n\n/**\n * Generate diff summary\n */\nexport function generateDiffSummary(\n appeared: string[],\n disappeared: string[],\n modified: Array<{ description: string; property: string; from: string; to: string }>\n): string {\n const lines: string[] = [];\n\n if (appeared.length > 0) {\n lines.push(`Appeared: ${appeared.join(', ')}`);\n }\n\n if (disappeared.length > 0) {\n lines.push(`Disappeared: ${disappeared.join(', ')}`);\n }\n\n if (modified.length > 0) {\n lines.push('Changed:');\n for (const mod of modified.slice(0, 5)) {\n lines.push(` - ${mod.description}: ${mod.property} changed from \"${mod.from}\" to \"${mod.to}\"`);\n }\n if (modified.length > 5) {\n lines.push(` ... and ${modified.length - 5} more changes`);\n }\n }\n\n if (lines.length === 0) {\n return 'No changes detected';\n }\n\n return lines.join('\\n');\n}\n\n// ============================================================================\n// Helper Functions\n// ============================================================================\n\n/**\n * Count elements by type\n */\nfunction countElementTypes(elements: AIDiscoveredElement[]): Record<string, number> {\n const counts: Record<string, number> = {};\n\n for (const el of elements) {\n const type = el.type.toLowerCase();\n counts[type] = (counts[type] || 0) + 1;\n }\n\n return counts;\n}\n\n/**\n * Detect forms from elements\n */\nfunction detectForms(elements: AIDiscoveredElement[]): FormAnalysis[] {\n // Group inputs by common patterns (this is a simplified heuristic)\n const formElements = elements.filter(\n (el) => el.type === 'input' || el.type === 'textarea' || el.type === 'select' || el.type === 'checkbox'\n );\n\n if (formElements.length === 0) return [];\n\n // For simplicity, treat all inputs as one form if no explicit forms\n const forms: FormAnalysis[] = [];\n\n // Find submit buttons\n const submitButtons = elements.filter(\n (el) =>\n el.type === 'button' &&\n (el.state.textContent?.toLowerCase().includes('submit') ||\n el.state.textContent?.toLowerCase().includes('save') ||\n el.state.textContent?.toLowerCase().includes('send') ||\n el.semanticType === 'submit-button')\n );\n\n // Create a default form\n const defaultForm: FormAnalysis = {\n id: 'detected-form',\n purpose: inferFormPurpose(formElements),\n fields: formElements.map((el) => ({\n id: el.id,\n label: el.labelText || el.accessibleName || el.placeholder || el.id,\n type: el.type,\n value: el.state.value || '',\n valid: true, // Can't determine without validation state\n required: false, // Can't determine without DOM access\n placeholder: el.placeholder,\n })),\n isValid: true,\n submitButton: submitButtons[0]?.id,\n };\n\n if (defaultForm.fields.length > 0) {\n forms.push(defaultForm);\n }\n\n return forms;\n}\n\n/**\n * Infer form purpose from fields\n */\nfunction inferFormPurpose(fields: AIDiscoveredElement[]): string {\n const labels = fields.map((f) =>\n (f.labelText || f.accessibleName || f.placeholder || '').toLowerCase()\n );\n const allLabels = labels.join(' ');\n\n if (allLabels.includes('email') && allLabels.includes('password')) {\n if (allLabels.includes('confirm') || allLabels.includes('name')) {\n return 'Registration form';\n }\n return 'Login form';\n }\n\n if (allLabels.includes('search')) {\n return 'Search form';\n }\n\n if (allLabels.includes('address') || allLabels.includes('city') || allLabels.includes('zip')) {\n return 'Address form';\n }\n\n if (allLabels.includes('card') || allLabels.includes('cvv') || allLabels.includes('expir')) {\n return 'Payment form';\n }\n\n if (allLabels.includes('contact') || allLabels.includes('message')) {\n return 'Contact form';\n }\n\n return 'Form';\n}\n\n/**\n * Get key interactive elements for summary\n */\nfunction getKeyElements(elements: AIDiscoveredElement[]): AIDiscoveredElement[] {\n const keyElements: AIDiscoveredElement[] = [];\n\n // Prioritize submit/action buttons\n const actionButtons = elements.filter(\n (el) =>\n el.type === 'button' &&\n el.state.visible &&\n (el.semanticType?.includes('submit') ||\n el.semanticType?.includes('action') ||\n el.semanticType?.includes('next'))\n );\n keyElements.push(...actionButtons.slice(0, 2));\n\n // Add primary inputs\n const primaryInputs = elements.filter(\n (el) => (el.type === 'input' || el.type === 'textarea') && el.state.visible\n );\n keyElements.push(...primaryInputs.slice(0, 3));\n\n // Add visible links\n const links = elements.filter((el) => el.type === 'link' && el.state.visible);\n keyElements.push(...links.slice(0, 2));\n\n // Deduplicate and limit\n const unique = [...new Map(keyElements.map((e) => [e.id, e])).values()];\n return unique.slice(0, 8);\n}\n\n/**\n * Format page type for display\n */\nfunction formatPageType(\n pageType: PageContext['pageType']\n): string {\n const typeLabels: Record<NonNullable<PageContext['pageType']>, string> = {\n login: 'Login page',\n dashboard: 'Dashboard',\n form: 'Form page',\n list: 'List/table page',\n detail: 'Detail page',\n search: 'Search page',\n checkout: 'Checkout page',\n settings: 'Settings page',\n unknown: 'Unknown',\n };\n\n return typeLabels[pageType || 'unknown'] || 'Page';\n}\n\n/**\n * Format element type for display\n */\nfunction formatElementType(type: string): string {\n const typeLabels: Record<string, string> = {\n button: 'button',\n input: 'input field',\n textarea: 'text area',\n select: 'dropdown',\n checkbox: 'checkbox',\n radio: 'radio button',\n link: 'link',\n form: 'form',\n menu: 'menu',\n menuitem: 'menu item',\n tab: 'tab',\n dialog: 'dialog',\n switch: 'switch',\n slider: 'slider',\n };\n\n return typeLabels[type.toLowerCase()] || type;\n}\n\n/**\n * Truncate string with ellipsis\n */\nfunction truncate(str: string, maxLength: number): string {\n if (str.length <= maxLength) return str;\n return str.substring(0, maxLength - 3) + '...';\n}\n\n/**\n * Infer page type from URL and elements\n */\nexport function inferPageType(\n url: string,\n title: string,\n elements: AIDiscoveredElement[]\n): PageContext['pageType'] {\n const urlLower = url.toLowerCase();\n const titleLower = title.toLowerCase();\n\n // URL-based detection\n if (urlLower.includes('login') || urlLower.includes('signin')) return 'login';\n if (urlLower.includes('dashboard')) return 'dashboard';\n if (urlLower.includes('search')) return 'search';\n if (urlLower.includes('checkout') || urlLower.includes('payment')) return 'checkout';\n if (urlLower.includes('settings') || urlLower.includes('preferences')) return 'settings';\n\n // Title-based detection\n if (titleLower.includes('login') || titleLower.includes('sign in')) return 'login';\n if (titleLower.includes('dashboard')) return 'dashboard';\n if (titleLower.includes('search')) return 'search';\n\n // Element-based detection\n const hasLoginForm =\n elements.some((el) => el.type === 'input' && el.semanticType === 'email-input') &&\n elements.some((el) => el.type === 'input' && el.semanticType === 'password-input');\n if (hasLoginForm) return 'login';\n\n const hasSearchInput = elements.some(\n (el) => el.type === 'input' && el.semanticType === 'search-input'\n );\n if (hasSearchInput) return 'search';\n\n // Check for form presence\n const inputCount = elements.filter(\n (el) => el.type === 'input' || el.type === 'textarea' || el.type === 'select'\n ).length;\n if (inputCount >= 3) return 'form';\n\n // Check for list/table\n const hasTable = elements.some((el) => el.tagName === 'table');\n const hasMany = elements.length > 20;\n if (hasTable || hasMany) return 'list';\n\n return 'unknown';\n}\n","/**\n * Natural Language Action Parser\n *\n * Parses natural language instructions into structured action requests.\n * Handles patterns like \"click the Submit button\" or \"type 'hello' in the search box\".\n */\n\nimport type { ParsedAction, AssertionType } from './types';\n\n/**\n * Action pattern definition\n */\ninterface ActionPattern {\n /** Regex pattern to match */\n regex: RegExp;\n /** Action type */\n action: ParsedAction['action'];\n /** Capture group index for target */\n targetGroup: number;\n /** Capture group index for value (optional) */\n valueGroup?: number;\n /** Extract modifiers from match */\n modifierExtractor?: (match: RegExpMatchArray) => ParsedAction['modifiers'];\n /** Confidence level for this pattern */\n confidence: number;\n}\n\n/**\n * Action patterns for natural language parsing\n */\nconst ACTION_PATTERNS: ActionPattern[] = [\n // Click patterns\n {\n regex: /^click\\s+(?:on\\s+)?(?:the\\s+)?(.+?)(?:\\s+button)?$/i,\n action: 'click',\n targetGroup: 1,\n confidence: 0.95,\n },\n {\n regex: /^press\\s+(?:the\\s+)?(.+?)(?:\\s+button)?$/i,\n action: 'click',\n targetGroup: 1,\n confidence: 0.9,\n },\n {\n regex: /^tap\\s+(?:on\\s+)?(?:the\\s+)?(.+)$/i,\n action: 'click',\n targetGroup: 1,\n confidence: 0.85,\n },\n {\n regex: /^activate\\s+(?:the\\s+)?(.+)$/i,\n action: 'click',\n targetGroup: 1,\n confidence: 0.8,\n },\n\n // Double click patterns\n {\n regex: /^double[\\s-]?click\\s+(?:on\\s+)?(?:the\\s+)?(.+)$/i,\n action: 'doubleClick',\n targetGroup: 1,\n confidence: 0.95,\n },\n\n // Right click patterns\n {\n regex: /^right[\\s-]?click\\s+(?:on\\s+)?(?:the\\s+)?(.+)$/i,\n action: 'rightClick',\n targetGroup: 1,\n confidence: 0.95,\n },\n {\n regex: /^context\\s+click\\s+(?:on\\s+)?(?:the\\s+)?(.+)$/i,\n action: 'rightClick',\n targetGroup: 1,\n confidence: 0.9,\n },\n\n // Type patterns - \"type X in Y\"\n {\n regex: /^type\\s+[\"'](.+?)[\"']\\s+(?:in(?:to)?|on)\\s+(?:the\\s+)?(.+)$/i,\n action: 'type',\n targetGroup: 2,\n valueGroup: 1,\n confidence: 0.95,\n },\n {\n regex: /^type\\s+(.+?)\\s+(?:in(?:to)?|on)\\s+(?:the\\s+)?(.+)$/i,\n action: 'type',\n targetGroup: 2,\n valueGroup: 1,\n confidence: 0.85,\n },\n\n // Type patterns - \"enter X in Y\"\n {\n regex: /^enter\\s+[\"'](.+?)[\"']\\s+(?:in(?:to)?|on)\\s+(?:the\\s+)?(.+)$/i,\n action: 'type',\n targetGroup: 2,\n valueGroup: 1,\n confidence: 0.95,\n },\n {\n regex: /^enter\\s+(.+?)\\s+(?:in(?:to)?|on)\\s+(?:the\\s+)?(.+)$/i,\n action: 'type',\n targetGroup: 2,\n valueGroup: 1,\n confidence: 0.85,\n },\n\n // Type patterns - \"input X into Y\"\n {\n regex: /^input\\s+[\"'](.+?)[\"']\\s+(?:in(?:to)?)\\s+(?:the\\s+)?(.+)$/i,\n action: 'type',\n targetGroup: 2,\n valueGroup: 1,\n confidence: 0.9,\n },\n\n // Type patterns - \"fill Y with X\"\n {\n regex: /^fill\\s+(?:in\\s+)?(?:the\\s+)?(.+?)\\s+with\\s+[\"'](.+?)[\"']$/i,\n action: 'type',\n targetGroup: 1,\n valueGroup: 2,\n confidence: 0.95,\n },\n {\n regex: /^fill\\s+(?:in\\s+)?(?:the\\s+)?(.+?)\\s+with\\s+(.+)$/i,\n action: 'type',\n targetGroup: 1,\n valueGroup: 2,\n confidence: 0.85,\n },\n\n // Type patterns - \"set Y to X\"\n {\n regex: /^set\\s+(?:the\\s+)?(.+?)\\s+to\\s+[\"'](.+?)[\"']$/i,\n action: 'type',\n targetGroup: 1,\n valueGroup: 2,\n confidence: 0.9,\n },\n\n // Select patterns\n {\n regex: /^select\\s+[\"'](.+?)[\"']\\s+(?:from|in)\\s+(?:the\\s+)?(.+)$/i,\n action: 'select',\n targetGroup: 2,\n valueGroup: 1,\n confidence: 0.95,\n },\n {\n regex: /^choose\\s+[\"'](.+?)[\"']\\s+(?:from|in)\\s+(?:the\\s+)?(.+)$/i,\n action: 'select',\n targetGroup: 2,\n valueGroup: 1,\n confidence: 0.9,\n },\n {\n regex: /^pick\\s+[\"'](.+?)[\"']\\s+(?:from|in)\\s+(?:the\\s+)?(.+)$/i,\n action: 'select',\n targetGroup: 2,\n valueGroup: 1,\n confidence: 0.85,\n },\n\n // Check patterns\n {\n regex: /^check\\s+(?:the\\s+)?(.+?)(?:\\s+checkbox)?$/i,\n action: 'check',\n targetGroup: 1,\n confidence: 0.9,\n },\n {\n regex: /^enable\\s+(?:the\\s+)?(.+)$/i,\n action: 'check',\n targetGroup: 1,\n confidence: 0.8,\n },\n {\n regex: /^tick\\s+(?:the\\s+)?(.+)$/i,\n action: 'check',\n targetGroup: 1,\n confidence: 0.85,\n },\n\n // Uncheck patterns\n {\n regex: /^uncheck\\s+(?:the\\s+)?(.+?)(?:\\s+checkbox)?$/i,\n action: 'uncheck',\n targetGroup: 1,\n confidence: 0.9,\n },\n {\n regex: /^disable\\s+(?:the\\s+)?(.+)$/i,\n action: 'uncheck',\n targetGroup: 1,\n confidence: 0.8,\n },\n {\n regex: /^untick\\s+(?:the\\s+)?(.+)$/i,\n action: 'uncheck',\n targetGroup: 1,\n confidence: 0.85,\n },\n\n // Clear patterns\n {\n regex: /^clear\\s+(?:the\\s+)?(.+)$/i,\n action: 'clear',\n targetGroup: 1,\n confidence: 0.9,\n },\n {\n regex: /^erase\\s+(?:the\\s+)?(.+)$/i,\n action: 'clear',\n targetGroup: 1,\n confidence: 0.85,\n },\n {\n regex: /^empty\\s+(?:the\\s+)?(.+)$/i,\n action: 'clear',\n targetGroup: 1,\n confidence: 0.8,\n },\n\n // Hover patterns\n {\n regex: /^hover\\s+(?:over\\s+)?(?:the\\s+)?(.+)$/i,\n action: 'hover',\n targetGroup: 1,\n confidence: 0.9,\n },\n {\n regex: /^mouse\\s+over\\s+(?:the\\s+)?(.+)$/i,\n action: 'hover',\n targetGroup: 1,\n confidence: 0.85,\n },\n\n // Focus patterns\n {\n regex: /^focus\\s+(?:on\\s+)?(?:the\\s+)?(.+)$/i,\n action: 'focus',\n targetGroup: 1,\n confidence: 0.9,\n },\n\n // Scroll patterns\n {\n regex: /^scroll\\s+(up|down|left|right)$/i,\n action: 'scroll',\n targetGroup: 1,\n confidence: 0.9,\n },\n {\n regex: /^scroll\\s+(?:the\\s+)?(.+?)\\s+(up|down|left|right)$/i,\n action: 'scroll',\n targetGroup: 1,\n confidence: 0.85,\n },\n {\n regex: /^scroll\\s+to\\s+(?:the\\s+)?(.+)$/i,\n action: 'scroll',\n targetGroup: 1,\n confidence: 0.85,\n },\n\n // Wait patterns\n {\n regex: /^wait\\s+(?:for\\s+)?(?:the\\s+)?(.+?)(?:\\s+to\\s+(?:be\\s+)?(.+))?$/i,\n action: 'wait',\n targetGroup: 1,\n confidence: 0.85,\n },\n {\n regex: /^wait\\s+until\\s+(?:the\\s+)?(.+?)(?:\\s+(?:is|becomes)\\s+(.+))?$/i,\n action: 'wait',\n targetGroup: 1,\n confidence: 0.85,\n },\n\n // Assert patterns\n {\n regex: /^(?:assert|verify|check)\\s+(?:that\\s+)?(?:the\\s+)?(.+?)\\s+(?:is\\s+)?(visible|hidden|enabled|disabled|checked|unchecked|focused)$/i,\n action: 'assert',\n targetGroup: 1,\n confidence: 0.9,\n },\n {\n regex: /^(?:assert|verify|check)\\s+(?:that\\s+)?(?:the\\s+)?(.+?)\\s+(?:contains|has)\\s+[\"'](.+?)[\"']$/i,\n action: 'assert',\n targetGroup: 1,\n valueGroup: 2,\n confidence: 0.9,\n },\n {\n regex: /^(?:the\\s+)?(.+?)\\s+should\\s+(?:be\\s+)?(visible|hidden|enabled|disabled|checked|unchecked|focused)$/i,\n action: 'assert',\n targetGroup: 1,\n confidence: 0.85,\n },\n];\n\n/**\n * Assertion type mappings\n */\nconst ASSERTION_TYPE_MAP: Record<string, AssertionType> = {\n visible: 'visible',\n hidden: 'hidden',\n enabled: 'enabled',\n disabled: 'disabled',\n checked: 'checked',\n unchecked: 'unchecked',\n focused: 'focused',\n contains: 'containsText',\n has: 'hasText',\n};\n\n/**\n * Parse a natural language instruction into a structured action\n */\nexport function parseNLInstruction(instruction: string): ParsedAction | null {\n const trimmed = instruction.trim();\n if (!trimmed) return null;\n\n // Try each pattern\n for (const pattern of ACTION_PATTERNS) {\n const match = trimmed.match(pattern.regex);\n if (match) {\n const parsed: ParsedAction = {\n action: pattern.action,\n targetDescription: cleanTargetDescription(match[pattern.targetGroup] || ''),\n rawInstruction: instruction,\n parseConfidence: pattern.confidence,\n };\n\n // Extract value if present\n if (pattern.valueGroup && match[pattern.valueGroup]) {\n parsed.value = match[pattern.valueGroup];\n }\n\n // Extract modifiers if extractor provided\n if (pattern.modifierExtractor) {\n parsed.modifiers = pattern.modifierExtractor(match);\n }\n\n // Handle scroll direction\n if (pattern.action === 'scroll') {\n const directionMatch = trimmed.match(/(up|down|left|right)/i);\n if (directionMatch) {\n parsed.scrollDirection = directionMatch[1].toLowerCase() as ParsedAction['scrollDirection'];\n }\n }\n\n // Handle assertion type\n if (pattern.action === 'assert') {\n const assertMatch = trimmed.match(/(visible|hidden|enabled|disabled|checked|unchecked|focused|contains|has)/i);\n if (assertMatch) {\n parsed.assertionType = ASSERTION_TYPE_MAP[assertMatch[1].toLowerCase()];\n }\n }\n\n // Handle wait condition\n if (pattern.action === 'wait') {\n const waitCondition = match[2];\n if (waitCondition) {\n parsed.waitCondition = waitCondition;\n }\n }\n\n return parsed;\n }\n }\n\n // Try to infer action from common words as fallback\n return inferAction(trimmed);\n}\n\n/**\n * Clean up target description\n */\nfunction cleanTargetDescription(target: string): string {\n return target\n .trim()\n // Remove leading articles\n .replace(/^(the|a|an)\\s+/i, '')\n // Remove trailing type indicators\n .replace(/\\s+(button|field|input|link|dropdown|checkbox|radio)$/i, '')\n .trim();\n}\n\n/**\n * Infer action from instruction as fallback\n */\nfunction inferAction(instruction: string): ParsedAction | null {\n const lower = instruction.toLowerCase();\n\n // Simple click inference\n if (lower.includes('click') || lower.includes('press') || lower.includes('tap')) {\n const target = instruction\n .replace(/click|press|tap|on|the/gi, '')\n .trim();\n if (target) {\n return {\n action: 'click',\n targetDescription: cleanTargetDescription(target),\n rawInstruction: instruction,\n parseConfidence: 0.6,\n };\n }\n }\n\n // Simple type inference\n if (lower.includes('type') || lower.includes('enter') || lower.includes('input')) {\n // Try to extract quoted value\n const quotedMatch = instruction.match(/[\"'](.+?)[\"']/);\n if (quotedMatch) {\n const target = instruction\n .replace(/type|enter|input|into|in|the|[\"'].*?[\"']/gi, '')\n .trim();\n return {\n action: 'type',\n targetDescription: cleanTargetDescription(target),\n value: quotedMatch[1],\n rawInstruction: instruction,\n parseConfidence: 0.5,\n };\n }\n }\n\n // Could not parse\n return null;\n}\n\n/**\n * Parse multiple instructions\n */\nexport function parseNLInstructions(instructions: string[]): ParsedAction[] {\n const parsed: ParsedAction[] = [];\n\n for (const instruction of instructions) {\n const result = parseNLInstruction(instruction);\n if (result) {\n parsed.push(result);\n }\n }\n\n return parsed;\n}\n\n/**\n * Split a complex instruction into simple ones\n * e.g., \"click Login and type 'admin' in username\" -> [\"click Login\", \"type 'admin' in username\"]\n */\nexport function splitCompoundInstruction(instruction: string): string[] {\n // Split on common conjunctions\n const parts = instruction.split(/\\s+(?:and|then|,\\s*then|,\\s*and|,)\\s+/i);\n\n return parts.map((p) => p.trim()).filter((p) => p.length > 0);\n}\n\n/**\n * Extract modifiers from instruction\n */\nexport function extractModifiers(instruction: string): ParsedAction['modifiers'] {\n const modifiers: ParsedAction['modifiers'] = [];\n const lower = instruction.toLowerCase();\n\n if (lower.includes('shift') || lower.includes('with shift')) {\n modifiers.push('shift');\n }\n if (lower.includes('ctrl') || lower.includes('control') || lower.includes('with ctrl')) {\n modifiers.push('ctrl');\n }\n if (lower.includes('alt') || lower.includes('with alt') || lower.includes('option')) {\n modifiers.push('alt');\n }\n if (lower.includes('meta') || lower.includes('command') || lower.includes('cmd') || lower.includes('windows')) {\n modifiers.push('meta');\n }\n\n return modifiers.length > 0 ? modifiers : undefined;\n}\n\n/**\n * Validate a parsed action\n */\nexport function validateParsedAction(action: ParsedAction): { valid: boolean; errors: string[] } {\n const errors: string[] = [];\n\n if (!action.targetDescription && action.action !== 'scroll') {\n errors.push('No target element specified');\n }\n\n if ((action.action === 'type' || action.action === 'select') && !action.value) {\n errors.push(`No value specified for ${action.action} action`);\n }\n\n if (action.parseConfidence < 0.5) {\n errors.push('Low confidence parsing - instruction may be ambiguous');\n }\n\n return {\n valid: errors.length === 0,\n errors,\n };\n}\n\n/**\n * Generate a human-readable description of a parsed action\n */\nexport function describeAction(action: ParsedAction): string {\n switch (action.action) {\n case 'click':\n return `Click on \"${action.targetDescription}\"`;\n case 'doubleClick':\n return `Double-click on \"${action.targetDescription}\"`;\n case 'rightClick':\n return `Right-click on \"${action.targetDescription}\"`;\n case 'type':\n return `Type \"${action.value}\" into \"${action.targetDescription}\"`;\n case 'select':\n return `Select \"${action.value}\" from \"${action.targetDescription}\"`;\n case 'check':\n return `Check \"${action.targetDescription}\"`;\n case 'uncheck':\n return `Uncheck \"${action.targetDescription}\"`;\n case 'clear':\n return `Clear \"${action.targetDescription}\"`;\n case 'hover':\n return `Hover over \"${action.targetDescription}\"`;\n case 'focus':\n return `Focus on \"${action.targetDescription}\"`;\n case 'scroll':\n if (action.scrollDirection) {\n return `Scroll ${action.scrollDirection}`;\n }\n return `Scroll to \"${action.targetDescription}\"`;\n case 'wait':\n return `Wait for \"${action.targetDescription}\"${action.waitCondition ? ` to be ${action.waitCondition}` : ''}`;\n case 'assert':\n return `Assert \"${action.targetDescription}\" is ${action.assertionType || 'valid'}`;\n default:\n return `${action.action} on \"${action.targetDescription}\"`;\n }\n}\n","/**\n * Error Context\n *\n * Creates rich error context for AI agents to understand and recover\n * from failures during UI automation.\n */\n\nimport type { RegisteredElement, ElementState } from '../core/types';\nimport type { DiscoveredElement } from '../control/types';\nimport type {\n AIErrorContext,\n RecoverySuggestion,\n SearchCriteria,\n SearchResult,\n AIDiscoveredElement,\n} from './types';\n\n/**\n * Any element type that can be used with error context\n */\ntype AnyElement = DiscoveredElement | AIDiscoveredElement | RegisteredElement;\n\n/**\n * Helper to get element state from any element type\n * DiscoveredElement has a `state` property, RegisteredElement has a `getState()` method\n */\nfunction getElementState(el: AnyElement): ElementState | undefined {\n if ('state' in el && el.state) {\n return el.state;\n }\n if ('getState' in el && typeof el.getState === 'function') {\n try {\n return el.getState();\n } catch {\n return undefined;\n }\n }\n return undefined;\n}\n\n/**\n * Standard error codes\n */\nexport const ErrorCodes = {\n // Parsing errors\n PARSE_ERROR: 'PARSE_ERROR',\n VALIDATION_ERROR: 'VALIDATION_ERROR',\n\n // Element errors\n ELEMENT_NOT_FOUND: 'ELEMENT_NOT_FOUND',\n ELEMENT_NOT_VISIBLE: 'ELEMENT_NOT_VISIBLE',\n ELEMENT_DISABLED: 'ELEMENT_DISABLED',\n ELEMENT_BLOCKED: 'ELEMENT_BLOCKED',\n MULTIPLE_ELEMENTS: 'MULTIPLE_ELEMENTS',\n\n // Search errors\n LOW_CONFIDENCE: 'LOW_CONFIDENCE',\n AMBIGUOUS_MATCH: 'AMBIGUOUS_MATCH',\n\n // Action errors\n ACTION_FAILED: 'ACTION_FAILED',\n ACTION_TIMEOUT: 'ACTION_TIMEOUT',\n UNSUPPORTED_ACTION: 'UNSUPPORTED_ACTION',\n\n // State errors\n UNEXPECTED_STATE: 'UNEXPECTED_STATE',\n STALE_ELEMENT: 'STALE_ELEMENT',\n\n // Page errors\n PAGE_LOAD_ERROR: 'PAGE_LOAD_ERROR',\n NAVIGATION_ERROR: 'NAVIGATION_ERROR',\n} as const;\n\nexport type ErrorCode = (typeof ErrorCodes)[keyof typeof ErrorCodes];\n\n/**\n * Error messages for each error code\n */\nconst ERROR_MESSAGES: Record<ErrorCode, string> = {\n PARSE_ERROR: 'Could not parse the natural language instruction',\n VALIDATION_ERROR: 'The parsed action failed validation',\n ELEMENT_NOT_FOUND: 'No element matching the description could be found',\n ELEMENT_NOT_VISIBLE: 'The element exists but is not visible',\n ELEMENT_DISABLED: 'The element is disabled and cannot be interacted with',\n ELEMENT_BLOCKED: 'The element is blocked by another element',\n MULTIPLE_ELEMENTS: 'Multiple elements match the description',\n LOW_CONFIDENCE: 'The best match has low confidence',\n AMBIGUOUS_MATCH: 'Multiple elements match with similar confidence',\n ACTION_FAILED: 'The action could not be completed',\n ACTION_TIMEOUT: 'The action timed out waiting for a condition',\n UNSUPPORTED_ACTION: 'The requested action is not supported',\n UNEXPECTED_STATE: 'The element is in an unexpected state',\n STALE_ELEMENT: 'The element is no longer attached to the DOM',\n PAGE_LOAD_ERROR: 'The page failed to load correctly',\n NAVIGATION_ERROR: 'Navigation to the target page failed',\n};\n\n/**\n * Recovery suggestions for each error code\n */\nconst ERROR_SUGGESTIONS: Record<ErrorCode, RecoverySuggestion[]> = {\n PARSE_ERROR: [\n {\n action: 'Use a simpler instruction format like \"click Submit button\"',\n confidence: 0.8,\n priority: 1,\n },\n {\n action: 'Use specific element names visible on the page',\n confidence: 0.7,\n priority: 2,\n },\n ],\n VALIDATION_ERROR: [\n {\n action: 'Provide required parameters for the action',\n confidence: 0.9,\n priority: 1,\n },\n {\n action: 'Check the instruction format',\n confidence: 0.7,\n priority: 2,\n },\n ],\n ELEMENT_NOT_FOUND: [\n {\n action: 'Wait for the page to fully load',\n command: 'wait for page to load',\n confidence: 0.7,\n priority: 1,\n },\n {\n action: 'Use a different description for the element',\n confidence: 0.8,\n priority: 2,\n },\n {\n action: 'Scroll the page to reveal the element',\n command: 'scroll down',\n confidence: 0.6,\n priority: 3,\n },\n ],\n ELEMENT_NOT_VISIBLE: [\n {\n action: 'Scroll to make the element visible',\n command: 'scroll to element',\n confidence: 0.9,\n priority: 1,\n },\n {\n action: 'Close any overlaying elements',\n confidence: 0.7,\n priority: 2,\n },\n {\n action: 'Wait for loading to complete',\n command: 'wait for loading',\n confidence: 0.6,\n priority: 3,\n },\n ],\n ELEMENT_DISABLED: [\n {\n action: 'Fill in required fields first',\n confidence: 0.8,\n priority: 1,\n },\n {\n action: 'Complete prerequisite steps',\n confidence: 0.7,\n priority: 2,\n },\n {\n action: 'Wait for the element to become enabled',\n command: 'wait for element to be enabled',\n confidence: 0.6,\n priority: 3,\n },\n ],\n ELEMENT_BLOCKED: [\n {\n action: 'Close the modal or popup',\n command: 'click close button',\n confidence: 0.9,\n priority: 1,\n },\n {\n action: 'Dismiss the overlay',\n confidence: 0.8,\n priority: 2,\n },\n {\n action: 'Wait for the blocking element to disappear',\n confidence: 0.6,\n priority: 3,\n },\n ],\n MULTIPLE_ELEMENTS: [\n {\n action: 'Use a more specific description',\n confidence: 0.9,\n priority: 1,\n },\n {\n action: 'Include the element position (first, second, etc.)',\n confidence: 0.8,\n priority: 2,\n },\n {\n action: 'Use the element ID directly',\n confidence: 0.7,\n priority: 3,\n },\n ],\n LOW_CONFIDENCE: [\n {\n action: 'Use the exact text shown on the element',\n confidence: 0.9,\n priority: 1,\n },\n {\n action: 'Lower the confidence threshold if the match is correct',\n confidence: 0.7,\n priority: 2,\n },\n {\n action: 'Try a different way to describe the element',\n confidence: 0.6,\n priority: 3,\n },\n ],\n AMBIGUOUS_MATCH: [\n {\n action: 'Be more specific about which element you mean',\n confidence: 0.9,\n priority: 1,\n },\n {\n action: 'Include the section or form name',\n confidence: 0.8,\n priority: 2,\n },\n ],\n ACTION_FAILED: [\n {\n action: 'Check if the element is interactable',\n confidence: 0.7,\n priority: 1,\n },\n {\n action: 'Wait and retry the action',\n command: 'wait 1 second then retry',\n confidence: 0.6,\n priority: 2,\n },\n ],\n ACTION_TIMEOUT: [\n {\n action: 'Increase the timeout duration',\n confidence: 0.8,\n priority: 1,\n },\n {\n action: 'Check if the condition can ever be met',\n confidence: 0.7,\n priority: 2,\n },\n ],\n UNSUPPORTED_ACTION: [\n {\n action: 'Use a different action type',\n confidence: 0.9,\n priority: 1,\n },\n {\n action: 'Break down into simpler actions',\n confidence: 0.7,\n priority: 2,\n },\n ],\n UNEXPECTED_STATE: [\n {\n action: 'Refresh the page state',\n command: 'refresh',\n confidence: 0.7,\n priority: 1,\n },\n {\n action: 'Wait for state to stabilize',\n command: 'wait 2 seconds',\n confidence: 0.6,\n priority: 2,\n },\n ],\n STALE_ELEMENT: [\n {\n action: 'Re-find the element',\n confidence: 0.9,\n priority: 1,\n },\n {\n action: 'Wait for page to stabilize',\n command: 'wait 1 second',\n confidence: 0.7,\n priority: 2,\n },\n ],\n PAGE_LOAD_ERROR: [\n {\n action: 'Refresh the page',\n command: 'refresh page',\n confidence: 0.8,\n priority: 1,\n },\n {\n action: 'Check network connectivity',\n confidence: 0.6,\n priority: 2,\n },\n ],\n NAVIGATION_ERROR: [\n {\n action: 'Try the navigation again',\n confidence: 0.7,\n priority: 1,\n },\n {\n action: 'Check if the URL is correct',\n confidence: 0.6,\n priority: 2,\n },\n ],\n};\n\n/**\n * Create a rich error context\n */\nexport function createErrorContext(\n errorCode: ErrorCode,\n attemptedAction: string,\n availableElements: AnyElement[],\n searchCriteria?: SearchCriteria,\n nearestMatch?: SearchResult\n): AIErrorContext {\n // Get base message and suggestions\n const message = ERROR_MESSAGES[errorCode] || 'An unknown error occurred';\n const baseSuggestions = ERROR_SUGGESTIONS[errorCode] || [];\n\n // Detect possible blockers\n const possibleBlockers = detectPossibleBlockers(availableElements);\n\n // Count visible elements\n const visibleElements = availableElements.filter((el) => {\n const state = getElementState(el);\n return state?.visible ?? false;\n }).length;\n\n // Build enhanced suggestions\n const suggestions = enhanceSuggestions(\n baseSuggestions,\n errorCode,\n nearestMatch,\n possibleBlockers\n );\n\n return {\n code: errorCode,\n message,\n attemptedAction,\n searchCriteria,\n searchResults: {\n candidatesFound: availableElements.length,\n nearestMatch: nearestMatch\n ? {\n element: nearestMatch.element,\n confidence: nearestMatch.confidence,\n whyNotSelected: determineWhyNotSelected(errorCode, nearestMatch),\n }\n : undefined,\n },\n pageContext: {\n url: typeof window !== 'undefined' ? window.location.href : '',\n title: typeof document !== 'undefined' ? document.title : '',\n visibleElements,\n possibleBlockers,\n },\n suggestions,\n timestamp: Date.now(),\n };\n}\n\n/**\n * Detect possible blocking elements\n */\nfunction detectPossibleBlockers(\n elements: AnyElement[]\n): string[] {\n const blockers: string[] = [];\n\n for (const el of elements) {\n const state = getElementState(el);\n if (!state) continue;\n\n // Check for modals\n if (el.type === 'dialog' && state.visible) {\n blockers.push(`Modal dialog: ${el.id}`);\n }\n\n // Check for overlays (heuristic based on computed styles)\n if (state.computedStyles?.pointerEvents === 'none') {\n continue; // Non-blocking overlay\n }\n\n // Check for full-screen elements (would need rect comparison)\n }\n\n return blockers;\n}\n\n/**\n * Enhance suggestions based on context\n */\nfunction enhanceSuggestions(\n baseSuggestions: RecoverySuggestion[],\n errorCode: ErrorCode,\n nearestMatch?: SearchResult,\n possibleBlockers?: string[]\n): RecoverySuggestion[] {\n const suggestions = [...baseSuggestions];\n\n // Add blocker-specific suggestions\n if (possibleBlockers && possibleBlockers.length > 0) {\n suggestions.unshift({\n action: `Close the blocking element: ${possibleBlockers[0]}`,\n command: 'click close button',\n confidence: 0.85,\n priority: 0,\n });\n }\n\n // Add nearest match suggestion\n if (nearestMatch && errorCode === 'LOW_CONFIDENCE') {\n suggestions.unshift({\n action: `Did you mean: \"${nearestMatch.element.description}\"?`,\n command: `click \"${nearestMatch.element.description}\"`,\n confidence: nearestMatch.confidence,\n priority: 0,\n });\n }\n\n // Sort by priority\n suggestions.sort((a, b) => a.priority - b.priority);\n\n return suggestions;\n}\n\n/**\n * Determine why the nearest match was not selected\n */\nfunction determineWhyNotSelected(\n errorCode: ErrorCode,\n nearestMatch: SearchResult\n): string {\n switch (errorCode) {\n case 'LOW_CONFIDENCE':\n return `Confidence (${(nearestMatch.confidence * 100).toFixed(0)}%) below threshold`;\n\n case 'ELEMENT_NOT_VISIBLE':\n return 'Element is not visible';\n\n case 'ELEMENT_DISABLED':\n return 'Element is disabled';\n\n case 'AMBIGUOUS_MATCH':\n return 'Multiple elements with similar confidence';\n\n default:\n return 'Did not meet selection criteria';\n }\n}\n\n/**\n * Format error context for display\n */\nexport function formatErrorContext(context: AIErrorContext): string {\n const lines: string[] = [];\n\n lines.push(`Error: ${context.code}`);\n lines.push(`Message: ${context.message}`);\n lines.push(`Attempted: ${context.attemptedAction}`);\n lines.push('');\n\n if (context.searchResults.nearestMatch) {\n const match = context.searchResults.nearestMatch;\n lines.push(`Nearest match: \"${match.element.description}\" (${(match.confidence * 100).toFixed(0)}% confidence)`);\n lines.push(`Why not used: ${match.whyNotSelected}`);\n lines.push('');\n }\n\n lines.push(`Page: ${context.pageContext.title || context.pageContext.url}`);\n lines.push(`Visible elements: ${context.pageContext.visibleElements}`);\n\n if (context.pageContext.possibleBlockers.length > 0) {\n lines.push(`Possible blockers: ${context.pageContext.possibleBlockers.join(', ')}`);\n }\n\n lines.push('');\n lines.push('Suggestions:');\n for (const suggestion of context.suggestions.slice(0, 3)) {\n lines.push(` - ${suggestion.action}`);\n if (suggestion.command) {\n lines.push(` Command: ${suggestion.command}`);\n }\n }\n\n return lines.join('\\n');\n}\n\n/**\n * Create a simple error response\n */\nexport function createSimpleError(\n code: ErrorCode,\n message?: string\n): { code: string; message: string } {\n return {\n code,\n message: message || ERROR_MESSAGES[code] || 'Unknown error',\n };\n}\n\n/**\n * Check if an error is recoverable\n */\nexport function isRecoverableError(code: ErrorCode): boolean {\n const unrecoverableErrors: ErrorCode[] = [\n 'UNSUPPORTED_ACTION',\n 'PAGE_LOAD_ERROR',\n 'NAVIGATION_ERROR',\n ];\n\n return !unrecoverableErrors.includes(code);\n}\n\n/**\n * Get the best recovery suggestion for an error\n */\nexport function getBestRecoverySuggestion(\n context: AIErrorContext\n): RecoverySuggestion | null {\n if (context.suggestions.length === 0) return null;\n\n // Return highest confidence suggestion\n const sorted = [...context.suggestions].sort((a, b) => b.confidence - a.confidence);\n return sorted[0];\n}\n","/**\n * Natural Language Action Executor\n *\n * Executes parsed natural language actions by searching for elements\n * and performing the requested actions with confidence scoring.\n */\n\nimport type { RegisteredElement, ElementState, StandardAction } from '../core/types';\nimport type { DiscoveredElement, ActionExecutor } from '../control/types';\nimport type {\n NLActionRequest,\n NLActionResponse,\n ParsedAction,\n SearchCriteria,\n AIDiscoveredElement,\n AIErrorContext,\n SearchResult,\n} from './types';\nimport { parseNLInstruction, describeAction, validateParsedAction } from './nl-action-parser';\nimport { SearchEngine, type SearchEngineConfig } from './search-engine';\nimport { createErrorContext, ErrorCodes } from './error-context';\n\n/**\n * Configuration for the NL action executor\n */\nexport interface NLActionExecutorConfig {\n /** Default confidence threshold for element matching */\n defaultConfidenceThreshold: number;\n /** Default timeout for actions */\n defaultTimeout: number;\n /** Maximum alternatives to return on failure */\n maxAlternatives: number;\n /** Search engine configuration */\n searchConfig?: Partial<SearchEngineConfig>;\n /** Enable verbose logging */\n verbose: boolean;\n}\n\n/**\n * Default executor configuration\n */\nexport const DEFAULT_EXECUTOR_CONFIG: NLActionExecutorConfig = {\n defaultConfidenceThreshold: 0.7,\n defaultTimeout: 5000,\n maxAlternatives: 3,\n verbose: false,\n};\n\n/**\n * Natural Language Action Executor\n */\nexport class NLActionExecutor {\n private config: NLActionExecutorConfig;\n private searchEngine: SearchEngine;\n private actionExecutor: ActionExecutor | null = null;\n private elements: Array<DiscoveredElement | RegisteredElement> = [];\n\n constructor(config: Partial<NLActionExecutorConfig> = {}) {\n this.config = { ...DEFAULT_EXECUTOR_CONFIG, ...config };\n this.searchEngine = new SearchEngine(this.config.searchConfig);\n }\n\n /**\n * Set the action executor for performing DOM actions\n */\n setActionExecutor(executor: ActionExecutor): void {\n this.actionExecutor = executor;\n }\n\n /**\n * Update available elements for search\n */\n updateElements(elements: Array<DiscoveredElement | RegisteredElement>): void {\n this.elements = elements;\n this.searchEngine.updateElements(elements);\n }\n\n /**\n * Execute a natural language instruction\n */\n async execute(request: NLActionRequest): Promise<NLActionResponse> {\n const startTime = performance.now();\n const threshold = request.confidenceThreshold ?? this.config.defaultConfidenceThreshold;\n\n // Parse the instruction\n const parsed = parseNLInstruction(request.instruction);\n\n if (!parsed) {\n return this.createFailureResponse(\n startTime,\n 'PARSE_ERROR',\n `Could not parse instruction: \"${request.instruction}\"`,\n request.instruction,\n [],\n threshold\n );\n }\n\n // Validate the parsed action\n const validation = validateParsedAction(parsed);\n if (!validation.valid) {\n return this.createFailureResponse(\n startTime,\n 'VALIDATION_ERROR',\n validation.errors.join('; '),\n request.instruction,\n [],\n threshold\n );\n }\n\n // Build search criteria from parsed action\n const searchCriteria = this.buildSearchCriteria(parsed);\n\n // Search for the target element\n const searchResponse = this.searchEngine.search(searchCriteria);\n\n if (!searchResponse.bestMatch) {\n return this.createFailureResponse(\n startTime,\n 'ELEMENT_NOT_FOUND',\n `Could not find element matching: \"${parsed.targetDescription}\"`,\n request.instruction,\n searchResponse.results,\n threshold,\n searchCriteria\n );\n }\n\n // Check confidence threshold\n if (searchResponse.bestMatch.confidence < threshold) {\n const alternatives = searchResponse.results.slice(0, this.config.maxAlternatives);\n return this.createFailureResponse(\n startTime,\n 'LOW_CONFIDENCE',\n `Best match confidence (${(searchResponse.bestMatch.confidence * 100).toFixed(0)}%) is below threshold (${(threshold * 100).toFixed(0)}%)`,\n request.instruction,\n alternatives,\n threshold,\n searchCriteria,\n searchResponse.bestMatch\n );\n }\n\n // Execute the action\n try {\n const result = await this.performAction(\n parsed,\n searchResponse.bestMatch.element,\n request.timeout ?? this.config.defaultTimeout\n );\n\n return {\n success: true,\n executedAction: describeAction(parsed),\n elementUsed: searchResponse.bestMatch.element,\n confidence: searchResponse.bestMatch.confidence,\n elementState: result.elementState,\n durationMs: performance.now() - startTime,\n timestamp: Date.now(),\n };\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n const alternatives = searchResponse.results\n .filter((r) => r !== searchResponse.bestMatch)\n .slice(0, this.config.maxAlternatives);\n\n return this.createFailureResponse(\n startTime,\n 'ACTION_FAILED',\n errorMessage,\n request.instruction,\n alternatives,\n threshold,\n searchCriteria,\n searchResponse.bestMatch\n );\n }\n }\n\n /**\n * Execute a parsed action directly (skip parsing)\n */\n async executeParsed(parsed: ParsedAction, threshold?: number): Promise<NLActionResponse> {\n const startTime = performance.now();\n const confidenceThreshold = threshold ?? this.config.defaultConfidenceThreshold;\n\n // Build search criteria\n const searchCriteria = this.buildSearchCriteria(parsed);\n\n // Search for element\n const searchResponse = this.searchEngine.search(searchCriteria);\n\n if (!searchResponse.bestMatch) {\n return this.createFailureResponse(\n startTime,\n 'ELEMENT_NOT_FOUND',\n `Could not find element: \"${parsed.targetDescription}\"`,\n parsed.rawInstruction,\n [],\n confidenceThreshold,\n searchCriteria\n );\n }\n\n if (searchResponse.bestMatch.confidence < confidenceThreshold) {\n return this.createFailureResponse(\n startTime,\n 'LOW_CONFIDENCE',\n `Best match confidence too low`,\n parsed.rawInstruction,\n searchResponse.results.slice(0, this.config.maxAlternatives),\n confidenceThreshold,\n searchCriteria,\n searchResponse.bestMatch\n );\n }\n\n // Execute\n try {\n const result = await this.performAction(\n parsed,\n searchResponse.bestMatch.element,\n this.config.defaultTimeout\n );\n\n return {\n success: true,\n executedAction: describeAction(parsed),\n elementUsed: searchResponse.bestMatch.element,\n confidence: searchResponse.bestMatch.confidence,\n elementState: result.elementState,\n durationMs: performance.now() - startTime,\n timestamp: Date.now(),\n };\n } catch (error) {\n return this.createFailureResponse(\n startTime,\n 'ACTION_FAILED',\n error instanceof Error ? error.message : String(error),\n parsed.rawInstruction,\n searchResponse.results\n .filter((r) => r !== searchResponse.bestMatch)\n .slice(0, this.config.maxAlternatives),\n confidenceThreshold,\n searchCriteria,\n searchResponse.bestMatch\n );\n }\n }\n\n /**\n * Build search criteria from a parsed action\n */\n private buildSearchCriteria(parsed: ParsedAction): SearchCriteria {\n const criteria: SearchCriteria = {\n text: parsed.targetDescription,\n fuzzy: true,\n fuzzyThreshold: this.config.defaultConfidenceThreshold,\n };\n\n // Add type hints based on action\n switch (parsed.action) {\n case 'click':\n case 'doubleClick':\n case 'rightClick':\n // Could be button or link\n break;\n case 'type':\n case 'clear':\n // Should be an input\n criteria.type = 'input';\n break;\n case 'select':\n criteria.type = 'select';\n break;\n case 'check':\n case 'uncheck':\n criteria.type = 'checkbox';\n break;\n }\n\n return criteria;\n }\n\n /**\n * Perform the actual action on an element\n */\n private async performAction(\n parsed: ParsedAction,\n element: AIDiscoveredElement,\n timeout: number\n ): Promise<{ elementState: ElementState }> {\n if (!this.actionExecutor) {\n throw new Error('No action executor configured');\n }\n\n // Map parsed action to standard action\n const actionMap: Record<ParsedAction['action'], StandardAction | null> = {\n click: 'click',\n doubleClick: 'doubleClick',\n rightClick: 'rightClick',\n type: 'type',\n select: 'select',\n check: 'check',\n uncheck: 'uncheck',\n scroll: 'scroll',\n wait: null, // Special handling\n assert: null, // Special handling\n hover: 'hover',\n focus: 'focus',\n clear: 'clear',\n };\n\n const standardAction = actionMap[parsed.action];\n\n if (!standardAction) {\n // Handle special actions\n if (parsed.action === 'wait') {\n const waitResult = await this.actionExecutor.waitFor(element.id, {\n visible: true,\n timeout,\n });\n if (!waitResult.met) {\n throw new Error(waitResult.error || 'Wait condition not met');\n }\n return { elementState: waitResult.state! };\n }\n\n if (parsed.action === 'assert') {\n // Assertions are handled by the assertions module\n throw new Error('Use the assertions module for assert actions');\n }\n\n throw new Error(`Unsupported action: ${parsed.action}`);\n }\n\n // Build action request\n const actionRequest: {\n action: StandardAction;\n params?: Record<string, unknown>;\n waitOptions?: { visible?: boolean; enabled?: boolean; timeout?: number };\n } = {\n action: standardAction,\n waitOptions: {\n visible: true,\n enabled: true,\n timeout,\n },\n };\n\n // Add action-specific params\n if (standardAction === 'type' && parsed.value) {\n actionRequest.params = { text: parsed.value };\n } else if (standardAction === 'select' && parsed.value) {\n actionRequest.params = { value: parsed.value };\n } else if (standardAction === 'scroll' && parsed.scrollDirection) {\n actionRequest.params = { direction: parsed.scrollDirection };\n }\n\n // Execute the action\n const response = await this.actionExecutor.executeAction(element.id, actionRequest);\n\n if (!response.success) {\n throw new Error(response.error || 'Action failed');\n }\n\n return { elementState: response.elementState! };\n }\n\n /**\n * Create a failure response with suggestions\n */\n private createFailureResponse(\n startTime: number,\n errorCode: string,\n errorMessage: string,\n instruction: string,\n alternatives: SearchResult[],\n threshold: number,\n searchCriteria?: SearchCriteria,\n nearestMatch?: SearchResult\n ): NLActionResponse {\n // Generate suggestions\n const suggestions = this.generateSuggestions(\n errorCode,\n instruction,\n alternatives,\n nearestMatch\n );\n\n // Create a dummy element for the response\n const dummyElement: AIDiscoveredElement = nearestMatch?.element || {\n id: 'not-found',\n type: 'unknown',\n tagName: 'unknown',\n actions: [],\n state: {\n visible: false,\n enabled: false,\n focused: false,\n rect: { x: 0, y: 0, width: 0, height: 0, top: 0, right: 0, bottom: 0, left: 0 },\n },\n registered: false,\n description: 'Element not found',\n aliases: [],\n suggestedActions: [],\n };\n\n return {\n success: false,\n executedAction: instruction,\n elementUsed: dummyElement,\n confidence: nearestMatch?.confidence || 0,\n elementState: dummyElement.state,\n durationMs: performance.now() - startTime,\n timestamp: Date.now(),\n error: errorMessage,\n errorCode,\n suggestions,\n alternatives: alternatives.slice(0, this.config.maxAlternatives),\n };\n }\n\n /**\n * Generate recovery suggestions\n */\n private generateSuggestions(\n errorCode: string,\n instruction: string,\n alternatives: SearchResult[],\n nearestMatch?: SearchResult\n ): string[] {\n const suggestions: string[] = [];\n\n switch (errorCode) {\n case 'PARSE_ERROR':\n suggestions.push('Try using a simpler phrase like \"click Submit button\"');\n suggestions.push('Ensure the instruction follows patterns like \"click X\" or \"type Y into X\"');\n break;\n\n case 'ELEMENT_NOT_FOUND':\n if (alternatives.length > 0) {\n suggestions.push(`Did you mean: \"${alternatives[0].element.description}\"?`);\n }\n suggestions.push('Check if the element is visible on the page');\n suggestions.push('Try using a more specific description');\n break;\n\n case 'LOW_CONFIDENCE':\n if (nearestMatch) {\n suggestions.push(\n `Found \"${nearestMatch.element.description}\" with ${(nearestMatch.confidence * 100).toFixed(0)}% confidence`\n );\n }\n suggestions.push('Try using the exact text shown on the element');\n suggestions.push('Lower the confidence threshold if this match is correct');\n break;\n\n case 'ACTION_FAILED':\n suggestions.push('Check if the element is enabled');\n suggestions.push('Wait for any loading to complete');\n suggestions.push('Ensure no modal or overlay is blocking the element');\n break;\n\n default:\n suggestions.push('Try a different approach or check the page state');\n }\n\n return suggestions;\n }\n\n /**\n * Get rich error context for debugging\n */\n getErrorContext(\n errorCode: string,\n instruction: string,\n searchCriteria?: SearchCriteria,\n nearestMatch?: SearchResult\n ): AIErrorContext {\n return createErrorContext(\n errorCode as keyof typeof ErrorCodes,\n instruction,\n this.elements,\n searchCriteria,\n nearestMatch\n );\n }\n}\n\n/**\n * Create a default NL action executor\n */\nexport function createNLActionExecutor(\n config?: Partial<NLActionExecutorConfig>\n): NLActionExecutor {\n return new NLActionExecutor(config);\n}\n","/**\n * Assertions Module\n *\n * Provides verification/assertion API for AI agents to validate\n * page state without writing Playwright tests.\n */\n\nimport type { ElementState } from '../core/types';\nimport type { DiscoveredElement } from '../control/types';\nimport type {\n AssertionType,\n AssertionRequest,\n AssertionResult,\n BatchAssertionRequest,\n BatchAssertionResult,\n SearchCriteria,\n AIDiscoveredElement,\n} from './types';\nimport { SearchEngine } from './search-engine';\n\n/**\n * Configuration for assertions\n */\nexport interface AssertionConfig {\n /** Default timeout for wait-based assertions */\n defaultTimeout: number;\n /** Polling interval for wait-based assertions */\n pollInterval: number;\n /** Default fuzzy threshold for element search */\n fuzzyThreshold: number;\n /** Include suggestions in failure messages */\n includeSuggestions: boolean;\n}\n\n/**\n * Default assertion configuration\n */\nexport const DEFAULT_ASSERTION_CONFIG: AssertionConfig = {\n defaultTimeout: 5000,\n pollInterval: 100,\n fuzzyThreshold: 0.7,\n includeSuggestions: true,\n};\n\n/**\n * Assertion executor class\n */\nexport class AssertionExecutor {\n private config: AssertionConfig;\n private searchEngine: SearchEngine;\n private elements: Array<DiscoveredElement | AIDiscoveredElement> = [];\n\n constructor(config: Partial<AssertionConfig> = {}) {\n this.config = { ...DEFAULT_ASSERTION_CONFIG, ...config };\n this.searchEngine = new SearchEngine({ fuzzyThreshold: this.config.fuzzyThreshold });\n }\n\n /**\n * Update available elements for assertions\n */\n updateElements(elements: Array<DiscoveredElement | AIDiscoveredElement>): void {\n this.elements = elements;\n this.searchEngine.updateElements(elements);\n }\n\n /**\n * Execute a single assertion\n */\n async assert(request: AssertionRequest): Promise<AssertionResult> {\n const startTime = performance.now();\n const timeout = request.timeout ?? this.config.defaultTimeout;\n\n // Find the target element\n const element = await this.findElement(request.target, request.fuzzy !== false);\n\n if (!element && request.type !== 'notExists') {\n return this.createResult(\n false,\n typeof request.target === 'string' ? request.target : JSON.stringify(request.target),\n 'element not found',\n request.type === 'exists' ? true : request.expected,\n null,\n 'Element could not be found',\n this.config.includeSuggestions ? 'Check if the element exists and is properly labeled' : undefined,\n startTime\n );\n }\n\n // Execute the assertion based on type\n return this.executeAssertion(request, element, timeout, startTime);\n }\n\n /**\n * Execute multiple assertions\n */\n async assertBatch(request: BatchAssertionRequest): Promise<BatchAssertionResult> {\n const startTime = performance.now();\n const results: AssertionResult[] = [];\n let passedCount = 0;\n let failedCount = 0;\n\n for (const assertion of request.assertions) {\n const result = await this.assert(assertion);\n results.push(result);\n\n if (result.passed) {\n passedCount++;\n } else {\n failedCount++;\n\n // Stop on first failure if configured\n if (request.stopOnFailure) {\n // Mark remaining assertions as skipped\n break;\n }\n }\n }\n\n // Determine overall pass/fail\n const passed = request.mode === 'all'\n ? failedCount === 0\n : passedCount > 0;\n\n return {\n passed,\n results,\n passedCount,\n failedCount,\n durationMs: performance.now() - startTime,\n timestamp: Date.now(),\n };\n }\n\n /**\n * Convenience method: assert element is visible\n */\n async assertVisible(target: string | SearchCriteria, timeout?: number): Promise<AssertionResult> {\n return this.assert({ target, type: 'visible', timeout });\n }\n\n /**\n * Convenience method: assert element is hidden\n */\n async assertHidden(target: string | SearchCriteria, timeout?: number): Promise<AssertionResult> {\n return this.assert({ target, type: 'hidden', timeout });\n }\n\n /**\n * Convenience method: assert element is enabled\n */\n async assertEnabled(target: string | SearchCriteria, timeout?: number): Promise<AssertionResult> {\n return this.assert({ target, type: 'enabled', timeout });\n }\n\n /**\n * Convenience method: assert element is disabled\n */\n async assertDisabled(target: string | SearchCriteria, timeout?: number): Promise<AssertionResult> {\n return this.assert({ target, type: 'disabled', timeout });\n }\n\n /**\n * Convenience method: assert element has text\n */\n async assertHasText(\n target: string | SearchCriteria,\n text: string,\n timeout?: number\n ): Promise<AssertionResult> {\n return this.assert({ target, type: 'hasText', expected: text, timeout });\n }\n\n /**\n * Convenience method: assert element contains text\n */\n async assertContainsText(\n target: string | SearchCriteria,\n text: string,\n timeout?: number\n ): Promise<AssertionResult> {\n return this.assert({ target, type: 'containsText', expected: text, timeout });\n }\n\n /**\n * Convenience method: assert element has value\n */\n async assertHasValue(\n target: string | SearchCriteria,\n value: string,\n timeout?: number\n ): Promise<AssertionResult> {\n return this.assert({ target, type: 'hasValue', expected: value, timeout });\n }\n\n /**\n * Convenience method: assert element exists\n */\n async assertExists(target: string | SearchCriteria, timeout?: number): Promise<AssertionResult> {\n return this.assert({ target, type: 'exists', timeout });\n }\n\n /**\n * Convenience method: assert element does not exist\n */\n async assertNotExists(target: string | SearchCriteria, timeout?: number): Promise<AssertionResult> {\n return this.assert({ target, type: 'notExists', timeout });\n }\n\n /**\n * Convenience method: assert checkbox is checked\n */\n async assertChecked(target: string | SearchCriteria, timeout?: number): Promise<AssertionResult> {\n return this.assert({ target, type: 'checked', timeout });\n }\n\n /**\n * Convenience method: assert checkbox is unchecked\n */\n async assertUnchecked(target: string | SearchCriteria, timeout?: number): Promise<AssertionResult> {\n return this.assert({ target, type: 'unchecked', timeout });\n }\n\n /**\n * Convenience method: assert element count\n */\n async assertCount(\n target: SearchCriteria,\n expectedCount: number,\n timeout?: number\n ): Promise<AssertionResult> {\n return this.assert({ target, type: 'count', expected: expectedCount, timeout });\n }\n\n /**\n * Find element by target (string or criteria)\n */\n private async findElement(\n target: string | SearchCriteria,\n fuzzy: boolean = true\n ): Promise<AIDiscoveredElement | null> {\n const criteria: SearchCriteria =\n typeof target === 'string' ? { text: target, fuzzy } : { ...target, fuzzy };\n\n const searchResult = this.searchEngine.findBest(criteria);\n\n if (searchResult && searchResult.confidence >= this.config.fuzzyThreshold) {\n return searchResult.element;\n }\n\n return null;\n }\n\n /**\n * Execute the actual assertion\n */\n private async executeAssertion(\n request: AssertionRequest,\n element: AIDiscoveredElement | null,\n timeout: number,\n startTime: number\n ): Promise<AssertionResult> {\n const targetStr = typeof request.target === 'string'\n ? request.target\n : JSON.stringify(request.target);\n\n const elementDescription = element?.description || targetStr;\n\n switch (request.type) {\n case 'visible':\n return this.assertVisibility(element!, true, elementDescription, request.message, startTime);\n\n case 'hidden':\n return this.assertVisibility(element!, false, elementDescription, request.message, startTime);\n\n case 'enabled':\n return this.assertEnabledState(element!, true, elementDescription, request.message, startTime);\n\n case 'disabled':\n return this.assertEnabledState(element!, false, elementDescription, request.message, startTime);\n\n case 'focused':\n return this.assertFocused(element!, elementDescription, request.message, startTime);\n\n case 'checked':\n return this.assertCheckedState(element!, true, elementDescription, request.message, startTime);\n\n case 'unchecked':\n return this.assertCheckedState(element!, false, elementDescription, request.message, startTime);\n\n case 'hasText':\n return this.assertTextMatch(\n element!,\n request.expected as string,\n true,\n elementDescription,\n request.message,\n startTime\n );\n\n case 'containsText':\n return this.assertTextMatch(\n element!,\n request.expected as string,\n false,\n elementDescription,\n request.message,\n startTime\n );\n\n case 'hasValue':\n return this.assertValue(\n element!,\n request.expected as string,\n elementDescription,\n request.message,\n startTime\n );\n\n case 'exists':\n return this.createResult(\n element !== null,\n targetStr,\n elementDescription,\n true,\n element !== null,\n element === null ? 'Element does not exist' : undefined,\n undefined,\n startTime,\n element?.state\n );\n\n case 'notExists':\n return this.createResult(\n element === null,\n targetStr,\n elementDescription,\n false,\n element === null,\n element !== null ? 'Element exists but should not' : undefined,\n undefined,\n startTime,\n element?.state\n );\n\n case 'count':\n return this.assertElementCount(\n request.target as SearchCriteria,\n request.expected as number,\n targetStr,\n request.message,\n startTime\n );\n\n case 'attribute':\n return this.assertAttribute(\n element!,\n request.attributeName!,\n request.expected,\n elementDescription,\n request.message,\n startTime\n );\n\n case 'hasClass':\n return this.assertHasClass(\n element!,\n request.expected as string,\n elementDescription,\n request.message,\n startTime\n );\n\n case 'cssProperty':\n return this.assertCssProperty(\n element!,\n request.propertyName!,\n request.expected,\n elementDescription,\n request.message,\n startTime\n );\n\n default:\n return this.createResult(\n false,\n targetStr,\n elementDescription,\n undefined,\n undefined,\n `Unknown assertion type: ${request.type}`,\n undefined,\n startTime\n );\n }\n }\n\n /**\n * Assert visibility state\n */\n private assertVisibility(\n element: AIDiscoveredElement,\n expectedVisible: boolean,\n description: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n const isVisible = element.state.visible;\n const passed = isVisible === expectedVisible;\n\n return this.createResult(\n passed,\n element.id,\n description,\n expectedVisible,\n isVisible,\n passed ? undefined : message || `Element is ${isVisible ? 'visible' : 'hidden'} but expected ${expectedVisible ? 'visible' : 'hidden'}`,\n passed ? undefined : 'Check if element is covered by another element or has display:none',\n startTime,\n element.state\n );\n }\n\n /**\n * Assert enabled state\n */\n private assertEnabledState(\n element: AIDiscoveredElement,\n expectedEnabled: boolean,\n description: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n const isEnabled = element.state.enabled;\n const passed = isEnabled === expectedEnabled;\n\n return this.createResult(\n passed,\n element.id,\n description,\n expectedEnabled,\n isEnabled,\n passed ? undefined : message || `Element is ${isEnabled ? 'enabled' : 'disabled'} but expected ${expectedEnabled ? 'enabled' : 'disabled'}`,\n passed ? undefined : 'Check if the element has a disabled attribute or aria-disabled',\n startTime,\n element.state\n );\n }\n\n /**\n * Assert focused state\n */\n private assertFocused(\n element: AIDiscoveredElement,\n description: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n const isFocused = element.state.focused;\n\n return this.createResult(\n isFocused,\n element.id,\n description,\n true,\n isFocused,\n isFocused ? undefined : message || 'Element is not focused',\n isFocused ? undefined : 'Click or focus the element first',\n startTime,\n element.state\n );\n }\n\n /**\n * Assert checked state\n */\n private assertCheckedState(\n element: AIDiscoveredElement,\n expectedChecked: boolean,\n description: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n const isChecked = element.state.checked ?? false;\n const passed = isChecked === expectedChecked;\n\n return this.createResult(\n passed,\n element.id,\n description,\n expectedChecked,\n isChecked,\n passed ? undefined : message || `Element is ${isChecked ? 'checked' : 'unchecked'} but expected ${expectedChecked ? 'checked' : 'unchecked'}`,\n passed ? undefined : 'Click the checkbox to change its state',\n startTime,\n element.state\n );\n }\n\n /**\n * Assert text content\n */\n private assertTextMatch(\n element: AIDiscoveredElement,\n expectedText: string,\n exact: boolean,\n description: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n const actualText = element.state.textContent || '';\n const passed = exact\n ? actualText === expectedText\n : actualText.includes(expectedText);\n\n return this.createResult(\n passed,\n element.id,\n description,\n expectedText,\n actualText,\n passed\n ? undefined\n : message || (exact\n ? `Text \"${actualText}\" does not match expected \"${expectedText}\"`\n : `Text \"${actualText}\" does not contain \"${expectedText}\"`),\n passed ? undefined : 'Verify the element contains the expected text',\n startTime,\n element.state\n );\n }\n\n /**\n * Assert input value\n */\n private assertValue(\n element: AIDiscoveredElement,\n expectedValue: string,\n description: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n const actualValue = element.state.value || '';\n const passed = actualValue === expectedValue;\n\n return this.createResult(\n passed,\n element.id,\n description,\n expectedValue,\n actualValue,\n passed ? undefined : message || `Value \"${actualValue}\" does not match expected \"${expectedValue}\"`,\n passed ? undefined : 'Type the expected value into the input',\n startTime,\n element.state\n );\n }\n\n /**\n * Assert element count\n */\n private assertElementCount(\n criteria: SearchCriteria,\n expectedCount: number,\n targetStr: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n const searchResponse = this.searchEngine.search(criteria);\n const actualCount = searchResponse.results.length;\n const passed = actualCount === expectedCount;\n\n return this.createResult(\n passed,\n targetStr,\n `${actualCount} elements matching criteria`,\n expectedCount,\n actualCount,\n passed ? undefined : message || `Found ${actualCount} elements but expected ${expectedCount}`,\n passed ? undefined : 'Adjust search criteria or wait for elements to load',\n startTime\n );\n }\n\n /**\n * Assert attribute value (placeholder for DOM attribute assertions)\n */\n private assertAttribute(\n element: AIDiscoveredElement,\n attributeName: string,\n expectedValue: unknown,\n description: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n // Note: Would need DOM access for actual attribute checking\n // For now, handle known attributes from state\n let actualValue: unknown;\n\n switch (attributeName.toLowerCase()) {\n case 'placeholder':\n actualValue = element.placeholder;\n break;\n case 'title':\n actualValue = element.title;\n break;\n default:\n return this.createResult(\n false,\n element.id,\n description,\n expectedValue,\n undefined,\n `Cannot check attribute \"${attributeName}\" without DOM access`,\n 'Use the server API to check element attributes',\n startTime,\n element.state\n );\n }\n\n const passed = actualValue === expectedValue;\n\n return this.createResult(\n passed,\n element.id,\n description,\n expectedValue,\n actualValue,\n passed ? undefined : message || `Attribute \"${attributeName}\" is \"${actualValue}\" but expected \"${expectedValue}\"`,\n undefined,\n startTime,\n element.state\n );\n }\n\n /**\n * Assert element has CSS class\n */\n private assertHasClass(\n element: AIDiscoveredElement,\n className: string,\n description: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n // Note: Would need DOM access for actual class checking\n return this.createResult(\n false,\n element.id,\n description,\n className,\n undefined,\n 'Cannot check CSS classes without DOM access',\n 'Use the server API to check element classes',\n startTime,\n element.state\n );\n }\n\n /**\n * Assert CSS property value\n */\n private assertCssProperty(\n element: AIDiscoveredElement,\n propertyName: string,\n expectedValue: unknown,\n description: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n const computedStyles = element.state.computedStyles;\n if (!computedStyles) {\n return this.createResult(\n false,\n element.id,\n description,\n expectedValue,\n undefined,\n 'Computed styles not available',\n 'Request element state with computed styles',\n startTime,\n element.state\n );\n }\n\n const styleKey = propertyName as keyof typeof computedStyles;\n const actualValue = computedStyles[styleKey];\n const passed = actualValue === expectedValue;\n\n return this.createResult(\n passed,\n element.id,\n description,\n expectedValue,\n actualValue,\n passed ? undefined : message || `CSS property \"${propertyName}\" is \"${actualValue}\" but expected \"${expectedValue}\"`,\n undefined,\n startTime,\n element.state\n );\n }\n\n /**\n * Create an assertion result\n */\n private createResult(\n passed: boolean,\n target: string,\n targetDescription: string,\n expected: unknown,\n actual: unknown,\n failureReason?: string,\n suggestion?: string,\n startTime: number = performance.now(),\n elementState?: ElementState\n ): AssertionResult {\n return {\n passed,\n target,\n targetDescription,\n expected,\n actual,\n failureReason,\n suggestion: this.config.includeSuggestions ? suggestion : undefined,\n elementState,\n durationMs: performance.now() - startTime,\n timestamp: Date.now(),\n };\n }\n}\n\n/**\n * Create a default assertion executor\n */\nexport function createAssertionExecutor(config?: Partial<AssertionConfig>): AssertionExecutor {\n return new AssertionExecutor(config);\n}\n","/**\n * Semantic Snapshot\n *\n * Creates enhanced state snapshots with AI-friendly element descriptions,\n * form analysis, and modal detection.\n */\n\nimport type { ElementState } from '../core/types';\nimport type { ControlSnapshot, DiscoveredElement } from '../control/types';\nimport type {\n SemanticSnapshot,\n AIDiscoveredElement,\n PageContext,\n FormState,\n FormFieldState,\n ModalState,\n FormAnalysis,\n FormFieldAnalysis,\n} from './types';\nimport { SearchEngine } from './search-engine';\nimport {\n generatePageSummary,\n generateElementDescription,\n inferPageType,\n} from './summary-generator';\nimport {\n generateAliases,\n generateDescription,\n generatePurpose,\n generateSuggestedActions,\n} from './alias-generator';\n\n/**\n * Configuration for semantic snapshots\n */\nexport interface SemanticSnapshotConfig {\n /** Include form analysis */\n analyzeForms: boolean;\n /** Include modal detection */\n detectModals: boolean;\n /** Include page type inference */\n inferPageType: boolean;\n /** Generate element descriptions */\n generateDescriptions: boolean;\n /** Maximum elements to include */\n maxElements: number;\n}\n\n/**\n * Default snapshot configuration\n */\nexport const DEFAULT_SNAPSHOT_CONFIG: SemanticSnapshotConfig = {\n analyzeForms: true,\n detectModals: true,\n inferPageType: true,\n generateDescriptions: true,\n maxElements: 500,\n};\n\n/**\n * Snapshot history for diffing\n */\ninterface SnapshotHistory {\n snapshot: SemanticSnapshot;\n timestamp: number;\n}\n\n/**\n * Semantic Snapshot Manager\n */\nexport class SemanticSnapshotManager {\n private config: SemanticSnapshotConfig;\n private searchEngine: SearchEngine;\n private history: SnapshotHistory[] = [];\n private readonly maxHistorySize = 10;\n private snapshotCounter = 0;\n\n constructor(config: Partial<SemanticSnapshotConfig> = {}) {\n this.config = { ...DEFAULT_SNAPSHOT_CONFIG, ...config };\n this.searchEngine = new SearchEngine();\n }\n\n /**\n * Create a semantic snapshot from a control snapshot\n */\n createSnapshot(\n controlSnapshot: ControlSnapshot,\n pageContext?: Partial<PageContext>\n ): SemanticSnapshot {\n const snapshotId = `snapshot-${++this.snapshotCounter}-${Date.now()}`;\n\n // Convert elements to AI elements\n const aiElements = this.convertElements(controlSnapshot.elements);\n\n // Update search engine\n this.searchEngine.updateElements(aiElements);\n\n // Build page context\n const fullPageContext = this.buildPageContext(aiElements, pageContext);\n\n // Analyze forms\n const forms = this.config.analyzeForms\n ? this.analyzeForms(aiElements)\n : [];\n\n // Detect modals\n const modals = this.config.detectModals\n ? this.detectModals(aiElements)\n : [];\n\n // Count elements by type\n const elementCounts = this.countElementTypes(aiElements);\n\n // Generate summary\n const summary = generatePageSummary(aiElements, fullPageContext);\n\n // Find focused element\n const focusedElement = aiElements.find((el) => el.state.focused)?.id;\n\n const snapshot: SemanticSnapshot = {\n timestamp: Date.now(),\n snapshotId,\n page: fullPageContext,\n elements: aiElements.slice(0, this.config.maxElements),\n forms,\n activeModals: modals,\n focusedElement,\n summary,\n elementCounts,\n };\n\n // Add to history\n this.addToHistory(snapshot);\n\n return snapshot;\n }\n\n /**\n * Get the last snapshot\n */\n getLastSnapshot(): SemanticSnapshot | null {\n if (this.history.length === 0) return null;\n return this.history[this.history.length - 1].snapshot;\n }\n\n /**\n * Get snapshot by ID\n */\n getSnapshot(snapshotId: string): SemanticSnapshot | null {\n const entry = this.history.find((h) => h.snapshot.snapshotId === snapshotId);\n return entry?.snapshot || null;\n }\n\n /**\n * Get snapshot history\n */\n getHistory(): SemanticSnapshot[] {\n return this.history.map((h) => h.snapshot);\n }\n\n /**\n * Clear history\n */\n clearHistory(): void {\n this.history = [];\n }\n\n /**\n * Convert control snapshot elements to AI elements\n */\n private convertElements(\n elements: ControlSnapshot['elements']\n ): AIDiscoveredElement[] {\n return elements.map((el) => this.convertElement(el));\n }\n\n /**\n * Convert a single element to AI element\n */\n private convertElement(\n element: ControlSnapshot['elements'][0]\n ): AIDiscoveredElement {\n const aliases = generateAliases({\n textContent: element.state.textContent,\n elementType: element.type,\n id: element.id,\n labelText: element.label,\n });\n\n const description = this.config.generateDescriptions\n ? generateDescription({\n textContent: element.state.textContent,\n elementType: element.type,\n id: element.id,\n labelText: element.label,\n })\n : element.label || element.id;\n\n const purpose = generatePurpose({\n textContent: element.state.textContent,\n elementType: element.type,\n });\n\n const suggestedActions = generateSuggestedActions({\n textContent: element.state.textContent,\n elementType: element.type,\n });\n\n return {\n id: element.id,\n type: element.type,\n label: element.label,\n tagName: this.inferTagName(element.type),\n role: this.inferRole(element.type),\n accessibleName: element.label || element.state.textContent?.trim(),\n actions: element.actions,\n state: element.state,\n registered: true,\n description,\n aliases,\n purpose,\n suggestedActions,\n semanticType: this.inferSemanticType(element),\n };\n }\n\n /**\n * Build full page context\n */\n private buildPageContext(\n elements: AIDiscoveredElement[],\n partial?: Partial<PageContext>\n ): PageContext {\n const url = partial?.url || (typeof window !== 'undefined' ? window.location.href : '');\n const title = partial?.title || (typeof document !== 'undefined' ? document.title : '');\n\n const pageType = this.config.inferPageType\n ? inferPageType(url, title, elements)\n : partial?.pageType || 'unknown';\n\n // Detect active modals from elements\n const activeModals = elements\n .filter((el) => el.type === 'dialog' && el.state.visible)\n .map((el) => el.id);\n\n return {\n url,\n title,\n pageType,\n activeModals: partial?.activeModals || activeModals,\n focusedElement: partial?.focusedElement || elements.find((el) => el.state.focused)?.id,\n navigation: partial?.navigation,\n };\n }\n\n /**\n * Analyze forms in the snapshot\n */\n private analyzeForms(elements: AIDiscoveredElement[]): FormState[] {\n const forms: FormState[] = [];\n\n // Find form elements\n const formElements = elements.filter((el) => el.type === 'form');\n\n // If no explicit forms, try to detect implicit forms\n if (formElements.length === 0) {\n const implicitForm = this.detectImplicitForm(elements);\n if (implicitForm) {\n forms.push(implicitForm);\n }\n } else {\n for (const form of formElements) {\n const formState = this.analyzeForm(form, elements);\n if (formState) {\n forms.push(formState);\n }\n }\n }\n\n return forms;\n }\n\n /**\n * Detect implicit form from inputs\n */\n private detectImplicitForm(elements: AIDiscoveredElement[]): FormState | null {\n const inputs = elements.filter(\n (el) =>\n el.type === 'input' ||\n el.type === 'textarea' ||\n el.type === 'select' ||\n el.type === 'checkbox'\n );\n\n if (inputs.length === 0) return null;\n\n // Find potential submit button\n const submitButton = elements.find(\n (el) =>\n el.type === 'button' &&\n el.state.visible &&\n (el.semanticType === 'submit-button' ||\n el.state.textContent?.toLowerCase().match(/submit|save|send|continue/))\n );\n\n const fields = this.analyzeFormFields(inputs);\n const hasErrors = fields.some((f) => !f.valid);\n\n return {\n id: 'implicit-form',\n purpose: this.inferFormPurpose(inputs),\n fields,\n isValid: !hasErrors,\n submitButton: submitButton?.id,\n isDirty: fields.some((f) => f.value !== '' && f.touched),\n };\n }\n\n /**\n * Analyze a specific form\n */\n private analyzeForm(\n form: AIDiscoveredElement,\n allElements: AIDiscoveredElement[]\n ): FormState | null {\n // Find form fields (simplified - would need DOM relationship data)\n const inputs = allElements.filter(\n (el) =>\n (el.type === 'input' || el.type === 'textarea' || el.type === 'select') &&\n el.state.visible\n );\n\n const fields = this.analyzeFormFields(inputs);\n const hasErrors = fields.some((f) => !f.valid);\n\n // Find submit button\n const submitButton = allElements.find(\n (el) =>\n el.type === 'button' &&\n el.state.visible &&\n el.semanticType === 'submit-button'\n );\n\n return {\n id: form.id,\n name: form.label,\n purpose: form.purpose,\n fields,\n isValid: !hasErrors,\n submitButton: submitButton?.id,\n isDirty: fields.some((f) => f.value !== ''),\n };\n }\n\n /**\n * Analyze form fields\n */\n private analyzeFormFields(inputs: AIDiscoveredElement[]): FormFieldState[] {\n return inputs.map((input) => ({\n id: input.id,\n label: input.accessibleName || input.label || input.id,\n type: input.type,\n value: input.state.value || '',\n valid: true, // Would need validation state\n required: false, // Would need DOM access\n touched: input.state.focused || (input.state.value?.length || 0) > 0,\n }));\n }\n\n /**\n * Detect modal dialogs\n */\n private detectModals(elements: AIDiscoveredElement[]): ModalState[] {\n const modals: ModalState[] = [];\n\n // Find dialog elements\n const dialogElements = elements.filter(\n (el) => el.type === 'dialog' && el.state.visible\n );\n\n for (const dialog of dialogElements) {\n // Try to find close button within dialog context\n const closeButton = elements.find(\n (el) =>\n el.type === 'button' &&\n el.state.visible &&\n (el.semanticType === 'cancel-button' ||\n el.state.textContent?.toLowerCase().match(/close|cancel|x|dismiss/))\n );\n\n // Try to find primary action\n const primaryAction = elements.find(\n (el) =>\n el.type === 'button' &&\n el.state.visible &&\n el.semanticType === 'submit-button'\n );\n\n modals.push({\n id: dialog.id,\n title: dialog.accessibleName || dialog.label,\n type: this.inferModalType(dialog),\n blocking: true, // Assume dialogs are blocking\n closeButton: closeButton?.id,\n primaryAction: primaryAction?.id,\n });\n }\n\n return modals;\n }\n\n /**\n * Infer modal type\n */\n private inferModalType(dialog: AIDiscoveredElement): ModalState['type'] {\n const text = (dialog.accessibleName || dialog.state.textContent || '').toLowerCase();\n\n if (text.includes('alert') || text.includes('warning') || text.includes('error')) {\n return 'alert';\n }\n if (text.includes('confirm') || text.includes('are you sure')) {\n return 'confirm';\n }\n if (text.includes('prompt') || text.includes('enter')) {\n return 'prompt';\n }\n\n return 'dialog';\n }\n\n /**\n * Count elements by type\n */\n private countElementTypes(elements: AIDiscoveredElement[]): Record<string, number> {\n const counts: Record<string, number> = {};\n\n for (const el of elements) {\n const type = el.type.toLowerCase();\n counts[type] = (counts[type] || 0) + 1;\n }\n\n return counts;\n }\n\n /**\n * Infer form purpose from fields\n */\n private inferFormPurpose(fields: AIDiscoveredElement[]): string {\n const labels = fields.map((f) =>\n (f.accessibleName || f.label || '').toLowerCase()\n );\n const allLabels = labels.join(' ');\n\n if (allLabels.includes('email') && allLabels.includes('password')) {\n if (allLabels.includes('confirm') || allLabels.includes('name')) {\n return 'Registration';\n }\n return 'Login';\n }\n\n if (allLabels.includes('search')) return 'Search';\n if (allLabels.includes('address') || allLabels.includes('city')) return 'Address';\n if (allLabels.includes('card') || allLabels.includes('payment')) return 'Payment';\n if (allLabels.includes('contact') || allLabels.includes('message')) return 'Contact';\n\n return 'Form';\n }\n\n /**\n * Infer tag name from element type\n */\n private inferTagName(type: string): string {\n const typeMap: Record<string, string> = {\n button: 'button',\n input: 'input',\n textarea: 'textarea',\n select: 'select',\n checkbox: 'input',\n radio: 'input',\n link: 'a',\n form: 'form',\n dialog: 'dialog',\n };\n return typeMap[type] || 'div';\n }\n\n /**\n * Infer ARIA role from element type\n */\n private inferRole(type: string): string | undefined {\n const roleMap: Record<string, string> = {\n button: 'button',\n input: 'textbox',\n textarea: 'textbox',\n select: 'combobox',\n checkbox: 'checkbox',\n radio: 'radio',\n link: 'link',\n dialog: 'dialog',\n menu: 'menu',\n menuitem: 'menuitem',\n tab: 'tab',\n };\n return roleMap[type];\n }\n\n /**\n * Infer semantic type\n */\n private inferSemanticType(element: ControlSnapshot['elements'][0]): string {\n const text = (element.state.textContent || element.label || '').toLowerCase();\n const type = element.type.toLowerCase();\n\n if (type === 'button') {\n if (text.match(/submit|save|confirm|ok|done|apply/)) return 'submit-button';\n if (text.match(/cancel|close|dismiss/)) return 'cancel-button';\n if (text.match(/delete|remove|trash/)) return 'delete-button';\n if (text.match(/add|create|new|\\+/)) return 'add-button';\n if (text.match(/edit|modify/)) return 'edit-button';\n if (text.match(/next|continue/)) return 'next-button';\n if (text.match(/back|previous/)) return 'back-button';\n return 'action-button';\n }\n\n if (type === 'input') {\n if (text.includes('email') || element.id.includes('email')) return 'email-input';\n if (text.includes('password') || element.id.includes('password')) return 'password-input';\n if (text.includes('search') || element.id.includes('search')) return 'search-input';\n return 'text-input';\n }\n\n return type;\n }\n\n /**\n * Add snapshot to history\n */\n private addToHistory(snapshot: SemanticSnapshot): void {\n this.history.push({\n snapshot,\n timestamp: Date.now(),\n });\n\n // Trim history if needed\n if (this.history.length > this.maxHistorySize) {\n this.history = this.history.slice(-this.maxHistorySize);\n }\n }\n}\n\n/**\n * Create a semantic snapshot manager\n */\nexport function createSnapshotManager(\n config?: Partial<SemanticSnapshotConfig>\n): SemanticSnapshotManager {\n return new SemanticSnapshotManager(config);\n}\n","/**\n * Semantic Diff\n *\n * Tracks and describes semantic changes between snapshots\n * with LLM-friendly summaries and suggested actions.\n */\n\nimport type {\n SemanticSnapshot,\n SemanticDiff,\n ElementChange,\n ElementModification,\n AIDiscoveredElement,\n} from './types';\nimport { generateDiffSummary } from './summary-generator';\n\n/**\n * Configuration for semantic diff\n */\nexport interface SemanticDiffConfig {\n /** Ignore insignificant changes */\n ignoreInsignificant: boolean;\n /** Properties to track for modifications */\n trackedProperties: string[];\n /** Generate suggested actions */\n generateSuggestions: boolean;\n /** Maximum modifications to report */\n maxModifications: number;\n}\n\n/**\n * Default diff configuration\n */\nexport const DEFAULT_DIFF_CONFIG: SemanticDiffConfig = {\n ignoreInsignificant: true,\n trackedProperties: ['visible', 'enabled', 'focused', 'checked', 'value', 'textContent'],\n generateSuggestions: true,\n maxModifications: 20,\n};\n\n/**\n * Properties that are considered insignificant\n */\nconst INSIGNIFICANT_PROPERTIES = new Set(['rect', 'computedStyles', 'innerHTML']);\n\n/**\n * Compute semantic diff between two snapshots\n */\nexport function computeDiff(\n fromSnapshot: SemanticSnapshot,\n toSnapshot: SemanticSnapshot,\n config: Partial<SemanticDiffConfig> = {}\n): SemanticDiff {\n const startTime = performance.now();\n const finalConfig = { ...DEFAULT_DIFF_CONFIG, ...config };\n\n // Build element maps for comparison\n const fromElements = new Map(fromSnapshot.elements.map((el) => [el.id, el]));\n const toElements = new Map(toSnapshot.elements.map((el) => [el.id, el]));\n\n // Find appeared elements\n const appeared: ElementChange[] = [];\n for (const [id, element] of toElements) {\n if (!fromElements.has(id)) {\n appeared.push({\n elementId: id,\n description: element.description,\n type: element.type,\n semanticType: element.semanticType,\n });\n }\n }\n\n // Find disappeared elements\n const disappeared: ElementChange[] = [];\n for (const [id, element] of fromElements) {\n if (!toElements.has(id)) {\n disappeared.push({\n elementId: id,\n description: element.description,\n type: element.type,\n semanticType: element.semanticType,\n });\n }\n }\n\n // Find modified elements\n const modified: ElementModification[] = [];\n for (const [id, toElement] of toElements) {\n const fromElement = fromElements.get(id);\n if (fromElement) {\n const modifications = compareElements(fromElement, toElement, finalConfig);\n modified.push(...modifications);\n }\n }\n\n // Limit modifications\n const limitedModifications = modified.slice(0, finalConfig.maxModifications);\n\n // Detect probable trigger\n const probableTrigger = detectTrigger(appeared, disappeared, limitedModifications);\n\n // Generate suggested actions\n const suggestedActions = finalConfig.generateSuggestions\n ? generateSuggestedActionsFromDiff(appeared, disappeared, limitedModifications, probableTrigger)\n : undefined;\n\n // Detect page changes\n const pageChanges = detectPageChanges(fromSnapshot, toSnapshot);\n\n // Generate summary\n const summary = generateDiffSummary(\n appeared.map((e) => e.description),\n disappeared.map((e) => e.description),\n limitedModifications\n );\n\n return {\n summary,\n fromSnapshotId: fromSnapshot.snapshotId,\n toSnapshotId: toSnapshot.snapshotId,\n changes: {\n appeared,\n disappeared,\n modified: limitedModifications,\n },\n probableTrigger,\n suggestedActions,\n pageChanges,\n durationMs: performance.now() - startTime,\n timestamp: Date.now(),\n };\n}\n\n/**\n * Compare two elements and return modifications\n */\nfunction compareElements(\n fromElement: AIDiscoveredElement,\n toElement: AIDiscoveredElement,\n config: SemanticDiffConfig\n): ElementModification[] {\n const modifications: ElementModification[] = [];\n\n for (const property of config.trackedProperties) {\n const fromValue = getPropertyValue(fromElement, property);\n const toValue = getPropertyValue(toElement, property);\n\n if (fromValue !== toValue) {\n // Check significance\n const isSignificant = isSignificantChange(property, fromValue, toValue);\n\n if (!config.ignoreInsignificant || isSignificant) {\n modifications.push({\n elementId: toElement.id,\n description: toElement.description,\n property,\n from: formatValue(fromValue),\n to: formatValue(toValue),\n significant: isSignificant,\n });\n }\n }\n }\n\n return modifications;\n}\n\n/**\n * Get a property value from an element\n */\nfunction getPropertyValue(element: AIDiscoveredElement, property: string): unknown {\n if (property in element.state) {\n return element.state[property as keyof typeof element.state];\n }\n return element[property as keyof AIDiscoveredElement];\n}\n\n/**\n * Check if a change is significant\n */\nfunction isSignificantChange(property: string, fromValue: unknown, toValue: unknown): boolean {\n // Insignificant properties\n if (INSIGNIFICANT_PROPERTIES.has(property)) {\n return false;\n }\n\n // Visibility changes are always significant\n if (property === 'visible') {\n return true;\n }\n\n // Enabled state changes are significant\n if (property === 'enabled') {\n return true;\n }\n\n // Focus changes are significant\n if (property === 'focused') {\n return true;\n }\n\n // Checked state changes are significant\n if (property === 'checked') {\n return true;\n }\n\n // Value changes are significant if non-empty\n if (property === 'value') {\n return Boolean(fromValue) || Boolean(toValue);\n }\n\n // Text content changes are significant if substantial\n if (property === 'textContent') {\n const fromText = String(fromValue || '');\n const toText = String(toValue || '');\n // Significant if more than whitespace changes\n return fromText.trim() !== toText.trim();\n }\n\n return true;\n}\n\n/**\n * Format a value for display\n */\nfunction formatValue(value: unknown): string {\n if (value === undefined) return 'undefined';\n if (value === null) return 'null';\n if (typeof value === 'boolean') return value ? 'true' : 'false';\n if (typeof value === 'string') {\n // Truncate long strings\n if (value.length > 50) {\n return value.substring(0, 47) + '...';\n }\n return value;\n }\n if (typeof value === 'object') {\n return JSON.stringify(value);\n }\n return String(value);\n}\n\n/**\n * Detect the probable trigger for the changes\n */\nfunction detectTrigger(\n appeared: ElementChange[],\n disappeared: ElementChange[],\n modified: ElementModification[]\n): string | undefined {\n // Check for form validation\n const hasNewErrors = appeared.some(\n (e) => e.description.toLowerCase().includes('error') || e.type === 'error'\n );\n if (hasNewErrors) {\n return 'Form validation';\n }\n\n // Check for modal appearance\n const hasNewModal = appeared.some(\n (e) => e.type === 'dialog' || e.semanticType?.includes('dialog')\n );\n if (hasNewModal) {\n return 'Modal opened';\n }\n\n // Check for modal dismissal\n const hasModalDismissed = disappeared.some(\n (e) => e.type === 'dialog' || e.semanticType?.includes('dialog')\n );\n if (hasModalDismissed) {\n return 'Modal closed';\n }\n\n // Check for loading state\n const hasLoading = modified.some((m) => m.description.toLowerCase().includes('loading'));\n if (hasLoading) {\n return 'Loading state change';\n }\n\n // Check for focus change\n const hasFocusChange = modified.some((m) => m.property === 'focused');\n if (hasFocusChange && modified.length <= 2) {\n return 'Focus changed';\n }\n\n // Check for value change (user input)\n const hasValueChange = modified.some((m) => m.property === 'value');\n if (hasValueChange && modified.length <= 2) {\n return 'User input';\n }\n\n // Check for visibility changes (dropdown, accordion)\n const visibilityChanges = modified.filter((m) => m.property === 'visible');\n if (visibilityChanges.length > 0 && visibilityChanges.length <= 5) {\n return 'UI expansion/collapse';\n }\n\n // Multiple elements appeared (navigation)\n if (appeared.length > 5) {\n return 'Page navigation';\n }\n\n return undefined;\n}\n\n/**\n * Detect page-level changes\n */\nfunction detectPageChanges(\n fromSnapshot: SemanticSnapshot,\n toSnapshot: SemanticSnapshot\n): SemanticDiff['pageChanges'] | undefined {\n const urlChanged = fromSnapshot.page.url !== toSnapshot.page.url;\n const titleChanged = fromSnapshot.page.title !== toSnapshot.page.title;\n\n if (!urlChanged && !titleChanged) {\n return undefined;\n }\n\n return {\n urlChanged,\n titleChanged,\n newUrl: urlChanged ? toSnapshot.page.url : undefined,\n newTitle: titleChanged ? toSnapshot.page.title : undefined,\n };\n}\n\n/**\n * Generate suggested actions based on the diff\n */\nfunction generateSuggestedActionsFromDiff(\n appeared: ElementChange[],\n disappeared: ElementChange[],\n modified: ElementModification[],\n trigger?: string\n): string[] {\n const suggestions: string[] = [];\n\n // Suggestions based on trigger\n if (trigger === 'Form validation') {\n suggestions.push('Fix the validation errors before submitting');\n }\n\n if (trigger === 'Modal opened') {\n const modal = appeared.find(\n (e) => e.type === 'dialog' || e.semanticType?.includes('dialog')\n );\n if (modal) {\n suggestions.push(`Interact with the \"${modal.description}\" dialog`);\n }\n }\n\n if (trigger === 'Modal closed') {\n suggestions.push('Continue with the main page interaction');\n }\n\n // Suggestions based on appeared elements\n for (const element of appeared.slice(0, 3)) {\n if (element.type === 'button' && element.semanticType === 'submit-button') {\n suggestions.push(`Click the \"${element.description}\" to proceed`);\n }\n if (element.description.toLowerCase().includes('error')) {\n suggestions.push(`Address the error: ${element.description}`);\n }\n }\n\n // Suggestions based on modifications\n for (const mod of modified.slice(0, 3)) {\n if (mod.property === 'enabled' && mod.to === 'true') {\n suggestions.push(`\"${mod.description}\" is now enabled`);\n }\n if (mod.property === 'visible' && mod.to === 'true') {\n suggestions.push(`\"${mod.description}\" is now visible`);\n }\n }\n\n return suggestions.slice(0, 5);\n}\n\n/**\n * Create a diff manager for tracking changes over time\n */\nexport class SemanticDiffManager {\n private config: SemanticDiffConfig;\n private lastSnapshot: SemanticSnapshot | null = null;\n\n constructor(config: Partial<SemanticDiffConfig> = {}) {\n this.config = { ...DEFAULT_DIFF_CONFIG, ...config };\n }\n\n /**\n * Update with new snapshot and get diff\n */\n update(newSnapshot: SemanticSnapshot): SemanticDiff | null {\n if (!this.lastSnapshot) {\n this.lastSnapshot = newSnapshot;\n return null;\n }\n\n const diff = computeDiff(this.lastSnapshot, newSnapshot, this.config);\n this.lastSnapshot = newSnapshot;\n return diff;\n }\n\n /**\n * Get diff from a specific snapshot to current\n */\n diffFrom(fromSnapshot: SemanticSnapshot): SemanticDiff | null {\n if (!this.lastSnapshot) return null;\n return computeDiff(fromSnapshot, this.lastSnapshot, this.config);\n }\n\n /**\n * Reset the manager\n */\n reset(): void {\n this.lastSnapshot = null;\n }\n\n /**\n * Get the last known snapshot\n */\n getLastSnapshot(): SemanticSnapshot | null {\n return this.lastSnapshot;\n }\n}\n\n/**\n * Create a semantic diff manager\n */\nexport function createDiffManager(config?: Partial<SemanticDiffConfig>): SemanticDiffManager {\n return new SemanticDiffManager(config);\n}\n\n/**\n * Utility: Check if any significant changes occurred\n */\nexport function hasSignificantChanges(diff: SemanticDiff): boolean {\n if (diff.changes.appeared.length > 0) return true;\n if (diff.changes.disappeared.length > 0) return true;\n if (diff.changes.modified.some((m) => m.significant)) return true;\n if (diff.pageChanges?.urlChanged) return true;\n return false;\n}\n\n/**\n * Utility: Get a brief description of what changed\n */\nexport function describeDiff(diff: SemanticDiff): string {\n const parts: string[] = [];\n\n if (diff.changes.appeared.length > 0) {\n parts.push(`${diff.changes.appeared.length} elements appeared`);\n }\n\n if (diff.changes.disappeared.length > 0) {\n parts.push(`${diff.changes.disappeared.length} elements disappeared`);\n }\n\n const significantMods = diff.changes.modified.filter((m) => m.significant);\n if (significantMods.length > 0) {\n parts.push(`${significantMods.length} elements modified`);\n }\n\n if (diff.pageChanges?.urlChanged) {\n parts.push('URL changed');\n }\n\n if (parts.length === 0) {\n return 'No significant changes';\n }\n\n return parts.join(', ');\n}\n","/**\n * UI Bridge Server Handlers\n *\n * Factory function to create handler implementations for all UI Bridge endpoints.\n */\n\nimport type {\n UIBridgeServerHandlers,\n APIResponse,\n RenderLogQuery,\n} from './types';\nimport type {\n ControlSnapshot,\n} from '../control';\nimport type { RenderLogEntry } from '../render-log';\nimport type {\n ActionFailureDetails,\n ActionErrorCode,\n} from '../core';\nimport type {\n SearchCriteria,\n SearchResponse,\n NLActionRequest,\n NLActionResponse,\n AssertionRequest,\n AssertionResult,\n BatchAssertionRequest,\n BatchAssertionResult,\n SemanticSnapshot,\n SemanticDiff,\n SemanticSearchCriteria,\n SemanticSearchResponse,\n SemanticSearchResult,\n AIDiscoveredElement,\n} from '../ai';\nimport {\n SearchEngine,\n NLActionExecutor,\n AssertionExecutor,\n SemanticSnapshotManager,\n SemanticDiffManager,\n generatePageSummary,\n} from '../ai';\n\n/**\n * Registry interface - minimal contract for handler usage\n */\nexport interface RegistryLike {\n getAllElements(): unknown[];\n getElement(id: string): unknown | undefined;\n getAllComponents(): unknown[];\n getComponent(id: string): unknown | undefined;\n getComponentState?(id: string): { state: Record<string, unknown>; computed: Record<string, unknown>; timestamp: number } | null;\n createSnapshot(): ControlSnapshot;\n getRenderLog?(): RenderLogEntry[];\n clearRenderLog?(): void;\n captureSnapshot?(): unknown;\n findElements?(request?: unknown): unknown[];\n getAllWorkflows?(): unknown[];\n getWorkflow?(id: string): unknown;\n getActionHistory?(): unknown[];\n getMetrics?(): unknown;\n highlightElement?(id: string): void;\n getElementTree?(): unknown;\n}\n\n/**\n * Action executor interface - minimal contract for handler usage\n */\nexport interface ActionExecutorLike {\n executeAction(\n elementId: string,\n request: { action: string; params?: Record<string, unknown>; waitOptions?: unknown }\n ): Promise<unknown>;\n executeComponentAction(\n componentId: string,\n request: { action: string; params?: Record<string, unknown> }\n ): Promise<unknown>;\n}\n\n/**\n * Configuration for creating handlers\n */\nexport interface CreateHandlersConfig {\n /** Optional render log path */\n renderLogPath?: string;\n /** Verbose logging */\n verbose?: boolean;\n}\n\n/**\n * Create a success response\n */\nfunction success<T>(data: T): APIResponse<T> {\n return {\n success: true,\n data,\n timestamp: Date.now(),\n };\n}\n\n/**\n * Create an error response\n */\nfunction error<T = unknown>(message: string, code?: string): APIResponse<T> {\n return {\n success: false,\n error: message,\n code,\n timestamp: Date.now(),\n };\n}\n\n/**\n * Generate recovery suggestions based on error code\n */\nfunction getRecoverySuggestions(errorCode: ActionErrorCode): Array<{\n suggestion: string;\n command?: string;\n confidence: number;\n retryable: boolean;\n}> {\n switch (errorCode) {\n case 'ELEMENT_NOT_FOUND':\n return [\n { suggestion: 'Wait for the page to fully load', command: 'wait for page to load', confidence: 0.7, retryable: true },\n { suggestion: 'Use a different description for the element', confidence: 0.8, retryable: false },\n { suggestion: 'Scroll the page to reveal the element', command: 'scroll down', confidence: 0.6, retryable: true },\n ];\n case 'ELEMENT_NOT_VISIBLE':\n return [\n { suggestion: 'Scroll to make the element visible', command: 'scroll to element', confidence: 0.9, retryable: true },\n { suggestion: 'Wait for any loading overlays to disappear', confidence: 0.7, retryable: true },\n { suggestion: 'Close any blocking modals or popups', command: 'click close button', confidence: 0.8, retryable: true },\n ];\n case 'ELEMENT_NOT_ENABLED':\n return [\n { suggestion: 'Fill in required fields first', confidence: 0.8, retryable: false },\n { suggestion: 'Complete prerequisite steps in the form', confidence: 0.7, retryable: false },\n { suggestion: 'Wait for the element to become enabled', command: 'wait for element to be enabled', confidence: 0.6, retryable: true },\n ];\n case 'ELEMENT_NOT_INTERACTABLE':\n return [\n { suggestion: 'Close any modal or popup blocking the element', command: 'click close button', confidence: 0.9, retryable: true },\n { suggestion: 'Wait for animations to complete', confidence: 0.7, retryable: true },\n { suggestion: 'Scroll the element into the viewport', command: 'scroll to element', confidence: 0.8, retryable: true },\n ];\n case 'ACTION_TIMEOUT':\n return [\n { suggestion: 'Increase the timeout duration', confidence: 0.8, retryable: true },\n { suggestion: 'Check if the condition can ever be met', confidence: 0.7, retryable: false },\n { suggestion: 'Verify the page is responding', command: 'check page status', confidence: 0.6, retryable: true },\n ];\n case 'LOW_CONFIDENCE':\n return [\n { suggestion: 'Use the exact text shown on the element', confidence: 0.9, retryable: false },\n { suggestion: 'Try a different description that more closely matches the element', confidence: 0.8, retryable: false },\n { suggestion: 'Lower the confidence threshold if the match is correct', confidence: 0.7, retryable: true },\n ];\n case 'AMBIGUOUS_MATCH':\n return [\n { suggestion: 'Be more specific about which element you mean', confidence: 0.9, retryable: false },\n { suggestion: 'Include the section or form name in the description', confidence: 0.8, retryable: false },\n { suggestion: 'Use the element ID directly', confidence: 0.7, retryable: false },\n ];\n default:\n return [\n { suggestion: 'Try a different approach or check the page state', confidence: 0.5, retryable: false },\n ];\n }\n}\n\n/**\n * Create structured failure details\n */\nfunction createFailureDetails(\n errorCode: ActionErrorCode,\n message: string,\n options: {\n elementId?: string;\n selectorsTried?: string[];\n durationMs?: number;\n timeoutMs?: number;\n } = {}\n): ActionFailureDetails {\n const retryableErrors: ActionErrorCode[] = [\n 'ELEMENT_NOT_VISIBLE',\n 'ACTION_TIMEOUT',\n 'LOW_CONFIDENCE',\n 'NETWORK_ERROR',\n 'STATE_NOT_REACHED',\n ];\n\n return {\n errorCode,\n message,\n elementId: options.elementId,\n selectorsTried: options.selectorsTried,\n suggestedActions: getRecoverySuggestions(errorCode),\n retryRecommended: retryableErrors.includes(errorCode),\n durationMs: options.durationMs,\n timeoutMs: options.timeoutMs,\n };\n}\n\n/**\n * Create server handlers for UI Bridge\n *\n * @param registry - The UI Bridge registry instance\n * @param actionExecutor - The action executor instance\n * @param config - Optional configuration\n * @returns Handler implementations for all endpoints\n *\n * @example\n * ```ts\n * import { createHandlers } from '@qontinui/ui-bridge/server';\n * import { getGlobalRegistry, createActionExecutor } from '@qontinui/ui-bridge';\n *\n * const registry = getGlobalRegistry();\n * const executor = createActionExecutor(registry);\n * const handlers = createHandlers(registry, executor);\n *\n * // Use with Express\n * const router = createExpressRouter(handlers);\n *\n * // Use with standalone server\n * const server = new StandaloneServer(handlers);\n * ```\n */\nexport function createHandlers(\n registry: RegistryLike,\n actionExecutor: ActionExecutorLike,\n config: CreateHandlersConfig = {}\n): UIBridgeServerHandlers {\n // Create AI module instances\n const searchEngine = new SearchEngine();\n const nlExecutor = new NLActionExecutor();\n const assertionExecutor = new AssertionExecutor();\n const snapshotManager = new SemanticSnapshotManager();\n const diffManager = new SemanticDiffManager();\n\n // Helper to get fresh elements and update AI modules\n function refreshElements(): void {\n const elements = registry.getAllElements();\n searchEngine.updateElements(elements as any[]);\n nlExecutor.updateElements(elements as any[]);\n nlExecutor.setActionExecutor(actionExecutor as any);\n assertionExecutor.updateElements(elements as any[]);\n }\n\n return {\n // =========================================================================\n // Render Log Handlers\n // =========================================================================\n\n getRenderLog: async (query?: RenderLogQuery): Promise<APIResponse<RenderLogEntry[]>> => {\n try {\n const entries = registry.getRenderLog?.() ?? [];\n\n let filtered = entries;\n\n if (query?.type) {\n filtered = filtered.filter((e) => e.type === query.type);\n }\n if (query?.since) {\n filtered = filtered.filter((e) => e.timestamp >= query.since!);\n }\n if (query?.until) {\n filtered = filtered.filter((e) => e.timestamp <= query.until!);\n }\n if (query?.limit) {\n filtered = filtered.slice(0, query.limit);\n }\n\n return success(filtered);\n } catch (err) {\n return error((err as Error).message, 'RENDER_LOG_ERROR');\n }\n },\n\n clearRenderLog: async (): Promise<APIResponse<void>> => {\n try {\n registry.clearRenderLog?.();\n return success(undefined);\n } catch (err) {\n return error((err as Error).message, 'RENDER_LOG_ERROR');\n }\n },\n\n captureSnapshot: async (): Promise<APIResponse<unknown>> => {\n try {\n const snapshot = registry.captureSnapshot?.();\n return success(snapshot);\n } catch (err) {\n return error((err as Error).message, 'SNAPSHOT_ERROR');\n }\n },\n\n getRenderLogPath: async (): Promise<APIResponse<{ path: string }>> => {\n return success({ path: config.renderLogPath || '' });\n },\n\n // =========================================================================\n // Element Handlers\n // =========================================================================\n\n getElements: async (): Promise<APIResponse<ControlSnapshot['elements']>> => {\n try {\n const elements = registry.getAllElements();\n return success(elements as ControlSnapshot['elements']);\n } catch (err) {\n return error((err as Error).message, 'ELEMENTS_ERROR');\n }\n },\n\n getElement: async (id: string): Promise<APIResponse<ControlSnapshot['elements'][0]>> => {\n try {\n const element = registry.getElement(id);\n if (!element) {\n const failureDetails = createFailureDetails('ELEMENT_NOT_FOUND', `Element not found: ${id}`, {\n elementId: id,\n selectorsTried: [id],\n });\n return {\n success: false,\n error: `Element not found: ${id}`,\n code: 'ELEMENT_NOT_FOUND',\n data: { failureDetails } as any,\n timestamp: Date.now(),\n };\n }\n return success(element as ControlSnapshot['elements'][0]);\n } catch (err) {\n return error((err as Error).message, 'ELEMENT_ERROR');\n }\n },\n\n getElementState: async (id: string): Promise<APIResponse<unknown>> => {\n try {\n const element = registry.getElement(id) as { state?: unknown } | undefined;\n if (!element) {\n return error(`Element not found: ${id}`, 'NOT_FOUND');\n }\n return success(element.state);\n } catch (err) {\n return error((err as Error).message, 'ELEMENT_STATE_ERROR');\n }\n },\n\n executeElementAction: async (\n id: string,\n request: { action: string; params?: Record<string, unknown>; waitOptions?: unknown }\n ) => {\n const startTime = Date.now();\n try {\n // Check if element exists first\n const element = registry.getElement(id);\n if (!element) {\n const failureDetails = createFailureDetails('ELEMENT_NOT_FOUND', `Element not found: ${id}`, {\n elementId: id,\n selectorsTried: [id],\n durationMs: Date.now() - startTime,\n });\n return {\n success: false,\n error: `Element not found: ${id}`,\n code: 'ELEMENT_NOT_FOUND',\n data: {\n success: false,\n error: `Element not found: ${id}`,\n failureDetails,\n durationMs: Date.now() - startTime,\n timestamp: Date.now(),\n },\n timestamp: Date.now(),\n } as APIResponse<any>;\n }\n\n const result = await actionExecutor.executeAction(id, {\n action: request.action,\n params: request.params,\n waitOptions: request.waitOptions,\n });\n\n // If the action executor returned a failure, enhance with structured details\n if (result && typeof result === 'object' && 'success' in result && !result.success) {\n const actionResult = result as { success: boolean; error?: string; elementState?: unknown };\n // Determine error code based on error message\n let errorCode: ActionErrorCode = 'UNKNOWN_ERROR';\n const errorMsg = actionResult.error?.toLowerCase() || '';\n\n if (errorMsg.includes('not found')) {\n errorCode = 'ELEMENT_NOT_FOUND';\n } else if (errorMsg.includes('not visible') || errorMsg.includes('hidden')) {\n errorCode = 'ELEMENT_NOT_VISIBLE';\n } else if (errorMsg.includes('disabled') || errorMsg.includes('not enabled')) {\n errorCode = 'ELEMENT_NOT_ENABLED';\n } else if (errorMsg.includes('timeout')) {\n errorCode = 'ACTION_TIMEOUT';\n } else if (errorMsg.includes('blocked') || errorMsg.includes('interactable')) {\n errorCode = 'ELEMENT_NOT_INTERACTABLE';\n }\n\n const failureDetails = createFailureDetails(errorCode, actionResult.error || 'Action failed', {\n elementId: id,\n durationMs: Date.now() - startTime,\n });\n\n return success({\n ...actionResult,\n failureDetails,\n }) as APIResponse<any>;\n }\n\n return success(result) as APIResponse<any>;\n } catch (err) {\n const errorMessage = (err as Error).message;\n let errorCode: ActionErrorCode = 'UNKNOWN_ERROR';\n\n if (errorMessage.includes('not found')) {\n errorCode = 'ELEMENT_NOT_FOUND';\n } else if (errorMessage.includes('timeout')) {\n errorCode = 'ACTION_TIMEOUT';\n } else if (errorMessage.includes('network') || errorMessage.includes('fetch')) {\n errorCode = 'NETWORK_ERROR';\n }\n\n const failureDetails = createFailureDetails(errorCode, errorMessage, {\n elementId: id,\n durationMs: Date.now() - startTime,\n });\n\n return {\n success: false,\n error: errorMessage,\n code: errorCode,\n data: {\n success: false,\n error: errorMessage,\n failureDetails,\n durationMs: Date.now() - startTime,\n timestamp: Date.now(),\n },\n timestamp: Date.now(),\n } as APIResponse<any>;\n }\n },\n\n // =========================================================================\n // Component Handlers\n // =========================================================================\n\n getComponents: async (): Promise<APIResponse<ControlSnapshot['components']>> => {\n try {\n const components = registry.getAllComponents();\n return success(components as ControlSnapshot['components']);\n } catch (err) {\n return error((err as Error).message, 'COMPONENTS_ERROR');\n }\n },\n\n getComponent: async (id: string): Promise<APIResponse<ControlSnapshot['components'][0]>> => {\n try {\n const component = registry.getComponent(id);\n if (!component) {\n return error(`Component not found: ${id}`, 'NOT_FOUND');\n }\n return success(component as ControlSnapshot['components'][0]);\n } catch (err) {\n return error((err as Error).message, 'COMPONENT_ERROR');\n }\n },\n\n getComponentState: async (id: string): Promise<APIResponse<{ state: Record<string, unknown>; computed: Record<string, unknown>; timestamp: number }>> => {\n try {\n // First check if the component exists\n const component = registry.getComponent(id);\n if (!component) {\n return error(`Component not found: ${id}`, 'NOT_FOUND');\n }\n\n // Use registry's getComponentState if available\n if (registry.getComponentState) {\n const stateResponse = registry.getComponentState(id);\n if (!stateResponse) {\n return error(`Component not found or not mounted: ${id}`, 'NOT_FOUND');\n }\n return success(stateResponse);\n }\n\n // Fallback: component exists but doesn't expose state\n const comp = component as { getState?: () => Record<string, unknown>; getComputed?: () => Record<string, unknown> };\n return success({\n state: comp.getState?.() ?? {},\n computed: comp.getComputed?.() ?? {},\n timestamp: Date.now(),\n });\n } catch (err) {\n return error((err as Error).message, 'COMPONENT_STATE_ERROR');\n }\n },\n\n executeComponentAction: async (\n id: string,\n request: { action: string; params?: Record<string, unknown> }\n ) => {\n try {\n const result = await actionExecutor.executeComponentAction(id, {\n action: request.action,\n params: request.params,\n });\n return success(result) as APIResponse<any>;\n } catch (err) {\n return error((err as Error).message, 'COMPONENT_ACTION_ERROR');\n }\n },\n\n // =========================================================================\n // Find/Discovery Handlers\n // =========================================================================\n\n find: async (request?: unknown) => {\n try {\n const findRequest = request as { types?: string[]; selector?: string; limit?: number } | undefined;\n const elements = registry.findElements?.(findRequest) ?? registry.getAllElements();\n return success({ elements, timestamp: Date.now(), total: (elements as unknown[]).length, durationMs: 0 }) as APIResponse<any>;\n } catch (err) {\n return error((err as Error).message, 'FIND_ERROR');\n }\n },\n\n discover: async (request?: unknown) => {\n // Deprecated, delegates to find\n try {\n const findRequest = request as { types?: string[]; selector?: string; limit?: number } | undefined;\n const elements = registry.findElements?.(findRequest) ?? registry.getAllElements();\n return success({ elements, timestamp: Date.now(), total: (elements as unknown[]).length, durationMs: 0 }) as APIResponse<any>;\n } catch (err) {\n return error((err as Error).message, 'DISCOVER_ERROR');\n }\n },\n\n getControlSnapshot: async (): Promise<APIResponse<ControlSnapshot>> => {\n try {\n const snapshot = registry.createSnapshot();\n return success(snapshot);\n } catch (err) {\n return error((err as Error).message, 'SNAPSHOT_ERROR');\n }\n },\n\n // =========================================================================\n // Workflow Handlers\n // =========================================================================\n\n getWorkflows: async (): Promise<APIResponse<ControlSnapshot['workflows']>> => {\n try {\n const workflows = registry.getAllWorkflows?.() ?? [];\n return success(workflows as ControlSnapshot['workflows']);\n } catch (err) {\n return error((err as Error).message, 'WORKFLOWS_ERROR');\n }\n },\n\n runWorkflow: async (\n id: string,\n _request?: unknown\n ) => {\n try {\n const workflow = registry.getWorkflow?.(id);\n if (!workflow) {\n return error(`Workflow not found: ${id}`, 'NOT_FOUND');\n }\n // TODO: Implement actual workflow execution\n const runId = `run-${Date.now()}`;\n return success({\n runId,\n workflowId: id,\n status: 'pending',\n startedAt: Date.now(),\n steps: [],\n totalSteps: 0,\n }) as APIResponse<any>;\n } catch (err) {\n return error((err as Error).message, 'WORKFLOW_ERROR');\n }\n },\n\n getWorkflowStatus: async (runId: string) => {\n try {\n // TODO: Implement workflow status tracking\n return success({\n runId,\n workflowId: '',\n status: 'completed',\n completedAt: Date.now(),\n startedAt: Date.now(),\n steps: [],\n totalSteps: 0,\n }) as APIResponse<any>;\n } catch (err) {\n return error((err as Error).message, 'WORKFLOW_STATUS_ERROR');\n }\n },\n\n // =========================================================================\n // Debug Handlers\n // =========================================================================\n\n getActionHistory: async (limit?: number): Promise<APIResponse<unknown[]>> => {\n try {\n const history = registry.getActionHistory?.() ?? [];\n const limited = limit ? history.slice(-limit) : history;\n return success(limited);\n } catch (err) {\n return error((err as Error).message, 'ACTION_HISTORY_ERROR');\n }\n },\n\n getMetrics: async (): Promise<APIResponse<unknown>> => {\n try {\n const metrics = registry.getMetrics?.() ?? {\n elementCount: registry.getAllElements().length,\n componentCount: registry.getAllComponents().length,\n };\n return success(metrics);\n } catch (err) {\n return error((err as Error).message, 'METRICS_ERROR');\n }\n },\n\n highlightElement: async (id: string): Promise<APIResponse<void>> => {\n try {\n registry.highlightElement?.(id);\n return success(undefined);\n } catch (err) {\n return error((err as Error).message, 'HIGHLIGHT_ERROR');\n }\n },\n\n getElementTree: async (): Promise<APIResponse<unknown>> => {\n try {\n const tree = registry.getElementTree?.() ?? { root: null, elements: [] };\n return success(tree);\n } catch (err) {\n return error((err as Error).message, 'ELEMENT_TREE_ERROR');\n }\n },\n\n // =========================================================================\n // AI-Native Handlers\n // =========================================================================\n\n aiSearch: async (criteria: SearchCriteria): Promise<APIResponse<SearchResponse>> => {\n try {\n // Refresh elements before search\n refreshElements();\n const response = searchEngine.search(criteria);\n return success(response);\n } catch (err) {\n return error((err as Error).message, 'AI_SEARCH_ERROR');\n }\n },\n\n aiExecute: async (request: NLActionRequest): Promise<APIResponse<NLActionResponse>> => {\n try {\n // Refresh elements before execution\n refreshElements();\n const response = await nlExecutor.execute(request);\n return success(response);\n } catch (err) {\n return error((err as Error).message, 'AI_EXECUTE_ERROR');\n }\n },\n\n aiAssert: async (request: AssertionRequest): Promise<APIResponse<AssertionResult>> => {\n try {\n // Refresh elements before assertion\n refreshElements();\n const result = await assertionExecutor.assert(request);\n return success(result);\n } catch (err) {\n return error((err as Error).message, 'AI_ASSERT_ERROR');\n }\n },\n\n aiAssertBatch: async (request: BatchAssertionRequest): Promise<APIResponse<BatchAssertionResult>> => {\n try {\n // Refresh elements before batch assertion\n refreshElements();\n const result = await assertionExecutor.assertBatch(request);\n return success(result);\n } catch (err) {\n return error((err as Error).message, 'AI_ASSERT_BATCH_ERROR');\n }\n },\n\n getSemanticSnapshot: async (): Promise<APIResponse<SemanticSnapshot>> => {\n try {\n const controlSnapshot = registry.createSnapshot();\n const snapshot = snapshotManager.createSnapshot(controlSnapshot);\n return success(snapshot);\n } catch (err) {\n return error((err as Error).message, 'SEMANTIC_SNAPSHOT_ERROR');\n }\n },\n\n getSemanticDiff: async (_since?: number): Promise<APIResponse<SemanticDiff | null>> => {\n try {\n // Create current snapshot\n const controlSnapshot = registry.createSnapshot();\n const currentSnapshot = snapshotManager.createSnapshot(controlSnapshot);\n\n // Update the diff manager and get the diff from previous state\n const diff = diffManager.update(currentSnapshot);\n return success(diff);\n } catch (err) {\n return error((err as Error).message, 'SEMANTIC_DIFF_ERROR');\n }\n },\n\n getPageSummary: async (): Promise<APIResponse<string>> => {\n try {\n const snapshot = registry.createSnapshot();\n // Convert snapshot elements to AI elements format for summary\n const elements = snapshot.elements.map(el => ({\n ...el,\n description: el.label || el.id,\n aliases: [],\n suggestedActions: [],\n tagName: el.type,\n accessibleName: el.label,\n registered: true,\n })) as any[];\n const summary = generatePageSummary(elements);\n return success(summary);\n } catch (err) {\n return error((err as Error).message, 'PAGE_SUMMARY_ERROR');\n }\n },\n\n // =========================================================================\n // Semantic Search Handler (Embedding-based)\n // =========================================================================\n\n aiSemanticSearch: async (criteria: SemanticSearchCriteria): Promise<APIResponse<SemanticSearchResponse>> => {\n const startTime = performance.now();\n try {\n // Refresh elements for search\n refreshElements();\n\n // Get all elements\n const allElements = registry.getAllElements() as any[];\n\n // Convert to AI discovered elements for semantic search\n const aiElements: Array<{ element: AIDiscoveredElement; text: string }> = allElements.map(el => {\n // Build searchable text from element properties\n const textParts: string[] = [];\n\n // Prioritize description and accessible name for semantic matching\n const state = 'getState' in el ? (el as any).getState() : el.state;\n const textContent = state?.textContent || '';\n const label = el.label || '';\n const accessibleName = el.accessibleName || '';\n const placeholder = el.placeholder || '';\n const title = el.title || '';\n\n if (label) textParts.push(label);\n if (accessibleName && accessibleName !== label) textParts.push(accessibleName);\n if (textContent && textContent !== label && textContent !== accessibleName) {\n textParts.push(textContent);\n }\n if (placeholder) textParts.push(`placeholder: ${placeholder}`);\n if (title) textParts.push(title);\n\n const combinedText = textParts.join(' ').trim() || el.id;\n\n return {\n element: {\n id: el.id,\n type: el.type,\n label: el.label,\n tagName: el.tagName || el.type,\n role: el.role,\n accessibleName: el.accessibleName,\n actions: el.actions || [],\n state: state || {},\n registered: true,\n description: label || el.id,\n aliases: [],\n suggestedActions: [],\n } as AIDiscoveredElement,\n text: combinedText,\n };\n });\n\n // Apply type/role filters if specified\n let filteredElements = aiElements;\n if (criteria.type) {\n filteredElements = filteredElements.filter(\n ({ element }) => element.type.toLowerCase() === criteria.type!.toLowerCase()\n );\n }\n if (criteria.role) {\n filteredElements = filteredElements.filter(\n ({ element }) => element.role?.toLowerCase() === criteria.role!.toLowerCase()\n );\n }\n\n // NOTE: Semantic search with embeddings requires server-side embedding support.\n // This handler provides the API structure. Actual embedding computation\n // should be delegated to the qontinui library or a separate embedding service.\n //\n // For now, we fall back to fuzzy text matching as a placeholder.\n // In production, this would call the qontinui embeddings module.\n\n const query = criteria.query.toLowerCase();\n const threshold = criteria.threshold ?? 0.5;\n const limit = criteria.limit ?? 10;\n\n // Simple text similarity as fallback (to be replaced with embedding similarity)\n const scoredResults: SemanticSearchResult[] = filteredElements.map(({ element, text }) => {\n // Calculate basic text similarity\n const textLower = text.toLowerCase();\n let similarity = 0;\n\n // Exact match\n if (textLower.includes(query)) {\n similarity = 0.9;\n } else {\n // Word overlap similarity\n const queryWords = new Set(query.split(/\\s+/).filter((w: string) => w.length > 2));\n const textWords = new Set(textLower.split(/\\s+/).filter((w: string) => w.length > 2));\n\n if (queryWords.size > 0 && textWords.size > 0) {\n let matchCount = 0;\n for (const word of queryWords) {\n for (const textWord of textWords) {\n if (textWord.includes(word) || word.includes(textWord)) {\n matchCount++;\n break;\n }\n }\n }\n similarity = matchCount / queryWords.size * 0.7;\n }\n }\n\n return {\n element,\n similarity,\n rank: 0, // Will be set after sorting\n embeddedText: text,\n };\n });\n\n // Filter by threshold and sort by similarity\n const filteredResults = scoredResults\n .filter(r => r.similarity >= threshold)\n .sort((a, b) => b.similarity - a.similarity)\n .slice(0, limit);\n\n // Set ranks\n filteredResults.forEach((result, index) => {\n result.rank = index + 1;\n });\n\n const response: SemanticSearchResponse = {\n results: filteredResults,\n bestMatch: filteredResults.length > 0 ? filteredResults[0] : null,\n scannedCount: filteredElements.length,\n durationMs: performance.now() - startTime,\n query: criteria.query,\n providerInfo: {\n provider: 'text-fallback',\n model: 'simple-similarity',\n dimension: 0,\n },\n timestamp: Date.now(),\n };\n\n return success(response);\n } catch (err) {\n return error((err as Error).message, 'AI_SEMANTIC_SEARCH_ERROR');\n }\n },\n };\n}\n\n/**\n * Create partial handlers for AI-specific functionality only\n *\n * Use this when you want to add AI endpoints to an existing handler setup.\n */\nexport function createAIHandlers(\n registry: RegistryLike,\n actionExecutor: ActionExecutorLike\n): Pick<\n UIBridgeServerHandlers,\n | 'aiSearch'\n | 'aiExecute'\n | 'aiAssert'\n | 'aiAssertBatch'\n | 'getSemanticSnapshot'\n | 'getSemanticDiff'\n | 'getPageSummary'\n> {\n const searchEngine = new SearchEngine();\n const nlExecutor = new NLActionExecutor();\n const assertionExecutor = new AssertionExecutor();\n const snapshotManager = new SemanticSnapshotManager();\n const diffManager = new SemanticDiffManager();\n\n function refreshElements(): void {\n const elements = registry.getAllElements();\n searchEngine.updateElements(elements as any[]);\n nlExecutor.updateElements(elements as any[]);\n nlExecutor.setActionExecutor(actionExecutor as any);\n assertionExecutor.updateElements(elements as any[]);\n }\n\n return {\n aiSearch: async (criteria: SearchCriteria): Promise<APIResponse<SearchResponse>> => {\n try {\n refreshElements();\n const response = searchEngine.search(criteria);\n return { success: true, data: response, timestamp: Date.now() };\n } catch (err) {\n return { success: false, error: (err as Error).message, code: 'AI_SEARCH_ERROR', timestamp: Date.now() };\n }\n },\n\n aiExecute: async (request: NLActionRequest): Promise<APIResponse<NLActionResponse>> => {\n try {\n refreshElements();\n const response = await nlExecutor.execute(request);\n return { success: true, data: response, timestamp: Date.now() };\n } catch (err) {\n return { success: false, error: (err as Error).message, code: 'AI_EXECUTE_ERROR', timestamp: Date.now() };\n }\n },\n\n aiAssert: async (request: AssertionRequest): Promise<APIResponse<AssertionResult>> => {\n try {\n refreshElements();\n const result = await assertionExecutor.assert(request);\n return { success: true, data: result, timestamp: Date.now() };\n } catch (err) {\n return { success: false, error: (err as Error).message, code: 'AI_ASSERT_ERROR', timestamp: Date.now() };\n }\n },\n\n aiAssertBatch: async (request: BatchAssertionRequest): Promise<APIResponse<BatchAssertionResult>> => {\n try {\n refreshElements();\n const result = await assertionExecutor.assertBatch(request);\n return { success: true, data: result, timestamp: Date.now() };\n } catch (err) {\n return { success: false, error: (err as Error).message, code: 'AI_ASSERT_BATCH_ERROR', timestamp: Date.now() };\n }\n },\n\n getSemanticSnapshot: async (): Promise<APIResponse<SemanticSnapshot>> => {\n try {\n const controlSnapshot = registry.createSnapshot();\n const snapshot = snapshotManager.createSnapshot(controlSnapshot);\n return { success: true, data: snapshot, timestamp: Date.now() };\n } catch (err) {\n return { success: false, error: (err as Error).message, code: 'SEMANTIC_SNAPSHOT_ERROR', timestamp: Date.now() };\n }\n },\n\n getSemanticDiff: async (_since?: number): Promise<APIResponse<SemanticDiff | null>> => {\n try {\n const controlSnapshot = registry.createSnapshot();\n const currentSnapshot = snapshotManager.createSnapshot(controlSnapshot);\n const diff = diffManager.update(currentSnapshot);\n return { success: true, data: diff, timestamp: Date.now() };\n } catch (err) {\n return { success: false, error: (err as Error).message, code: 'SEMANTIC_DIFF_ERROR', timestamp: Date.now() };\n }\n },\n\n getPageSummary: async (): Promise<APIResponse<string>> => {\n try {\n const snapshot = registry.createSnapshot();\n // Convert snapshot elements to AI elements format for summary\n const elements = snapshot.elements.map(el => ({\n ...el,\n description: el.label || el.id,\n aliases: [],\n suggestedActions: [],\n tagName: el.type,\n accessibleName: el.label,\n registered: true,\n })) as any[];\n const summary = generatePageSummary(elements);\n return { success: true, data: summary, timestamp: Date.now() };\n } catch (err) {\n return { success: false, error: (err as Error).message, code: 'PAGE_SUMMARY_ERROR', timestamp: Date.now() };\n }\n },\n };\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../../src/ai/fuzzy-matcher.ts","../../src/ai/alias-generator.ts","../../src/annotations/types.ts","../../src/annotations/store.ts","../../src/ai/search-engine.ts","../../src/ai/summary-generator.ts","../../src/ai/nl-action-parser.ts","../../src/ai/error-context.ts","../../src/ai/nl-action-executor.ts","../../src/ai/assertions.ts","../../src/ai/semantic-snapshot.ts","../../src/ai/semantic-diff.ts","../../src/ai/data-extraction.ts","../../src/ai/region-segmentation.ts","../../src/ai/table-extraction.ts","../../src/ai/format-analysis.ts","../../src/ai/cross-app-diff.ts","../../src/ai/action-parity.ts","../../src/ai/navigation-map.ts","../../src/ai/component-comparison.ts","../../src/ai/layout-comparison.ts","../../src/ai/content-comparison.ts","../../src/ai/comparison-report.ts","../../src/server/handlers.ts"],"names":["aliases","error","result","getElementText","isContentElement","config"],"mappings":";;;AA8BO,IAAM,oBAAA,GAAyC;AAAA,EACpD,SAAA,EAAW,GAAA;AAAA,EACX,iBAAA,EAAmB,GAAA;AAAA,EACnB,iBAAA,EAAmB,GAAA;AAAA,EACnB,WAAA,EAAa,GAAA;AAAA,EACb,SAAA,EAAW,CAAA;AAAA,EACX,aAAA,EAAe,KAAA;AAAA,EACf,gBAAA,EAAkB;AACpB,CAAA;AAyBO,SAAS,mBAAA,CAAoB,IAAY,EAAA,EAAoB;AAClE,EAAA,MAAM,OAAO,EAAA,CAAG,MAAA;AAChB,EAAA,MAAM,OAAO,EAAA,CAAG,MAAA;AAGhB,EAAA,MAAM,SAAqB,KAAA,CAAM,IAAA,GAAO,CAAC,CAAA,CACtC,KAAK,IAAI,CAAA,CACT,GAAA,CAAI,MAAM,MAAM,IAAA,GAAO,CAAC,CAAA,CAAE,IAAA,CAAK,CAAC,CAAC,CAAA;AAGpC,EAAA,KAAA,IAAS,CAAA,GAAI,GAAG,CAAA,IAAK,IAAA,EAAM,KAAK,MAAA,CAAO,CAAC,CAAA,CAAE,CAAC,CAAA,GAAI,CAAA;AAC/C,EAAA,KAAA,IAAS,CAAA,GAAI,GAAG,CAAA,IAAK,IAAA,EAAM,KAAK,MAAA,CAAO,CAAC,CAAA,CAAE,CAAC,CAAA,GAAI,CAAA;AAG/C,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,IAAK,IAAA,EAAM,CAAA,EAAA,EAAK;AAC9B,IAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,IAAK,IAAA,EAAM,CAAA,EAAA,EAAK;AAC9B,MAAA,MAAM,IAAA,GAAO,GAAG,CAAA,GAAI,CAAC,MAAM,EAAA,CAAG,CAAA,GAAI,CAAC,CAAA,GAAI,CAAA,GAAI,CAAA;AAC3C,MAAA,MAAA,CAAO,CAAC,CAAA,CAAE,CAAC,CAAA,GAAI,IAAA,CAAK,GAAA;AAAA,QAClB,MAAA,CAAO,CAAA,GAAI,CAAC,CAAA,CAAE,CAAC,CAAA,GAAI,CAAA;AAAA;AAAA,QACnB,MAAA,CAAO,CAAC,CAAA,CAAE,CAAA,GAAI,CAAC,CAAA,GAAI,CAAA;AAAA;AAAA,QACnB,OAAO,CAAA,GAAI,CAAC,CAAA,CAAE,CAAA,GAAI,CAAC,CAAA,GAAI;AAAA;AAAA,OACzB;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO,MAAA,CAAO,IAAI,CAAA,CAAE,IAAI,CAAA;AAC1B;AAKO,SAAS,qBAAA,CAAsB,IAAY,EAAA,EAAoB;AACpE,EAAA,IAAI,GAAG,MAAA,KAAW,CAAA,IAAK,EAAA,CAAG,MAAA,KAAW,GAAG,OAAO,CAAA;AAC/C,EAAA,IAAI,GAAG,MAAA,KAAW,CAAA,IAAK,EAAA,CAAG,MAAA,KAAW,GAAG,OAAO,CAAA;AAE/C,EAAA,MAAM,QAAA,GAAW,mBAAA,CAAoB,EAAA,EAAI,EAAE,CAAA;AAC3C,EAAA,MAAM,YAAY,IAAA,CAAK,GAAA,CAAI,EAAA,CAAG,MAAA,EAAQ,GAAG,MAAM,CAAA;AAE/C,EAAA,OAAO,IAAI,QAAA,GAAW,SAAA;AACxB;AAKO,SAAS,cAAA,CAAe,IAAY,EAAA,EAAoB;AAC7D,EAAA,IAAI,GAAG,MAAA,KAAW,CAAA,IAAK,EAAA,CAAG,MAAA,KAAW,GAAG,OAAO,CAAA;AAC/C,EAAA,IAAI,GAAG,MAAA,KAAW,CAAA,IAAK,EAAA,CAAG,MAAA,KAAW,GAAG,OAAO,CAAA;AAE/C,EAAA,MAAM,aAAA,GAAgB,IAAA,CAAK,KAAA,CAAM,IAAA,CAAK,GAAA,CAAI,EAAA,CAAG,MAAA,EAAQ,EAAA,CAAG,MAAM,CAAA,GAAI,CAAC,CAAA,GAAI,CAAA;AACvE,EAAA,MAAM,YAAY,IAAI,KAAA,CAAM,GAAG,MAAM,CAAA,CAAE,KAAK,KAAK,CAAA;AACjD,EAAA,MAAM,YAAY,IAAI,KAAA,CAAM,GAAG,MAAM,CAAA,CAAE,KAAK,KAAK,CAAA;AAEjD,EAAA,IAAI,OAAA,GAAU,CAAA;AACd,EAAA,IAAI,cAAA,GAAiB,CAAA;AAGrB,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,EAAA,CAAG,QAAQ,CAAA,EAAA,EAAK;AAClC,IAAA,MAAM,KAAA,GAAQ,IAAA,CAAK,GAAA,CAAI,CAAA,EAAG,IAAI,aAAa,CAAA;AAC3C,IAAA,MAAM,MAAM,IAAA,CAAK,GAAA,CAAI,IAAI,aAAA,GAAgB,CAAA,EAAG,GAAG,MAAM,CAAA;AAErD,IAAA,KAAA,IAAS,CAAA,GAAI,KAAA,EAAO,CAAA,GAAI,GAAA,EAAK,CAAA,EAAA,EAAK;AAChC,MAAA,IAAI,SAAA,CAAU,CAAC,CAAA,IAAK,EAAA,CAAG,CAAC,CAAA,KAAM,EAAA,CAAG,CAAC,CAAA,EAAG;AACrC,MAAA,SAAA,CAAU,CAAC,CAAA,GAAI,IAAA;AACf,MAAA,SAAA,CAAU,CAAC,CAAA,GAAI,IAAA;AACf,MAAA,OAAA,EAAA;AACA,MAAA;AAAA,IACF;AAAA,EACF;AAEA,EAAA,IAAI,OAAA,KAAY,GAAG,OAAO,CAAA;AAG1B,EAAA,IAAI,CAAA,GAAI,CAAA;AACR,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,EAAA,CAAG,QAAQ,CAAA,EAAA,EAAK;AAClC,IAAA,IAAI,CAAC,SAAA,CAAU,CAAC,CAAA,EAAG;AACnB,IAAA,OAAO,CAAC,SAAA,CAAU,CAAC,CAAA,EAAG,CAAA,EAAA;AACtB,IAAA,IAAI,EAAA,CAAG,CAAC,CAAA,KAAM,EAAA,CAAG,CAAC,CAAA,EAAG,cAAA,EAAA;AACrB,IAAA,CAAA,EAAA;AAAA,EACF;AAEA,EAAA,OAAA,CAAQ,OAAA,GAAU,GAAG,MAAA,GAAS,OAAA,GAAU,GAAG,MAAA,GAAA,CAAU,OAAA,GAAU,cAAA,GAAiB,CAAA,IAAK,OAAA,IAAW,CAAA;AAClG;AAMO,SAAS,qBAAA,CAAsB,EAAA,EAAY,EAAA,EAAY,WAAA,GAAsB,GAAA,EAAa;AAC/F,EAAA,MAAM,OAAA,GAAU,cAAA,CAAe,EAAA,EAAI,EAAE,CAAA;AAGrC,EAAA,IAAI,YAAA,GAAe,CAAA;AACnB,EAAA,MAAM,SAAA,GAAY,IAAA,CAAK,GAAA,CAAI,CAAA,EAAG,IAAA,CAAK,IAAI,EAAA,CAAG,MAAA,EAAQ,EAAA,CAAG,MAAM,CAAC,CAAA;AAE5D,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,SAAA,EAAW,CAAA,EAAA,EAAK;AAClC,IAAA,IAAI,EAAA,CAAG,CAAC,CAAA,KAAM,EAAA,CAAG,CAAC,CAAA,EAAG;AACnB,MAAA,YAAA,EAAA;AAAA,IACF,CAAA,MAAO;AACL,MAAA;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO,OAAA,GAAU,YAAA,GAAe,WAAA,IAAe,CAAA,GAAI,OAAA,CAAA;AACrD;AAKO,SAAS,cAAA,CAAe,GAAW,CAAA,EAAwB;AAChE,EAAA,MAAM,MAAA,uBAAa,GAAA,EAAY;AAE/B,EAAA,IAAI,CAAA,CAAE,SAAS,CAAA,EAAG;AAChB,IAAA,MAAA,CAAO,IAAI,CAAC,CAAA;AACZ,IAAA,OAAO,MAAA;AAAA,EACT;AAEA,EAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,IAAK,CAAA,CAAE,MAAA,GAAS,GAAG,CAAA,EAAA,EAAK;AACtC,IAAA,MAAA,CAAO,IAAI,CAAA,CAAE,SAAA,CAAU,CAAA,EAAG,CAAA,GAAI,CAAC,CAAC,CAAA;AAAA,EAClC;AAEA,EAAA,OAAO,MAAA;AACT;AAKO,SAAS,eAAA,CAAgB,EAAA,EAAY,EAAA,EAAY,CAAA,GAAY,CAAA,EAAW;AAC7E,EAAA,IAAI,GAAG,MAAA,KAAW,CAAA,IAAK,EAAA,CAAG,MAAA,KAAW,GAAG,OAAO,CAAA;AAC/C,EAAA,IAAI,GAAG,MAAA,KAAW,CAAA,IAAK,EAAA,CAAG,MAAA,KAAW,GAAG,OAAO,CAAA;AAE/C,EAAA,MAAM,OAAA,GAAU,cAAA,CAAe,EAAA,EAAI,CAAC,CAAA;AACpC,EAAA,MAAM,OAAA,GAAU,cAAA,CAAe,EAAA,EAAI,CAAC,CAAA;AAGpC,EAAA,IAAI,YAAA,GAAe,CAAA;AACnB,EAAA,KAAA,MAAW,SAAS,OAAA,EAAS;AAC3B,IAAA,IAAI,OAAA,CAAQ,GAAA,CAAI,KAAK,CAAA,EAAG;AACtB,MAAA,YAAA,EAAA;AAAA,IACF;AAAA,EACF;AAGA,EAAA,MAAM,KAAA,GAAQ,OAAA,CAAQ,IAAA,GAAO,OAAA,CAAQ,IAAA,GAAO,YAAA;AAE5C,EAAA,OAAO,KAAA,KAAU,CAAA,GAAI,CAAA,GAAI,YAAA,GAAe,KAAA;AAC1C;AAKO,SAAS,eAAA,CAAgB,CAAA,EAAW,MAAA,GAAoC,EAAC,EAAW;AACzF,EAAA,IAAI,UAAA,GAAa,CAAA;AAGjB,EAAA,IAAI,CAAC,OAAO,aAAA,EAAe;AACzB,IAAA,UAAA,GAAa,WAAW,WAAA,EAAY;AAAA,EACtC;AAGA,EAAA,IAAI,MAAA,CAAO,qBAAqB,KAAA,EAAO;AACrC,IAAA,UAAA,GAAa,UAAA,CAAW,OAAA,CAAQ,MAAA,EAAQ,GAAG,EAAE,IAAA,EAAK;AAAA,EACpD;AAEA,EAAA,OAAO,UAAA;AACT;AAMO,SAAS,UAAA,CACd,MAAA,EACA,MAAA,EACA,MAAA,GAAoC,EAAC,EACnB;AAClB,EAAA,MAAM,WAAA,GAAc,EAAE,GAAG,oBAAA,EAAsB,GAAG,MAAA,EAAO;AAGzD,EAAA,MAAM,gBAAA,GAAmB,eAAA,CAAgB,MAAA,EAAQ,WAAW,CAAA;AAC5D,EAAA,MAAM,gBAAA,GAAmB,eAAA,CAAgB,MAAA,EAAQ,WAAW,CAAA;AAG5D,EAAA,MAAM,gBAAA,GAAmB,qBAAA,CAAsB,gBAAA,EAAkB,gBAAgB,CAAA;AACjF,EAAA,MAAM,gBAAA,GAAmB,qBAAA,CAAsB,gBAAA,EAAkB,gBAAgB,CAAA;AACjF,EAAA,MAAM,UAAA,GAAa,eAAA,CAAgB,gBAAA,EAAkB,gBAAA,EAAkB,YAAY,SAAS,CAAA;AAG5F,EAAA,MAAM,UAAA,GACJ,mBAAmB,WAAA,CAAY,iBAAA,GAC/B,mBAAmB,WAAA,CAAY,iBAAA,GAC/B,aAAa,WAAA,CAAY,WAAA;AAE3B,EAAA,OAAO;AAAA,IACL,UAAA;AAAA,IACA,OAAA,EAAS,cAAc,WAAA,CAAY,SAAA;AAAA,IACnC,MAAA,EAAQ;AAAA,MACN,WAAA,EAAa,gBAAA;AAAA,MACb,WAAA,EAAa,gBAAA;AAAA,MACb,KAAA,EAAO;AAAA,KACT;AAAA,IACA,gBAAA;AAAA,IACA;AAAA,GACF;AACF;AA0DO,SAAS,aAAA,CACd,MAAA,EACA,MAAA,EACA,MAAA,GAAoC,EAAC,EAC5B;AACT,EAAA,MAAM,WAAA,GAAc,EAAE,GAAG,oBAAA,EAAsB,GAAG,MAAA,EAAO;AACzD,EAAA,MAAM,gBAAA,GAAmB,eAAA,CAAgB,MAAA,EAAQ,WAAW,CAAA;AAC5D,EAAA,MAAM,gBAAA,GAAmB,eAAA,CAAgB,MAAA,EAAQ,WAAW,CAAA;AAG5D,EAAA,IAAI,gBAAA,CAAiB,QAAA,CAAS,gBAAgB,CAAA,EAAG;AAC/C,IAAA,OAAO,IAAA;AAAA,EACT;AAGA,EAAA,MAAM,WAAA,GAAc,gBAAA,CAAiB,KAAA,CAAM,KAAK,CAAA;AAChD,EAAA,MAAM,WAAA,GAAc,gBAAA,CAAiB,KAAA,CAAM,KAAK,CAAA;AAGhD,EAAA,KAAA,MAAW,cAAc,WAAA,EAAa;AACpC,IAAA,MAAM,QAAA,GAAW,WAAA,CAAY,IAAA,CAAK,CAAC,UAAA,KAAe;AAChD,MAAA,MAAM,MAAA,GAAS,WAAW,UAAA,EAAY,UAAA,EAAY,EAAE,GAAG,WAAA,EAAa,SAAA,EAAW,GAAA,EAAK,CAAA;AACpF,MAAA,OAAO,MAAA,CAAO,OAAA;AAAA,IAChB,CAAC,CAAA;AAED,IAAA,IAAI,CAAC,QAAA,EAAU;AACb,MAAA,OAAO,KAAA;AAAA,IACT;AAAA,EACF;AAEA,EAAA,OAAO,IAAA;AACT;AAMO,SAAS,cAAA,CACd,EAAA,EACA,EAAA,EACA,MAAA,GAAoC,EAAC,EAC7B;AACR,EAAA,MAAM,WAAA,GAAc,EAAE,GAAG,oBAAA,EAAsB,GAAG,MAAA,EAAO;AACzD,EAAA,MAAM,SAAS,eAAA,CAAgB,EAAA,EAAI,WAAW,CAAA,CAAE,MAAM,KAAK,CAAA;AAC3D,EAAA,MAAM,SAAS,eAAA,CAAgB,EAAA,EAAI,WAAW,CAAA,CAAE,MAAM,KAAK,CAAA;AAE3D,EAAA,IAAI,OAAO,MAAA,KAAW,CAAA,IAAK,MAAA,CAAO,MAAA,KAAW,GAAG,OAAO,CAAA;AACvD,EAAA,IAAI,OAAO,MAAA,KAAW,CAAA,IAAK,MAAA,CAAO,MAAA,KAAW,GAAG,OAAO,CAAA;AAEvD,EAAA,IAAI,eAAA,GAAkB,CAAA;AACtB,EAAA,IAAI,UAAA,GAAa,CAAA;AAGjB,EAAA,KAAA,MAAW,SAAS,MAAA,EAAQ;AAC1B,IAAA,IAAI,OAAA,GAAU,CAAA;AACd,IAAA,KAAA,MAAW,SAAS,MAAA,EAAQ;AAC1B,MAAA,MAAM,MAAA,GAAS,UAAA,CAAW,KAAA,EAAO,KAAA,EAAO,WAAW,CAAA;AACnD,MAAA,IAAI,MAAA,CAAO,aAAa,OAAA,EAAS;AAC/B,QAAA,OAAA,GAAU,MAAA,CAAO,UAAA;AAAA,MACnB;AAAA,IACF;AACA,IAAA,eAAA,IAAmB,OAAA;AACnB,IAAA,IAAI,OAAA,IAAW,YAAY,SAAA,EAAW;AACpC,MAAA,UAAA,EAAA;AAAA,IACF;AAAA,EACF;AAGA,EAAA,MAAM,aAAA,GAAgB,kBAAkB,MAAA,CAAO,MAAA;AAC/C,EAAA,MAAM,aAAa,UAAA,GAAa,IAAA,CAAK,IAAI,MAAA,CAAO,MAAA,EAAQ,OAAO,MAAM,CAAA;AAErE,EAAA,OAAO,aAAA,GAAgB,MAAM,UAAA,GAAa,GAAA;AAC5C;AAMO,SAAS,SAAS,CAAA,EAAqB;AAC5C,EAAA,OACE,CAAA,CAEG,OAAA,CAAQ,iBAAA,EAAmB,OAAO,CAAA,CAElC,QAAQ,OAAA,EAAS,GAAG,CAAA,CAEpB,OAAA,CAAQ,MAAA,EAAQ,GAAG,EACnB,IAAA,EAAK,CACL,WAAA,EAAY,CACZ,KAAA,CAAM,GAAG,CAAA,CACT,MAAA,CAAO,CAAC,KAAA,KAAU,KAAA,CAAM,MAAA,GAAS,CAAC,CAAA;AAEzC;AAMO,SAAS,eAAA,CAAgB,IAAY,EAAA,EAAoB;AAC9D,EAAA,MAAM,OAAA,GAAU,SAAS,EAAE,CAAA;AAC3B,EAAA,MAAM,OAAA,GAAU,SAAS,EAAE,CAAA;AAE3B,EAAA,IAAI,QAAQ,MAAA,KAAW,CAAA,IAAK,OAAA,CAAQ,MAAA,KAAW,GAAG,OAAO,CAAA;AACzD,EAAA,IAAI,QAAQ,MAAA,KAAW,CAAA,IAAK,OAAA,CAAQ,MAAA,KAAW,GAAG,OAAO,CAAA;AAEzD,EAAA,MAAM,IAAA,GAAO,IAAI,GAAA,CAAI,OAAO,CAAA;AAC5B,EAAA,MAAM,IAAA,GAAO,IAAI,GAAA,CAAI,OAAO,CAAA;AAG5B,EAAA,IAAI,YAAA,GAAe,CAAA;AACnB,EAAA,KAAA,MAAW,SAAS,IAAA,EAAM;AACxB,IAAA,IAAI,IAAA,CAAK,GAAA,CAAI,KAAK,CAAA,EAAG;AACnB,MAAA,YAAA,EAAA;AAAA,IACF;AAAA,EACF;AAEA,EAAA,MAAM,KAAA,GAAQ,IAAA,CAAK,IAAA,GAAO,IAAA,CAAK,IAAA,GAAO,YAAA;AACtC,EAAA,OAAO,KAAA,KAAU,CAAA,GAAI,CAAA,GAAI,YAAA,GAAe,KAAA;AAC1C;;;ACxZO,IAAM,oBAAA,GAA6C;AAAA,EACxD,WAAA,EAAa,IAAA;AAAA,EACb,gBAAA,EAAkB,IAAA;AAAA,EAClB,kBAAA,EAAoB,IAAA;AAAA,EACpB,YAAA,EAAc,IAAA;AAAA,EACd,eAAA,EAAiB,IAAA;AAAA,EACjB,UAAA,EAAY,EAAA;AAAA,EACZ,SAAA,EAAW,CAAA;AAAA,EACX,SAAA,EAAW;AACb,CAAA;AAKA,IAAM,QAAA,GAAqC;AAAA;AAAA,EAEzC,MAAA,EAAQ,CAAC,MAAA,EAAQ,IAAA,EAAM,WAAW,IAAA,EAAM,OAAA,EAAS,MAAA,EAAQ,MAAA,EAAQ,QAAQ,CAAA;AAAA,EACzE,IAAA,EAAM,CAAC,QAAA,EAAU,SAAA,EAAW,MAAM,CAAA;AAAA,EAClC,IAAA,EAAM,CAAC,QAAA,EAAU,OAAA,EAAS,QAAQ,OAAO,CAAA;AAAA,EACzC,MAAA,EAAQ,CAAC,OAAA,EAAS,SAAA,EAAW,SAAS,MAAA,EAAQ,MAAA,EAAQ,QAAQ,WAAW,CAAA;AAAA,EACzE,KAAA,EAAO,CAAC,QAAA,EAAU,SAAA,EAAW,QAAQ,GAAG,CAAA;AAAA,EACxC,QAAQ,CAAC,QAAA,EAAU,OAAA,EAAS,OAAA,EAAS,SAAS,SAAS,CAAA;AAAA,EACvD,MAAA,EAAQ,CAAC,QAAA,EAAU,OAAA,EAAS,SAAS,CAAA;AAAA,EACrC,IAAA,EAAM,CAAC,QAAA,EAAU,QAAA,EAAU,UAAU,OAAO,CAAA;AAAA,EAC5C,MAAA,EAAQ,CAAC,MAAA,EAAQ,QAAA,EAAU,QAAQ,SAAS,CAAA;AAAA,EAC5C,GAAA,EAAK,CAAC,QAAA,EAAU,KAAA,EAAO,QAAQ,QAAQ,CAAA;AAAA,EACvC,MAAA,EAAQ,CAAC,KAAA,EAAO,KAAA,EAAO,MAAM,CAAA;AAAA,EAC7B,MAAA,EAAQ,CAAC,MAAA,EAAQ,QAAA,EAAU,SAAS,QAAQ,CAAA;AAAA,EAC5C,IAAA,EAAM,CAAC,QAAA,EAAU,QAAA,EAAU,QAAQ,CAAA;AAAA,EACnC,OAAO,CAAC,QAAA,EAAU,SAAA,EAAW,QAAA,EAAU,gBAAgB,OAAO,CAAA;AAAA,EAC9D,MAAA,EAAQ,CAAC,SAAA,EAAW,UAAA,EAAY,WAAW,MAAM,CAAA;AAAA,EACjD,QAAA,EAAU,CAAC,QAAA,EAAU,SAAA,EAAW,QAAQ,gBAAgB,CAAA;AAAA,EACxD,IAAA,EAAM,CAAC,UAAA,EAAY,SAAA,EAAW,WAAW,SAAS,CAAA;AAAA,EAClD,QAAA,EAAU,CAAC,MAAA,EAAQ,UAAA,EAAY,UAAU,OAAO,CAAA;AAAA,EAChD,IAAA,EAAM,CAAC,UAAA,EAAY,QAAA,EAAU,UAAU,CAAA;AAAA,EACvC,OAAO,CAAC,OAAA,EAAS,QAAA,EAAU,UAAA,EAAY,OAAO,SAAS,CAAA;AAAA,EACvD,IAAA,EAAM,CAAC,KAAA,EAAO,MAAA,EAAQ,SAAS,WAAW,CAAA;AAAA,EAC1C,MAAA,EAAQ,CAAC,UAAA,EAAY,SAAA,EAAW,WAAW,CAAA;AAAA,EAC3C,OAAA,EAAS,CAAC,YAAA,EAAc,UAAA,EAAY,YAAY,CAAA;AAAA,EAChD,IAAA,EAAM,CAAC,SAAA,EAAW,QAAA,EAAU,QAAQ,MAAM,CAAA;AAAA,EAC1C,IAAA,EAAM,CAAC,SAAA,EAAW,UAAA,EAAY,OAAO,CAAA;AAAA,EACrC,MAAA,EAAQ,CAAC,MAAA,EAAQ,MAAA,EAAQ,UAAU,QAAQ,CAAA;AAAA,EAC3C,QAAA,EAAU,CAAC,OAAA,EAAS,MAAA,EAAQ,QAAQ,UAAU,CAAA;AAAA,EAC9C,GAAA,EAAK,CAAC,IAAA,EAAM,SAAA,EAAW,SAAS,QAAQ,CAAA;AAAA,EACxC,EAAA,EAAI,CAAC,QAAA,EAAU,SAAA,EAAW,UAAU,MAAM,CAAA;AAAA,EAC1C,MAAM,CAAC,SAAA,EAAW,YAAA,EAAc,MAAA,EAAQ,eAAe,KAAK,CAAA;AAAA,EAC5D,QAAA,EAAU,CAAC,aAAA,EAAe,SAAA,EAAW,UAAU,eAAe,CAAA;AAAA,EAC9D,OAAA,EAAS,CAAC,SAAA,EAAW,MAAA,EAAQ,IAAI,CAAA;AAAA,EACjC,QAAA,EAAU,CAAC,QAAA,EAAU,MAAA,EAAQ,KAAK,CAAA;AAAA,EAClC,MAAA,EAAQ,CAAC,QAAA,EAAU,MAAA,EAAQ,QAAQ,CAAA;AAAA,EACnC,OAAA,EAAS,CAAC,QAAA,EAAU,QAAA,EAAU,MAAM,CAAA;AAAA,EACpC,IAAA,EAAM,CAAC,WAAA,EAAa,OAAO,CAAA;AAAA,EAC3B,KAAA,EAAO,CAAC,QAAQ,CAAA;AAAA,EAChB,MAAA,EAAQ,CAAC,QAAA,EAAU,MAAM,CAAA;AAAA,EACzB,MAAA,EAAQ,CAAC,QAAA,EAAU,MAAM,CAAA;AAAA;AAAA,EAGzB,KAAA,EAAO,CAAC,QAAA,EAAU,MAAM,CAAA;AAAA,EACxB,QAAA,EAAU,CAAC,MAAA,EAAQ,KAAA,EAAO,QAAQ,CAAA;AAAA,EAClC,QAAA,EAAU,CAAC,MAAA,EAAQ,OAAA,EAAS,WAAW,MAAM,CAAA;AAAA,EAC7C,SAAA,EAAW,CAAC,YAAA,EAAc,YAAA,EAAc,UAAU,CAAA;AAAA,EAClD,QAAA,EAAU,CAAC,WAAA,EAAa,SAAA,EAAW,aAAa,CAAA;AAAA,EAChD,QAAA,EAAU,CAAC,WAAA,EAAa,MAAA,EAAQ,eAAe,CAAA;AAAA,EAC/C,KAAA,EAAO,CAAC,WAAA,EAAa,KAAA,EAAO,UAAU,MAAM,CAAA;AAAA,EAC5C,OAAA,EAAS,CAAC,UAAA,EAAY,QAAQ,CAAA;AAAA,EAC9B,IAAA,EAAM,CAAC,MAAM,CAAA;AAAA,EACb,OAAA,EAAS,CAAC,QAAQ,CAAA;AAAA,EAClB,GAAA,EAAK,CAAC,SAAA,EAAW,QAAA,EAAU,eAAe,UAAU,CAAA;AAAA;AAAA,EAGpD,IAAA,EAAM,CAAC,MAAA,EAAQ,OAAA,EAAS,WAAW,CAAA;AAAA,EACnC,IAAA,EAAM,CAAC,YAAA,EAAc,KAAK,CAAA;AAAA,EAC1B,OAAA,EAAS,CAAC,UAAA,EAAY,YAAA,EAAc,WAAW;AACjD,CAAA;AAKA,IAAM,oBAAA,GAAiD;AAAA,EACrD,MAAA,EAAQ,CAAC,QAAA,EAAU,KAAA,EAAO,OAAO,CAAA;AAAA,EACjC,KAAA,EAAO,CAAC,OAAA,EAAS,OAAA,EAAS,WAAW,KAAK,CAAA;AAAA,EAC1C,QAAA,EAAU,CAAC,UAAA,EAAY,WAAA,EAAa,cAAc,WAAW,CAAA;AAAA,EAC7D,QAAQ,CAAC,QAAA,EAAU,UAAA,EAAY,OAAA,EAAS,UAAU,SAAS,CAAA;AAAA,EAC3D,QAAA,EAAU,CAAC,UAAA,EAAY,OAAA,EAAS,MAAM,CAAA;AAAA,EACtC,KAAA,EAAO,CAAC,OAAA,EAAS,QAAA,EAAU,QAAQ,CAAA;AAAA,EACnC,IAAA,EAAM,CAAC,MAAA,EAAQ,QAAA,EAAU,MAAM,CAAA;AAAA,EAC/B,IAAA,EAAM,CAAC,MAAM,CAAA;AAAA,EACb,IAAA,EAAM,CAAC,MAAM,CAAA;AAAA,EACb,QAAA,EAAU,CAAC,WAAA,EAAa,QAAQ,CAAA;AAAA,EAChC,GAAA,EAAK,CAAC,KAAK,CAAA;AAAA,EACX,MAAA,EAAQ,CAAC,QAAA,EAAU,OAAA,EAAS,OAAO,CAAA;AAAA,EACnC,MAAA,EAAQ,CAAC,QAAA,EAAU,QAAQ,CAAA;AAAA,EAC3B,MAAA,EAAQ,CAAC,QAAA,EAAU,OAAO;AAC5B,CAAA;AAKA,SAAS,eAAe,IAAA,EAAsB;AAC5C,EAAA,OAAO,IAAA,CACJ,WAAA,EAAY,CACZ,OAAA,CAAQ,UAAA,EAAY,GAAG,CAAA,CACvB,OAAA,CAAQ,MAAA,EAAQ,GAAG,CAAA,CACnB,IAAA,EAAK;AACV;AAKA,SAAS,aAAa,IAAA,EAAwB;AAC5C,EAAA,MAAM,MAAA,GAAS,SAAS,IAAI,CAAA;AAC5B,EAAA,OAAO,OAAO,MAAA,CAAO,CAAC,CAAA,KAAM,CAAA,CAAE,UAAU,CAAC,CAAA;AAC3C;AAKA,SAAS,mBAAA,CACP,MACA,MAAA,EACU;AACV,EAAA,IAAI,CAAC,IAAA,IAAQ,CAAC,MAAA,CAAO,WAAA,SAAoB,EAAC;AAE1C,EAAA,MAAM,UAAoB,EAAC;AAC3B,EAAA,MAAM,UAAA,GAAa,eAAe,IAAI,CAAA;AAGtC,EAAA,IAAI,WAAW,MAAA,IAAU,MAAA,CAAO,aAAa,UAAA,CAAW,MAAA,IAAU,OAAO,SAAA,EAAW;AAClF,IAAA,OAAA,CAAQ,KAAK,UAAU,CAAA;AAAA,EACzB;AAGA,EAAA,MAAM,KAAA,GAAQ,aAAa,IAAI,CAAA;AAC/B,EAAA,KAAA,MAAW,QAAQ,KAAA,EAAO;AACxB,IAAA,IAAI,IAAA,CAAK,MAAA,IAAU,MAAA,CAAO,SAAA,EAAW;AACnC,MAAA,OAAA,CAAQ,KAAK,IAAI,CAAA;AAAA,IACnB;AAAA,EACF;AAGA,EAAA,IAAI,KAAA,CAAM,MAAA,IAAU,CAAA,IAAK,KAAA,CAAM,UAAU,CAAA,EAAG;AAE1C,IAAA,MAAM,WAAW,KAAA,CAAM,KAAA,CAAM,GAAG,CAAC,CAAA,CAAE,KAAK,GAAG,CAAA;AAC3C,IAAA,IAAI,QAAA,CAAS,MAAA,IAAU,MAAA,CAAO,SAAA,EAAW;AACvC,MAAA,OAAA,CAAQ,KAAK,QAAQ,CAAA;AAAA,IACvB;AAGA,IAAA,IAAI,KAAA,CAAM,SAAS,CAAA,EAAG;AACpB,MAAA,MAAM,UAAU,KAAA,CAAM,KAAA,CAAM,EAAE,CAAA,CAAE,KAAK,GAAG,CAAA;AACxC,MAAA,IAAI,OAAA,CAAQ,MAAA,IAAU,MAAA,CAAO,SAAA,EAAW;AACtC,QAAA,OAAA,CAAQ,KAAK,OAAO,CAAA;AAAA,MACtB;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO,OAAA;AACT;AAKA,SAAS,gBAAA,CAAiB,SAAmB,MAAA,EAAwC;AACnF,EAAA,IAAI,CAAC,MAAA,CAAO,eAAA,EAAiB,OAAO,EAAC;AAErC,EAAA,MAAM,WAAqB,EAAC;AAE5B,EAAA,KAAA,MAAW,SAAS,OAAA,EAAS;AAC3B,IAAA,MAAM,KAAA,GAAQ,KAAA,CAAM,WAAA,EAAY,CAAE,MAAM,KAAK,CAAA;AAE7C,IAAA,KAAA,MAAW,QAAQ,KAAA,EAAO;AACxB,MAAA,IAAI,QAAA,CAAS,IAAI,CAAA,EAAG;AAClB,QAAA,KAAA,MAAW,OAAA,IAAW,QAAA,CAAS,IAAI,CAAA,EAAG;AAEpC,UAAA,MAAM,WAAW,KAAA,CAAM,WAAA,EAAY,CAAE,OAAA,CAAQ,MAAM,OAAO,CAAA;AAC1D,UAAA,IAAI,QAAA,KAAa,KAAA,CAAM,WAAA,EAAY,EAAG;AACpC,YAAA,QAAA,CAAS,KAAK,QAAQ,CAAA;AAAA,UACxB;AAGA,UAAA,IAAI,OAAA,CAAQ,MAAA,IAAU,MAAA,CAAO,SAAA,EAAW;AACtC,YAAA,QAAA,CAAS,KAAK,OAAO,CAAA;AAAA,UACvB;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO,QAAA;AACT;AAKA,SAAS,oBAAoB,WAAA,EAA+B;AAC1D,EAAA,MAAM,IAAA,GAAO,YAAY,WAAA,EAAY;AACrC,EAAA,OAAO,oBAAA,CAAqB,IAAI,CAAA,IAAK,CAAC,IAAI,CAAA;AAC5C;AAmCO,SAAS,eAAA,CACd,KAAA,EACA,MAAA,GAAwC,EAAC,EAC/B;AACV,EAAA,MAAM,WAAA,GAAc,EAAE,GAAG,oBAAA,EAAsB,GAAG,MAAA,EAAO;AACzD,EAAA,MAAM,QAAA,uBAAe,GAAA,EAAY;AAGjC,EAAA,MAAM,QAAA,GAAW,CAAC,KAAA,KAAkB;AAClC,IAAA,MAAM,UAAA,GAAa,eAAe,KAAK,CAAA;AACvC,IAAA,IAAI,WAAW,MAAA,IAAU,WAAA,CAAY,aAAa,UAAA,CAAW,MAAA,IAAU,YAAY,SAAA,EAAW;AAC5F,MAAA,QAAA,CAAS,IAAI,UAAU,CAAA;AAAA,IACzB;AAAA,EACF,CAAA;AAGA,EAAA,MAAM,UAAA,GAAa,CAACA,QAAAA,KAAsB;AACxC,IAAA,KAAA,MAAW,SAASA,QAAAA,EAAS;AAC3B,MAAA,QAAA,CAAS,KAAK,CAAA;AAAA,IAChB;AAAA,EACF,CAAA;AAGA,EAAA,IAAI,WAAA,CAAY,WAAA,IAAe,KAAA,CAAM,WAAA,EAAa;AAChD,IAAA,UAAA,CAAW,mBAAA,CAAoB,KAAA,CAAM,WAAA,EAAa,WAAW,CAAC,CAAA;AAAA,EAChE;AAGA,EAAA,IAAI,WAAA,CAAY,gBAAA,IAAoB,KAAA,CAAM,SAAA,EAAW;AACnD,IAAA,UAAA,CAAW,mBAAA,CAAoB,KAAA,CAAM,SAAA,EAAW,WAAW,CAAC,CAAA;AAAA,EAC9D;AAGA,EAAA,IAAI,WAAA,CAAY,gBAAA,IAAoB,KAAA,CAAM,cAAA,EAAgB;AACxD,IAAA,UAAA,CAAW,mBAAA,CAAoB,KAAA,CAAM,cAAA,EAAgB,WAAW,CAAC,CAAA;AAAA,EACnE;AAGA,EAAA,IAAI,WAAA,CAAY,kBAAA,IAAsB,KAAA,CAAM,WAAA,EAAa;AACvD,IAAA,UAAA,CAAW,mBAAA,CAAoB,KAAA,CAAM,WAAA,EAAa,WAAW,CAAC,CAAA;AAAA,EAChE;AAGA,EAAA,IAAI,WAAA,CAAY,YAAA,IAAgB,KAAA,CAAM,KAAA,EAAO;AAC3C,IAAA,UAAA,CAAW,mBAAA,CAAoB,KAAA,CAAM,KAAA,EAAO,WAAW,CAAC,CAAA;AAAA,EAC1D;AAGA,EAAA,IAAI,MAAM,SAAA,EAAW;AACnB,IAAA,UAAA,CAAW,mBAAA,CAAoB,KAAA,CAAM,SAAA,EAAW,WAAW,CAAC,CAAA;AAAA,EAC9D;AAGA,EAAA,IAAI,MAAM,EAAA,EAAI;AACZ,IAAA,UAAA,CAAW,YAAA,CAAa,KAAA,CAAM,EAAE,CAAC,CAAA;AAAA,EACnC;AAGA,EAAA,IAAI,MAAM,IAAA,EAAM;AACd,IAAA,UAAA,CAAW,YAAA,CAAa,KAAA,CAAM,IAAI,CAAC,CAAA;AAAA,EACrC;AAGA,EAAA,IACE,KAAA,CAAM,KAAA,KACL,KAAA,CAAM,WAAA,KAAgB,QAAA,IAAY,MAAM,SAAA,KAAc,QAAA,IAAY,KAAA,CAAM,SAAA,KAAc,QAAA,CAAA,EACvF;AACA,IAAA,UAAA,CAAW,mBAAA,CAAoB,KAAA,CAAM,KAAA,EAAO,WAAW,CAAC,CAAA;AAAA,EAC1D;AAGA,EAAA,IAAI,MAAM,WAAA,EAAa;AACrB,IAAA,UAAA,CAAW,mBAAA,CAAoB,KAAA,CAAM,WAAW,CAAC,CAAA;AAAA,EACnD;AAGA,EAAA,IAAI,MAAM,SAAA,EAAW;AACnB,IAAA,QAAA,CAAS,MAAM,SAAS,CAAA;AAGxB,IAAA,IAAI,KAAA,CAAM,cAAc,OAAA,EAAS;AAC/B,MAAA,UAAA,CAAW,CAAC,OAAA,EAAS,QAAA,EAAU,eAAe,CAAC,CAAA;AAAA,IACjD,CAAA,MAAA,IAAW,KAAA,CAAM,SAAA,KAAc,UAAA,EAAY;AACzC,MAAA,UAAA,CAAW,CAAC,UAAA,EAAY,MAAA,EAAQ,KAAK,CAAC,CAAA;AAAA,IACxC,CAAA,MAAA,IAAW,KAAA,CAAM,SAAA,KAAc,KAAA,EAAO;AACpC,MAAA,UAAA,CAAW,CAAC,OAAA,EAAS,WAAA,EAAa,QAAQ,CAAC,CAAA;AAAA,IAC7C,CAAA,MAAA,IAAW,KAAA,CAAM,SAAA,KAAc,KAAA,EAAO;AACpC,MAAA,UAAA,CAAW,CAAC,KAAA,EAAO,SAAA,EAAW,MAAA,EAAQ,SAAS,CAAC,CAAA;AAAA,IAClD,CAAA,MAAA,IAAW,KAAA,CAAM,SAAA,KAAc,QAAA,EAAU;AACvC,MAAA,UAAA,CAAW,CAAC,QAAA,EAAU,MAAA,EAAQ,OAAO,CAAC,CAAA;AAAA,IACxC;AAAA,EACF;AAGA,EAAA,IAAI,YAAY,eAAA,EAAiB;AAC/B,IAAA,MAAM,cAAA,GAAiB,KAAA,CAAM,IAAA,CAAK,QAAQ,CAAA;AAC1C,IAAA,UAAA,CAAW,gBAAA,CAAiB,cAAA,EAAgB,WAAW,CAAC,CAAA;AAAA,EAC1D;AAGA,EAAA,IAAI,OAAA,GAAU,KAAA,CAAM,IAAA,CAAK,QAAQ,CAAA;AAGjC,EAAA,OAAA,CAAQ,KAAK,CAAC,CAAA,EAAG,MAAM,CAAA,CAAE,MAAA,GAAS,EAAE,MAAM,CAAA;AAG1C,EAAA,IAAI,OAAA,CAAQ,MAAA,GAAS,WAAA,CAAY,UAAA,EAAY;AAC3C,IAAA,OAAA,GAAU,OAAA,CAAQ,KAAA,CAAM,CAAA,EAAG,WAAA,CAAY,UAAU,CAAA;AAAA,EACnD;AAEA,EAAA,OAAO,OAAA;AACT;AAKO,SAAS,oBAAoB,KAAA,EAAoC;AACtE,EAAA,MAAM,QAAkB,EAAC;AAGzB,EAAA,IAAI,IAAA,GACF,KAAA,CAAM,SAAA,IACN,KAAA,CAAM,SAAA,IACN,KAAA,CAAM,WAAA,IACN,KAAA,CAAM,WAAA,IACN,KAAA,CAAM,KAAA,IACN,KAAA,CAAM,MACN,KAAA,CAAM,IAAA;AAER,EAAA,IAAI,IAAA,EAAM;AACR,IAAA,IAAA,GAAO,KAAK,IAAA,EAAK;AAEjB,IAAA,IAAI,IAAA,CAAK,SAAS,EAAA,EAAI;AACpB,MAAA,IAAA,GAAO,IAAA,CAAK,SAAA,CAAU,CAAA,EAAG,EAAE,CAAA,GAAI,KAAA;AAAA,IACjC;AACA,IAAA,KAAA,CAAM,IAAA,CAAK,CAAA,CAAA,EAAI,IAAI,CAAA,CAAA,CAAG,CAAA;AAAA,EACxB;AAGA,EAAA,MAAM,SAAA,GAAY,oBAAA,CAAqB,KAAA,CAAM,WAAA,IAAe,EAAE,CAAA,IAAK;AAAA,IACjE,MAAM,WAAA,IAAe;AAAA,GACvB;AACA,EAAA,KAAA,CAAM,IAAA,CAAK,SAAA,CAAU,CAAC,CAAC,CAAA;AAGvB,EAAA,IAAI,KAAA,CAAM,SAAA,IAAa,KAAA,CAAM,SAAA,KAAc,MAAA,EAAQ;AACjD,IAAA,KAAA,CAAM,IAAA,CAAK,CAAA,CAAA,EAAI,KAAA,CAAM,SAAS,CAAA,CAAA,CAAG,CAAA;AAAA,EACnC;AAEA,EAAA,OAAO,KAAA,CAAM,KAAK,GAAG,CAAA;AACvB;AAKA,IAAM,aAAA,uBAAoB,GAAA,CAAI;AAAA,EAC5B,SAAA;AAAA,EACA,WAAA;AAAA,EACA,WAAA;AAAA,EACA,YAAA;AAAA,EACA,cAAA;AAAA,EACA,OAAA;AAAA,EACA,SAAA;AAAA,EACA,YAAA;AAAA,EACA,YAAA;AAAA,EACA,OAAA;AAAA,EACA,gBAAA;AAAA,EACA,cAAA;AAAA,EACA,kBAAA;AAAA,EACA,UAAA;AAAA,EACA;AACF,CAAC,CAAA;AAKM,SAAS,gBAAgB,KAAA,EAAgD;AAC9E,EAAA,MAAM,IAAA,GAAA,CAAQ,MAAM,WAAA,IAAe,KAAA,CAAM,aAAa,KAAA,CAAM,KAAA,IAAS,IAAI,WAAA,EAAY;AACrF,EAAA,MAAM,IAAA,GAAO,KAAA,CAAM,WAAA,EAAa,WAAA,EAAY,IAAK,EAAA;AACjD,EAAA,MAAM,SAAA,GAAY,KAAA,CAAM,SAAA,EAAW,WAAA,EAAY,IAAK,EAAA;AAGpD,EAAA,IAAI,aAAA,CAAc,GAAA,CAAI,IAAI,CAAA,EAAG;AAC3B,IAAA,QAAQ,IAAA;AAAM,MACZ,KAAK,SAAA;AACH,QAAA,OAAO,iBAAA;AAAA,MACT,KAAK,WAAA;AACH,QAAA,OAAO,mBAAA;AAAA,MACT,KAAK,WAAA;AACH,QAAA,OAAO,WAAA;AAAA,MACT,KAAK,YAAA;AACH,QAAA,OAAO,iBAAA;AAAA,MACT,KAAK,cAAA;AACH,QAAA,OAAO,qBAAA;AAAA,MACT,KAAK,OAAA;AACH,QAAA,OAAO,gCAAA;AAAA,MACT,KAAK,SAAA;AACH,QAAA,OAAO,yBAAA;AAAA,MACT,KAAK,YAAA;AACH,QAAA,OAAO,gBAAA;AAAA,MACT,KAAK,YAAA;AACH,QAAA,OAAO,2BAAA;AAAA,MACT,KAAK,OAAA;AACH,QAAA,OAAO,qBAAA;AAAA,MACT,KAAK,gBAAA;AACH,QAAA,OAAO,0BAAA;AAAA,MACT,KAAK,cAAA;AACH,QAAA,OAAO,2BAAA;AAAA,MACT,KAAK,kBAAA;AACH,QAAA,OAAO,2BAAA;AAAA,MACT,KAAK,UAAA;AACH,QAAA,OAAO,kBAAA;AAAA,MACT,KAAK,iBAAA;AACH,QAAA,OAAO,cAAA;AAAA,MACT;AACE,QAAA,OAAO,gBAAA;AAAA;AACX,EACF;AAGA,EAAA,IAAI,IAAA,KAAS,QAAA,IAAY,SAAA,KAAc,QAAA,EAAU;AAC/C,IAAA,IAAI,IAAA,CAAK,KAAA,CAAM,+CAA+C,CAAA,EAAG;AAC/D,MAAA,OAAO,kBAAA;AAAA,IACT;AACA,IAAA,IAAI,IAAA,CAAK,KAAA,CAAM,gCAAgC,CAAA,EAAG;AAChD,MAAA,OAAO,sCAAA;AAAA,IACT;AACA,IAAA,IAAI,IAAA,CAAK,KAAA,CAAM,2BAA2B,CAAA,EAAG;AAC3C,MAAA,OAAO,4BAAA;AAAA,IACT;AACA,IAAA,IAAI,IAAA,CAAK,KAAA,CAAM,2BAA2B,CAAA,EAAG;AAC3C,MAAA,OAAO,2BAAA;AAAA,IACT;AACA,IAAA,IAAI,IAAA,CAAK,KAAA,CAAM,mBAAmB,CAAA,EAAG;AACnC,MAAA,OAAO,4BAAA;AAAA,IACT;AACA,IAAA,IAAI,IAAA,CAAK,KAAA,CAAM,oBAAoB,CAAA,EAAG;AACpC,MAAA,OAAO,mBAAA;AAAA,IACT;AACA,IAAA,IAAI,IAAA,CAAK,KAAA,CAAM,gBAAgB,CAAA,EAAG;AAChC,MAAA,OAAO,mBAAA;AAAA,IACT;AACA,IAAA,IAAI,IAAA,CAAK,KAAA,CAAM,kBAAkB,CAAA,EAAG;AAClC,MAAA,OAAO,oBAAA;AAAA,IACT;AACA,IAAA,IAAI,IAAA,CAAK,KAAA,CAAM,wBAAwB,CAAA,EAAG;AACxC,MAAA,OAAO,uBAAA;AAAA,IACT;AACA,IAAA,IAAI,IAAA,CAAK,KAAA,CAAM,uBAAuB,CAAA,EAAG;AACvC,MAAA,OAAO,2BAAA;AAAA,IACT;AACA,IAAA,IAAI,IAAA,CAAK,KAAA,CAAM,sBAAsB,CAAA,EAAG;AACtC,MAAA,OAAO,8BAAA;AAAA,IACT;AAAA,EACF;AAEA,EAAA,IAAI,IAAA,KAAS,OAAA,IAAW,IAAA,KAAS,UAAA,EAAY;AAC3C,IAAA,IAAI,SAAA,KAAc,SAAS,OAAO,6BAAA;AAClC,IAAA,IAAI,SAAA,KAAc,YAAY,OAAO,wBAAA;AACrC,IAAA,IAAI,SAAA,KAAc,UAAU,OAAO,4BAAA;AACnC,IAAA,IAAI,SAAA,KAAc,OAAO,OAAO,4BAAA;AAChC,IAAA,IAAI,SAAA,KAAc,OAAO,OAAO,mBAAA;AAChC,IAAA,IAAI,SAAA,KAAc,UAAU,OAAO,uBAAA;AACnC,IAAA,IAAI,SAAA,KAAc,QAAQ,OAAO,oBAAA;AACjC,IAAA,IAAI,SAAA,KAAc,QAAQ,OAAO,qBAAA;AAAA,EACnC;AAEA,EAAA,IAAI,SAAS,UAAA,EAAY;AACvB,IAAA,OAAO,6BAAA;AAAA,EACT;AAEA,EAAA,IAAI,SAAS,OAAA,EAAS;AACpB,IAAA,OAAO,iCAAA;AAAA,EACT;AAEA,EAAA,IAAI,SAAS,QAAA,EAAU;AACrB,IAAA,OAAO,mCAAA;AAAA,EACT;AAEA,EAAA,IAAI,SAAS,MAAA,EAAQ;AACnB,IAAA,OAAO,2BAAA;AAAA,EACT;AAEA,EAAA,OAAO,MAAA;AACT;AAKO,SAAS,yBAAyB,KAAA,EAAsC;AAC7E,EAAA,MAAM,IAAA,GAAO,KAAA,CAAM,WAAA,EAAa,WAAA,EAAY,IAAK,EAAA;AACjD,EAAA,MAAM,SAAA,GAAY,KAAA,CAAM,SAAA,EAAW,WAAA,EAAY,IAAK,EAAA;AACpD,EAAA,MAAM,QAAQ,KAAA,CAAM,WAAA,IAAe,KAAA,CAAM,SAAA,IAAa,IAAI,WAAA,EAAY;AACtE,EAAA,MAAM,UAAoB,EAAC;AAG3B,EAAA,IAAI,aAAA,CAAc,GAAA,CAAI,IAAI,CAAA,EAAG;AAC3B,IAAA,OAAA,CAAQ,IAAA,CAAK,qBAAqB,8BAA8B,CAAA;AAChE,IAAA,OAAO,OAAA;AAAA,EACT;AAEA,EAAA,QAAQ,IAAA;AAAM,IACZ,KAAK,QAAA;AACH,MAAA,OAAA,CAAQ,IAAA,CAAK,CAAA,OAAA,EAAU,IAAA,IAAQ,aAAa,CAAA,CAAA,CAAG,CAAA;AAC/C,MAAA;AAAA,IACF,KAAK,OAAA;AACH,MAAA,IAAI,cAAc,UAAA,EAAY;AAC5B,QAAA,OAAA,CAAQ,IAAA,CAAK,mBAAmB,oBAAoB,CAAA;AAAA,MACtD,CAAA,MAAA,IAAW,cAAc,OAAA,EAAS;AAChC,QAAA,OAAA,CAAQ,KAAK,oBAAoB,CAAA;AAAA,MACnC,CAAA,MAAO;AACL,QAAA,OAAA,CAAQ,IAAA,CAAK,CAAA,WAAA,EAAc,IAAA,IAAQ,YAAY,CAAA,CAAA,CAAG,CAAA;AAClD,QAAA,OAAA,CAAQ,KAAK,iBAAiB,CAAA;AAAA,MAChC;AACA,MAAA;AAAA,IACF,KAAK,UAAA;AACH,MAAA,OAAA,CAAQ,IAAA,CAAK,CAAA,WAAA,EAAc,IAAA,IAAQ,gBAAgB,CAAA,CAAA,CAAG,CAAA;AACtD,MAAA,OAAA,CAAQ,KAAK,mBAAmB,CAAA;AAChC,MAAA;AAAA,IACF,KAAK,QAAA;AACH,MAAA,OAAA,CAAQ,IAAA,CAAK,CAAA,uBAAA,EAA0B,IAAA,IAAQ,eAAe,CAAA,CAAA,CAAG,CAAA;AACjE,MAAA;AAAA,IACF,KAAK,UAAA;AACH,MAAA,OAAA,CAAQ,IAAA,CAAK,mBAAmB,oBAAoB,CAAA;AACpD,MAAA;AAAA,IACF,KAAK,OAAA;AACH,MAAA,OAAA,CAAQ,KAAK,oBAAoB,CAAA;AACjC,MAAA;AAAA,IACF,KAAK,MAAA;AACH,MAAA,OAAA,CAAQ,IAAA,CAAK,CAAA,sBAAA,EAAyB,IAAA,IAAQ,iBAAiB,CAAA,CAAA,CAAG,CAAA;AAClE,MAAA;AAAA,IACF,KAAK,QAAA;AACH,MAAA,OAAA,CAAQ,IAAA,CAAK,aAAa,YAAY,CAAA;AACtC,MAAA;AAAA,IACF;AACE,MAAA,OAAA,CAAQ,KAAK,OAAO,CAAA;AAAA;AAGxB,EAAA,OAAO,OAAA;AACT;AAaO,SAAS,WAAA,CAAY,OAAe,KAAA,EAAwB;AACjE,EAAA,MAAM,EAAA,GAAK,KAAA,CAAM,WAAA,EAAY,CAAE,IAAA,EAAK;AACpC,EAAA,MAAM,EAAA,GAAK,KAAA,CAAM,WAAA,EAAY,CAAE,IAAA,EAAK;AAEpC,EAAA,IAAI,EAAA,KAAO,IAAI,OAAO,IAAA;AAEtB,EAAA,MAAM,SAAA,GAAY,QAAA,CAAS,EAAE,CAAA,IAAK,EAAC;AACnC,EAAA,MAAM,SAAA,GAAY,QAAA,CAAS,EAAE,CAAA,IAAK,EAAC;AAEnC,EAAA,OAAO,UAAU,QAAA,CAAS,EAAE,CAAA,IAAK,SAAA,CAAU,SAAS,EAAE,CAAA;AACxD;;;ACzeO,IAAM,yBAAA,GAA4B,OAAA;;;ACnDlC,IAAM,kBAAN,MAAsB;AAAA,EAAtB,WAAA,GAAA;AACL,IAAA,IAAA,CAAQ,KAAA,uBAAY,GAAA,EAA+B;AACnD,IAAA,IAAA,CAAQ,SAAA,uBAAgB,GAAA,EAAwB;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA,EAKhD,IAAI,SAAA,EAAkD;AACpD,IAAA,OAAO,IAAA,CAAK,KAAA,CAAM,GAAA,CAAI,SAAS,CAAA;AAAA,EACjC;AAAA;AAAA;AAAA;AAAA,EAKA,MAAA,GAA4C;AAC1C,IAAA,MAAM,SAA4C,EAAC;AACnD,IAAA,KAAA,MAAW,CAAC,EAAA,EAAI,UAAU,CAAA,IAAK,KAAK,KAAA,EAAO;AACzC,MAAA,MAAA,CAAO,EAAE,CAAA,GAAI,UAAA;AAAA,IACf;AACA,IAAA,OAAO,MAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,GAAA,CAAI,WAAmB,UAAA,EAAqC;AAC1D,IAAA,MAAM,OAAA,GAA6B;AAAA,MACjC,GAAG,UAAA;AAAA,MACH,SAAA,EAAW,KAAK,GAAA;AAAI,KACtB;AACA,IAAA,IAAA,CAAK,KAAA,CAAM,GAAA,CAAI,SAAA,EAAW,OAAO,CAAA;AACjC,IAAA,IAAA,CAAK,IAAA,CAAK;AAAA,MACR,IAAA,EAAM,gBAAA;AAAA,MACN,SAAA;AAAA,MACA,UAAA,EAAY,OAAA;AAAA,MACZ,SAAA,EAAW,KAAK,GAAA;AAAI,KACrB,CAAA;AAAA,EACH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAO,SAAA,EAA4B;AACjC,IAAA,MAAM,OAAA,GAAU,IAAA,CAAK,KAAA,CAAM,MAAA,CAAO,SAAS,CAAA;AAC3C,IAAA,IAAI,OAAA,EAAS;AACX,MAAA,IAAA,CAAK,IAAA,CAAK;AAAA,QACR,IAAA,EAAM,oBAAA;AAAA,QACN,SAAA;AAAA,QACA,SAAA,EAAW,KAAK,GAAA;AAAI,OACrB,CAAA;AAAA,IACH;AACA,IAAA,OAAO,OAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,IAAI,SAAA,EAA4B;AAC9B,IAAA,OAAO,IAAA,CAAK,KAAA,CAAM,GAAA,CAAI,SAAS,CAAA;AAAA,EACjC;AAAA;AAAA;AAAA;AAAA,EAKA,IAAI,KAAA,GAAgB;AAClB,IAAA,OAAO,KAAK,KAAA,CAAM,IAAA;AAAA,EACpB;AAAA;AAAA;AAAA;AAAA,EAKA,KAAA,GAAc;AACZ,IAAA,IAAA,CAAK,MAAM,KAAA,EAAM;AACjB,IAAA,IAAA,CAAK,IAAA,CAAK;AAAA,MACR,IAAA,EAAM,oBAAA;AAAA,MACN,SAAA,EAAW,KAAK,GAAA;AAAI,KACrB,CAAA;AAAA,EACH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAqBA,aAAa,MAAA,EAAkC;AAC7C,IAAA,IAAI,KAAA,GAAQ,CAAA;AACZ,IAAA,KAAA,MAAW,CAAC,IAAI,UAAU,CAAA,IAAK,OAAO,OAAA,CAAQ,MAAA,CAAO,WAAW,CAAA,EAAG;AACjE,MAAA,IAAA,CAAK,KAAA,CAAM,IAAI,EAAA,EAAI;AAAA,QACjB,GAAG,UAAA;AAAA,QACH,SAAA,EAAW,UAAA,CAAW,SAAA,IAAa,IAAA,CAAK,GAAA;AAAI,OAC7C,CAAA;AACD,MAAA,KAAA,EAAA;AAAA,IACF;AACA,IAAA,IAAA,CAAK,IAAA,CAAK;AAAA,MACR,IAAA,EAAM,qBAAA;AAAA,MACN,KAAA;AAAA,MACA,SAAA,EAAW,KAAK,GAAA;AAAI,KACrB,CAAA;AACD,IAAA,OAAO,KAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAsBA,aAAa,QAAA,EAA2D;AACtE,IAAA,OAAO;AAAA,MACL,OAAA,EAAS,yBAAA;AAAA,MACT,WAAA,EAAa,KAAK,MAAA,EAAO;AAAA,MACzB,QAAA,EAAU;AAAA,QACR,GAAG,QAAA;AAAA,QACH,UAAA,EAAY,KAAK,GAAA;AAAI;AACvB,KACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAwBA,YAAY,aAAA,EAA6C;AACvD,IAAA,MAAM,eAAyB,EAAC;AAChC,IAAA,MAAM,iBAA2B,EAAC;AAElC,IAAA,KAAA,MAAW,MAAM,aAAA,EAAe;AAC9B,MAAA,IAAI,IAAA,CAAK,KAAA,CAAM,GAAA,CAAI,EAAE,CAAA,EAAG;AACtB,QAAA,YAAA,CAAa,KAAK,EAAE,CAAA;AAAA,MACtB,CAAA,MAAO;AACL,QAAA,cAAA,CAAe,KAAK,EAAE,CAAA;AAAA,MACxB;AAAA,IACF;AAEA,IAAA,MAAM,QAAQ,aAAA,CAAc,MAAA;AAC5B,IAAA,OAAO;AAAA,MACL,aAAA,EAAe,KAAA;AAAA,MACf,mBAAmB,YAAA,CAAa,MAAA;AAAA,MAChC,iBAAiB,KAAA,GAAQ,CAAA,GAAK,YAAA,CAAa,MAAA,GAAS,QAAS,GAAA,GAAM,CAAA;AAAA,MACnE,YAAA;AAAA,MACA,cAAA;AAAA,MACA,SAAA,EAAW,KAAK,GAAA;AAAI,KACtB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAyBA,GAAG,QAAA,EAA0C;AAC3C,IAAA,IAAA,CAAK,SAAA,CAAU,IAAI,QAAQ,CAAA;AAC3B,IAAA,OAAO,MAAM;AACX,MAAA,IAAA,CAAK,SAAA,CAAU,OAAO,QAAQ,CAAA;AAAA,IAChC,CAAA;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,KAAK,KAAA,EAA8B;AACzC,IAAA,KAAA,MAAW,QAAA,IAAY,KAAK,SAAA,EAAW;AACrC,MAAA,IAAI;AACF,QAAA,QAAA,CAAS,KAAK,CAAA;AAAA,MAChB,CAAA,CAAA,MAAQ;AAAA,MAER;AAAA,IACF;AAAA,EACF;AACF,CAAA;AAGA,IAAI,WAAA,GAAsC,IAAA;AAKnC,SAAS,wBAAA,GAA4C;AAC1D,EAAA,IAAI,CAAC,WAAA,EAAa;AAChB,IAAA,WAAA,GAAc,IAAI,eAAA,EAAgB;AAAA,EACpC;AACA,EAAA,OAAO,WAAA;AACT;;;AC7RO,IAAM,qBAAA,GAA4C;AAAA,EACvD,cAAA,EAAgB,GAAA;AAAA,EAChB,UAAA,EAAY,IAAA;AAAA,EACZ,mBAAA,EAAqB,IAAA;AAAA,EACrB,UAAA,EAAY,IAAA;AAAA,EACZ,aAAA,EAAe,GAAA;AAAA,EACf,WAAA,EAAa,IAAA;AAAA,EACb,UAAA,EAAY,EAAA;AAAA,EACZ,aAAA,EAAe;AACjB,CAAA;AA2BO,IAAM,eAAN,MAAmB;AAAA;AAAA,EAMxB,WAAA,CAAY,MAAA,GAAsC,EAAC,EAAG;AAJtD,IAAA,IAAA,CAAQ,iBAAsC,EAAC;AAC/C,IAAA,IAAA,CAAQ,cAAA,GAAyB,CAAA;AACjC,IAAA,IAAA,CAAiB,eAAA,GAAkB,GAAA;AAGjC,IAAA,IAAA,CAAK,MAAA,GAAS,EAAE,GAAG,qBAAA,EAAuB,GAAG,MAAA,EAAO;AAAA,EACtD;AAAA;AAAA;AAAA;AAAA,EAKA,cAAA,CACE,UACA,QAAA,EACM;AACN,IAAA,IAAA,CAAK,cAAA,GAAiB,SAAS,GAAA,CAAI,CAAC,OAAO,IAAA,CAAK,YAAA,CAAa,EAAA,EAAI,QAAQ,CAAC,CAAA;AAC1E,IAAA,IAAA,CAAK,cAAA,GAAiB,KAAK,GAAA,EAAI;AAAA,EACjC;AAAA;AAAA;AAAA;AAAA,EAKQ,YAAA,CACN,SACA,QAAA,EACmB;AAEnB,IAAA,IAAI,KAAA;AACJ,IAAA,IAAI,WAAA;AACJ,IAAA,IAAI,OAAA;AACJ,IAAA,IAAI,IAAA;AACJ,IAAA,IAAI,SAAA;AACJ,IAAA,IAAI,WAAA;AACJ,IAAA,IAAI,KAAA;AACJ,IAAA,IAAI,SAAA;AACJ,IAAA,IAAI,KAAA;AAEJ,IAAA,IAAI,UAAA,IAAc,OAAA,IAAW,OAAO,OAAA,CAAQ,aAAa,UAAA,EAAY;AAGnE,MAAA,KAAA,GAAQ,QAAA,GAAW,QAAA,CAAS,OAAO,CAAA,GAAI,QAAQ,QAAA,EAAS;AACxD,MAAA,WAAA,GAAc,MAAM,WAAA,IAAe,MAAA;AAGnC,MAAA,IAAI;AACF,QAAA,OAAA,GAAU,OAAA,CAAQ,OAAA,CAAQ,OAAA,CAAQ,WAAA,EAAY;AAAA,MAChD,CAAA,CAAA,MAAQ;AACN,QAAA,OAAA,GAAU,QAAQ,IAAA,IAAQ,SAAA;AAAA,MAC5B;AAEA,MAAA,IAAI;AACF,QAAA,IAAA,GAAO,OAAA,CAAQ,OAAA,CAAQ,YAAA,CAAa,MAAM,CAAA,IAAK,KAAA,CAAA;AAC/C,QAAA,SAAA,GAAY,OAAA,CAAQ,OAAA,CAAQ,YAAA,CAAa,YAAY,CAAA,IAAK,KAAA,CAAA;AAC1D,QAAA,WAAA,GAAc,OAAA,CAAQ,OAAA,CAAQ,YAAA,CAAa,aAAa,CAAA,IAAK,KAAA,CAAA;AAC7D,QAAA,KAAA,GAAQ,OAAA,CAAQ,OAAA,CAAQ,YAAA,CAAa,OAAO,CAAA,IAAK,KAAA,CAAA;AAAA,MACnD,CAAA,CAAA,MAAQ;AAAA,MAER;AAGA,MAAA,IAAI,CAAC,SAAA,IAAa,OAAA,CAAQ,KAAA,EAAO;AAC/B,QAAA,SAAA,GAAY,OAAA,CAAQ,KAAA;AAAA,MACtB;AAEA,MAAA,IAAI;AACF,QAAA,IAAI,OAAA,CAAQ,QAAQ,EAAA,EAAI;AACtB,UAAA,MAAM,UAAU,QAAA,CAAS,aAAA,CAAc,cAAc,OAAA,CAAQ,OAAA,CAAQ,EAAE,CAAA,EAAA,CAAI,CAAA;AAC3E,UAAA,SAAA,GAAY,OAAA,EAAS,WAAA,EAAa,IAAA,EAAK,IAAK,KAAA,CAAA;AAAA,QAC9C;AAAA,MACF,CAAA,CAAA,MAAQ;AAAA,MAER;AACA,MAAA,IAAI,CAAC,SAAA,IAAa,OAAA,CAAQ,KAAA,EAAO;AAC/B,QAAA,SAAA,GAAY,OAAA,CAAQ,KAAA;AAAA,MACtB;AAGA,MAAA,IAAI,CAAC,WAAA,IAAe,OAAA,CAAQ,KAAA,EAAO;AACjC,QAAA,WAAA,GAAc,OAAA,CAAQ,KAAA;AAAA,MACxB;AAGA,MAAA,IAAI;AACF,QAAA,IACE,OAAA,CAAQ,mBAAmB,gBAAA,IAC3B,OAAA,CAAQ,mBAAmB,mBAAA,IAC3B,OAAA,CAAQ,mBAAmB,iBAAA,EAC3B;AACA,UAAA,KAAA,GAAS,OAAA,CAAQ,QAA6B,KAAA,IAAS,KAAA,CAAA;AAAA,QACzD;AAAA,MACF,CAAA,CAAA,MAAQ;AACN,QAAA,KAAA,GAAQ,MAAM,KAAA,IAAS,MAAA;AAAA,MACzB;AAAA,IACF,CAAA,MAAO;AAEL,MAAA,MAAM,UAAA,GAAa,OAAA;AACnB,MAAA,KAAA,GAAQ,UAAA,CAAW,KAAA;AACnB,MAAA,WAAA,GAAc,MAAM,WAAA,IAAe,MAAA;AACnC,MAAA,OAAA,GAAU,UAAA,CAAW,OAAA;AACrB,MAAA,IAAA,GAAO,WAAW,IAAA,IAAQ,MAAA;AAC1B,MAAA,SAAA,GAAY,WAAW,cAAA,IAAkB,MAAA;AAEzC,MAAA,IAAI,CAAC,SAAA,IAAc,OAAA,CAA+B,KAAA,EAAO;AACvD,QAAA,SAAA,GAAa,OAAA,CAA+B,KAAA;AAAA,MAC9C;AAAA,IACF;AAGA,IAAA,IAAI,UAAU,eAAA,CAAgB;AAAA,MAC5B,WAAA;AAAA,MACA,SAAA;AAAA,MACA,WAAA;AAAA,MACA,KAAA;AAAA,MACA,aAAa,OAAA,CAAQ,IAAA;AAAA,MAErB,IAAI,OAAA,CAAQ,EAAA;AAAA,MACZ,SAAA;AAAA,MACA;AAAA,KACD,CAAA;AAGD,IAAA,IAAI,SAAA,IAAa,OAAA,IAAW,KAAA,CAAM,OAAA,CAAQ,OAAA,CAAQ,OAAO,CAAA,IAAK,OAAA,CAAQ,OAAA,CAAQ,MAAA,GAAS,CAAA,EAAG;AACxF,MAAA,MAAM,QAAA,uBAAe,GAAA,CAAI;AAAA,QACvB,GAAG,OAAA;AAAA,QACH,GAAG,QAAQ,OAAA,CAAQ,GAAA,CAAI,CAAC,CAAA,KAAc,CAAA,CAAE,aAAa;AAAA,OACtD,CAAA;AACD,MAAA,OAAA,GAAU,CAAC,GAAG,QAAQ,CAAA;AAAA,IACxB;AAEA,IAAA,IAAI,cAAc,mBAAA,CAAoB;AAAA,MACpC,WAAA;AAAA,MACA,SAAA;AAAA,MACA,WAAA;AAAA,MACA,KAAA;AAAA,MACA,aAAa,OAAA,CAAQ,IAAA;AAAA,MAErB,IAAI,OAAA,CAAQ,EAAA;AAAA,MACZ;AAAA,KACD,CAAA;AAGD,IAAA,IAAI,CAAC,WAAA,IAAe,aAAA,IAAiB,OAAA,IAAW,QAAQ,WAAA,EAAa;AACnE,MAAA,WAAA,GAAc,OAAA,CAAQ,WAAA;AAAA,IACxB;AAGA,IAAA,MAAM,UAAA,GAAa,wBAAA,EAAyB,CAAE,GAAA,CAAI,QAAQ,EAAE,CAAA;AAC5D,IAAA,IAAI,UAAA,EAAY;AACd,MAAA,IAAI,WAAW,WAAA,EAAa;AAC1B,QAAA,WAAA,GAAc,UAAA,CAAW,WAAA;AAAA,MAC3B;AACA,MAAA,IAAI,UAAA,CAAW,IAAA,IAAQ,UAAA,CAAW,IAAA,CAAK,SAAS,CAAA,EAAG;AAEjD,QAAA,MAAM,yBAAS,IAAI,GAAA,CAAI,CAAC,GAAG,SAAS,GAAG,UAAA,CAAW,IAAA,CAAK,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,CAAE,WAAA,EAAa,CAAC,CAAC,CAAA;AACnF,QAAA,OAAA,GAAU,CAAC,GAAG,MAAM,CAAA;AAAA,MACtB;AACA,MAAA,IAAI,WAAW,KAAA,EAAO;AAEpB,QAAA,OAAA,CAAQ,IAAA,CAAK,UAAA,CAAW,KAAA,CAAM,WAAA,EAAa,CAAA;AAAA,MAC7C;AAAA,IACF;AAEA,IAAA,OAAO;AAAA,MACL,IAAI,OAAA,CAAQ,EAAA;AAAA,MACZ,OAAA;AAAA,MACA,KAAA;AAAA,MACA,WAAA;AAAA,MACA,SAAA;AAAA,MACA,WAAA;AAAA,MACA,KAAA;AAAA,MACA,IAAA;AAAA,MACA,OAAA;AAAA,MACA,MAAM,OAAA,CAAQ,IAAA;AAAA,MACd,OAAA;AAAA,MACA,WAAA;AAAA,MACA,MAAM,KAAA,CAAM,IAAA;AAAA,MACZ,SAAA;AAAA,MACA;AAAA,KACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,MAAA,CACE,UACA,QAAA,EACgB;AAChB,IAAA,MAAM,SAAA,GAAY,YAAY,GAAA,EAAI;AAGlC,IAAA,IAAI,QAAA,EAAU;AACZ,MAAA,IAAA,CAAK,eAAe,QAAQ,CAAA;AAAA,IAC9B;AAGA,IAAA,IAAI,qBAAqB,IAAA,CAAK,cAAA;AAC9B,IAAA,IAAI,CAAC,IAAA,CAAK,MAAA,CAAO,aAAA,IAAiB,CAAC,SAAS,KAAA,EAAO;AACjD,MAAA,kBAAA,GAAqB,mBAAmB,MAAA,CAAO,CAAC,EAAA,KAAO,EAAA,CAAG,MAAM,OAAO,CAAA;AAAA,IACzE;AAGA,IAAA,MAAM,UAA0B,EAAC;AAEjC,IAAA,KAAA,MAAW,cAAc,kBAAA,EAAoB;AAC3C,MAAA,MAAM,MAAA,GAAS,IAAA,CAAK,YAAA,CAAa,UAAA,EAAY,QAAQ,CAAA;AACrD,MAAA,IAAI,OAAO,UAAA,KAAe,QAAA,CAAS,cAAA,IAAkB,IAAA,CAAK,OAAO,cAAA,CAAA,EAAiB;AAChF,QAAA,OAAA,CAAQ,KAAK,MAAM,CAAA;AAAA,MACrB;AAAA,IACF;AAGA,IAAA,OAAA,CAAQ,KAAK,CAAC,CAAA,EAAG,MAAM,CAAA,CAAE,UAAA,GAAa,EAAE,UAAU,CAAA;AAGlD,IAAA,MAAM,iBAAiB,OAAA,CAAQ,KAAA,CAAM,CAAA,EAAG,IAAA,CAAK,OAAO,UAAU,CAAA;AAE9D,IAAA,OAAO;AAAA,MACL,OAAA,EAAS,cAAA;AAAA,MACT,WAAW,cAAA,CAAe,MAAA,GAAS,CAAA,GAAI,cAAA,CAAe,CAAC,CAAA,GAAI,IAAA;AAAA,MAC3D,cAAc,kBAAA,CAAmB,MAAA;AAAA,MACjC,UAAA,EAAY,WAAA,CAAY,GAAA,EAAI,GAAI,SAAA;AAAA,MAChC,QAAA;AAAA,MACA,SAAA,EAAW,KAAK,GAAA;AAAI,KACtB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,QAAA,CACE,UACA,QAAA,EACqB;AACrB,IAAA,MAAM,QAAA,GAAW,IAAA,CAAK,MAAA,CAAO,QAAA,EAAU,QAAQ,CAAA;AAC/C,IAAA,OAAO,QAAA,CAAS,SAAA;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA,EAKA,UAAA,CACE,IAAA,EACA,KAAA,GAAiB,IAAA,EACjB,QAAA,EACgB;AAChB,IAAA,OAAO,KAAK,MAAA,CAAO,EAAE,MAAM,KAAA,EAAM,EAAG,QAAQ,CAAA,CAAE,OAAA;AAAA,EAChD;AAAA;AAAA;AAAA;AAAA,EAKA,UAAA,CACE,IAAA,EACA,IAAA,EACA,QAAA,EACgB;AAChB,IAAA,MAAM,QAAA,GAA2B,EAAE,IAAA,EAAK;AACxC,IAAA,IAAI,IAAA,EAAM;AACR,MAAA,QAAA,CAAS,cAAA,GAAiB,IAAA;AAAA,IAC5B;AACA,IAAA,OAAO,IAAA,CAAK,MAAA,CAAO,QAAA,EAAU,QAAQ,CAAA,CAAE,OAAA;AAAA,EACzC;AAAA;AAAA;AAAA;AAAA,EAKA,oBAAA,CACE,MACA,QAAA,EACgB;AAChB,IAAA,OAAO,IAAA,CAAK,OAAO,EAAE,cAAA,EAAgB,MAAM,KAAA,EAAO,IAAA,EAAK,EAAG,QAAQ,CAAA,CAAE,OAAA;AAAA,EACtE;AAAA;AAAA;AAAA;AAAA,EAKA,QAAA,CACE,WAAA,EACA,QAAA,EACA,QAAA,EACgB;AAChB,IAAA,OAAO,IAAA,CAAK,OAAO,EAAE,GAAG,UAAU,IAAA,EAAM,WAAA,EAAY,EAAG,QAAQ,CAAA,CAAE,OAAA;AAAA,EACnE;AAAA;AAAA;AAAA;AAAA,EAKA,UAAA,CACE,WAAA,EACA,QAAA,EACA,QAAA,EACgB;AAChB,IAAA,OAAO,IAAA,CAAK,OAAO,EAAE,GAAG,UAAU,MAAA,EAAQ,WAAA,EAAY,EAAG,QAAQ,CAAA,CAAE,OAAA;AAAA,EACrE;AAAA;AAAA;AAAA;AAAA,EAKQ,YAAA,CAAa,YAA+B,QAAA,EAAwC;AAC1F,IAAA,MAAM,SAAiC,EAAC;AACxC,IAAA,MAAM,eAAyB,EAAC;AAChC,IAAA,IAAI,WAAA,GAAc,CAAA;AAClB,IAAA,IAAI,aAAA,GAAgB,CAAA;AAEpB,IAAA,MAAM,WAAA,GAAc;AAAA,MAClB,GAAG,oBAAA;AAAA,MACH,SAAA,EAAW,QAAA,CAAS,cAAA,IAAkB,IAAA,CAAK,MAAA,CAAO;AAAA,KACpD;AAGA,IAAA,IAAI,SAAS,IAAA,EAAM;AACjB,MAAA,MAAM,YAAY,IAAA,CAAK,cAAA;AAAA,QACrB,UAAA;AAAA,QACA,QAAA,CAAS,IAAA;AAAA,QACT,SAAS,KAAA,KAAU,KAAA;AAAA,QACnB,WAAA,CAAY;AAAA,OACd;AACA,MAAA,MAAA,CAAO,OAAO,SAAA,CAAU,KAAA;AACxB,MAAA,IAAI,SAAA,CAAU,QAAQ,CAAA,EAAG;AACvB,QAAA,YAAA,CAAa,IAAA,CAAK,GAAG,SAAA,CAAU,OAAO,CAAA;AAAA,MACxC;AACA,MAAA,aAAA,IAAiB,SAAA,CAAU,KAAA,GAAQ,IAAA,CAAK,MAAA,CAAO,UAAA;AAC/C,MAAA,WAAA,IAAe,KAAK,MAAA,CAAO,UAAA;AAAA,IAC7B;AAMA,IAAA,IAAI,QAAA,CAAS,WAAA,IAAe,CAAC,QAAA,CAAS,IAAA,EAAM;AAE1C,MAAA,MAAM,YAAA,GAAe,SAAS,WAAA,CAAY,QAAA,CAAS,GAAG,CAAA,GAClD,QAAA,CAAS,WAAA,CACN,KAAA,CAAM,GAAG,CAAA,CACT,IAAI,CAAC,CAAA,KAAM,CAAA,CAAE,IAAA,EAAM,CAAA,CACnB,OAAO,OAAO,CAAA,GACjB,CAAC,QAAA,CAAS,WAAW,CAAA;AAEzB,MAAA,IAAI,SAAA,GAAY,CAAA;AAChB,MAAA,IAAI,cAAwB,EAAC;AAE7B,MAAA,KAAA,MAAW,OAAO,YAAA,EAAc;AAC9B,QAAA,MAAM,aAAa,IAAA,CAAK,cAAA;AAAA,UACtB,UAAA;AAAA,UACA,GAAA;AAAA,UACA,SAAS,KAAA,KAAU,KAAA;AAAA,UACnB,WAAA,CAAY;AAAA,SACd;AACA,QAAA,MAAM,gBAAgB,IAAA,CAAK,kBAAA,CAAmB,YAAY,GAAA,EAAK,QAAA,CAAS,UAAU,KAAK,CAAA;AACvF,QAAA,MAAM,UAAU,IAAA,CAAK,GAAA,CAAI,UAAA,CAAW,KAAA,EAAO,cAAc,KAAK,CAAA;AAC9D,QAAA,IAAI,UAAU,SAAA,EAAW;AACvB,UAAA,SAAA,GAAY,OAAA;AACZ,UAAA,WAAA,GACE,WAAW,KAAA,IAAS,aAAA,CAAc,KAAA,GAAQ,UAAA,CAAW,UAAU,aAAA,CAAc,OAAA;AAAA,QACjF;AAAA,MACF;AAEA,MAAA,MAAA,CAAO,IAAA,GAAO,SAAA;AACd,MAAA,IAAI,YAAY,CAAA,EAAG;AACjB,QAAA,YAAA,CAAa,IAAA,CAAK,GAAG,WAAW,CAAA;AAAA,MAClC;AACA,MAAA,aAAA,IAAiB,SAAA,GAAY,KAAK,MAAA,CAAO,UAAA;AACzC,MAAA,WAAA,IAAe,KAAK,MAAA,CAAO,UAAA;AAAA,IAC7B;AAGA,IAAA,IAAI,SAAS,YAAA,EAAc;AACzB,MAAA,MAAM,gBAAgB,IAAA,CAAK,kBAAA;AAAA,QACzB,UAAA;AAAA,QACA,QAAA,CAAS,YAAA;AAAA,QACT,SAAS,KAAA,KAAU;AAAA,OACrB;AACA,MAAA,MAAA,CAAO,OAAO,IAAA,CAAK,GAAA,CAAI,OAAO,IAAA,IAAQ,CAAA,EAAG,cAAc,KAAK,CAAA;AAC5D,MAAA,IAAI,cAAc,KAAA,GAAQ,CAAA,IAAK,aAAA,CAAc,OAAA,CAAQ,SAAS,CAAA,EAAG;AAC/D,QAAA,YAAA,CAAa,IAAA,CAAK,GAAG,aAAA,CAAc,OAAO,CAAA;AAAA,MAC5C;AACA,MAAA,aAAA,IAAiB,aAAA,CAAc,KAAA,GAAQ,IAAA,CAAK,MAAA,CAAO,UAAA;AACnD,MAAA,WAAA,IAAe,KAAK,MAAA,CAAO,UAAA;AAAA,IAC7B;AAGA,IAAA,IAAI,SAAS,cAAA,EAAgB;AAC3B,MAAA,MAAM,qBAAqB,IAAA,CAAK,uBAAA;AAAA,QAC9B,UAAA;AAAA,QACA,QAAA,CAAS,cAAA;AAAA,QACT,SAAS,KAAA,KAAU,KAAA;AAAA,QACnB,WAAA,CAAY;AAAA,OACd;AACA,MAAA,MAAA,CAAO,gBAAgB,kBAAA,CAAmB,KAAA;AAC1C,MAAA,IAAI,kBAAA,CAAmB,QAAQ,CAAA,EAAG;AAChC,QAAA,YAAA,CAAa,IAAA,CAAK,GAAG,kBAAA,CAAmB,OAAO,CAAA;AAAA,MACjD;AACA,MAAA,aAAA,IAAiB,kBAAA,CAAmB,KAAA,GAAQ,IAAA,CAAK,MAAA,CAAO,mBAAA;AACxD,MAAA,WAAA,IAAe,KAAK,MAAA,CAAO,mBAAA;AAAA,IAC7B;AAGA,IAAA,IAAI,SAAS,IAAA,EAAM;AACjB,MAAA,MAAM,SAAA,GAAY,IAAA,CAAK,cAAA,CAAe,UAAA,EAAY,SAAS,IAAI,CAAA;AAC/D,MAAA,MAAA,CAAO,OAAO,SAAA,CAAU,KAAA;AACxB,MAAA,IAAI,SAAA,CAAU,QAAQ,CAAA,EAAG;AACvB,QAAA,YAAA,CAAa,IAAA,CAAK,GAAG,SAAA,CAAU,OAAO,CAAA;AAAA,MACxC;AACA,MAAA,aAAA,IAAiB,SAAA,CAAU,KAAA,GAAQ,IAAA,CAAK,MAAA,CAAO,UAAA;AAC/C,MAAA,WAAA,IAAe,KAAK,MAAA,CAAO,UAAA;AAAA,IAC7B;AAGA,IAAA,IAAI,SAAS,IAAA,EAAM;AACjB,MAAA,MAAM,YAAY,UAAA,CAAW,IAAA,CAAK,aAAY,KAAM,QAAA,CAAS,KAAK,WAAA,EAAY;AAC9E,MAAA,IAAI,SAAA,EAAW;AACb,QAAA,YAAA,CAAa,IAAA,CAAK,CAAA,MAAA,EAAS,QAAA,CAAS,IAAI,CAAA,CAAE,CAAA;AAC1C,QAAA,aAAA,IAAiB,CAAA,GAAM,KAAK,MAAA,CAAO,UAAA;AACnC,QAAA,WAAA,IAAe,KAAK,MAAA,CAAO,UAAA;AAAA,MAC7B;AAAA,IACF;AAGA,IAAA,IAAI,SAAS,IAAA,EAAM;AACjB,MAAA,MAAM,YAAA,GAAe,IAAA,CAAK,iBAAA,CAAkB,UAAA,EAAY,SAAS,IAAI,CAAA;AACrE,MAAA,MAAA,CAAO,UAAU,YAAA,CAAa,KAAA;AAC9B,MAAA,IAAI,YAAA,CAAa,QAAQ,CAAA,EAAG;AAC1B,QAAA,YAAA,CAAa,IAAA,CAAK,GAAG,YAAA,CAAa,OAAO,CAAA;AAAA,MAC3C;AACA,MAAA,aAAA,IAAiB,YAAA,CAAa,KAAA,GAAQ,IAAA,CAAK,MAAA,CAAO,aAAA;AAClD,MAAA,WAAA,IAAe,KAAK,MAAA,CAAO,aAAA;AAAA,IAC7B;AAGA,IAAA,IAAI,QAAA,CAAS,WAAA,IAAe,UAAA,CAAW,WAAA,EAAa;AAClD,MAAA,MAAM,iBAAA,GAAoB,UAAA;AAAA,QACxB,UAAA,CAAW,WAAA;AAAA,QACX,QAAA,CAAS,WAAA;AAAA,QACT;AAAA,OACF;AACA,MAAA,IAAI,kBAAkB,OAAA,EAAS;AAC7B,QAAA,YAAA,CAAa,KAAK,CAAA,mBAAA,CAAqB,CAAA;AACvC,QAAA,aAAA,IAAiB,iBAAA,CAAkB,UAAA,GAAa,IAAA,CAAK,MAAA,CAAO,UAAA;AAC5D,QAAA,WAAA,IAAe,KAAK,MAAA,CAAO,UAAA;AAAA,MAC7B;AAAA,IACF;AAGA,IAAA,IAAI,QAAA,CAAS,KAAA,IAAS,UAAA,CAAW,KAAA,EAAO;AACtC,MAAA,MAAM,cAAc,UAAA,CAAW,UAAA,CAAW,KAAA,EAAO,QAAA,CAAS,OAAO,WAAW,CAAA;AAC5E,MAAA,IAAI,YAAY,OAAA,EAAS;AACvB,QAAA,YAAA,CAAa,KAAK,CAAA,aAAA,CAAe,CAAA;AACjC,QAAA,aAAA,IAAiB,WAAA,CAAY,UAAA,GAAa,IAAA,CAAK,MAAA,CAAO,UAAA;AACtD,QAAA,WAAA,IAAe,KAAK,MAAA,CAAO,UAAA;AAAA,MAC7B;AAAA,IACF;AAGA,IAAA,IAAI,SAAS,SAAA,EAAW;AACtB,MAAA,MAAM,UAAU,IAAA,CAAK,YAAA,CAAa,UAAA,CAAW,EAAA,EAAI,SAAS,SAAS,CAAA;AACnE,MAAA,IAAI,OAAA,EAAS;AACX,QAAA,YAAA,CAAa,KAAK,CAAA,kBAAA,CAAoB,CAAA;AACtC,QAAA,aAAA,IAAiB,CAAA,GAAM,KAAK,MAAA,CAAO,UAAA;AACnC,QAAA,WAAA,IAAe,KAAK,MAAA,CAAO,UAAA;AAAA,MAC7B;AAAA,IACF;AAGA,IAAA,MAAM,aAAa,IAAA,CAAK,eAAA,CAAgB,UAAA,EAAY,QAAA,EAAU,YAAY,SAAS,CAAA;AACnF,IAAA,IAAI,UAAA,CAAW,QAAQ,CAAA,EAAG;AACxB,MAAA,MAAA,CAAO,QAAQ,UAAA,CAAW,KAAA;AAC1B,MAAA,YAAA,CAAa,IAAA,CAAK,GAAG,UAAA,CAAW,OAAO,CAAA;AACvC,MAAA,aAAA,IAAiB,UAAA,CAAW,KAAA,GAAQ,IAAA,CAAK,MAAA,CAAO,WAAA;AAChD,MAAA,WAAA,IAAe,KAAK,MAAA,CAAO,WAAA;AAAA,IAC7B;AAGA,IAAA,MAAM,UAAA,GAAa,WAAA,GAAc,CAAA,GAAI,aAAA,GAAgB,WAAA,GAAc,CAAA;AAGnE,IAAA,MAAM,SAAA,GAAY,IAAA,CAAK,qBAAA,CAAsB,UAAU,CAAA;AAEvD,IAAA,OAAO;AAAA,MACL,OAAA,EAAS,SAAA;AAAA,MACT,UAAA;AAAA,MACA,YAAA;AAAA,MACA;AAAA,KACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,cAAA,CACN,UAAA,EACA,IAAA,EACA,KAAA,EACA,SAAA,EACsC;AACtC,IAAA,MAAM,UAAoB,EAAC;AAC3B,IAAA,IAAI,QAAA,GAAW,CAAA;AAEf,IAAA,MAAM,YAAA,GAAe,CAAC,UAAA,CAAW,WAAA,EAAa,WAAW,SAAA,EAAW,UAAA,CAAW,KAAK,CAAA,CAAE,MAAA;AAAA,MACpF;AAAA,KACF;AAEA,IAAA,KAAA,MAAW,cAAc,YAAA,EAAc;AAErC,MAAA,IAAI,UAAA,CAAW,WAAA,EAAY,KAAM,IAAA,CAAK,aAAY,EAAG;AACnD,QAAA,QAAA,GAAW,IAAA,CAAK,GAAA,CAAI,QAAA,EAAU,CAAG,CAAA;AACjC,QAAA,OAAA,CAAQ,KAAK,kBAAkB,CAAA;AAC/B,QAAA;AAAA,MACF;AAGA,MAAA,IAAI,KAAA,EAAO;AACT,QAAA,MAAM,SAAS,UAAA,CAAW,UAAA,EAAY,IAAA,EAAM,EAAE,WAAW,CAAA;AACzD,QAAA,IAAI,MAAA,CAAO,OAAA,IAAW,MAAA,CAAO,UAAA,GAAa,QAAA,EAAU;AAClD,UAAA,QAAA,GAAW,MAAA,CAAO,UAAA;AAClB,UAAA,OAAA,CAAQ,IAAA,CAAK,qBAAqB,MAAA,CAAO,UAAA,GAAa,KAAK,OAAA,CAAQ,CAAC,CAAC,CAAA,CAAA,CAAG,CAAA;AAAA,QAC1E;AAGA,QAAA,MAAM,UAAU,cAAA,CAAe,UAAA,EAAY,IAAA,EAAM,EAAE,WAAW,CAAA;AAC9D,QAAA,IAAI,OAAA,GAAU,QAAA,IAAY,OAAA,IAAW,SAAA,EAAW;AAC9C,UAAA,QAAA,GAAW,OAAA;AACX,UAAA,OAAA,CAAQ,KAAK,CAAA,YAAA,EAAA,CAAgB,OAAA,GAAU,KAAK,OAAA,CAAQ,CAAC,CAAC,CAAA,CAAA,CAAG,CAAA;AAAA,QAC3D;AAAA,MACF;AAAA,IACF;AAEA,IAAA,OAAO,EAAE,KAAA,EAAO,QAAA,EAAU,OAAA,EAAQ;AAAA,EACpC;AAAA;AAAA;AAAA;AAAA,EAKQ,kBAAA,CACN,UAAA,EACA,IAAA,EACA,KAAA,EACsC;AACtC,IAAA,MAAM,UAAoB,EAAC;AAC3B,IAAA,IAAI,QAAA,GAAW,CAAA;AAEf,IAAA,MAAM,YAAA,GAAe;AAAA,MACnB,UAAA,CAAW,WAAA;AAAA,MACX,UAAA,CAAW,SAAA;AAAA,MACX,UAAA,CAAW;AAAA,KACb,CAAE,OAAO,OAAO,CAAA;AAEhB,IAAA,KAAA,MAAW,cAAc,YAAA,EAAc;AAErC,MAAA,IAAI,WAAW,WAAA,EAAY,CAAE,SAAS,IAAA,CAAK,WAAA,EAAa,CAAA,EAAG;AACzD,QAAA,QAAA,GAAW,IAAA,CAAK,GAAA,CAAI,QAAA,EAAU,GAAG,CAAA;AACjC,QAAA,OAAA,CAAQ,KAAK,qBAAqB,CAAA;AAClC,QAAA;AAAA,MACF;AAGA,MAAA,IAAI,KAAA,IAAS,aAAA,CAAc,UAAA,EAAY,IAAI,CAAA,EAAG;AAC5C,QAAA,QAAA,GAAW,IAAA,CAAK,GAAA,CAAI,QAAA,EAAU,GAAG,CAAA;AACjC,QAAA,OAAA,CAAQ,KAAK,sBAAsB,CAAA;AAAA,MACrC;AAAA,IACF;AAEA,IAAA,OAAO,EAAE,KAAA,EAAO,QAAA,EAAU,OAAA,EAAQ;AAAA,EACpC;AAAA;AAAA;AAAA;AAAA,EAKQ,uBAAA,CACN,UAAA,EACA,IAAA,EACA,KAAA,EACA,SAAA,EACsC;AACtC,IAAA,MAAM,UAAoB,EAAC;AAC3B,IAAA,IAAI,QAAA,GAAW,CAAA;AAEf,IAAA,MAAM,eAAA,GAAkB;AAAA,MACtB,UAAA,CAAW,SAAA;AAAA,MACX,UAAA,CAAW,cAAA;AAAA,MACX,UAAA,CAAW,SAAA;AAAA,MACX,UAAA,CAAW;AAAA,KACb,CAAE,OAAO,OAAO,CAAA;AAEhB,IAAA,KAAA,MAAW,kBAAkB,eAAA,EAAiB;AAE5C,MAAA,IAAI,cAAA,CAAe,WAAA,EAAY,KAAM,IAAA,CAAK,aAAY,EAAG;AACvD,QAAA,QAAA,GAAW,IAAA,CAAK,GAAA,CAAI,QAAA,EAAU,CAAG,CAAA;AACjC,QAAA,OAAA,CAAQ,KAAK,6BAA6B,CAAA;AAC1C,QAAA;AAAA,MACF;AAGA,MAAA,IAAI,KAAA,EAAO;AACT,QAAA,MAAM,SAAS,UAAA,CAAW,cAAA,EAAgB,IAAA,EAAM,EAAE,WAAW,CAAA;AAC7D,QAAA,IAAI,MAAA,CAAO,OAAA,IAAW,MAAA,CAAO,UAAA,GAAa,QAAA,EAAU;AAClD,UAAA,QAAA,GAAW,MAAA,CAAO,UAAA;AAClB,UAAA,OAAA,CAAQ,IAAA,CAAK,gCAAgC,MAAA,CAAO,UAAA,GAAa,KAAK,OAAA,CAAQ,CAAC,CAAC,CAAA,CAAA,CAAG,CAAA;AAAA,QACrF;AAAA,MACF;AAAA,IACF;AAEA,IAAA,OAAO,EAAE,KAAA,EAAO,QAAA,EAAU,OAAA,EAAQ;AAAA,EACpC;AAAA;AAAA;AAAA;AAAA,EAKQ,cAAA,CACN,YACA,IAAA,EACsC;AACtC,IAAA,MAAM,UAAoB,EAAC;AAC3B,IAAA,MAAM,cAAA,GAAiB,KAAK,WAAA,EAAY;AAGxC,IAAA,IAAI,UAAA,CAAW,IAAA,EAAM,WAAA,EAAY,KAAM,cAAA,EAAgB;AACrD,MAAA,OAAO,EAAE,OAAO,CAAA,EAAK,OAAA,EAAS,CAAC,CAAA,MAAA,EAAS,IAAI,EAAE,CAAA,EAAE;AAAA,IAClD;AAGA,IAAA,MAAM,UAAA,GAAuC;AAAA,MAC3C,MAAA,EAAQ,CAAC,QAAA,EAAU,oBAAA,EAAsB,oBAAoB,CAAA;AAAA,MAC7D,OAAA,EAAS,CAAC,OAAA,EAAS,UAAU,CAAA;AAAA,MAC7B,QAAA,EAAU,CAAC,sBAAsB,CAAA;AAAA,MACjC,KAAA,EAAO,CAAC,mBAAmB,CAAA;AAAA,MAC3B,IAAA,EAAM,CAAC,GAAG,CAAA;AAAA,MACV,OAAA,EAAS,CAAC,QAAQ,CAAA;AAAA,MAClB,QAAA,EAAU,CAAC,QAAA,EAAU,aAAa,CAAA;AAAA,MAClC,UAAA,EAAY,CAAC,KAAK,CAAA;AAAA,MAClB,IAAA,EAAM,CAAC,MAAM,CAAA;AAAA,MACb,SAAS,CAAC,IAAA,EAAM,MAAM,IAAA,EAAM,IAAA,EAAM,MAAM,IAAI;AAAA,KAC9C;AAEA,IAAA,MAAM,aAAA,GAAgB,UAAA,CAAW,cAAc,CAAA,IAAK,EAAC;AACrD,IAAA,IACE,aAAA,CAAc,IAAA;AAAA,MACZ,CAAC,MAAM,UAAA,CAAW,OAAA,KAAY,KAAK,UAAA,CAAW,IAAA,CAAK,aAAY,KAAM;AAAA,KACvE,EACA;AACA,MAAA,OAAO,EAAE,OAAO,GAAA,EAAK,OAAA,EAAS,CAAC,CAAA,eAAA,EAAkB,IAAI,EAAE,CAAA,EAAE;AAAA,IAC3D;AAEA,IAAA,OAAO,EAAE,KAAA,EAAO,CAAA,EAAG,OAAA,EAAQ;AAAA,EAC7B;AAAA;AAAA;AAAA;AAAA,EAKQ,iBAAA,CACN,YACA,MAAA,EACsC;AAEtC,IAAA,MAAM,SAAA,GAAY,KAAK,cAAA,CAAe,IAAA,CAAK,CAAC,EAAA,KAAO,EAAA,CAAG,OAAO,MAAM,CAAA;AACnE,IAAA,IAAI,CAAC,SAAA,EAAW;AACd,MAAA,OAAO,EAAE,KAAA,EAAO,CAAA,EAAG,OAAA,EAAS,EAAC,EAAE;AAAA,IACjC;AAGA,IAAA,MAAM,WAAW,IAAA,CAAK,iBAAA,CAAkB,UAAA,CAAW,IAAA,EAAM,UAAU,IAAI,CAAA;AAIvE,IAAA,MAAM,aAAA,GAAgB,GAAA;AACtB,IAAA,IAAI,QAAA,GAAW,gBAAgB,CAAA,EAAG;AAChC,MAAA,OAAO,EAAE,KAAA,EAAO,CAAA,EAAG,OAAA,EAAS,EAAC,EAAE;AAAA,IACjC;AAEA,IAAA,MAAM,QAAQ,IAAA,CAAK,GAAA,CAAI,GAAG,CAAA,GAAI,QAAA,IAAY,gBAAgB,CAAA,CAAE,CAAA;AAC5D,IAAA,OAAO;AAAA,MACL,KAAA;AAAA,MACA,OAAA,EAAS,CAAC,CAAA,EAAG,QAAA,CAAS,QAAQ,CAAC,CAAC,CAAA,QAAA,EAAW,MAAM,CAAA,CAAE;AAAA,KACrD;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,iBAAA,CAAkB,OAA6B,KAAA,EAAqC;AAC1F,IAAA,MAAM,OAAA,GAAU;AAAA,MACd,CAAA,EAAG,KAAA,CAAM,CAAA,GAAI,KAAA,CAAM,KAAA,GAAQ,CAAA;AAAA,MAC3B,CAAA,EAAG,KAAA,CAAM,CAAA,GAAI,KAAA,CAAM,MAAA,GAAS;AAAA,KAC9B;AACA,IAAA,MAAM,OAAA,GAAU;AAAA,MACd,CAAA,EAAG,KAAA,CAAM,CAAA,GAAI,KAAA,CAAM,KAAA,GAAQ,CAAA;AAAA,MAC3B,CAAA,EAAG,KAAA,CAAM,CAAA,GAAI,KAAA,CAAM,MAAA,GAAS;AAAA,KAC9B;AAEA,IAAA,OAAO,KAAK,IAAA,CAAK,IAAA,CAAK,GAAA,CAAI,OAAA,CAAQ,IAAI,OAAA,CAAQ,CAAA,EAAG,CAAC,CAAA,GAAI,KAAK,GAAA,CAAI,OAAA,CAAQ,IAAI,OAAA,CAAQ,CAAA,EAAG,CAAC,CAAC,CAAA;AAAA,EAC1F;AAAA;AAAA;AAAA;AAAA,EAKQ,eAAA,CACN,UAAA,EACA,QAAA,EACA,SAAA,EACsC;AACtC,IAAA,MAAM,UAAoB,EAAC;AAC3B,IAAA,IAAI,QAAA,GAAW,CAAA;AAGf,IAAA,MAAM,cAAwB,EAAC;AAC/B,IAAA,IAAI,QAAA,CAAS,IAAA,EAAM,WAAA,CAAY,IAAA,CAAK,SAAS,IAAI,CAAA;AACjD,IAAA,IAAI,QAAA,CAAS,YAAA,EAAc,WAAA,CAAY,IAAA,CAAK,SAAS,YAAY,CAAA;AACjE,IAAA,IAAI,QAAA,CAAS,cAAA,EAAgB,WAAA,CAAY,IAAA,CAAK,SAAS,cAAc,CAAA;AAErE,IAAA,KAAA,MAAW,cAAc,WAAA,EAAa;AACpC,MAAA,MAAM,SAAA,GAAY,WAAW,WAAA,EAAY;AAEzC,MAAA,KAAA,MAAW,KAAA,IAAS,WAAW,OAAA,EAAS;AAEtC,QAAA,IAAI,UAAU,SAAA,EAAW;AACvB,UAAA,QAAA,GAAW,IAAA,CAAK,GAAA,CAAI,QAAA,EAAU,CAAG,CAAA;AACjC,UAAA,OAAA,CAAQ,IAAA,CAAK,CAAA,cAAA,EAAiB,KAAK,CAAA,CAAA,CAAG,CAAA;AACtC,UAAA;AAAA,QACF;AAGA,QAAA,MAAM,WAAA,GAAc,SAAA,CAAU,KAAA,CAAM,KAAK,CAAA;AACzC,QAAA,MAAM,UAAA,GAAa,KAAA,CAAM,KAAA,CAAM,KAAK,CAAA;AAEpC,QAAA,KAAA,MAAW,cAAc,WAAA,EAAa;AACpC,UAAA,KAAA,MAAW,aAAa,UAAA,EAAY;AAClC,YAAA,IAAI,WAAA,CAAY,UAAA,EAAY,SAAS,CAAA,EAAG;AACtC,cAAA,QAAA,GAAW,IAAA,CAAK,GAAA,CAAI,QAAA,EAAU,IAAI,CAAA;AAClC,cAAA,OAAA,CAAQ,IAAA,CAAK,CAAA,gBAAA,EAAmB,UAAU,CAAA,KAAA,EAAQ,SAAS,CAAA,CAAA,CAAG,CAAA;AAAA,YAChE;AAAA,UACF;AAAA,QACF;AAGA,QAAA,MAAM,SAAS,UAAA,CAAW,KAAA,EAAO,SAAA,EAAW,EAAE,WAAW,CAAA;AACzD,QAAA,IAAI,MAAA,CAAO,OAAA,IAAW,MAAA,CAAO,UAAA,GAAa,QAAA,EAAU;AAClD,UAAA,QAAA,GAAW,MAAA,CAAO,UAAA;AAClB,UAAA,OAAA,CAAQ,IAAA,CAAK,CAAA,cAAA,EAAiB,KAAK,CAAA,GAAA,EAAA,CAAO,MAAA,CAAO,aAAa,GAAA,EAAK,OAAA,CAAQ,CAAC,CAAC,CAAA,EAAA,CAAI,CAAA;AAAA,QACnF;AAGA,QAAA,MAAM,QAAA,GAAW,eAAA,CAAgB,KAAA,EAAO,SAAS,CAAA;AACjD,QAAA,IAAI,QAAA,GAAW,QAAA,IAAY,QAAA,IAAY,SAAA,EAAW;AAChD,UAAA,QAAA,GAAW,QAAA;AACX,UAAA,OAAA,CAAQ,IAAA,CAAK,CAAA,cAAA,EAAiB,KAAK,CAAA,CAAA,CAAG,CAAA;AAAA,QACxC;AAAA,MACF;AAAA,IACF;AAEA,IAAA,OAAO,EAAE,KAAA,EAAO,QAAA,EAAU,OAAA,EAAQ;AAAA,EACpC;AAAA;AAAA;AAAA;AAAA,EAKQ,YAAA,CAAa,KAAa,OAAA,EAA0B;AAC1D,IAAA,MAAM,YAAA,GAAe,QAAQ,OAAA,CAAQ,qBAAA,EAAuB,MAAM,CAAA,CAAE,OAAA,CAAQ,SAAS,IAAI,CAAA;AACzF,IAAA,OAAO,IAAI,OAAO,CAAA,CAAA,EAAI,YAAY,KAAK,GAAG,CAAA,CAAE,KAAK,GAAG,CAAA;AAAA,EACtD;AAAA;AAAA;AAAA;AAAA,EAKQ,sBAAsB,UAAA,EAAoD;AAChF,IAAA,MAAM,cAAA,GACJ,UAAA,IAAc,UAAA,CAAW,OAAA,GACrB;AAAA,MACE,IAAI,UAAA,CAAW,EAAA;AAAA,MACf,MAAM,UAAA,CAAW,IAAA;AAAA,MACjB,KAAA,EAAQ,WAAW,OAAA,CAA8B,KAAA;AAAA,MACjD,SAAS,UAAA,CAAW,OAAA;AAAA,MACpB,MAAM,UAAA,CAAW,IAAA;AAAA,MACjB,gBAAgB,UAAA,CAAW,SAAA;AAAA,MAC3B,OAAA,EAAU,WAAW,OAAA,CAA8B,OAAA;AAAA,MACnD,OAAO,UAAA,CAAW,KAAA;AAAA,MAClB,UAAA,EAAY;AAAA,QAEb,UAAA,CAAW,OAAA;AAElB,IAAA,OAAO;AAAA,MACL,GAAG,cAAA;AAAA,MACH,aAAa,UAAA,CAAW,WAAA;AAAA,MACxB,SAAS,UAAA,CAAW,OAAA;AAAA,MACpB,SAAS,eAAA,CAAgB;AAAA,QACvB,aAAa,UAAA,CAAW,WAAA;AAAA,QACxB,WAAW,UAAA,CAAW,SAAA;AAAA,QACtB,aAAa,UAAA,CAAW,IAAA;AAAA,QACxB,SAAS,UAAA,CAAW;AAAA,OACrB,CAAA;AAAA,MACD,aAAA,EAAe,MAAA;AAAA;AAAA,MACf,kBAAkB,wBAAA,CAAyB;AAAA,QACzC,aAAa,UAAA,CAAW,WAAA;AAAA,QACxB,WAAW,UAAA,CAAW,SAAA;AAAA,QACtB,aAAa,UAAA,CAAW,IAAA;AAAA,QACxB,SAAS,UAAA,CAAW;AAAA,OACrB,CAAA;AAAA,MACD,YAAA,EAAc,IAAA,CAAK,iBAAA,CAAkB,UAAU,CAAA;AAAA,MAC/C,WAAW,UAAA,CAAW,SAAA;AAAA,MACtB,aAAa,UAAA,CAAW,WAAA;AAAA,MACxB,OAAO,UAAA,CAAW;AAAA,KACpB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,kBAAkB,UAAA,EAAuC;AAC/D,IAAA,MAAM,QAAQ,UAAA,CAAW,WAAA,IAAe,UAAA,CAAW,SAAA,IAAa,IAAI,WAAA,EAAY;AAChF,IAAA,MAAM,IAAA,GAAO,UAAA,CAAW,IAAA,CAAK,WAAA,EAAY;AAGzC,IAAA,IAAI,IAAA,KAAS,OAAA,IAAW,IAAA,KAAS,UAAA,EAAY;AAC3C,MAAA,IAAI,UAAA,CAAW,WAAA,EAAa,WAAA,EAAY,CAAE,QAAA,CAAS,OAAO,CAAA,IAAK,IAAA,CAAK,QAAA,CAAS,OAAO,CAAA,EAAG;AACrF,QAAA,OAAO,aAAA;AAAA,MACT;AACA,MAAA,IAAI,UAAA,CAAW,WAAA,EAAa,WAAA,EAAY,CAAE,QAAA,CAAS,UAAU,CAAA,IAAK,IAAA,CAAK,QAAA,CAAS,UAAU,CAAA,EAAG;AAC3F,QAAA,OAAO,gBAAA;AAAA,MACT;AACA,MAAA,IAAI,UAAA,CAAW,WAAA,EAAa,WAAA,EAAY,CAAE,QAAA,CAAS,QAAQ,CAAA,IAAK,IAAA,CAAK,QAAA,CAAS,QAAQ,CAAA,EAAG;AACvF,QAAA,OAAO,cAAA;AAAA,MACT;AACA,MAAA,OAAO,YAAA;AAAA,IACT;AAGA,IAAA,IAAI,SAAS,QAAA,EAAU;AACrB,MAAA,IAAI,IAAA,CAAK,KAAA,CAAM,mCAAmC,CAAA,EAAG,OAAO,eAAA;AAC5D,MAAA,IAAI,IAAA,CAAK,KAAA,CAAM,sBAAsB,CAAA,EAAG,OAAO,eAAA;AAC/C,MAAA,IAAI,IAAA,CAAK,KAAA,CAAM,qBAAqB,CAAA,EAAG,OAAO,eAAA;AAC9C,MAAA,IAAI,IAAA,CAAK,KAAA,CAAM,mBAAmB,CAAA,EAAG,OAAO,YAAA;AAC5C,MAAA,IAAI,IAAA,CAAK,KAAA,CAAM,aAAa,CAAA,EAAG,OAAO,aAAA;AACtC,MAAA,IAAI,IAAA,CAAK,KAAA,CAAM,eAAe,CAAA,EAAG,OAAO,aAAA;AACxC,MAAA,IAAI,IAAA,CAAK,KAAA,CAAM,eAAe,CAAA,EAAG,OAAO,aAAA;AACxC,MAAA,OAAO,eAAA;AAAA,IACT;AAGA,IAAA,IAAI,SAAS,MAAA,EAAQ;AACnB,MAAA,IAAI,IAAA,CAAK,KAAA,CAAM,gBAAgB,CAAA,EAAG,OAAO,WAAA;AACzC,MAAA,IAAI,IAAA,CAAK,KAAA,CAAM,gBAAgB,CAAA,EAAG,OAAO,YAAA;AACzC,MAAA,IAAI,IAAA,CAAK,KAAA,CAAM,kBAAkB,CAAA,EAAG,OAAO,aAAA;AAC3C,MAAA,OAAO,iBAAA;AAAA,IACT;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AACF,CAAA;;;ACn4BO,IAAM,sBAAA,GAAwC;AAAA,EACnD,SAAA,EAAW,GAAA;AAAA,EACX,YAAA,EAAc,IAAA;AAAA,EACd,oBAAA,EAAsB,IAAA;AAAA,EACtB,aAAA,EAAe,IAAA;AAAA,EACf,cAAA,EAAgB,IAAA;AAAA,EAChB,SAAA,EAAW;AACb,CAAA;AAKO,SAAS,mBAAA,CACd,QAAA,EACA,WAAA,EACA,MAAA,GAAiC,EAAC,EAC1B;AACR,EAAA,MAAM,WAAA,GAAc,EAAE,GAAG,sBAAA,EAAwB,GAAG,MAAA,EAAO;AAC3D,EAAA,MAAM,QAAkB,EAAC;AAGzB,EAAA,IAAI,WAAA,EAAa;AACf,IAAA,IAAI,YAAY,KAAA,EAAO;AACrB,MAAA,KAAA,CAAM,IAAA,CAAK,CAAA,OAAA,EAAU,WAAA,CAAY,KAAK,CAAA,CAAA,CAAG,CAAA;AAAA,IAC3C;AACA,IAAA,IAAI,WAAA,CAAY,QAAA,IAAY,WAAA,CAAY,QAAA,KAAa,SAAA,EAAW;AAC9D,MAAA,KAAA,CAAM,KAAK,CAAA,MAAA,EAAS,cAAA,CAAe,WAAA,CAAY,QAAQ,CAAC,CAAA,CAAE,CAAA;AAAA,IAC5D;AAAA,EACF;AAGA,EAAA,IAAI,YAAY,oBAAA,EAAsB;AACpC,IAAA,MAAM,MAAA,GAAS,kBAAkB,QAAQ,CAAA;AACzC,IAAA,MAAM,aAAuB,EAAC;AAE9B,IAAA,IAAI,OAAO,MAAA,GAAS,CAAA;AAClB,MAAA,UAAA,CAAW,IAAA,CAAK,CAAA,EAAG,MAAA,CAAO,MAAM,CAAA,OAAA,EAAU,OAAO,MAAA,GAAS,CAAA,GAAI,GAAA,GAAM,EAAE,CAAA,CAAE,CAAA;AAC1E,IAAA,IAAI,MAAA,CAAO,KAAA,GAAQ,CAAA,EAAG,UAAA,CAAW,KAAK,CAAA,EAAG,MAAA,CAAO,KAAK,CAAA,MAAA,EAAS,MAAA,CAAO,KAAA,GAAQ,CAAA,GAAI,GAAA,GAAM,EAAE,CAAA,CAAE,CAAA;AAC3F,IAAA,IAAI,MAAA,CAAO,IAAA,GAAO,CAAA,EAAG,UAAA,CAAW,KAAK,CAAA,EAAG,MAAA,CAAO,IAAI,CAAA,KAAA,EAAQ,MAAA,CAAO,IAAA,GAAO,CAAA,GAAI,GAAA,GAAM,EAAE,CAAA,CAAE,CAAA;AACvF,IAAA,IAAI,OAAO,MAAA,GAAS,CAAA;AAClB,MAAA,UAAA,CAAW,IAAA,CAAK,CAAA,EAAG,MAAA,CAAO,MAAM,CAAA,SAAA,EAAY,OAAO,MAAA,GAAS,CAAA,GAAI,GAAA,GAAM,EAAE,CAAA,CAAE,CAAA;AAC5E,IAAA,IAAI,OAAO,QAAA,GAAW,CAAA;AACpB,MAAA,UAAA,CAAW,IAAA,CAAK,CAAA,EAAG,MAAA,CAAO,QAAQ,CAAA,SAAA,EAAY,OAAO,QAAA,GAAW,CAAA,GAAI,IAAA,GAAO,EAAE,CAAA,CAAE,CAAA;AAEjF,IAAA,IAAI,UAAA,CAAW,SAAS,CAAA,EAAG;AACzB,MAAA,KAAA,CAAM,KAAK,CAAA,UAAA,EAAa,UAAA,CAAW,IAAA,CAAK,IAAI,CAAC,CAAA,CAAE,CAAA;AAAA,IACjD;AAAA,EACF;AAGA,EAAA,IAAI,YAAY,YAAA,EAAc;AAC5B,IAAA,MAAM,KAAA,GAAQ,YAAY,QAAQ,CAAA;AAClC,IAAA,IAAI,KAAA,CAAM,SAAS,CAAA,EAAG;AACpB,MAAA,KAAA,CAAM,KAAK,EAAE,CAAA;AACb,MAAA,KAAA,CAAM,KAAK,QAAQ,CAAA;AACnB,MAAA,KAAA,MAAW,QAAQ,KAAA,EAAO;AACxB,QAAA,KAAA,CAAM,IAAA,CAAK,mBAAA,CAAoB,IAAA,EAAM,WAAA,CAAY,SAAS,CAAC,CAAA;AAAA,MAC7D;AAAA,IACF;AAAA,EACF;AAGA,EAAA,IACE,YAAY,aAAA,IACZ,WAAA,EAAa,gBACb,WAAA,CAAY,YAAA,CAAa,SAAS,CAAA,EAClC;AACA,IAAA,KAAA,CAAM,KAAK,EAAE,CAAA;AACb,IAAA,KAAA,CAAM,KAAK,CAAA,eAAA,EAAkB,WAAA,CAAY,aAAa,IAAA,CAAK,IAAI,CAAC,CAAA,CAAE,CAAA;AAAA,EACpE;AAGA,EAAA,IAAI,WAAA,CAAY,cAAA,IAAkB,WAAA,EAAa,cAAA,EAAgB;AAC7D,IAAA,KAAA,CAAM,IAAA,CAAK,CAAA,OAAA,EAAU,WAAA,CAAY,cAAc,CAAA,CAAE,CAAA;AAAA,EACnD;AAGA,EAAA,MAAM,WAAA,GAAc,eAAe,QAAQ,CAAA;AAC3C,EAAA,IAAI,WAAA,CAAY,SAAS,CAAA,EAAG;AAC1B,IAAA,KAAA,CAAM,KAAK,EAAE,CAAA;AACb,IAAA,KAAA,CAAM,KAAK,eAAe,CAAA;AAC1B,IAAA,KAAA,MAAW,MAAM,WAAA,EAAa;AAC5B,MAAA,KAAA,CAAM,IAAA,CAAK,CAAA,IAAA,EAAO,EAAA,CAAG,WAAW,CAAA,EAAG,GAAG,KAAA,CAAM,OAAA,GAAU,EAAA,GAAK,aAAa,CAAA,CAAE,CAAA;AAAA,IAC5E;AAAA,EACF;AAGA,EAAA,IAAI,OAAA,GAAU,KAAA,CAAM,IAAA,CAAK,IAAI,CAAA;AAG7B,EAAA,IAAI,OAAA,CAAQ,MAAA,GAAS,WAAA,CAAY,SAAA,EAAW;AAC1C,IAAA,OAAA,GAAU,QAAQ,SAAA,CAAU,CAAA,EAAG,WAAA,CAAY,SAAA,GAAY,CAAC,CAAA,GAAI,KAAA;AAAA,EAC9D;AAEA,EAAA,OAAO,OAAA;AACT;AAwCA,SAAS,mBAAA,CAAoB,MAAoB,SAAA,EAA+C;AAC9F,EAAA,MAAM,QAAkB,EAAC;AACzB,EAAA,MAAM,QAAA,GAAW,IAAA,CAAK,IAAA,IAAQ,IAAA,CAAK,WAAW,IAAA,CAAK,EAAA;AAEnD,EAAA,KAAA,CAAM,IAAA,CAAK,CAAA,EAAA,EAAK,QAAQ,CAAA,CAAA,CAAG,CAAA;AAE3B,EAAA,IAAI,cAAc,OAAA,EAAS;AACzB,IAAA,MAAM,UAAA,GAAa,KAAK,MAAA,CAAO,MAAA;AAC/B,IAAA,MAAM,WAAA,GAAc,KAAK,MAAA,CAAO,MAAA,CAAO,CAAC,CAAA,KAAM,CAAA,CAAE,KAAK,CAAA,CAAE,MAAA;AACvD,IAAA,KAAA,CAAM,IAAA;AAAA,MACJ,CAAA,IAAA,EAAO,WAAW,CAAA,CAAA,EAAI,UAAU,mBAAmB,IAAA,CAAK,OAAA,GAAU,UAAU,YAAY,CAAA;AAAA,KAC1F;AAAA,EACF,CAAA,MAAO;AAEL,IAAA,KAAA,MAAW,KAAA,IAAS,KAAK,MAAA,EAAQ;AAC/B,MAAA,IAAI,SAAA,GAAY,CAAA,MAAA,EAAS,KAAA,CAAM,KAAA,IAAS,MAAM,EAAE,CAAA,CAAA;AAEhD,MAAA,IAAI,MAAM,KAAA,EAAO;AACf,QAAA,SAAA,IAAa,CAAA,IAAA,EAAO,QAAA,CAAS,KAAA,CAAM,KAAA,EAAO,EAAE,CAAC,CAAA,CAAA,CAAA;AAAA,MAC/C,CAAA,MAAA,IAAW,MAAM,WAAA,EAAa;AAC5B,QAAA,SAAA,IAAa,CAAA,EAAA,EAAK,MAAM,WAAW,CAAA,CAAA,CAAA;AAAA,MACrC,CAAA,MAAO;AACL,QAAA,SAAA,IAAa,UAAA;AAAA,MACf;AAEA,MAAA,IAAI,CAAC,KAAA,CAAM,KAAA,IAAS,KAAA,CAAM,KAAA,EAAO;AAC/B,QAAA,SAAA,IAAa,CAAA,SAAA,EAAY,MAAM,KAAK,CAAA,CAAA,CAAA;AAAA,MACtC,CAAA,MAAA,IAAW,KAAA,CAAM,QAAA,IAAY,CAAC,MAAM,KAAA,EAAO;AACzC,QAAA,SAAA,IAAa,aAAA;AAAA,MACf;AAEA,MAAA,KAAA,CAAM,KAAK,SAAS,CAAA;AAAA,IACtB;AAGA,IAAA,IAAI,KAAK,YAAA,EAAc;AACrB,MAAA,KAAA,CAAM,IAAA,CAAK,CAAA,YAAA,EAAe,IAAA,CAAK,YAAY,CAAA,CAAE,CAAA;AAAA,IAC/C;AAAA,EACF;AAEA,EAAA,OAAO,KAAA,CAAM,KAAK,IAAI,CAAA;AACxB;AA8FO,SAAS,mBAAA,CACd,QAAA,EACA,WAAA,EACA,QAAA,EACQ;AACR,EAAA,MAAM,QAAkB,EAAC;AAEzB,EAAA,IAAI,QAAA,CAAS,SAAS,CAAA,EAAG;AACvB,IAAA,KAAA,CAAM,KAAK,CAAA,UAAA,EAAa,QAAA,CAAS,IAAA,CAAK,IAAI,CAAC,CAAA,CAAE,CAAA;AAAA,EAC/C;AAEA,EAAA,IAAI,WAAA,CAAY,SAAS,CAAA,EAAG;AAC1B,IAAA,KAAA,CAAM,KAAK,CAAA,aAAA,EAAgB,WAAA,CAAY,IAAA,CAAK,IAAI,CAAC,CAAA,CAAE,CAAA;AAAA,EACrD;AAEA,EAAA,IAAI,QAAA,CAAS,SAAS,CAAA,EAAG;AACvB,IAAA,KAAA,CAAM,KAAK,UAAU,CAAA;AACrB,IAAA,KAAA,MAAW,GAAA,IAAO,QAAA,CAAS,KAAA,CAAM,CAAA,EAAG,CAAC,CAAA,EAAG;AACtC,MAAA,KAAA,CAAM,IAAA;AAAA,QACJ,CAAA,IAAA,EAAO,GAAA,CAAI,WAAW,CAAA,EAAA,EAAK,GAAA,CAAI,QAAQ,CAAA,eAAA,EAAkB,GAAA,CAAI,IAAI,CAAA,MAAA,EAAS,GAAA,CAAI,EAAE,CAAA,CAAA;AAAA,OAClF;AAAA,IACF;AACA,IAAA,IAAI,QAAA,CAAS,SAAS,CAAA,EAAG;AACvB,MAAA,KAAA,CAAM,IAAA,CAAK,CAAA,UAAA,EAAa,QAAA,CAAS,MAAA,GAAS,CAAC,CAAA,aAAA,CAAe,CAAA;AAAA,IAC5D;AAAA,EACF;AAEA,EAAA,IAAI,KAAA,CAAM,WAAW,CAAA,EAAG;AACtB,IAAA,OAAO,qBAAA;AAAA,EACT;AAEA,EAAA,OAAO,KAAA,CAAM,KAAK,IAAI,CAAA;AACxB;AASA,SAAS,kBAAkB,QAAA,EAAyD;AAClF,EAAA,MAAM,SAAiC,EAAC;AAExC,EAAA,KAAA,MAAW,MAAM,QAAA,EAAU;AACzB,IAAA,MAAM,IAAA,GAAO,EAAA,CAAG,IAAA,CAAK,WAAA,EAAY;AACjC,IAAA,MAAA,CAAO,IAAI,CAAA,GAAA,CAAK,MAAA,CAAO,IAAI,KAAK,CAAA,IAAK,CAAA;AAAA,EACvC;AAEA,EAAA,OAAO,MAAA;AACT;AAKA,SAAS,YAAY,QAAA,EAAiD;AAEpE,EAAA,MAAM,eAAe,QAAA,CAAS,MAAA;AAAA,IAC5B,CAAC,EAAA,KACC,EAAA,CAAG,IAAA,KAAS,OAAA,IACZ,EAAA,CAAG,IAAA,KAAS,UAAA,IACZ,EAAA,CAAG,IAAA,KAAS,QAAA,IACZ,EAAA,CAAG,IAAA,KAAS;AAAA,GAChB;AAEA,EAAA,IAAI,YAAA,CAAa,MAAA,KAAW,CAAA,EAAG,OAAO,EAAC;AAGvC,EAAA,MAAM,QAAwB,EAAC;AAG/B,EAAA,MAAM,gBAAgB,QAAA,CAAS,MAAA;AAAA,IAC7B,CAAC,EAAA,KACC,EAAA,CAAG,IAAA,KAAS,QAAA,KACX,EAAA,CAAG,KAAA,CAAM,WAAA,EAAa,WAAA,EAAY,CAAE,QAAA,CAAS,QAAQ,KACpD,EAAA,CAAG,KAAA,CAAM,WAAA,EAAa,WAAA,EAAY,CAAE,QAAA,CAAS,MAAM,CAAA,IACnD,EAAA,CAAG,KAAA,CAAM,WAAA,EAAa,WAAA,EAAY,CAAE,QAAA,CAAS,MAAM,CAAA,IACnD,GAAG,YAAA,KAAiB,eAAA;AAAA,GAC1B;AAGA,EAAA,MAAM,WAAA,GAA4B;AAAA,IAChC,EAAA,EAAI,eAAA;AAAA,IACJ,OAAA,EAAS,iBAAiB,YAAY,CAAA;AAAA,IACtC,MAAA,EAAQ,YAAA,CAAa,GAAA,CAAI,CAAC,EAAA,MAAQ;AAAA,MAChC,IAAI,EAAA,CAAG,EAAA;AAAA,MACP,OAAO,EAAA,CAAG,SAAA,IAAa,GAAG,cAAA,IAAkB,EAAA,CAAG,eAAe,EAAA,CAAG,EAAA;AAAA,MACjE,MAAM,EAAA,CAAG,IAAA;AAAA,MACT,KAAA,EAAO,EAAA,CAAG,KAAA,CAAM,KAAA,IAAS,EAAA;AAAA,MACzB,KAAA,EAAO,IAAA;AAAA;AAAA,MACP,QAAA,EAAU,KAAA;AAAA;AAAA,MACV,aAAa,EAAA,CAAG;AAAA,KAClB,CAAE,CAAA;AAAA,IACF,OAAA,EAAS,IAAA;AAAA,IACT,YAAA,EAAc,aAAA,CAAc,CAAC,CAAA,EAAG;AAAA,GAClC;AAEA,EAAA,IAAI,WAAA,CAAY,MAAA,CAAO,MAAA,GAAS,CAAA,EAAG;AACjC,IAAA,KAAA,CAAM,KAAK,WAAW,CAAA;AAAA,EACxB;AAEA,EAAA,OAAO,KAAA;AACT;AAKA,SAAS,iBAAiB,MAAA,EAAuC;AAC/D,EAAA,MAAM,SAAS,MAAA,CAAO,GAAA;AAAA,IAAI,CAAC,OACxB,CAAA,CAAE,SAAA,IAAa,EAAE,cAAA,IAAkB,CAAA,CAAE,WAAA,IAAe,EAAA,EAAI,WAAA;AAAY,GACvE;AACA,EAAA,MAAM,SAAA,GAAY,MAAA,CAAO,IAAA,CAAK,GAAG,CAAA;AAEjC,EAAA,IAAI,UAAU,QAAA,CAAS,OAAO,KAAK,SAAA,CAAU,QAAA,CAAS,UAAU,CAAA,EAAG;AACjE,IAAA,IAAI,UAAU,QAAA,CAAS,SAAS,KAAK,SAAA,CAAU,QAAA,CAAS,MAAM,CAAA,EAAG;AAC/D,MAAA,OAAO,mBAAA;AAAA,IACT;AACA,IAAA,OAAO,YAAA;AAAA,EACT;AAEA,EAAA,IAAI,SAAA,CAAU,QAAA,CAAS,QAAQ,CAAA,EAAG;AAChC,IAAA,OAAO,aAAA;AAAA,EACT;AAEA,EAAA,IAAI,SAAA,CAAU,QAAA,CAAS,SAAS,CAAA,IAAK,SAAA,CAAU,QAAA,CAAS,MAAM,CAAA,IAAK,SAAA,CAAU,QAAA,CAAS,KAAK,CAAA,EAAG;AAC5F,IAAA,OAAO,cAAA;AAAA,EACT;AAEA,EAAA,IAAI,SAAA,CAAU,QAAA,CAAS,MAAM,CAAA,IAAK,SAAA,CAAU,QAAA,CAAS,KAAK,CAAA,IAAK,SAAA,CAAU,QAAA,CAAS,OAAO,CAAA,EAAG;AAC1F,IAAA,OAAO,cAAA;AAAA,EACT;AAEA,EAAA,IAAI,UAAU,QAAA,CAAS,SAAS,KAAK,SAAA,CAAU,QAAA,CAAS,SAAS,CAAA,EAAG;AAClE,IAAA,OAAO,cAAA;AAAA,EACT;AAEA,EAAA,OAAO,MAAA;AACT;AAKA,SAAS,eAAe,QAAA,EAAwD;AAC9E,EAAA,MAAM,cAAqC,EAAC;AAG5C,EAAA,MAAM,gBAAgB,QAAA,CAAS,MAAA;AAAA,IAC7B,CAAC,OACC,EAAA,CAAG,IAAA,KAAS,YACZ,EAAA,CAAG,KAAA,CAAM,YACR,EAAA,CAAG,YAAA,EAAc,SAAS,QAAQ,CAAA,IACjC,GAAG,YAAA,EAAc,QAAA,CAAS,QAAQ,CAAA,IAClC,EAAA,CAAG,YAAA,EAAc,QAAA,CAAS,MAAM,CAAA;AAAA,GACtC;AACA,EAAA,WAAA,CAAY,KAAK,GAAG,aAAA,CAAc,KAAA,CAAM,CAAA,EAAG,CAAC,CAAC,CAAA;AAG7C,EAAA,MAAM,gBAAgB,QAAA,CAAS,MAAA;AAAA,IAC7B,CAAC,QAAQ,EAAA,CAAG,IAAA,KAAS,WAAW,EAAA,CAAG,IAAA,KAAS,UAAA,KAAe,EAAA,CAAG,KAAA,CAAM;AAAA,GACtE;AACA,EAAA,WAAA,CAAY,KAAK,GAAG,aAAA,CAAc,KAAA,CAAM,CAAA,EAAG,CAAC,CAAC,CAAA;AAG7C,EAAA,MAAM,KAAA,GAAQ,QAAA,CAAS,MAAA,CAAO,CAAC,EAAA,KAAO,GAAG,IAAA,KAAS,MAAA,IAAU,EAAA,CAAG,KAAA,CAAM,OAAO,CAAA;AAC5E,EAAA,WAAA,CAAY,KAAK,GAAG,KAAA,CAAM,KAAA,CAAM,CAAA,EAAG,CAAC,CAAC,CAAA;AAGrC,EAAA,MAAM,SAAS,CAAC,GAAG,IAAI,GAAA,CAAI,YAAY,GAAA,CAAI,CAAC,CAAA,KAAM,CAAC,EAAE,EAAA,EAAI,CAAC,CAAC,CAAC,CAAA,CAAE,QAAQ,CAAA;AACtE,EAAA,OAAO,MAAA,CAAO,KAAA,CAAM,CAAA,EAAG,CAAC,CAAA;AAC1B;AAKA,SAAS,eAAe,QAAA,EAA2C;AACjE,EAAA,MAAM,UAAA,GAAmE;AAAA,IACvE,KAAA,EAAO,YAAA;AAAA,IACP,SAAA,EAAW,WAAA;AAAA,IACX,IAAA,EAAM,WAAA;AAAA,IACN,IAAA,EAAM,iBAAA;AAAA,IACN,MAAA,EAAQ,aAAA;AAAA,IACR,MAAA,EAAQ,aAAA;AAAA,IACR,QAAA,EAAU,eAAA;AAAA,IACV,QAAA,EAAU,eAAA;AAAA,IACV,OAAA,EAAS;AAAA,GACX;AAEA,EAAA,OAAO,UAAA,CAAW,QAAA,IAAY,SAAS,CAAA,IAAK,MAAA;AAC9C;AA6BA,SAAS,QAAA,CAAS,KAAa,SAAA,EAA2B;AACxD,EAAA,IAAI,GAAA,CAAI,MAAA,IAAU,SAAA,EAAW,OAAO,GAAA;AACpC,EAAA,OAAO,GAAA,CAAI,SAAA,CAAU,CAAA,EAAG,SAAA,GAAY,CAAC,CAAA,GAAI,KAAA;AAC3C;AAKO,SAAS,aAAA,CACd,GAAA,EACA,KAAA,EACA,QAAA,EACyB;AACzB,EAAA,MAAM,QAAA,GAAW,IAAI,WAAA,EAAY;AACjC,EAAA,MAAM,UAAA,GAAa,MAAM,WAAA,EAAY;AAGrC,EAAA,IAAI,QAAA,CAAS,SAAS,OAAO,CAAA,IAAK,SAAS,QAAA,CAAS,QAAQ,GAAG,OAAO,OAAA;AACtE,EAAA,IAAI,QAAA,CAAS,QAAA,CAAS,WAAW,CAAA,EAAG,OAAO,WAAA;AAC3C,EAAA,IAAI,QAAA,CAAS,QAAA,CAAS,QAAQ,CAAA,EAAG,OAAO,QAAA;AACxC,EAAA,IAAI,QAAA,CAAS,SAAS,UAAU,CAAA,IAAK,SAAS,QAAA,CAAS,SAAS,GAAG,OAAO,UAAA;AAC1E,EAAA,IAAI,QAAA,CAAS,SAAS,UAAU,CAAA,IAAK,SAAS,QAAA,CAAS,aAAa,GAAG,OAAO,UAAA;AAG9E,EAAA,IAAI,UAAA,CAAW,SAAS,OAAO,CAAA,IAAK,WAAW,QAAA,CAAS,SAAS,GAAG,OAAO,OAAA;AAC3E,EAAA,IAAI,UAAA,CAAW,QAAA,CAAS,WAAW,CAAA,EAAG,OAAO,WAAA;AAC7C,EAAA,IAAI,UAAA,CAAW,QAAA,CAAS,QAAQ,CAAA,EAAG,OAAO,QAAA;AAG1C,EAAA,MAAM,YAAA,GACJ,SAAS,IAAA,CAAK,CAAC,OAAO,EAAA,CAAG,IAAA,KAAS,WAAW,EAAA,CAAG,YAAA,KAAiB,aAAa,CAAA,IAC9E,QAAA,CAAS,KAAK,CAAC,EAAA,KAAO,GAAG,IAAA,KAAS,OAAA,IAAW,EAAA,CAAG,YAAA,KAAiB,gBAAgB,CAAA;AACnF,EAAA,IAAI,cAAc,OAAO,OAAA;AAEzB,EAAA,MAAM,iBAAiB,QAAA,CAAS,IAAA;AAAA,IAC9B,CAAC,EAAA,KAAO,EAAA,CAAG,IAAA,KAAS,OAAA,IAAW,GAAG,YAAA,KAAiB;AAAA,GACrD;AACA,EAAA,IAAI,gBAAgB,OAAO,QAAA;AAG3B,EAAA,MAAM,aAAa,QAAA,CAAS,MAAA;AAAA,IAC1B,CAAC,OAAO,EAAA,CAAG,IAAA,KAAS,WAAW,EAAA,CAAG,IAAA,KAAS,UAAA,IAAc,EAAA,CAAG,IAAA,KAAS;AAAA,GACvE,CAAE,MAAA;AACF,EAAA,IAAI,UAAA,IAAc,GAAG,OAAO,MAAA;AAG5B,EAAA,MAAM,WAAW,QAAA,CAAS,IAAA,CAAK,CAAC,EAAA,KAAO,EAAA,CAAG,YAAY,OAAO,CAAA;AAC7D,EAAA,MAAM,OAAA,GAAU,SAAS,MAAA,GAAS,EAAA;AAClC,EAAA,IAAI,QAAA,IAAY,SAAS,OAAO,MAAA;AAEhC,EAAA,OAAO,SAAA;AACT;;;AChiBA,IAAM,eAAA,GAAmC;AAAA;AAAA,EAEvC;AAAA,IACE,KAAA,EAAO,qDAAA;AAAA,IACP,MAAA,EAAQ,OAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,2CAAA;AAAA,IACP,MAAA,EAAQ,OAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,oCAAA;AAAA,IACP,MAAA,EAAQ,OAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,+BAAA;AAAA,IACP,MAAA,EAAQ,OAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA;AAAA,EAGA;AAAA,IACE,KAAA,EAAO,kDAAA;AAAA,IACP,MAAA,EAAQ,aAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA;AAAA,EAGA;AAAA,IACE,KAAA,EAAO,iDAAA;AAAA,IACP,MAAA,EAAQ,YAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,gDAAA;AAAA,IACP,MAAA,EAAQ,YAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA;AAAA,EAGA;AAAA,IACE,KAAA,EAAO,8DAAA;AAAA,IACP,MAAA,EAAQ,MAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY,CAAA;AAAA,IACZ,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,sDAAA;AAAA,IACP,MAAA,EAAQ,MAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY,CAAA;AAAA,IACZ,UAAA,EAAY;AAAA,GACd;AAAA;AAAA,EAGA;AAAA,IACE,KAAA,EAAO,+DAAA;AAAA,IACP,MAAA,EAAQ,MAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY,CAAA;AAAA,IACZ,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,uDAAA;AAAA,IACP,MAAA,EAAQ,MAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY,CAAA;AAAA,IACZ,UAAA,EAAY;AAAA,GACd;AAAA;AAAA,EAGA;AAAA,IACE,KAAA,EAAO,4DAAA;AAAA,IACP,MAAA,EAAQ,MAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY,CAAA;AAAA,IACZ,UAAA,EAAY;AAAA,GACd;AAAA;AAAA,EAGA;AAAA,IACE,KAAA,EAAO,6DAAA;AAAA,IACP,MAAA,EAAQ,MAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY,CAAA;AAAA,IACZ,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,oDAAA;AAAA,IACP,MAAA,EAAQ,MAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY,CAAA;AAAA,IACZ,UAAA,EAAY;AAAA,GACd;AAAA;AAAA,EAGA;AAAA,IACE,KAAA,EAAO,gDAAA;AAAA,IACP,MAAA,EAAQ,MAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY,CAAA;AAAA,IACZ,UAAA,EAAY;AAAA,GACd;AAAA;AAAA,EAGA;AAAA,IACE,KAAA,EAAO,2DAAA;AAAA,IACP,MAAA,EAAQ,QAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY,CAAA;AAAA,IACZ,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,2DAAA;AAAA,IACP,MAAA,EAAQ,QAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY,CAAA;AAAA,IACZ,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,yDAAA;AAAA,IACP,MAAA,EAAQ,QAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY,CAAA;AAAA,IACZ,UAAA,EAAY;AAAA,GACd;AAAA;AAAA,EAGA;AAAA,IACE,KAAA,EAAO,6CAAA;AAAA,IACP,MAAA,EAAQ,OAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,6BAAA;AAAA,IACP,MAAA,EAAQ,OAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,2BAAA;AAAA,IACP,MAAA,EAAQ,OAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA;AAAA,EAGA;AAAA,IACE,KAAA,EAAO,+CAAA;AAAA,IACP,MAAA,EAAQ,SAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,8BAAA;AAAA,IACP,MAAA,EAAQ,SAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,6BAAA;AAAA,IACP,MAAA,EAAQ,SAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA;AAAA,EAGA;AAAA,IACE,KAAA,EAAO,4BAAA;AAAA,IACP,MAAA,EAAQ,OAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,4BAAA;AAAA,IACP,MAAA,EAAQ,OAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,4BAAA;AAAA,IACP,MAAA,EAAQ,OAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA;AAAA,EAGA;AAAA,IACE,KAAA,EAAO,wCAAA;AAAA,IACP,MAAA,EAAQ,OAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,mCAAA;AAAA,IACP,MAAA,EAAQ,OAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA;AAAA,EAGA;AAAA,IACE,KAAA,EAAO,sCAAA;AAAA,IACP,MAAA,EAAQ,OAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA;AAAA,EAGA;AAAA,IACE,KAAA,EAAO,kCAAA;AAAA,IACP,MAAA,EAAQ,QAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,qDAAA;AAAA,IACP,MAAA,EAAQ,QAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,kCAAA;AAAA,IACP,MAAA,EAAQ,QAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA;AAAA,EAGA;AAAA,IACE,KAAA,EAAO,kEAAA;AAAA,IACP,MAAA,EAAQ,MAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EAAO,iEAAA;AAAA,IACP,MAAA,EAAQ,MAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA;AAAA,EAGA;AAAA,IACE,KAAA,EACE,mIAAA;AAAA,IACF,MAAA,EAAQ,QAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EACE,8FAAA;AAAA,IACF,MAAA,EAAQ,QAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY,CAAA;AAAA,IACZ,UAAA,EAAY;AAAA,GACd;AAAA,EACA;AAAA,IACE,KAAA,EACE,sGAAA;AAAA,IACF,MAAA,EAAQ,QAAA;AAAA,IACR,WAAA,EAAa,CAAA;AAAA,IACb,UAAA,EAAY;AAAA;AAEhB,CAAA;AAKA,IAAM,kBAAA,GAAoD;AAAA,EACxD,OAAA,EAAS,SAAA;AAAA,EACT,MAAA,EAAQ,QAAA;AAAA,EACR,OAAA,EAAS,SAAA;AAAA,EACT,QAAA,EAAU,UAAA;AAAA,EACV,OAAA,EAAS,SAAA;AAAA,EACT,SAAA,EAAW,WAAA;AAAA,EACX,OAAA,EAAS,SAAA;AAAA,EACT,QAAA,EAAU,cAAA;AAAA,EACV,GAAA,EAAK;AACP,CAAA;AAKO,SAAS,mBAAmB,WAAA,EAA0C;AAC3E,EAAA,MAAM,OAAA,GAAU,YAAY,IAAA,EAAK;AACjC,EAAA,IAAI,CAAC,SAAS,OAAO,IAAA;AAGrB,EAAA,KAAA,MAAW,WAAW,eAAA,EAAiB;AACrC,IAAA,MAAM,KAAA,GAAQ,OAAA,CAAQ,KAAA,CAAM,OAAA,CAAQ,KAAK,CAAA;AACzC,IAAA,IAAI,KAAA,EAAO;AACT,MAAA,MAAM,MAAA,GAAuB;AAAA,QAC3B,QAAQ,OAAA,CAAQ,MAAA;AAAA,QAChB,mBAAmB,sBAAA,CAAuB,KAAA,CAAM,OAAA,CAAQ,WAAW,KAAK,EAAE,CAAA;AAAA,QAC1E,cAAA,EAAgB,WAAA;AAAA,QAChB,iBAAiB,OAAA,CAAQ;AAAA,OAC3B;AAGA,MAAA,IAAI,OAAA,CAAQ,UAAA,IAAc,KAAA,CAAM,OAAA,CAAQ,UAAU,CAAA,EAAG;AACnD,QAAA,MAAA,CAAO,KAAA,GAAQ,KAAA,CAAM,OAAA,CAAQ,UAAU,CAAA;AAAA,MACzC;AAGA,MAAA,IAAI,QAAQ,iBAAA,EAAmB;AAC7B,QAAA,MAAA,CAAO,SAAA,GAAY,OAAA,CAAQ,iBAAA,CAAkB,KAAK,CAAA;AAAA,MACpD;AAGA,MAAA,IAAI,OAAA,CAAQ,WAAW,QAAA,EAAU;AAC/B,QAAA,MAAM,cAAA,GAAiB,OAAA,CAAQ,KAAA,CAAM,uBAAuB,CAAA;AAC5D,QAAA,IAAI,cAAA,EAAgB;AAClB,UAAA,MAAA,CAAO,eAAA,GACL,cAAA,CAAe,CAAC,CAAA,CAAE,WAAA,EAAY;AAAA,QAClC;AAAA,MACF;AAGA,MAAA,IAAI,OAAA,CAAQ,WAAW,QAAA,EAAU;AAC/B,QAAA,MAAM,cAAc,OAAA,CAAQ,KAAA;AAAA,UAC1B;AAAA,SACF;AACA,QAAA,IAAI,WAAA,EAAa;AACf,UAAA,MAAA,CAAO,gBAAgB,kBAAA,CAAmB,WAAA,CAAY,CAAC,CAAA,CAAE,aAAa,CAAA;AAAA,QACxE;AAAA,MACF;AAGA,MAAA,IAAI,OAAA,CAAQ,WAAW,MAAA,EAAQ;AAC7B,QAAA,MAAM,aAAA,GAAgB,MAAM,CAAC,CAAA;AAC7B,QAAA,IAAI,aAAA,EAAe;AACjB,UAAA,MAAA,CAAO,aAAA,GAAgB,aAAA;AAAA,QACzB;AAAA,MACF;AAEA,MAAA,OAAO,MAAA;AAAA,IACT;AAAA,EACF;AAGA,EAAA,OAAO,YAAY,OAAO,CAAA;AAC5B;AAKA,SAAS,uBAAuB,MAAA,EAAwB;AACtD,EAAA,OACE,MAAA,CACG,IAAA,EAAK,CAEL,OAAA,CAAQ,iBAAA,EAAmB,EAAE,CAAA,CAE7B,OAAA,CAAQ,wDAAA,EAA0D,EAAE,CAAA,CACpE,IAAA,EAAK;AAEZ;AAKA,SAAS,YAAY,WAAA,EAA0C;AAC7D,EAAA,MAAM,KAAA,GAAQ,YAAY,WAAA,EAAY;AAGtC,EAAA,IAAI,KAAA,CAAM,QAAA,CAAS,OAAO,CAAA,IAAK,KAAA,CAAM,QAAA,CAAS,OAAO,CAAA,IAAK,KAAA,CAAM,QAAA,CAAS,KAAK,CAAA,EAAG;AAC/E,IAAA,MAAM,SAAS,WAAA,CAAY,OAAA,CAAQ,0BAAA,EAA4B,EAAE,EAAE,IAAA,EAAK;AACxE,IAAA,IAAI,MAAA,EAAQ;AACV,MAAA,OAAO;AAAA,QACL,MAAA,EAAQ,OAAA;AAAA,QACR,iBAAA,EAAmB,uBAAuB,MAAM,CAAA;AAAA,QAChD,cAAA,EAAgB,WAAA;AAAA,QAChB,eAAA,EAAiB;AAAA,OACnB;AAAA,IACF;AAAA,EACF;AAGA,EAAA,IAAI,KAAA,CAAM,QAAA,CAAS,MAAM,CAAA,IAAK,KAAA,CAAM,QAAA,CAAS,OAAO,CAAA,IAAK,KAAA,CAAM,QAAA,CAAS,OAAO,CAAA,EAAG;AAEhF,IAAA,MAAM,WAAA,GAAc,WAAA,CAAY,KAAA,CAAM,eAAe,CAAA;AACrD,IAAA,IAAI,WAAA,EAAa;AACf,MAAA,MAAM,SAAS,WAAA,CAAY,OAAA,CAAQ,4CAAA,EAA8C,EAAE,EAAE,IAAA,EAAK;AAC1F,MAAA,OAAO;AAAA,QACL,MAAA,EAAQ,MAAA;AAAA,QACR,iBAAA,EAAmB,uBAAuB,MAAM,CAAA;AAAA,QAChD,KAAA,EAAO,YAAY,CAAC,CAAA;AAAA,QACpB,cAAA,EAAgB,WAAA;AAAA,QAChB,eAAA,EAAiB;AAAA,OACnB;AAAA,IACF;AAAA,EACF;AAGA,EAAA,OAAO,IAAA;AACT;AA4DO,SAAS,qBAAqB,MAAA,EAA4D;AAC/F,EAAA,MAAM,SAAmB,EAAC;AAE1B,EAAA,IAAI,CAAC,MAAA,CAAO,iBAAA,IAAqB,MAAA,CAAO,WAAW,QAAA,EAAU;AAC3D,IAAA,MAAA,CAAO,KAAK,6BAA6B,CAAA;AAAA,EAC3C;AAEA,EAAA,IAAA,CAAK,MAAA,CAAO,WAAW,MAAA,IAAU,MAAA,CAAO,WAAW,QAAA,KAAa,CAAC,OAAO,KAAA,EAAO;AAC7E,IAAA,MAAA,CAAO,IAAA,CAAK,CAAA,uBAAA,EAA0B,MAAA,CAAO,MAAM,CAAA,OAAA,CAAS,CAAA;AAAA,EAC9D;AAEA,EAAA,IAAI,MAAA,CAAO,kBAAkB,GAAA,EAAK;AAChC,IAAA,MAAA,CAAO,KAAK,uDAAuD,CAAA;AAAA,EACrE;AAEA,EAAA,OAAO;AAAA,IACL,KAAA,EAAO,OAAO,MAAA,KAAW,CAAA;AAAA,IACzB;AAAA,GACF;AACF;AAKO,SAAS,eAAe,MAAA,EAA8B;AAC3D,EAAA,QAAQ,OAAO,MAAA;AAAQ,IACrB,KAAK,OAAA;AACH,MAAA,OAAO,CAAA,UAAA,EAAa,OAAO,iBAAiB,CAAA,CAAA,CAAA;AAAA,IAC9C,KAAK,aAAA;AACH,MAAA,OAAO,CAAA,iBAAA,EAAoB,OAAO,iBAAiB,CAAA,CAAA,CAAA;AAAA,IACrD,KAAK,YAAA;AACH,MAAA,OAAO,CAAA,gBAAA,EAAmB,OAAO,iBAAiB,CAAA,CAAA,CAAA;AAAA,IACpD,KAAK,MAAA;AACH,MAAA,OAAO,CAAA,MAAA,EAAS,MAAA,CAAO,KAAK,CAAA,QAAA,EAAW,OAAO,iBAAiB,CAAA,CAAA,CAAA;AAAA,IACjE,KAAK,QAAA;AACH,MAAA,OAAO,CAAA,QAAA,EAAW,MAAA,CAAO,KAAK,CAAA,QAAA,EAAW,OAAO,iBAAiB,CAAA,CAAA,CAAA;AAAA,IACnE,KAAK,OAAA;AACH,MAAA,OAAO,CAAA,OAAA,EAAU,OAAO,iBAAiB,CAAA,CAAA,CAAA;AAAA,IAC3C,KAAK,SAAA;AACH,MAAA,OAAO,CAAA,SAAA,EAAY,OAAO,iBAAiB,CAAA,CAAA,CAAA;AAAA,IAC7C,KAAK,OAAA;AACH,MAAA,OAAO,CAAA,OAAA,EAAU,OAAO,iBAAiB,CAAA,CAAA,CAAA;AAAA,IAC3C,KAAK,OAAA;AACH,MAAA,OAAO,CAAA,YAAA,EAAe,OAAO,iBAAiB,CAAA,CAAA,CAAA;AAAA,IAChD,KAAK,OAAA;AACH,MAAA,OAAO,CAAA,UAAA,EAAa,OAAO,iBAAiB,CAAA,CAAA,CAAA;AAAA,IAC9C,KAAK,QAAA;AACH,MAAA,IAAI,OAAO,eAAA,EAAiB;AAC1B,QAAA,OAAO,CAAA,OAAA,EAAU,OAAO,eAAe,CAAA,CAAA;AAAA,MACzC;AACA,MAAA,OAAO,CAAA,WAAA,EAAc,OAAO,iBAAiB,CAAA,CAAA,CAAA;AAAA,IAC/C,KAAK,MAAA;AACH,MAAA,OAAO,CAAA,UAAA,EAAa,MAAA,CAAO,iBAAiB,CAAA,CAAA,EAAI,MAAA,CAAO,gBAAgB,CAAA,OAAA,EAAU,MAAA,CAAO,aAAa,CAAA,CAAA,GAAK,EAAE,CAAA,CAAA;AAAA,IAC9G,KAAK,QAAA;AACH,MAAA,OAAO,WAAW,MAAA,CAAO,iBAAiB,CAAA,KAAA,EAAQ,MAAA,CAAO,iBAAiB,OAAO,CAAA,CAAA;AAAA,IACnF;AACE,MAAA,OAAO,CAAA,EAAG,MAAA,CAAO,MAAM,CAAA,KAAA,EAAQ,OAAO,iBAAiB,CAAA,CAAA,CAAA;AAAA;AAE7D;;;ACnhBA,SAAS,gBAAgB,EAAA,EAA0C;AACjE,EAAA,IAAI,OAAA,IAAW,EAAA,IAAM,EAAA,CAAG,KAAA,EAAO;AAC7B,IAAA,OAAO,EAAA,CAAG,KAAA;AAAA,EACZ;AACA,EAAA,IAAI,UAAA,IAAc,EAAA,IAAM,OAAO,EAAA,CAAG,aAAa,UAAA,EAAY;AACzD,IAAA,IAAI;AACF,MAAA,OAAO,GAAG,QAAA,EAAS;AAAA,IACrB,CAAA,CAAA,MAAQ;AACN,MAAA,OAAO,MAAA;AAAA,IACT;AAAA,EACF;AACA,EAAA,OAAO,MAAA;AACT;AAwCA,IAAM,cAAA,GAA4C;AAAA,EAChD,WAAA,EAAa,kDAAA;AAAA,EACb,gBAAA,EAAkB,qCAAA;AAAA,EAClB,iBAAA,EAAmB,oDAAA;AAAA,EACnB,mBAAA,EAAqB,uCAAA;AAAA,EACrB,gBAAA,EAAkB,uDAAA;AAAA,EAClB,eAAA,EAAiB,2CAAA;AAAA,EACjB,iBAAA,EAAmB,yCAAA;AAAA,EACnB,cAAA,EAAgB,mCAAA;AAAA,EAChB,eAAA,EAAiB,iDAAA;AAAA,EACjB,aAAA,EAAe,mCAAA;AAAA,EACf,cAAA,EAAgB,8CAAA;AAAA,EAChB,kBAAA,EAAoB,uCAAA;AAAA,EACpB,gBAAA,EAAkB,uCAAA;AAAA,EAClB,aAAA,EAAe,8CAAA;AAAA,EACf,eAAA,EAAiB,mCAAA;AAAA,EACjB,gBAAA,EAAkB;AACpB,CAAA;AAKA,IAAM,iBAAA,GAA6D;AAAA,EACjE,WAAA,EAAa;AAAA,IACX;AAAA,MACE,MAAA,EAAQ,6DAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,gDAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA;AACZ,GACF;AAAA,EACA,gBAAA,EAAkB;AAAA,IAChB;AAAA,MACE,MAAA,EAAQ,4CAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,8BAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA;AACZ,GACF;AAAA,EACA,iBAAA,EAAmB;AAAA,IACjB;AAAA,MACE,MAAA,EAAQ,iCAAA;AAAA,MACR,OAAA,EAAS,uBAAA;AAAA,MACT,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,6CAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,uCAAA;AAAA,MACR,OAAA,EAAS,aAAA;AAAA,MACT,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA;AACZ,GACF;AAAA,EACA,mBAAA,EAAqB;AAAA,IACnB;AAAA,MACE,MAAA,EAAQ,oCAAA;AAAA,MACR,OAAA,EAAS,mBAAA;AAAA,MACT,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,+BAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,8BAAA;AAAA,MACR,OAAA,EAAS,kBAAA;AAAA,MACT,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA;AACZ,GACF;AAAA,EACA,gBAAA,EAAkB;AAAA,IAChB;AAAA,MACE,MAAA,EAAQ,+BAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,6BAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,wCAAA;AAAA,MACR,OAAA,EAAS,gCAAA;AAAA,MACT,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA;AACZ,GACF;AAAA,EACA,eAAA,EAAiB;AAAA,IACf;AAAA,MACE,MAAA,EAAQ,0BAAA;AAAA,MACR,OAAA,EAAS,oBAAA;AAAA,MACT,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,qBAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,4CAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA;AACZ,GACF;AAAA,EACA,iBAAA,EAAmB;AAAA,IACjB;AAAA,MACE,MAAA,EAAQ,iCAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,oDAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,6BAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA;AACZ,GACF;AAAA,EACA,cAAA,EAAgB;AAAA,IACd;AAAA,MACE,MAAA,EAAQ,yCAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,wDAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,6CAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA;AACZ,GACF;AAAA,EACA,eAAA,EAAiB;AAAA,IACf;AAAA,MACE,MAAA,EAAQ,+CAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,kCAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA;AACZ,GACF;AAAA,EACA,aAAA,EAAe;AAAA,IACb;AAAA,MACE,MAAA,EAAQ,sCAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,2BAAA;AAAA,MACR,OAAA,EAAS,0BAAA;AAAA,MACT,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA;AACZ,GACF;AAAA,EACA,cAAA,EAAgB;AAAA,IACd;AAAA,MACE,MAAA,EAAQ,+BAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,wCAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA;AACZ,GACF;AAAA,EACA,kBAAA,EAAoB;AAAA,IAClB;AAAA,MACE,MAAA,EAAQ,6BAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,iCAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA;AACZ,GACF;AAAA,EACA,gBAAA,EAAkB;AAAA,IAChB;AAAA,MACE,MAAA,EAAQ,wBAAA;AAAA,MACR,OAAA,EAAS,SAAA;AAAA,MACT,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,6BAAA;AAAA,MACR,OAAA,EAAS,gBAAA;AAAA,MACT,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA;AACZ,GACF;AAAA,EACA,aAAA,EAAe;AAAA,IACb;AAAA,MACE,MAAA,EAAQ,qBAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,4BAAA;AAAA,MACR,OAAA,EAAS,eAAA;AAAA,MACT,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA;AACZ,GACF;AAAA,EACA,eAAA,EAAiB;AAAA,IACf;AAAA,MACE,MAAA,EAAQ,kBAAA;AAAA,MACR,OAAA,EAAS,cAAA;AAAA,MACT,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,4BAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA;AACZ,GACF;AAAA,EACA,gBAAA,EAAkB;AAAA,IAChB;AAAA,MACE,MAAA,EAAQ,0BAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACZ;AAAA,IACA;AAAA,MACE,MAAA,EAAQ,6BAAA;AAAA,MACR,UAAA,EAAY,GAAA;AAAA,MACZ,QAAA,EAAU;AAAA;AACZ;AAEJ,CAAA;AAKO,SAAS,kBAAA,CACd,SAAA,EACA,eAAA,EACA,iBAAA,EACA,gBACA,YAAA,EACgB;AAEhB,EAAA,MAAM,OAAA,GAAU,cAAA,CAAe,SAAS,CAAA,IAAK,2BAAA;AAC7C,EAAA,MAAM,eAAA,GAAkB,iBAAA,CAAkB,SAAS,CAAA,IAAK,EAAC;AAGzD,EAAA,MAAM,gBAAA,GAAmB,uBAAuB,iBAAiB,CAAA;AAGjE,EAAA,MAAM,eAAA,GAAkB,iBAAA,CAAkB,MAAA,CAAO,CAAC,EAAA,KAAO;AACvD,IAAA,MAAM,KAAA,GAAQ,gBAAgB,EAAE,CAAA;AAChC,IAAA,OAAO,OAAO,OAAA,IAAW,KAAA;AAAA,EAC3B,CAAC,CAAA,CAAE,MAAA;AAGH,EAAA,MAAM,WAAA,GAAc,kBAAA;AAAA,IAClB,eAAA;AAAA,IACA,SAAA;AAAA,IACA,YAAA;AAAA,IACA;AAAA,GACF;AAEA,EAAA,OAAO;AAAA,IACL,IAAA,EAAM,SAAA;AAAA,IACN,OAAA;AAAA,IACA,eAAA;AAAA,IACA,cAAA;AAAA,IACA,aAAA,EAAe;AAAA,MACb,iBAAiB,iBAAA,CAAkB,MAAA;AAAA,MACnC,cAAc,YAAA,GACV;AAAA,QACE,SAAS,YAAA,CAAa,OAAA;AAAA,QACtB,YAAY,YAAA,CAAa,UAAA;AAAA,QACzB,cAAA,EAAgB,uBAAA,CAAwB,SAAA,EAAW,YAAY;AAAA,OACjE,GACA;AAAA,KACN;AAAA,IACA,WAAA,EAAa;AAAA,MACX,KAAK,OAAO,MAAA,KAAW,WAAA,GAAc,MAAA,CAAO,SAAS,IAAA,GAAO,EAAA;AAAA,MAC5D,KAAA,EAAO,OAAO,QAAA,KAAa,WAAA,GAAc,SAAS,KAAA,GAAQ,EAAA;AAAA,MAC1D,eAAA;AAAA,MACA;AAAA,KACF;AAAA,IACA,WAAA;AAAA,IACA,SAAA,EAAW,KAAK,GAAA;AAAI,GACtB;AACF;AAKA,SAAS,uBAAuB,QAAA,EAAkC;AAChE,EAAA,MAAM,WAAqB,EAAC;AAE5B,EAAA,KAAA,MAAW,MAAM,QAAA,EAAU;AACzB,IAAA,MAAM,KAAA,GAAQ,gBAAgB,EAAE,CAAA;AAChC,IAAA,IAAI,CAAC,KAAA,EAAO;AAGZ,IAAA,IAAI,EAAA,CAAG,IAAA,KAAS,QAAA,IAAY,KAAA,CAAM,OAAA,EAAS;AACzC,MAAA,QAAA,CAAS,IAAA,CAAK,CAAA,cAAA,EAAiB,EAAA,CAAG,EAAE,CAAA,CAAE,CAAA;AAAA,IACxC;AAGA,IAAA,IAAI,KAAA,CAAM,cAAA,EAAgB,aAAA,KAAkB,MAAA,EAAQ;AAClD,MAAA;AAAA,IACF;AAAA,EAGF;AAEA,EAAA,OAAO,QAAA;AACT;AAKA,SAAS,kBAAA,CACP,eAAA,EACA,SAAA,EACA,YAAA,EACA,gBAAA,EACsB;AACtB,EAAA,MAAM,WAAA,GAAc,CAAC,GAAG,eAAe,CAAA;AAGvC,EAAA,IAAI,gBAAA,IAAoB,gBAAA,CAAiB,MAAA,GAAS,CAAA,EAAG;AACnD,IAAA,WAAA,CAAY,OAAA,CAAQ;AAAA,MAClB,MAAA,EAAQ,CAAA,4BAAA,EAA+B,gBAAA,CAAiB,CAAC,CAAC,CAAA,CAAA;AAAA,MAC1D,OAAA,EAAS,oBAAA;AAAA,MACT,UAAA,EAAY,IAAA;AAAA,MACZ,QAAA,EAAU;AAAA,KACX,CAAA;AAAA,EACH;AAGA,EAAA,IAAI,YAAA,IAAgB,cAAc,gBAAA,EAAkB;AAClD,IAAA,WAAA,CAAY,OAAA,CAAQ;AAAA,MAClB,MAAA,EAAQ,CAAA,eAAA,EAAkB,YAAA,CAAa,OAAA,CAAQ,WAAW,CAAA,EAAA,CAAA;AAAA,MAC1D,OAAA,EAAS,CAAA,OAAA,EAAU,YAAA,CAAa,OAAA,CAAQ,WAAW,CAAA,CAAA,CAAA;AAAA,MACnD,YAAY,YAAA,CAAa,UAAA;AAAA,MACzB,QAAA,EAAU;AAAA,KACX,CAAA;AAAA,EACH;AAGA,EAAA,WAAA,CAAY,KAAK,CAAC,CAAA,EAAG,MAAM,CAAA,CAAE,QAAA,GAAW,EAAE,QAAQ,CAAA;AAElD,EAAA,OAAO,WAAA;AACT;AAKA,SAAS,uBAAA,CAAwB,WAAsB,YAAA,EAAoC;AACzF,EAAA,QAAQ,SAAA;AAAW,IACjB,KAAK,gBAAA;AACH,MAAA,OAAO,gBAAgB,YAAA,CAAa,UAAA,GAAa,GAAA,EAAK,OAAA,CAAQ,CAAC,CAAC,CAAA,kBAAA,CAAA;AAAA,IAElE,KAAK,qBAAA;AACH,MAAA,OAAO,wBAAA;AAAA,IAET,KAAK,kBAAA;AACH,MAAA,OAAO,qBAAA;AAAA,IAET,KAAK,iBAAA;AACH,MAAA,OAAO,2CAAA;AAAA,IAET;AACE,MAAA,OAAO,iCAAA;AAAA;AAEb;;;ACnbO,IAAM,uBAAA,GAAkD;AAAA,EAC7D,0BAAA,EAA4B,GAAA;AAAA,EAC5B,cAAA,EAAgB,GAAA;AAAA,EAChB,eAAA,EAAiB,CAAA;AAAA,EACjB,OAAA,EAAS;AACX,CAAA;AAKO,IAAM,mBAAN,MAAuB;AAAA,EAM5B,WAAA,CAAY,MAAA,GAA0C,EAAC,EAAG;AAH1D,IAAA,IAAA,CAAQ,cAAA,GAAwC,IAAA;AAChD,IAAA,IAAA,CAAQ,WAAyD,EAAC;AAGhE,IAAA,IAAA,CAAK,MAAA,GAAS,EAAE,GAAG,uBAAA,EAAyB,GAAG,MAAA,EAAO;AACtD,IAAA,IAAA,CAAK,YAAA,GAAe,IAAI,YAAA,CAAa,IAAA,CAAK,OAAO,YAAY,CAAA;AAAA,EAC/D;AAAA;AAAA;AAAA;AAAA,EAKA,kBAAkB,QAAA,EAAgC;AAChD,IAAA,IAAA,CAAK,cAAA,GAAiB,QAAA;AAAA,EACxB;AAAA;AAAA;AAAA;AAAA,EAKA,eAAe,QAAA,EAA8D;AAC3E,IAAA,IAAA,CAAK,QAAA,GAAW,QAAA;AAChB,IAAA,IAAA,CAAK,YAAA,CAAa,eAAe,QAAQ,CAAA;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,QAAQ,OAAA,EAAqD;AACjE,IAAA,MAAM,SAAA,GAAY,YAAY,GAAA,EAAI;AAClC,IAAA,MAAM,SAAA,GAAY,OAAA,CAAQ,mBAAA,IAAuB,IAAA,CAAK,MAAA,CAAO,0BAAA;AAG7D,IAAA,MAAM,MAAA,GAAS,kBAAA,CAAmB,OAAA,CAAQ,WAAW,CAAA;AAErD,IAAA,IAAI,CAAC,MAAA,EAAQ;AACX,MAAA,OAAO,IAAA,CAAK,qBAAA;AAAA,QACV,SAAA;AAAA,QACA,aAAA;AAAA,QACA,CAAA,8BAAA,EAAiC,QAAQ,WAAW,CAAA,CAAA,CAAA;AAAA,QACpD,OAAA,CAAQ,WAAA;AAAA,QACR,EAAC;AAAA,QACD;AAAA,OACF;AAAA,IACF;AAGA,IAAA,MAAM,UAAA,GAAa,qBAAqB,MAAM,CAAA;AAC9C,IAAA,IAAI,CAAC,WAAW,KAAA,EAAO;AACrB,MAAA,OAAO,IAAA,CAAK,qBAAA;AAAA,QACV,SAAA;AAAA,QACA,kBAAA;AAAA,QACA,UAAA,CAAW,MAAA,CAAO,IAAA,CAAK,IAAI,CAAA;AAAA,QAC3B,OAAA,CAAQ,WAAA;AAAA,QACR,EAAC;AAAA,QACD;AAAA,OACF;AAAA,IACF;AAGA,IAAA,MAAM,cAAA,GAAiB,IAAA,CAAK,mBAAA,CAAoB,MAAM,CAAA;AAGtD,IAAA,MAAM,cAAA,GAAiB,IAAA,CAAK,YAAA,CAAa,MAAA,CAAO,cAAc,CAAA;AAE9D,IAAA,IAAI,CAAC,eAAe,SAAA,EAAW;AAC7B,MAAA,OAAO,IAAA,CAAK,qBAAA;AAAA,QACV,SAAA;AAAA,QACA,mBAAA;AAAA,QACA,CAAA,kCAAA,EAAqC,OAAO,iBAAiB,CAAA,CAAA,CAAA;AAAA,QAC7D,OAAA,CAAQ,WAAA;AAAA,QACR,cAAA,CAAe,OAAA;AAAA,QACf,SAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF;AAGA,IAAA,IAAI,cAAA,CAAe,SAAA,CAAU,UAAA,GAAa,SAAA,EAAW;AACnD,MAAA,MAAM,eAAe,cAAA,CAAe,OAAA,CAAQ,MAAM,CAAA,EAAG,IAAA,CAAK,OAAO,eAAe,CAAA;AAChF,MAAA,OAAO,IAAA,CAAK,qBAAA;AAAA,QACV,SAAA;AAAA,QACA,gBAAA;AAAA,QACA,CAAA,uBAAA,EAAA,CAA2B,cAAA,CAAe,SAAA,CAAU,UAAA,GAAa,GAAA,EAAK,OAAA,CAAQ,CAAC,CAAC,CAAA,uBAAA,EAAA,CAA2B,SAAA,GAAY,GAAA,EAAK,OAAA,CAAQ,CAAC,CAAC,CAAA,EAAA,CAAA;AAAA,QACtI,OAAA,CAAQ,WAAA;AAAA,QACR,YAAA;AAAA,QACA,SAAA;AAAA,QACA,cAAA;AAAA,QACA,cAAA,CAAe;AAAA,OACjB;AAAA,IACF;AAGA,IAAA,IAAI;AACF,MAAA,MAAM,MAAA,GAAS,MAAM,IAAA,CAAK,aAAA;AAAA,QACxB,MAAA;AAAA,QACA,eAAe,SAAA,CAAU,OAAA;AAAA,QACzB,OAAA,CAAQ,OAAA,IAAW,IAAA,CAAK,MAAA,CAAO;AAAA,OACjC;AAEA,MAAA,OAAO;AAAA,QACL,OAAA,EAAS,IAAA;AAAA,QACT,cAAA,EAAgB,eAAe,MAAM,CAAA;AAAA,QACrC,WAAA,EAAa,eAAe,SAAA,CAAU,OAAA;AAAA,QACtC,UAAA,EAAY,eAAe,SAAA,CAAU,UAAA;AAAA,QACrC,cAAc,MAAA,CAAO,YAAA;AAAA,QACrB,UAAA,EAAY,WAAA,CAAY,GAAA,EAAI,GAAI,SAAA;AAAA,QAChC,SAAA,EAAW,KAAK,GAAA;AAAI,OACtB;AAAA,IACF,SAASC,MAAAA,EAAO;AACd,MAAA,MAAM,eAAeA,MAAAA,YAAiB,KAAA,GAAQA,MAAAA,CAAM,OAAA,GAAU,OAAOA,MAAK,CAAA;AAC1E,MAAA,MAAM,YAAA,GAAe,cAAA,CAAe,OAAA,CACjC,MAAA,CAAO,CAAC,CAAA,KAAM,CAAA,KAAM,cAAA,CAAe,SAAS,CAAA,CAC5C,KAAA,CAAM,CAAA,EAAG,IAAA,CAAK,OAAO,eAAe,CAAA;AAEvC,MAAA,OAAO,IAAA,CAAK,qBAAA;AAAA,QACV,SAAA;AAAA,QACA,eAAA;AAAA,QACA,YAAA;AAAA,QACA,OAAA,CAAQ,WAAA;AAAA,QACR,YAAA;AAAA,QACA,SAAA;AAAA,QACA,cAAA;AAAA,QACA,cAAA,CAAe;AAAA,OACjB;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,aAAA,CAAc,MAAA,EAAsB,SAAA,EAA+C;AACvF,IAAA,MAAM,SAAA,GAAY,YAAY,GAAA,EAAI;AAClC,IAAA,MAAM,mBAAA,GAAsB,SAAA,IAAa,IAAA,CAAK,MAAA,CAAO,0BAAA;AAGrD,IAAA,MAAM,cAAA,GAAiB,IAAA,CAAK,mBAAA,CAAoB,MAAM,CAAA;AAGtD,IAAA,MAAM,cAAA,GAAiB,IAAA,CAAK,YAAA,CAAa,MAAA,CAAO,cAAc,CAAA;AAE9D,IAAA,IAAI,CAAC,eAAe,SAAA,EAAW;AAC7B,MAAA,OAAO,IAAA,CAAK,qBAAA;AAAA,QACV,SAAA;AAAA,QACA,mBAAA;AAAA,QACA,CAAA,yBAAA,EAA4B,OAAO,iBAAiB,CAAA,CAAA,CAAA;AAAA,QACpD,MAAA,CAAO,cAAA;AAAA,QACP,EAAC;AAAA,QACD,mBAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF;AAEA,IAAA,IAAI,cAAA,CAAe,SAAA,CAAU,UAAA,GAAa,mBAAA,EAAqB;AAC7D,MAAA,OAAO,IAAA,CAAK,qBAAA;AAAA,QACV,SAAA;AAAA,QACA,gBAAA;AAAA,QACA,CAAA,6BAAA,CAAA;AAAA,QACA,MAAA,CAAO,cAAA;AAAA,QACP,eAAe,OAAA,CAAQ,KAAA,CAAM,CAAA,EAAG,IAAA,CAAK,OAAO,eAAe,CAAA;AAAA,QAC3D,mBAAA;AAAA,QACA,cAAA;AAAA,QACA,cAAA,CAAe;AAAA,OACjB;AAAA,IACF;AAGA,IAAA,IAAI;AACF,MAAA,MAAM,MAAA,GAAS,MAAM,IAAA,CAAK,aAAA;AAAA,QACxB,MAAA;AAAA,QACA,eAAe,SAAA,CAAU,OAAA;AAAA,QACzB,KAAK,MAAA,CAAO;AAAA,OACd;AAEA,MAAA,OAAO;AAAA,QACL,OAAA,EAAS,IAAA;AAAA,QACT,cAAA,EAAgB,eAAe,MAAM,CAAA;AAAA,QACrC,WAAA,EAAa,eAAe,SAAA,CAAU,OAAA;AAAA,QACtC,UAAA,EAAY,eAAe,SAAA,CAAU,UAAA;AAAA,QACrC,cAAc,MAAA,CAAO,YAAA;AAAA,QACrB,UAAA,EAAY,WAAA,CAAY,GAAA,EAAI,GAAI,SAAA;AAAA,QAChC,SAAA,EAAW,KAAK,GAAA;AAAI,OACtB;AAAA,IACF,SAASA,MAAAA,EAAO;AACd,MAAA,OAAO,IAAA,CAAK,qBAAA;AAAA,QACV,SAAA;AAAA,QACA,eAAA;AAAA,QACAA,MAAAA,YAAiB,KAAA,GAAQA,MAAAA,CAAM,OAAA,GAAU,OAAOA,MAAK,CAAA;AAAA,QACrD,MAAA,CAAO,cAAA;AAAA,QACP,cAAA,CAAe,OAAA,CACZ,MAAA,CAAO,CAAC,CAAA,KAAM,CAAA,KAAM,cAAA,CAAe,SAAS,CAAA,CAC5C,KAAA,CAAM,CAAA,EAAG,IAAA,CAAK,OAAO,eAAe,CAAA;AAAA,QACvC,mBAAA;AAAA,QACA,cAAA;AAAA,QACA,cAAA,CAAe;AAAA,OACjB;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,oBAAoB,MAAA,EAAsC;AAChE,IAAA,MAAM,QAAA,GAA2B;AAAA,MAC/B,MAAM,MAAA,CAAO,iBAAA;AAAA,MACb,KAAA,EAAO,IAAA;AAAA,MACP,cAAA,EAAgB,KAAK,MAAA,CAAO;AAAA,KAC9B;AAGA,IAAA,QAAQ,OAAO,MAAA;AAAQ,MACrB,KAAK,OAAA;AAAA,MACL,KAAK,aAAA;AAAA,MACL,KAAK,YAAA;AAEH,QAAA;AAAA,MACF,KAAK,MAAA;AAAA,MACL,KAAK,OAAA;AAEH,QAAA,QAAA,CAAS,IAAA,GAAO,OAAA;AAChB,QAAA;AAAA,MACF,KAAK,QAAA;AACH,QAAA,QAAA,CAAS,IAAA,GAAO,QAAA;AAChB,QAAA;AAAA,MACF,KAAK,OAAA;AAAA,MACL,KAAK,SAAA;AACH,QAAA,QAAA,CAAS,IAAA,GAAO,UAAA;AAChB,QAAA;AAAA;AAGJ,IAAA,OAAO,QAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,MAAc,aAAA,CACZ,MAAA,EACA,OAAA,EACA,OAAA,EACyC;AACzC,IAAA,IAAI,CAAC,KAAK,cAAA,EAAgB;AACxB,MAAA,MAAM,IAAI,MAAM,+BAA+B,CAAA;AAAA,IACjD;AAGA,IAAA,MAAM,SAAA,GAAmE;AAAA,MACvE,KAAA,EAAO,OAAA;AAAA,MACP,WAAA,EAAa,aAAA;AAAA,MACb,UAAA,EAAY,YAAA;AAAA,MACZ,IAAA,EAAM,MAAA;AAAA,MACN,MAAA,EAAQ,QAAA;AAAA,MACR,KAAA,EAAO,OAAA;AAAA,MACP,OAAA,EAAS,SAAA;AAAA,MACT,MAAA,EAAQ,QAAA;AAAA,MACR,IAAA,EAAM,IAAA;AAAA;AAAA,MACN,MAAA,EAAQ,IAAA;AAAA;AAAA,MACR,KAAA,EAAO,OAAA;AAAA,MACP,KAAA,EAAO,OAAA;AAAA,MACP,KAAA,EAAO;AAAA,KACT;AAEA,IAAA,MAAM,cAAA,GAAiB,SAAA,CAAU,MAAA,CAAO,MAAM,CAAA;AAE9C,IAAA,IAAI,CAAC,cAAA,EAAgB;AAEnB,MAAA,IAAI,MAAA,CAAO,WAAW,MAAA,EAAQ;AAC5B,QAAA,MAAM,aAAa,MAAM,IAAA,CAAK,cAAA,CAAe,OAAA,CAAQ,QAAQ,EAAA,EAAI;AAAA,UAC/D,OAAA,EAAS,IAAA;AAAA,UACT;AAAA,SACD,CAAA;AACD,QAAA,IAAI,CAAC,WAAW,GAAA,EAAK;AACnB,UAAA,MAAM,IAAI,KAAA,CAAM,UAAA,CAAW,KAAA,IAAS,wBAAwB,CAAA;AAAA,QAC9D;AACA,QAAA,OAAO,EAAE,YAAA,EAAc,UAAA,CAAW,KAAA,EAAO;AAAA,MAC3C;AAEA,MAAA,IAAI,MAAA,CAAO,WAAW,QAAA,EAAU;AAE9B,QAAA,MAAM,IAAI,MAAM,8CAA8C,CAAA;AAAA,MAChE;AAEA,MAAA,MAAM,IAAI,KAAA,CAAM,CAAA,oBAAA,EAAuB,MAAA,CAAO,MAAM,CAAA,CAAE,CAAA;AAAA,IACxD;AAGA,IAAA,MAAM,aAAA,GAIF;AAAA,MACF,MAAA,EAAQ,cAAA;AAAA,MACR,WAAA,EAAa;AAAA,QACX,OAAA,EAAS,IAAA;AAAA,QACT,OAAA,EAAS,IAAA;AAAA,QACT;AAAA;AACF,KACF;AAGA,IAAA,IAAI,cAAA,KAAmB,MAAA,IAAU,MAAA,CAAO,KAAA,EAAO;AAC7C,MAAA,aAAA,CAAc,MAAA,GAAS,EAAE,IAAA,EAAM,MAAA,CAAO,KAAA,EAAM;AAAA,IAC9C,CAAA,MAAA,IAAW,cAAA,KAAmB,QAAA,IAAY,MAAA,CAAO,KAAA,EAAO;AACtD,MAAA,aAAA,CAAc,MAAA,GAAS,EAAE,KAAA,EAAO,MAAA,CAAO,KAAA,EAAM;AAAA,IAC/C,CAAA,MAAA,IAAW,cAAA,KAAmB,QAAA,IAAY,MAAA,CAAO,eAAA,EAAiB;AAChE,MAAA,aAAA,CAAc,MAAA,GAAS,EAAE,SAAA,EAAW,MAAA,CAAO,eAAA,EAAgB;AAAA,IAC7D;AAGA,IAAA,MAAM,WAAW,MAAM,IAAA,CAAK,eAAe,aAAA,CAAc,OAAA,CAAQ,IAAI,aAAa,CAAA;AAElF,IAAA,IAAI,CAAC,SAAS,OAAA,EAAS;AACrB,MAAA,MAAM,IAAI,KAAA,CAAM,QAAA,CAAS,KAAA,IAAS,eAAe,CAAA;AAAA,IACnD;AAEA,IAAA,OAAO,EAAE,YAAA,EAAc,QAAA,CAAS,YAAA,EAAc;AAAA,EAChD;AAAA;AAAA;AAAA;AAAA,EAKQ,qBAAA,CACN,WACA,SAAA,EACA,YAAA,EACA,aACA,YAAA,EACA,SAAA,EACA,gBACA,YAAA,EACkB;AAElB,IAAA,MAAM,cAAc,IAAA,CAAK,mBAAA;AAAA,MACvB,SAAA;AAAA,MACA,WAAA;AAAA,MACA,YAAA;AAAA,MACA;AAAA,KACF;AAGA,IAAA,MAAM,YAAA,GAAoC,cAAc,OAAA,IAAW;AAAA,MACjE,EAAA,EAAI,WAAA;AAAA,MACJ,IAAA,EAAM,SAAA;AAAA,MACN,OAAA,EAAS,SAAA;AAAA,MACT,SAAS,EAAC;AAAA,MACV,KAAA,EAAO;AAAA,QACL,OAAA,EAAS,KAAA;AAAA,QACT,OAAA,EAAS,KAAA;AAAA,QACT,OAAA,EAAS,KAAA;AAAA,QACT,MAAM,EAAE,CAAA,EAAG,CAAA,EAAG,CAAA,EAAG,GAAG,KAAA,EAAO,CAAA,EAAG,MAAA,EAAQ,CAAA,EAAG,KAAK,CAAA,EAAG,KAAA,EAAO,GAAG,MAAA,EAAQ,CAAA,EAAG,MAAM,CAAA;AAAE,OAChF;AAAA,MACA,UAAA,EAAY,KAAA;AAAA,MACZ,WAAA,EAAa,mBAAA;AAAA,MACb,SAAS,EAAC;AAAA,MACV,kBAAkB;AAAC,KACrB;AAEA,IAAA,OAAO;AAAA,MACL,OAAA,EAAS,KAAA;AAAA,MACT,cAAA,EAAgB,WAAA;AAAA,MAChB,WAAA,EAAa,YAAA;AAAA,MACb,UAAA,EAAY,cAAc,UAAA,IAAc,CAAA;AAAA,MACxC,cAAc,YAAA,CAAa,KAAA;AAAA,MAC3B,UAAA,EAAY,WAAA,CAAY,GAAA,EAAI,GAAI,SAAA;AAAA,MAChC,SAAA,EAAW,KAAK,GAAA,EAAI;AAAA,MACpB,KAAA,EAAO,YAAA;AAAA,MACP,SAAA;AAAA,MACA,WAAA;AAAA,MACA,cAAc,YAAA,CAAa,KAAA,CAAM,CAAA,EAAG,IAAA,CAAK,OAAO,eAAe;AAAA,KACjE;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,mBAAA,CACN,SAAA,EACA,WAAA,EACA,YAAA,EACA,YAAA,EACU;AACV,IAAA,MAAM,cAAwB,EAAC;AAE/B,IAAA,QAAQ,SAAA;AAAW,MACjB,KAAK,aAAA;AACH,QAAA,WAAA,CAAY,KAAK,uDAAuD,CAAA;AACxE,QAAA,WAAA,CAAY,IAAA;AAAA,UACV;AAAA,SACF;AACA,QAAA;AAAA,MAEF,KAAK,mBAAA;AACH,QAAA,IAAI,YAAA,CAAa,SAAS,CAAA,EAAG;AAC3B,UAAA,WAAA,CAAY,KAAK,CAAA,eAAA,EAAkB,YAAA,CAAa,CAAC,CAAA,CAAE,OAAA,CAAQ,WAAW,CAAA,EAAA,CAAI,CAAA;AAAA,QAC5E;AACA,QAAA,WAAA,CAAY,KAAK,6CAA6C,CAAA;AAC9D,QAAA,WAAA,CAAY,KAAK,uCAAuC,CAAA;AACxD,QAAA;AAAA,MAEF,KAAK,gBAAA;AACH,QAAA,IAAI,YAAA,EAAc;AAChB,UAAA,WAAA,CAAY,IAAA;AAAA,YACV,CAAA,OAAA,EAAU,YAAA,CAAa,OAAA,CAAQ,WAAW,CAAA,OAAA,EAAA,CAAW,aAAa,UAAA,GAAa,GAAA,EAAK,OAAA,CAAQ,CAAC,CAAC,CAAA,YAAA;AAAA,WAChG;AAAA,QACF;AACA,QAAA,WAAA,CAAY,KAAK,+CAA+C,CAAA;AAChE,QAAA,WAAA,CAAY,KAAK,yDAAyD,CAAA;AAC1E,QAAA;AAAA,MAEF,KAAK,eAAA;AACH,QAAA,WAAA,CAAY,KAAK,iCAAiC,CAAA;AAClD,QAAA,WAAA,CAAY,KAAK,kCAAkC,CAAA;AACnD,QAAA,WAAA,CAAY,KAAK,oDAAoD,CAAA;AACrE,QAAA;AAAA,MAEF;AACE,QAAA,WAAA,CAAY,KAAK,kDAAkD,CAAA;AAAA;AAGvE,IAAA,OAAO,WAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,eAAA,CACE,SAAA,EACA,WAAA,EACA,cAAA,EACA,YAAA,EACgB;AAChB,IAAA,OAAO,kBAAA;AAAA,MACL,SAAA;AAAA,MACA,WAAA;AAAA,MACA,IAAA,CAAK,QAAA;AAAA,MACL,cAAA;AAAA,MACA;AAAA,KACF;AAAA,EACF;AACF,CAAA;;;ACtcO,IAAM,wBAAA,GAA4C;AAAA,EACvD,cAAA,EAAgB,GAAA;AAAA,EAChB,YAAA,EAAc,GAAA;AAAA,EACd,cAAA,EAAgB,GAAA;AAAA,EAChB,kBAAA,EAAoB;AACtB,CAAA;AAKO,IAAM,oBAAN,MAAwB;AAAA,EAK7B,WAAA,CAAY,MAAA,GAAmC,EAAC,EAAG;AAFnD,IAAA,IAAA,CAAQ,WAA2D,EAAC;AAGlE,IAAA,IAAA,CAAK,MAAA,GAAS,EAAE,GAAG,wBAAA,EAA0B,GAAG,MAAA,EAAO;AACvD,IAAA,IAAA,CAAK,YAAA,GAAe,IAAI,YAAA,CAAa,EAAE,gBAAgB,IAAA,CAAK,MAAA,CAAO,gBAAgB,CAAA;AAAA,EACrF;AAAA;AAAA;AAAA;AAAA,EAKA,eAAe,QAAA,EAAgE;AAC7E,IAAA,IAAA,CAAK,QAAA,GAAW,QAAA;AAChB,IAAA,IAAA,CAAK,YAAA,CAAa,eAAe,QAAQ,CAAA;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,OAAO,OAAA,EAAqD;AAChE,IAAA,MAAM,SAAA,GAAY,YAAY,GAAA,EAAI;AAClC,IAAA,MAAM,OAAA,GAAU,OAAA,CAAQ,OAAA,IAAW,IAAA,CAAK,MAAA,CAAO,cAAA;AAG/C,IAAA,MAAM,eAAe,IAAA,CAAK,mBAAA,CAAoB,QAAQ,MAAA,EAAQ,OAAA,CAAQ,UAAU,KAAK,CAAA;AACrF,IAAA,MAAM,OAAA,GAAU,cAAc,OAAA,IAAW,IAAA;AACzC,IAAA,MAAM,gBAAgB,YAAA,GAClB;AAAA,MACE,YAAY,YAAA,CAAa,UAAA;AAAA,MACzB,cAAc,YAAA,CAAa,YAAA;AAAA,MAC3B,cAAA,EAAgB,KAAK,QAAA,CAAS;AAAA,KAChC,GACA,MAAA;AAEJ,IAAA,IAAI,CAAC,OAAA,IAAW,OAAA,CAAQ,IAAA,KAAS,WAAA,EAAa;AAC5C,MAAA,MAAMC,UAAS,IAAA,CAAK,YAAA;AAAA,QAClB,KAAA;AAAA,QACA,OAAO,QAAQ,MAAA,KAAW,QAAA,GAAW,QAAQ,MAAA,GAAS,IAAA,CAAK,SAAA,CAAU,OAAA,CAAQ,MAAM,CAAA;AAAA,QACnF,mBAAA;AAAA,QACA,OAAA,CAAQ,IAAA,KAAS,QAAA,GAAW,IAAA,GAAO,OAAA,CAAQ,QAAA;AAAA,QAC3C,IAAA;AAAA,QACA,4BAAA;AAAA,QACA,IAAA,CAAK,MAAA,CAAO,kBAAA,GACR,qDAAA,GACA,MAAA;AAAA,QACJ;AAAA,OACF;AAEA,MAAA,IAAI,aAAA,EAAe;AACjB,QAAAA,QAAO,aAAA,GAAgB,aAAA;AAAA,MACzB;AACA,MAAA,OAAOA,OAAAA;AAAA,IACT;AAGA,IAAA,MAAM,SAAS,MAAM,IAAA,CAAK,iBAAiB,OAAA,EAAS,OAAA,EAAS,SAAS,SAAS,CAAA;AAE/E,IAAA,IAAI,aAAA,EAAe;AACjB,MAAA,MAAA,CAAO,aAAA,GAAgB,aAAA;AAAA,IACzB;AACA,IAAA,OAAO,MAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,YAAY,OAAA,EAA+D;AAC/E,IAAA,MAAM,SAAA,GAAY,YAAY,GAAA,EAAI;AAClC,IAAA,MAAM,UAA6B,EAAC;AACpC,IAAA,IAAI,WAAA,GAAc,CAAA;AAClB,IAAA,IAAI,WAAA,GAAc,CAAA;AAElB,IAAA,KAAA,MAAW,SAAA,IAAa,QAAQ,UAAA,EAAY;AAC1C,MAAA,MAAM,MAAA,GAAS,MAAM,IAAA,CAAK,MAAA,CAAO,SAAS,CAAA;AAC1C,MAAA,OAAA,CAAQ,KAAK,MAAM,CAAA;AAEnB,MAAA,IAAI,OAAO,MAAA,EAAQ;AACjB,QAAA,WAAA,EAAA;AAAA,MACF,CAAA,MAAO;AACL,QAAA,WAAA,EAAA;AAGA,QAAA,IAAI,QAAQ,aAAA,EAAe;AAEzB,UAAA;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAGA,IAAA,MAAM,SAAS,OAAA,CAAQ,IAAA,KAAS,KAAA,GAAQ,WAAA,KAAgB,IAAI,WAAA,GAAc,CAAA;AAE1E,IAAA,OAAO;AAAA,MACL,MAAA;AAAA,MACA,OAAA;AAAA,MACA,WAAA;AAAA,MACA,WAAA;AAAA,MACA,UAAA,EAAY,WAAA,CAAY,GAAA,EAAI,GAAI,SAAA;AAAA,MAChC,SAAA,EAAW,KAAK,GAAA;AAAI,KACtB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,aAAA,CAAc,MAAA,EAAiC,OAAA,EAA4C;AAC/F,IAAA,OAAO,KAAK,MAAA,CAAO,EAAE,QAAQ,IAAA,EAAM,SAAA,EAAW,SAAS,CAAA;AAAA,EACzD;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,YAAA,CAAa,MAAA,EAAiC,OAAA,EAA4C;AAC9F,IAAA,OAAO,KAAK,MAAA,CAAO,EAAE,QAAQ,IAAA,EAAM,QAAA,EAAU,SAAS,CAAA;AAAA,EACxD;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,aAAA,CAAc,MAAA,EAAiC,OAAA,EAA4C;AAC/F,IAAA,OAAO,KAAK,MAAA,CAAO,EAAE,QAAQ,IAAA,EAAM,SAAA,EAAW,SAAS,CAAA;AAAA,EACzD;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,cAAA,CACJ,MAAA,EACA,OAAA,EAC0B;AAC1B,IAAA,OAAO,KAAK,MAAA,CAAO,EAAE,QAAQ,IAAA,EAAM,UAAA,EAAY,SAAS,CAAA;AAAA,EAC1D;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,aAAA,CACJ,MAAA,EACA,IAAA,EACA,OAAA,EAC0B;AAC1B,IAAA,OAAO,IAAA,CAAK,OAAO,EAAE,MAAA,EAAQ,MAAM,SAAA,EAAW,QAAA,EAAU,IAAA,EAAM,OAAA,EAAS,CAAA;AAAA,EACzE;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,kBAAA,CACJ,MAAA,EACA,IAAA,EACA,OAAA,EAC0B;AAC1B,IAAA,OAAO,IAAA,CAAK,OAAO,EAAE,MAAA,EAAQ,MAAM,cAAA,EAAgB,QAAA,EAAU,IAAA,EAAM,OAAA,EAAS,CAAA;AAAA,EAC9E;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,cAAA,CACJ,MAAA,EACA,KAAA,EACA,OAAA,EAC0B;AAC1B,IAAA,OAAO,IAAA,CAAK,OAAO,EAAE,MAAA,EAAQ,MAAM,UAAA,EAAY,QAAA,EAAU,KAAA,EAAO,OAAA,EAAS,CAAA;AAAA,EAC3E;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,YAAA,CAAa,MAAA,EAAiC,OAAA,EAA4C;AAC9F,IAAA,OAAO,KAAK,MAAA,CAAO,EAAE,QAAQ,IAAA,EAAM,QAAA,EAAU,SAAS,CAAA;AAAA,EACxD;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,eAAA,CACJ,MAAA,EACA,OAAA,EAC0B;AAC1B,IAAA,OAAO,KAAK,MAAA,CAAO,EAAE,QAAQ,IAAA,EAAM,WAAA,EAAa,SAAS,CAAA;AAAA,EAC3D;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,aAAA,CAAc,MAAA,EAAiC,OAAA,EAA4C;AAC/F,IAAA,OAAO,KAAK,MAAA,CAAO,EAAE,QAAQ,IAAA,EAAM,SAAA,EAAW,SAAS,CAAA;AAAA,EACzD;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,eAAA,CACJ,MAAA,EACA,OAAA,EAC0B;AAC1B,IAAA,OAAO,KAAK,MAAA,CAAO,EAAE,QAAQ,IAAA,EAAM,WAAA,EAAa,SAAS,CAAA;AAAA,EAC3D;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,WAAA,CACJ,MAAA,EACA,aAAA,EACA,OAAA,EAC0B;AAC1B,IAAA,OAAO,IAAA,CAAK,OAAO,EAAE,MAAA,EAAQ,MAAM,OAAA,EAAS,QAAA,EAAU,aAAA,EAAe,OAAA,EAAS,CAAA;AAAA,EAChF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOQ,mBAAA,CACN,MAAA,EACA,KAAA,GAAiB,IAAA,EACI;AACrB,IAAA,MAAM,QAAA,GACJ,OAAO,MAAA,KAAW,QAAA,GAAW,EAAE,IAAA,EAAM,MAAA,EAAQ,KAAA,EAAM,GAAI,EAAE,GAAG,MAAA,EAAQ,KAAA,EAAM;AAE5E,IAAA,MAAM,eAAe,IAAA,CAAK,YAAA,CAAa,QAAA,CAAS,QAAA,EAAU,KAAK,QAAQ,CAAA;AAEvE,IAAA,IAAI,YAAA,IAAgB,YAAA,CAAa,UAAA,IAAc,IAAA,CAAK,OAAO,cAAA,EAAgB;AACzE,MAAA,OAAO,YAAA;AAAA,IACT;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,MAAa,WAAA,CACX,MAAA,EACA,KAAA,GAAiB,IAAA,EACoB;AACrC,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,mBAAA,CAAoB,MAAA,EAAQ,KAAK,CAAA;AACrD,IAAA,OAAO,QAAQ,OAAA,IAAW,IAAA;AAAA,EAC5B;AAAA;AAAA;AAAA;AAAA,EAKA,MAAc,gBAAA,CACZ,OAAA,EACA,OAAA,EACA,SACA,SAAA,EAC0B;AAC1B,IAAA,MAAM,SAAA,GACJ,OAAO,OAAA,CAAQ,MAAA,KAAW,QAAA,GAAW,QAAQ,MAAA,GAAS,IAAA,CAAK,SAAA,CAAU,OAAA,CAAQ,MAAM,CAAA;AAErF,IAAA,MAAM,kBAAA,GAAqB,SAAS,WAAA,IAAe,SAAA;AAEnD,IAAA,QAAQ,QAAQ,IAAA;AAAM,MACpB,KAAK,SAAA;AACH,QAAA,OAAO,IAAA,CAAK,gBAAA;AAAA,UACV,OAAA;AAAA,UACA,IAAA;AAAA,UACA,kBAAA;AAAA,UACA,OAAA,CAAQ,OAAA;AAAA,UACR;AAAA,SACF;AAAA,MAEF,KAAK,QAAA;AACH,QAAA,OAAO,IAAA,CAAK,gBAAA;AAAA,UACV,OAAA;AAAA,UACA,KAAA;AAAA,UACA,kBAAA;AAAA,UACA,OAAA,CAAQ,OAAA;AAAA,UACR;AAAA,SACF;AAAA,MAEF,KAAK,SAAA;AACH,QAAA,OAAO,IAAA,CAAK,kBAAA;AAAA,UACV,OAAA;AAAA,UACA,IAAA;AAAA,UACA,kBAAA;AAAA,UACA,OAAA,CAAQ,OAAA;AAAA,UACR;AAAA,SACF;AAAA,MAEF,KAAK,UAAA;AACH,QAAA,OAAO,IAAA,CAAK,kBAAA;AAAA,UACV,OAAA;AAAA,UACA,KAAA;AAAA,UACA,kBAAA;AAAA,UACA,OAAA,CAAQ,OAAA;AAAA,UACR;AAAA,SACF;AAAA,MAEF,KAAK,SAAA;AACH,QAAA,OAAO,KAAK,aAAA,CAAc,OAAA,EAAU,kBAAA,EAAoB,OAAA,CAAQ,SAAS,SAAS,CAAA;AAAA,MAEpF,KAAK,SAAA;AACH,QAAA,OAAO,IAAA,CAAK,kBAAA;AAAA,UACV,OAAA;AAAA,UACA,IAAA;AAAA,UACA,kBAAA;AAAA,UACA,OAAA,CAAQ,OAAA;AAAA,UACR;AAAA,SACF;AAAA,MAEF,KAAK,WAAA;AACH,QAAA,OAAO,IAAA,CAAK,kBAAA;AAAA,UACV,OAAA;AAAA,UACA,KAAA;AAAA,UACA,kBAAA;AAAA,UACA,OAAA,CAAQ,OAAA;AAAA,UACR;AAAA,SACF;AAAA,MAEF,KAAK,SAAA;AACH,QAAA,OAAO,IAAA,CAAK,eAAA;AAAA,UACV,OAAA;AAAA,UACA,OAAA,CAAQ,QAAA;AAAA,UACR,IAAA;AAAA,UACA,kBAAA;AAAA,UACA,OAAA,CAAQ,OAAA;AAAA,UACR;AAAA,SACF;AAAA,MAEF,KAAK,cAAA;AACH,QAAA,OAAO,IAAA,CAAK,eAAA;AAAA,UACV,OAAA;AAAA,UACA,OAAA,CAAQ,QAAA;AAAA,UACR,KAAA;AAAA,UACA,kBAAA;AAAA,UACA,OAAA,CAAQ,OAAA;AAAA,UACR;AAAA,SACF;AAAA,MAEF,KAAK,UAAA;AACH,QAAA,OAAO,IAAA,CAAK,WAAA;AAAA,UACV,OAAA;AAAA,UACA,OAAA,CAAQ,QAAA;AAAA,UACR,kBAAA;AAAA,UACA,OAAA,CAAQ,OAAA;AAAA,UACR;AAAA,SACF;AAAA,MAEF,KAAK,QAAA;AACH,QAAA,OAAO,IAAA,CAAK,YAAA;AAAA,UACV,OAAA,KAAY,IAAA;AAAA,UACZ,SAAA;AAAA,UACA,kBAAA;AAAA,UACA,IAAA;AAAA,UACA,OAAA,KAAY,IAAA;AAAA,UACZ,OAAA,KAAY,OAAO,wBAAA,GAA2B,MAAA;AAAA,UAC9C,MAAA;AAAA,UACA,SAAA;AAAA,UACA,OAAA,EAAS;AAAA,SACX;AAAA,MAEF,KAAK,WAAA;AACH,QAAA,OAAO,IAAA,CAAK,YAAA;AAAA,UACV,OAAA,KAAY,IAAA;AAAA,UACZ,SAAA;AAAA,UACA,kBAAA;AAAA,UACA,KAAA;AAAA,UACA,OAAA,KAAY,IAAA;AAAA,UACZ,OAAA,KAAY,OAAO,+BAAA,GAAkC,MAAA;AAAA,UACrD,MAAA;AAAA,UACA,SAAA;AAAA,UACA,OAAA,EAAS;AAAA,SACX;AAAA,MAEF,KAAK,OAAA;AACH,QAAA,OAAO,IAAA,CAAK,kBAAA;AAAA,UACV,OAAA,CAAQ,MAAA;AAAA,UACR,OAAA,CAAQ,QAAA;AAAA,UACR,SAAA;AAAA,UACA,OAAA,CAAQ,OAAA;AAAA,UACR;AAAA,SACF;AAAA,MAEF,KAAK,WAAA;AACH,QAAA,OAAO,IAAA,CAAK,eAAA;AAAA,UACV,OAAA;AAAA,UACA,OAAA,CAAQ,aAAA;AAAA,UACR,OAAA,CAAQ,QAAA;AAAA,UACR,kBAAA;AAAA,UACA,OAAA,CAAQ,OAAA;AAAA,UACR;AAAA,SACF;AAAA,MAEF,KAAK,UAAA;AACH,QAAA,OAAO,IAAA,CAAK,cAAA;AAAA,UACV,OAAA;AAAA,UACA,OAAA,CAAQ,QAAA;AAAA,UACR,kBAAA;AAAA,UACA,OAAA,CAAQ,OAAA;AAAA,UACR;AAAA,SACF;AAAA,MAEF,KAAK,aAAA;AACH,QAAA,OAAO,IAAA,CAAK,iBAAA;AAAA,UACV,OAAA;AAAA,UACA,OAAA,CAAQ,YAAA;AAAA,UACR,OAAA,CAAQ,QAAA;AAAA,UACR,kBAAA;AAAA,UACA,OAAA,CAAQ,OAAA;AAAA,UACR;AAAA,SACF;AAAA,MAEF;AACE,QAAA,OAAO,IAAA,CAAK,YAAA;AAAA,UACV,KAAA;AAAA,UACA,SAAA;AAAA,UACA,kBAAA;AAAA,UACA,MAAA;AAAA,UACA,MAAA;AAAA,UACA,CAAA,wBAAA,EAA2B,QAAQ,IAAI,CAAA,CAAA;AAAA,UACvC,MAAA;AAAA,UACA;AAAA,SACF;AAAA;AACJ,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,gBAAA,CACN,SACA,eAAA,EACA,WAAA,EACA,SACA,SAAA,GAAoB,WAAA,CAAY,KAAI,EACnB;AACjB,IAAA,MAAM,SAAA,GAAY,QAAQ,KAAA,CAAM,OAAA;AAChC,IAAA,MAAM,SAAS,SAAA,KAAc,eAAA;AAE7B,IAAA,OAAO,IAAA,CAAK,YAAA;AAAA,MACV,MAAA;AAAA,MACA,OAAA,CAAQ,EAAA;AAAA,MACR,WAAA;AAAA,MACA,eAAA;AAAA,MACA,SAAA;AAAA,MACA,MAAA,GACI,MAAA,GACA,OAAA,IACE,CAAA,WAAA,EAAc,SAAA,GAAY,YAAY,QAAQ,CAAA,cAAA,EAAiB,eAAA,GAAkB,SAAA,GAAY,QAAQ,CAAA,CAAA;AAAA,MAC3G,SAAS,MAAA,GAAY,oEAAA;AAAA,MACrB,SAAA;AAAA,MACA,OAAA,CAAQ;AAAA,KACV;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,kBAAA,CACN,SACA,eAAA,EACA,WAAA,EACA,SACA,SAAA,GAAoB,WAAA,CAAY,KAAI,EACnB;AACjB,IAAA,MAAM,SAAA,GAAY,QAAQ,KAAA,CAAM,OAAA;AAChC,IAAA,MAAM,SAAS,SAAA,KAAc,eAAA;AAE7B,IAAA,OAAO,IAAA,CAAK,YAAA;AAAA,MACV,MAAA;AAAA,MACA,OAAA,CAAQ,EAAA;AAAA,MACR,WAAA;AAAA,MACA,eAAA;AAAA,MACA,SAAA;AAAA,MACA,MAAA,GACI,MAAA,GACA,OAAA,IACE,CAAA,WAAA,EAAc,SAAA,GAAY,YAAY,UAAU,CAAA,cAAA,EAAiB,eAAA,GAAkB,SAAA,GAAY,UAAU,CAAA,CAAA;AAAA,MAC/G,SAAS,MAAA,GAAY,gEAAA;AAAA,MACrB,SAAA;AAAA,MACA,OAAA,CAAQ;AAAA,KACV;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,cACN,OAAA,EACA,WAAA,EACA,SACA,SAAA,GAAoB,WAAA,CAAY,KAAI,EACnB;AACjB,IAAA,MAAM,SAAA,GAAY,QAAQ,KAAA,CAAM,OAAA;AAEhC,IAAA,OAAO,IAAA,CAAK,YAAA;AAAA,MACV,SAAA;AAAA,MACA,OAAA,CAAQ,EAAA;AAAA,MACR,WAAA;AAAA,MACA,IAAA;AAAA,MACA,SAAA;AAAA,MACA,SAAA,GAAY,SAAY,OAAA,IAAW,wBAAA;AAAA,MACnC,YAAY,MAAA,GAAY,kCAAA;AAAA,MACxB,SAAA;AAAA,MACA,OAAA,CAAQ;AAAA,KACV;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,kBAAA,CACN,SACA,eAAA,EACA,WAAA,EACA,SACA,SAAA,GAAoB,WAAA,CAAY,KAAI,EACnB;AACjB,IAAA,MAAM,SAAA,GAAY,OAAA,CAAQ,KAAA,CAAM,OAAA,IAAW,KAAA;AAC3C,IAAA,MAAM,SAAS,SAAA,KAAc,eAAA;AAE7B,IAAA,OAAO,IAAA,CAAK,YAAA;AAAA,MACV,MAAA;AAAA,MACA,OAAA,CAAQ,EAAA;AAAA,MACR,WAAA;AAAA,MACA,eAAA;AAAA,MACA,SAAA;AAAA,MACA,MAAA,GACI,MAAA,GACA,OAAA,IACE,CAAA,WAAA,EAAc,SAAA,GAAY,YAAY,WAAW,CAAA,cAAA,EAAiB,eAAA,GAAkB,SAAA,GAAY,WAAW,CAAA,CAAA;AAAA,MACjH,SAAS,MAAA,GAAY,wCAAA;AAAA,MACrB,SAAA;AAAA,MACA,OAAA,CAAQ;AAAA,KACV;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,eAAA,CACN,SACA,YAAA,EACA,KAAA,EACA,aACA,OAAA,EACA,SAAA,GAAoB,WAAA,CAAY,GAAA,EAAI,EACnB;AACjB,IAAA,MAAM,UAAA,GAAa,OAAA,CAAQ,KAAA,CAAM,WAAA,IAAe,EAAA;AAChD,IAAA,MAAM,SAAS,KAAA,GAAQ,UAAA,KAAe,YAAA,GAAe,UAAA,CAAW,SAAS,YAAY,CAAA;AAErF,IAAA,OAAO,IAAA,CAAK,YAAA;AAAA,MACV,MAAA;AAAA,MACA,OAAA,CAAQ,EAAA;AAAA,MACR,WAAA;AAAA,MACA,YAAA;AAAA,MACA,UAAA;AAAA,MACA,MAAA,GACI,MAAA,GACA,OAAA,KACG,KAAA,GACG,CAAA,MAAA,EAAS,UAAU,CAAA,2BAAA,EAA8B,YAAY,CAAA,CAAA,CAAA,GAC7D,CAAA,MAAA,EAAS,UAAU,CAAA,oBAAA,EAAuB,YAAY,CAAA,CAAA,CAAA,CAAA;AAAA,MAChE,SAAS,MAAA,GAAY,+CAAA;AAAA,MACrB,SAAA;AAAA,MACA,OAAA,CAAQ;AAAA,KACV;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,WAAA,CACN,SACA,aAAA,EACA,WAAA,EACA,SACA,SAAA,GAAoB,WAAA,CAAY,KAAI,EACnB;AACjB,IAAA,MAAM,WAAA,GAAc,OAAA,CAAQ,KAAA,CAAM,KAAA,IAAS,EAAA;AAC3C,IAAA,MAAM,SAAS,WAAA,KAAgB,aAAA;AAE/B,IAAA,OAAO,IAAA,CAAK,YAAA;AAAA,MACV,MAAA;AAAA,MACA,OAAA,CAAQ,EAAA;AAAA,MACR,WAAA;AAAA,MACA,aAAA;AAAA,MACA,WAAA;AAAA,MACA,SACI,MAAA,GACA,OAAA,IAAW,CAAA,OAAA,EAAU,WAAW,8BAA8B,aAAa,CAAA,CAAA,CAAA;AAAA,MAC/E,SAAS,MAAA,GAAY,wCAAA;AAAA,MACrB,SAAA;AAAA,MACA,OAAA,CAAQ;AAAA,KACV;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,kBAAA,CACN,UACA,aAAA,EACA,SAAA,EACA,SACA,SAAA,GAAoB,WAAA,CAAY,KAAI,EACnB;AACjB,IAAA,MAAM,cAAA,GAAiB,IAAA,CAAK,YAAA,CAAa,MAAA,CAAO,QAAQ,CAAA;AACxD,IAAA,MAAM,WAAA,GAAc,eAAe,OAAA,CAAQ,MAAA;AAC3C,IAAA,MAAM,SAAS,WAAA,KAAgB,aAAA;AAE/B,IAAA,OAAO,IAAA,CAAK,YAAA;AAAA,MACV,MAAA;AAAA,MACA,SAAA;AAAA,MACA,GAAG,WAAW,CAAA,2BAAA,CAAA;AAAA,MACd,aAAA;AAAA,MACA,WAAA;AAAA,MACA,SAAS,MAAA,GAAY,OAAA,IAAW,CAAA,MAAA,EAAS,WAAW,0BAA0B,aAAa,CAAA,CAAA;AAAA,MAC3F,SAAS,MAAA,GAAY,qDAAA;AAAA,MACrB;AAAA,KACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,eAAA,CACN,SACA,aAAA,EACA,aAAA,EACA,aACA,OAAA,EACA,SAAA,GAAoB,WAAA,CAAY,GAAA,EAAI,EACnB;AAGjB,IAAA,IAAI,WAAA;AAEJ,IAAA,QAAQ,aAAA,CAAc,aAAY;AAAG,MACnC,KAAK,aAAA;AACH,QAAA,WAAA,GAAc,OAAA,CAAQ,WAAA;AACtB,QAAA;AAAA,MACF,KAAK,OAAA;AACH,QAAA,WAAA,GAAc,OAAA,CAAQ,KAAA;AACtB,QAAA;AAAA,MACF;AACE,QAAA,OAAO,IAAA,CAAK,YAAA;AAAA,UACV,KAAA;AAAA,UACA,OAAA,CAAQ,EAAA;AAAA,UACR,WAAA;AAAA,UACA,aAAA;AAAA,UACA,MAAA;AAAA,UACA,2BAA2B,aAAa,CAAA,oBAAA,CAAA;AAAA,UACxC,gDAAA;AAAA,UACA,SAAA;AAAA,UACA,OAAA,CAAQ;AAAA,SACV;AAAA;AAGJ,IAAA,MAAM,SAAS,WAAA,KAAgB,aAAA;AAE/B,IAAA,OAAO,IAAA,CAAK,YAAA;AAAA,MACV,MAAA;AAAA,MACA,OAAA,CAAQ,EAAA;AAAA,MACR,WAAA;AAAA,MACA,aAAA;AAAA,MACA,WAAA;AAAA,MACA,MAAA,GACI,SACA,OAAA,IACE,CAAA,WAAA,EAAc,aAAa,CAAA,MAAA,EAAS,WAAW,mBAAmB,aAAa,CAAA,CAAA,CAAA;AAAA,MACrF,MAAA;AAAA,MACA,SAAA;AAAA,MACA,OAAA,CAAQ;AAAA,KACV;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,cAAA,CACN,SACA,SAAA,EACA,WAAA,EACA,SACA,SAAA,GAAoB,WAAA,CAAY,KAAI,EACnB;AAEjB,IAAA,OAAO,IAAA,CAAK,YAAA;AAAA,MACV,KAAA;AAAA,MACA,OAAA,CAAQ,EAAA;AAAA,MACR,WAAA;AAAA,MACA,SAAA;AAAA,MACA,MAAA;AAAA,MACA,6CAAA;AAAA,MACA,6CAAA;AAAA,MACA,SAAA;AAAA,MACA,OAAA,CAAQ;AAAA,KACV;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,iBAAA,CACN,SACA,YAAA,EACA,aAAA,EACA,aACA,OAAA,EACA,SAAA,GAAoB,WAAA,CAAY,GAAA,EAAI,EACnB;AACjB,IAAA,MAAM,cAAA,GAAiB,QAAQ,KAAA,CAAM,cAAA;AACrC,IAAA,IAAI,CAAC,cAAA,EAAgB;AACnB,MAAA,OAAO,IAAA,CAAK,YAAA;AAAA,QACV,KAAA;AAAA,QACA,OAAA,CAAQ,EAAA;AAAA,QACR,WAAA;AAAA,QACA,aAAA;AAAA,QACA,MAAA;AAAA,QACA,+BAAA;AAAA,QACA,4CAAA;AAAA,QACA,SAAA;AAAA,QACA,OAAA,CAAQ;AAAA,OACV;AAAA,IACF;AAEA,IAAA,MAAM,QAAA,GAAW,YAAA;AACjB,IAAA,MAAM,WAAA,GAAc,eAAe,QAAQ,CAAA;AAC3C,IAAA,MAAM,SAAS,WAAA,KAAgB,aAAA;AAE/B,IAAA,OAAO,IAAA,CAAK,YAAA;AAAA,MACV,MAAA;AAAA,MACA,OAAA,CAAQ,EAAA;AAAA,MACR,WAAA;AAAA,MACA,aAAA;AAAA,MACA,WAAA;AAAA,MACA,MAAA,GACI,SACA,OAAA,IACE,CAAA,cAAA,EAAiB,YAAY,CAAA,MAAA,EAAS,WAAW,mBAAmB,aAAa,CAAA,CAAA,CAAA;AAAA,MACvF,MAAA;AAAA,MACA,SAAA;AAAA,MACA,OAAA,CAAQ;AAAA,KACV;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,YAAA,CACN,MAAA,EACA,MAAA,EACA,iBAAA,EACA,QAAA,EACA,MAAA,EACA,aAAA,EACA,UAAA,EACA,SAAA,GAAoB,WAAA,CAAY,GAAA,EAAI,EACpC,YAAA,EACiB;AACjB,IAAA,OAAO;AAAA,MACL,MAAA;AAAA,MACA,MAAA;AAAA,MACA,iBAAA;AAAA,MACA,QAAA;AAAA,MACA,MAAA;AAAA,MACA,aAAA;AAAA,MACA,UAAA,EAAY,IAAA,CAAK,MAAA,CAAO,kBAAA,GAAqB,UAAA,GAAa,MAAA;AAAA,MAC1D,YAAA;AAAA,MACA,UAAA,EAAY,WAAA,CAAY,GAAA,EAAI,GAAI,SAAA;AAAA,MAChC,SAAA,EAAW,KAAK,GAAA;AAAI,KACtB;AAAA,EACF;AACF,CAAA;;;ACrwBO,IAAM,uBAAA,GAAkD;AAAA,EAC7D,YAAA,EAAc,IAAA;AAAA,EACd,YAAA,EAAc,IAAA;AAAA,EACd,aAAA,EAAe,IAAA;AAAA,EACf,oBAAA,EAAsB,IAAA;AAAA,EACtB,WAAA,EAAa,GAAA;AAAA,EACb,cAAA,EAAgB;AAClB,CAAA;AAaO,IAAM,0BAAN,MAA8B;AAAA,EAOnC,WAAA,CAAY,MAAA,GAA0C,EAAC,EAAG;AAJ1D,IAAA,IAAA,CAAQ,UAA6B,EAAC;AACtC,IAAA,IAAA,CAAiB,cAAA,GAAiB,EAAA;AAClC,IAAA,IAAA,CAAQ,eAAA,GAAkB,CAAA;AAGxB,IAAA,IAAA,CAAK,MAAA,GAAS,EAAE,GAAG,uBAAA,EAAyB,GAAG,MAAA,EAAO;AACtD,IAAA,IAAA,CAAK,YAAA,GAAe,IAAI,YAAA,EAAa;AAAA,EACvC;AAAA;AAAA;AAAA;AAAA,EAKA,cAAA,CACE,iBACA,WAAA,EACkB;AAClB,IAAA,MAAM,UAAA,GAAa,YAAY,EAAE,IAAA,CAAK,eAAe,CAAA,CAAA,EAAI,IAAA,CAAK,KAAK,CAAA,CAAA;AAGnE,IAAA,MAAM,UAAA,GAAa,IAAA,CAAK,eAAA,CAAgB,eAAA,CAAgB,QAAQ,CAAA;AAGhE,IAAA,IAAA,CAAK,YAAA,CAAa,eAAe,UAAU,CAAA;AAG3C,IAAA,MAAM,eAAA,GAAkB,IAAA,CAAK,gBAAA,CAAiB,UAAA,EAAY,WAAW,CAAA;AAGrE,IAAA,MAAM,KAAA,GAAQ,KAAK,MAAA,CAAO,YAAA,GAAe,KAAK,YAAA,CAAa,UAAU,IAAI,EAAC;AAG1E,IAAA,MAAM,MAAA,GAAS,KAAK,MAAA,CAAO,YAAA,GAAe,KAAK,YAAA,CAAa,UAAU,IAAI,EAAC;AAG3E,IAAA,MAAM,aAAA,GAAgB,IAAA,CAAK,iBAAA,CAAkB,UAAU,CAAA;AAGvD,IAAA,MAAM,OAAA,GAAU,mBAAA,CAAoB,UAAA,EAAY,eAAe,CAAA;AAG/D,IAAA,MAAM,cAAA,GAAiB,WAAW,IAAA,CAAK,CAAC,OAAO,EAAA,CAAG,KAAA,CAAM,OAAO,CAAA,EAAG,EAAA;AAElE,IAAA,MAAM,QAAA,GAA6B;AAAA,MACjC,SAAA,EAAW,KAAK,GAAA,EAAI;AAAA,MACpB,UAAA;AAAA,MACA,IAAA,EAAM,eAAA;AAAA,MACN,UAAU,UAAA,CAAW,KAAA,CAAM,CAAA,EAAG,IAAA,CAAK,OAAO,WAAW,CAAA;AAAA,MACrD,KAAA;AAAA,MACA,YAAA,EAAc,MAAA;AAAA,MACd,cAAA;AAAA,MACA,OAAA;AAAA,MACA;AAAA,KACF;AAGA,IAAA,IAAA,CAAK,aAAa,QAAQ,CAAA;AAE1B,IAAA,OAAO,QAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,eAAA,GAA2C;AACzC,IAAA,IAAI,IAAA,CAAK,OAAA,CAAQ,MAAA,KAAW,CAAA,EAAG,OAAO,IAAA;AACtC,IAAA,OAAO,KAAK,OAAA,CAAQ,IAAA,CAAK,OAAA,CAAQ,MAAA,GAAS,CAAC,CAAA,CAAE,QAAA;AAAA,EAC/C;AAAA;AAAA;AAAA;AAAA,EAKA,YAAY,UAAA,EAA6C;AACvD,IAAA,MAAM,KAAA,GAAQ,KAAK,OAAA,CAAQ,IAAA,CAAK,CAAC,CAAA,KAAM,CAAA,CAAE,QAAA,CAAS,UAAA,KAAe,UAAU,CAAA;AAC3E,IAAA,OAAO,OAAO,QAAA,IAAY,IAAA;AAAA,EAC5B;AAAA;AAAA;AAAA;AAAA,EAKA,UAAA,GAAiC;AAC/B,IAAA,OAAO,KAAK,OAAA,CAAQ,GAAA,CAAI,CAAC,CAAA,KAAM,EAAE,QAAQ,CAAA;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA,EAKA,YAAA,GAAqB;AACnB,IAAA,IAAA,CAAK,UAAU,EAAC;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA,EAKQ,gBAAgB,QAAA,EAA8D;AACpF,IAAA,OAAO,SAAS,GAAA,CAAI,CAAC,OAAO,IAAA,CAAK,cAAA,CAAe,EAAE,CAAC,CAAA;AAAA,EACrD;AAAA;AAAA;AAAA;AAAA,EAKQ,eAAe,OAAA,EAA8D;AACnF,IAAA,MAAM,SAAA,GAAY,QAAQ,QAAA,KAAa,SAAA;AAEvC,IAAA,MAAM,UAAU,eAAA,CAAgB;AAAA,MAC9B,WAAA,EAAa,QAAQ,KAAA,CAAM,WAAA;AAAA,MAC3B,aAAa,OAAA,CAAQ,IAAA;AAAA,MACrB,IAAI,OAAA,CAAQ,EAAA;AAAA,MACZ,WAAW,OAAA,CAAQ;AAAA,KACpB,CAAA;AAGD,IAAA,IAAI,WAAA;AACJ,IAAA,IAAI,SAAA,IAAa,QAAQ,eAAA,EAAiB;AACxC,MAAA,WAAA,GAAc,IAAA,CAAK,2BAA2B,OAAO,CAAA;AAAA,IACvD,CAAA,MAAA,IAAW,IAAA,CAAK,MAAA,CAAO,oBAAA,EAAsB;AAC3C,MAAA,WAAA,GAAc,mBAAA,CAAoB;AAAA,QAChC,WAAA,EAAa,QAAQ,KAAA,CAAM,WAAA;AAAA,QAC3B,aAAa,OAAA,CAAQ,IAAA;AAAA,QACrB,IAAI,OAAA,CAAQ,EAAA;AAAA,QACZ,WAAW,OAAA,CAAQ;AAAA,OACpB,CAAA;AAAA,IACH,CAAA,MAAO;AACL,MAAA,WAAA,GAAc,OAAA,CAAQ,SAAS,OAAA,CAAQ,EAAA;AAAA,IACzC;AAEA,IAAA,MAAM,OAAA,GAAU,YACZ,eAAA,CAAgB,EAAE,aAAa,OAAA,CAAQ,KAAA,CAAM,WAAA,EAAa,WAAA,EAAa,OAAA,CAAQ,IAAA,EAAM,CAAA,GACrF,eAAA,CAAgB,EAAE,WAAA,EAAa,OAAA,CAAQ,MAAM,WAAA,EAAa,WAAA,EAAa,OAAA,CAAQ,IAAA,EAAM,CAAA;AAEzF,IAAA,MAAM,gBAAA,GAAmB,YACrB,wBAAA,CAAyB;AAAA,MACvB,WAAA,EAAa,QAAQ,KAAA,CAAM,WAAA;AAAA,MAC3B,aAAa,OAAA,CAAQ;AAAA,KACtB,IACD,wBAAA,CAAyB;AAAA,MACvB,WAAA,EAAa,QAAQ,KAAA,CAAM,WAAA;AAAA,MAC3B,aAAa,OAAA,CAAQ;AAAA,KACtB,CAAA;AAGL,IAAA,IAAI,gBAAA,GAAmB,WAAA;AACvB,IAAA,IAAI,YAAA,GAAe,OAAA;AACnB,IAAA,IAAI,YAAA,GAAe,OAAA;AAEnB,IAAA,IAAI,IAAA,CAAK,OAAO,cAAA,EAAgB;AAC9B,MAAA,MAAM,UAAA,GAAa,wBAAA,EAAyB,CAAE,GAAA,CAAI,QAAQ,EAAE,CAAA;AAC5D,MAAA,IAAI,UAAA,EAAY;AACd,QAAA,IAAI,WAAW,WAAA,EAAa;AAC1B,UAAA,gBAAA,GAAmB,UAAA,CAAW,WAAA;AAAA,QAChC;AACA,QAAA,IAAI,WAAW,OAAA,EAAS;AACtB,UAAA,YAAA,GAAe,UAAA,CAAW,OAAA;AAAA,QAC5B;AACA,QAAA,IAAI,UAAA,CAAW,IAAA,IAAQ,UAAA,CAAW,IAAA,CAAK,SAAS,CAAA,EAAG;AAEjD,UAAA,MAAM,yBAAS,IAAI,GAAA,CAAI,CAAC,GAAG,cAAc,GAAG,UAAA,CAAW,IAAA,CAAK,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,CAAE,WAAA,EAAa,CAAC,CAAC,CAAA;AACxF,UAAA,YAAA,GAAe,CAAC,GAAG,MAAM,CAAA;AAAA,QAC3B;AAAA,MACF;AAAA,IACF;AAEA,IAAA,OAAO;AAAA,MACL,IAAI,OAAA,CAAQ,EAAA;AAAA,MACZ,MAAM,OAAA,CAAQ,IAAA;AAAA,MACd,OAAO,OAAA,CAAQ,KAAA;AAAA,MACf,OAAA,EAAS,IAAA,CAAK,YAAA,CAAa,OAAA,CAAQ,IAAI,CAAA;AAAA,MACvC,IAAA,EAAM,IAAA,CAAK,SAAA,CAAU,OAAA,CAAQ,IAAI,CAAA;AAAA,MACjC,gBAAgB,OAAA,CAAQ,KAAA,IAAS,OAAA,CAAQ,KAAA,CAAM,aAAa,IAAA,EAAK;AAAA,MACjE,SAAS,OAAA,CAAQ,OAAA;AAAA,MACjB,OAAO,OAAA,CAAQ,KAAA;AAAA,MACf,UAAA,EAAY,IAAA;AAAA,MACZ,WAAA,EAAa,gBAAA;AAAA,MACb,OAAA,EAAS,YAAA;AAAA,MACT,OAAA,EAAS,YAAA;AAAA,MACT,gBAAA;AAAA,MACA,YAAA,EAAc,IAAA,CAAK,iBAAA,CAAkB,OAAO,CAAA;AAAA,MAC5C,UAAU,OAAA,CAAQ,QAAA;AAAA,MAClB,iBAAiB,OAAA,CAAQ;AAAA,KAC3B;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,2BAA2B,OAAA,EAAiD;AAClF,IAAA,MAAM,OAAO,OAAA,CAAQ,eAAA;AACrB,IAAA,MAAM,IAAA,GAAO,OAAA,CAAQ,KAAA,CAAM,WAAA,EAAa,MAAK,IAAK,EAAA;AAClD,IAAA,MAAM,aAAA,GAAgB,KAAK,MAAA,GAAS,EAAA,GAAK,KAAK,SAAA,CAAU,CAAA,EAAG,EAAE,CAAA,GAAI,KAAA,GAAQ,IAAA;AAEzE,IAAA,IAAI,CAAC,IAAA,EAAM,OAAO,CAAA,CAAA,EAAI,aAAa,CAAA,CAAA,CAAA;AAEnC,IAAA,QAAQ,KAAK,WAAA;AAAa,MACxB,KAAK,SAAA;AACH,QAAA,OAAO,CAAA,MAAA,EAAS,IAAA,CAAK,YAAA,IAAgB,GAAG,cAAc,aAAa,CAAA,CAAA,CAAA;AAAA,MACrE,KAAK,YAAA;AACH,QAAA,OAAO,CAAA,UAAA,EAAa,KAAK,iBAAA,GAAoB,CAAA,EAAA,EAAK,KAAK,iBAAiB,CAAA,CAAA,CAAA,GAAM,EAAE,CAAA,GAAA,EAAM,aAAa,CAAA,CAAA,CAAA;AAAA,MACrG,KAAK,cAAA;AACH,QAAA,OAAO,CAAA,YAAA,EAAe,KAAK,iBAAA,GAAoB,CAAA,EAAA,EAAK,KAAK,iBAAiB,CAAA,CAAA,CAAA,GAAM,EAAE,CAAA,GAAA,EAAM,aAAa,CAAA,CAAA,CAAA;AAAA,MACvG,KAAK,QAAA;AACH,QAAA,OAAO,oBAAoB,aAAa,CAAA,CAAA,CAAA;AAAA,MAC1C,KAAK,OAAA;AACH,QAAA,OAAO,WAAW,aAAa,CAAA,CAAA,CAAA;AAAA,MACjC,KAAK,QAAA;AACH,QAAA,OAAO,kBAAkB,aAAa,CAAA,CAAA,CAAA;AAAA,MACxC,KAAK,WAAA;AACH,QAAA,OAAO,UAAU,aAAa,CAAA,CAAA,CAAA;AAAA,MAChC,KAAK,WAAA;AACH,QAAA,OAAO,eAAe,aAAa,CAAA,CAAA,CAAA;AAAA,MACrC,KAAK,OAAA;AACH,QAAA,OAAO,gBAAgB,aAAa,CAAA,CAAA,CAAA;AAAA,MACtC,KAAK,MAAA;AACH,QAAA,OAAO,gBAAgB,aAAa,CAAA,CAAA,CAAA;AAAA,MACtC,KAAK,SAAA;AACH,QAAA,OAAO,aAAa,aAAa,CAAA,CAAA,CAAA;AAAA,MACnC,KAAK,OAAA;AACH,QAAA,OAAO,WAAW,aAAa,CAAA,CAAA,CAAA;AAAA,MACjC,KAAK,aAAA;AACH,QAAA,OAAO,iBAAiB,aAAa,CAAA,CAAA,CAAA;AAAA,MACvC,KAAK,YAAA;AACH,QAAA,OAAO,qBAAqB,aAAa,CAAA,CAAA,CAAA;AAAA,MAC3C;AACE,QAAA,OAAO,aAAa,aAAa,CAAA,CAAA,CAAA;AAAA;AACrC,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,gBAAA,CACN,UACA,OAAA,EACa;AACb,IAAA,MAAM,GAAA,GAAM,SAAS,GAAA,KAAQ,OAAO,WAAW,WAAA,GAAc,MAAA,CAAO,SAAS,IAAA,GAAO,EAAA,CAAA;AACpF,IAAA,MAAM,QAAQ,OAAA,EAAS,KAAA,KAAU,OAAO,QAAA,KAAa,WAAA,GAAc,SAAS,KAAA,GAAQ,EAAA,CAAA;AAEpF,IAAA,MAAM,QAAA,GAAW,IAAA,CAAK,MAAA,CAAO,aAAA,GACzB,aAAA,CAAc,KAAK,KAAA,EAAO,QAAQ,CAAA,GAClC,OAAA,EAAS,QAAA,IAAY,SAAA;AAGzB,IAAA,MAAM,eAAe,QAAA,CAClB,MAAA,CAAO,CAAC,EAAA,KAAO,GAAG,IAAA,KAAS,QAAA,IAAY,EAAA,CAAG,KAAA,CAAM,OAAO,CAAA,CACvD,GAAA,CAAI,CAAC,EAAA,KAAO,GAAG,EAAE,CAAA;AAEpB,IAAA,OAAO;AAAA,MACL,GAAA;AAAA,MACA,KAAA;AAAA,MACA,QAAA;AAAA,MACA,YAAA,EAAc,SAAS,YAAA,IAAgB,YAAA;AAAA,MACvC,cAAA,EAAgB,OAAA,EAAS,cAAA,IAAkB,QAAA,CAAS,IAAA,CAAK,CAAC,EAAA,KAAO,EAAA,CAAG,KAAA,CAAM,OAAO,CAAA,EAAG,EAAA;AAAA,MACpF,YAAY,OAAA,EAAS;AAAA,KACvB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,aAAa,QAAA,EAA8C;AACjE,IAAA,MAAM,QAAqB,EAAC;AAG5B,IAAA,MAAM,eAAe,QAAA,CAAS,MAAA,CAAO,CAAC,EAAA,KAAO,EAAA,CAAG,SAAS,MAAM,CAAA;AAG/D,IAAA,IAAI,YAAA,CAAa,WAAW,CAAA,EAAG;AAC7B,MAAA,MAAM,YAAA,GAAe,IAAA,CAAK,kBAAA,CAAmB,QAAQ,CAAA;AACrD,MAAA,IAAI,YAAA,EAAc;AAChB,QAAA,KAAA,CAAM,KAAK,YAAY,CAAA;AAAA,MACzB;AAAA,IACF,CAAA,MAAO;AACL,MAAA,KAAA,MAAW,QAAQ,YAAA,EAAc;AAC/B,QAAA,MAAM,SAAA,GAAY,IAAA,CAAK,WAAA,CAAY,IAAA,EAAM,QAAQ,CAAA;AACjD,QAAA,IAAI,SAAA,EAAW;AACb,UAAA,KAAA,CAAM,KAAK,SAAS,CAAA;AAAA,QACtB;AAAA,MACF;AAAA,IACF;AAEA,IAAA,OAAO,KAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKQ,mBAAmB,QAAA,EAAmD;AAC5E,IAAA,MAAM,SAAS,QAAA,CAAS,MAAA;AAAA,MACtB,CAAC,EAAA,KACC,EAAA,CAAG,IAAA,KAAS,OAAA,IACZ,EAAA,CAAG,IAAA,KAAS,UAAA,IACZ,EAAA,CAAG,IAAA,KAAS,QAAA,IACZ,EAAA,CAAG,IAAA,KAAS;AAAA,KAChB;AAEA,IAAA,IAAI,MAAA,CAAO,MAAA,KAAW,CAAA,EAAG,OAAO,IAAA;AAGhC,IAAA,MAAM,eAAe,QAAA,CAAS,IAAA;AAAA,MAC5B,CAAC,EAAA,KACC,EAAA,CAAG,IAAA,KAAS,QAAA,IACZ,GAAG,KAAA,CAAM,OAAA,KACR,EAAA,CAAG,YAAA,KAAiB,mBACnB,EAAA,CAAG,KAAA,CAAM,aAAa,WAAA,EAAY,CAAE,MAAM,2BAA2B,CAAA;AAAA,KAC3E;AAEA,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,iBAAA,CAAkB,MAAM,CAAA;AAC5C,IAAA,MAAM,YAAY,MAAA,CAAO,IAAA,CAAK,CAAC,CAAA,KAAM,CAAC,EAAE,KAAK,CAAA;AAE7C,IAAA,OAAO;AAAA,MACL,EAAA,EAAI,eAAA;AAAA,MACJ,OAAA,EAAS,IAAA,CAAK,gBAAA,CAAiB,MAAM,CAAA;AAAA,MACrC,MAAA;AAAA,MACA,SAAS,CAAC,SAAA;AAAA,MACV,cAAc,YAAA,EAAc,EAAA;AAAA,MAC5B,OAAA,EAAS,OAAO,IAAA,CAAK,CAAC,MAAM,CAAA,CAAE,KAAA,KAAU,EAAA,IAAM,CAAA,CAAE,OAAO;AAAA,KACzD;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,WAAA,CACN,MACA,WAAA,EACkB;AAElB,IAAA,MAAM,SAAS,WAAA,CAAY,MAAA;AAAA,MACzB,CAAC,EAAA,KAAA,CACE,EAAA,CAAG,IAAA,KAAS,OAAA,IAAW,EAAA,CAAG,IAAA,KAAS,UAAA,IAAc,EAAA,CAAG,IAAA,KAAS,QAAA,KAAa,EAAA,CAAG,KAAA,CAAM;AAAA,KACxF;AAEA,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,iBAAA,CAAkB,MAAM,CAAA;AAC5C,IAAA,MAAM,YAAY,MAAA,CAAO,IAAA,CAAK,CAAC,CAAA,KAAM,CAAC,EAAE,KAAK,CAAA;AAG7C,IAAA,MAAM,eAAe,WAAA,CAAY,IAAA;AAAA,MAC/B,CAAC,OAAO,EAAA,CAAG,IAAA,KAAS,YAAY,EAAA,CAAG,KAAA,CAAM,OAAA,IAAW,EAAA,CAAG,YAAA,KAAiB;AAAA,KAC1E;AAEA,IAAA,OAAO;AAAA,MACL,IAAI,IAAA,CAAK,EAAA;AAAA,MACT,MAAM,IAAA,CAAK,KAAA;AAAA,MACX,SAAS,IAAA,CAAK,OAAA;AAAA,MACd,MAAA;AAAA,MACA,SAAS,CAAC,SAAA;AAAA,MACV,cAAc,YAAA,EAAc,EAAA;AAAA,MAC5B,SAAS,MAAA,CAAO,IAAA,CAAK,CAAC,CAAA,KAAM,CAAA,CAAE,UAAU,EAAE;AAAA,KAC5C;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKQ,kBAAkB,MAAA,EAAiD;AACzE,IAAA,OAAO,MAAA,CAAO,GAAA,CAAI,CAAC,KAAA,MAAW;AAAA,MAC5B,IAAI,KAAA,CAAM,EAAA;AAAA,MACV,KAAA,EAAO,KAAA,CAAM,cAAA,IAAkB,KAAA,CAAM,SAAS,KAAA,CAAM,EAAA;AAAA,MACpD,MAAM,KAAA,CAAM,IAAA;AAAA,MACZ,KAAA,EAAO,KAAA,CAAM,KAAA,CAAM,KAAA,IAAS,EAAA;AAAA,MAC5B,KAAA,EAAO,IAAA;AAAA;AAAA,MACP,QAAA,EAAU,KAAA;AAAA;AAAA,MACV,OAAA,EAAS,MAAM,KAAA,CAAM,OAAA,IAAA,CAAY,MAAM,KAAA,CAAM,KAAA,EAAO,UAAU,CAAA,IAAK;AAAA,KACrE,CAAE,CAAA;AAAA,EACJ;AAAA;AAAA;AAAA;AAAA,EAKQ,aAAa,QAAA,EAA+C;AAClE,IAAA,MAAM,SAAuB,EAAC;AAG9B,IAAA,MAAM,cAAA,GAAiB,QAAA,CAAS,MAAA,CAAO,CAAC,EAAA,KAAO,GAAG,IAAA,KAAS,QAAA,IAAY,EAAA,CAAG,KAAA,CAAM,OAAO,CAAA;AAEvF,IAAA,KAAA,MAAW,UAAU,cAAA,EAAgB;AAEnC,MAAA,MAAM,cAAc,QAAA,CAAS,IAAA;AAAA,QAC3B,CAAC,EAAA,KACC,EAAA,CAAG,IAAA,KAAS,QAAA,IACZ,GAAG,KAAA,CAAM,OAAA,KACR,EAAA,CAAG,YAAA,KAAiB,mBACnB,EAAA,CAAG,KAAA,CAAM,aAAa,WAAA,EAAY,CAAE,MAAM,wBAAwB,CAAA;AAAA,OACxE;AAGA,MAAA,MAAM,gBAAgB,QAAA,CAAS,IAAA;AAAA,QAC7B,CAAC,OAAO,EAAA,CAAG,IAAA,KAAS,YAAY,EAAA,CAAG,KAAA,CAAM,OAAA,IAAW,EAAA,CAAG,YAAA,KAAiB;AAAA,OAC1E;AAEA,MAAA,MAAA,CAAO,IAAA,CAAK;AAAA,QACV,IAAI,MAAA,CAAO,EAAA;AAAA,QACX,KAAA,EAAO,MAAA,CAAO,cAAA,IAAkB,MAAA,CAAO,KAAA;AAAA,QACvC,IAAA,EAAM,IAAA,CAAK,cAAA,CAAe,MAAM,CAAA;AAAA,QAChC,QAAA,EAAU,IAAA;AAAA;AAAA,QACV,aAAa,WAAA,EAAa,EAAA;AAAA,QAC1B,eAAe,aAAA,EAAe;AAAA,OAC/B,CAAA;AAAA,IACH;AAEA,IAAA,OAAO,MAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKQ,eAAe,MAAA,EAAiD;AACtE,IAAA,MAAM,QAAQ,MAAA,CAAO,cAAA,IAAkB,OAAO,KAAA,CAAM,WAAA,IAAe,IAAI,WAAA,EAAY;AAEnF,IAAA,IAAI,IAAA,CAAK,QAAA,CAAS,OAAO,CAAA,IAAK,IAAA,CAAK,QAAA,CAAS,SAAS,CAAA,IAAK,IAAA,CAAK,QAAA,CAAS,OAAO,CAAA,EAAG;AAChF,MAAA,OAAO,OAAA;AAAA,IACT;AACA,IAAA,IAAI,KAAK,QAAA,CAAS,SAAS,KAAK,IAAA,CAAK,QAAA,CAAS,cAAc,CAAA,EAAG;AAC7D,MAAA,OAAO,SAAA;AAAA,IACT;AACA,IAAA,IAAI,KAAK,QAAA,CAAS,QAAQ,KAAK,IAAA,CAAK,QAAA,CAAS,OAAO,CAAA,EAAG;AACrD,MAAA,OAAO,QAAA;AAAA,IACT;AAEA,IAAA,OAAO,QAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKQ,kBAAkB,QAAA,EAAyD;AACjF,IAAA,MAAM,SAAiC,EAAC;AAExC,IAAA,KAAA,MAAW,MAAM,QAAA,EAAU;AACzB,MAAA,MAAM,IAAA,GAAO,EAAA,CAAG,IAAA,CAAK,WAAA,EAAY;AACjC,MAAA,MAAA,CAAO,IAAI,CAAA,GAAA,CAAK,MAAA,CAAO,IAAI,KAAK,CAAA,IAAK,CAAA;AAAA,IACvC;AAEA,IAAA,OAAO,MAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKQ,iBAAiB,MAAA,EAAuC;AAC9D,IAAA,MAAM,MAAA,GAAS,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA,KAAA,CAAO,CAAA,CAAE,cAAA,IAAkB,CAAA,CAAE,KAAA,IAAS,EAAA,EAAI,WAAA,EAAa,CAAA;AAClF,IAAA,MAAM,SAAA,GAAY,MAAA,CAAO,IAAA,CAAK,GAAG,CAAA;AAEjC,IAAA,IAAI,UAAU,QAAA,CAAS,OAAO,KAAK,SAAA,CAAU,QAAA,CAAS,UAAU,CAAA,EAAG;AACjE,MAAA,IAAI,UAAU,QAAA,CAAS,SAAS,KAAK,SAAA,CAAU,QAAA,CAAS,MAAM,CAAA,EAAG;AAC/D,QAAA,OAAO,cAAA;AAAA,MACT;AACA,MAAA,OAAO,OAAA;AAAA,IACT;AAEA,IAAA,IAAI,SAAA,CAAU,QAAA,CAAS,QAAQ,CAAA,EAAG,OAAO,QAAA;AACzC,IAAA,IAAI,SAAA,CAAU,SAAS,SAAS,CAAA,IAAK,UAAU,QAAA,CAAS,MAAM,GAAG,OAAO,SAAA;AACxE,IAAA,IAAI,SAAA,CAAU,SAAS,MAAM,CAAA,IAAK,UAAU,QAAA,CAAS,SAAS,GAAG,OAAO,SAAA;AACxE,IAAA,IAAI,SAAA,CAAU,SAAS,SAAS,CAAA,IAAK,UAAU,QAAA,CAAS,SAAS,GAAG,OAAO,SAAA;AAE3E,IAAA,OAAO,MAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKQ,aAAa,IAAA,EAAsB;AACzC,IAAA,MAAM,OAAA,GAAkC;AAAA,MACtC,MAAA,EAAQ,QAAA;AAAA,MACR,KAAA,EAAO,OAAA;AAAA,MACP,QAAA,EAAU,UAAA;AAAA,MACV,MAAA,EAAQ,QAAA;AAAA,MACR,QAAA,EAAU,OAAA;AAAA,MACV,KAAA,EAAO,OAAA;AAAA,MACP,IAAA,EAAM,GAAA;AAAA,MACN,IAAA,EAAM,MAAA;AAAA,MACN,MAAA,EAAQ;AAAA,KACV;AACA,IAAA,OAAO,OAAA,CAAQ,IAAI,CAAA,IAAK,KAAA;AAAA,EAC1B;AAAA;AAAA;AAAA;AAAA,EAKQ,UAAU,IAAA,EAAkC;AAClD,IAAA,MAAM,OAAA,GAAkC;AAAA,MACtC,MAAA,EAAQ,QAAA;AAAA,MACR,KAAA,EAAO,SAAA;AAAA,MACP,QAAA,EAAU,SAAA;AAAA,MACV,MAAA,EAAQ,UAAA;AAAA,MACR,QAAA,EAAU,UAAA;AAAA,MACV,KAAA,EAAO,OAAA;AAAA,MACP,IAAA,EAAM,MAAA;AAAA,MACN,MAAA,EAAQ,QAAA;AAAA,MACR,IAAA,EAAM,MAAA;AAAA,MACN,QAAA,EAAU,UAAA;AAAA,MACV,GAAA,EAAK;AAAA,KACP;AACA,IAAA,OAAO,QAAQ,IAAI,CAAA;AAAA,EACrB;AAAA;AAAA;AAAA;AAAA,EAKQ,kBAAkB,OAAA,EAAiD;AAEzE,IAAA,IAAI,OAAA,CAAQ,QAAA,KAAa,SAAA,IAAa,OAAA,CAAQ,eAAA,EAAiB;AAC7D,MAAA,MAAM,IAAA,GAAO,QAAQ,eAAA,CAAgB,WAAA;AACrC,MAAA,IAAI,IAAA,KAAS,SAAA,IAAa,OAAA,CAAQ,eAAA,CAAgB,YAAA,EAAc;AAC9D,QAAA,OAAO,CAAA,QAAA,EAAW,OAAA,CAAQ,eAAA,CAAgB,YAAY,CAAA,CAAA;AAAA,MACxD;AACA,MAAA,OAAO,IAAA;AAAA,IACT;AAEA,IAAA,MAAM,QAAQ,OAAA,CAAQ,KAAA,CAAM,eAAe,OAAA,CAAQ,KAAA,IAAS,IAAI,WAAA,EAAY;AAC5E,IAAA,MAAM,IAAA,GAAO,OAAA,CAAQ,IAAA,CAAK,WAAA,EAAY;AAEtC,IAAA,IAAI,SAAS,QAAA,EAAU;AACrB,MAAA,IAAI,IAAA,CAAK,KAAA,CAAM,mCAAmC,CAAA,EAAG,OAAO,eAAA;AAC5D,MAAA,IAAI,IAAA,CAAK,KAAA,CAAM,sBAAsB,CAAA,EAAG,OAAO,eAAA;AAC/C,MAAA,IAAI,IAAA,CAAK,KAAA,CAAM,qBAAqB,CAAA,EAAG,OAAO,eAAA;AAC9C,MAAA,IAAI,IAAA,CAAK,KAAA,CAAM,mBAAmB,CAAA,EAAG,OAAO,YAAA;AAC5C,MAAA,IAAI,IAAA,CAAK,KAAA,CAAM,aAAa,CAAA,EAAG,OAAO,aAAA;AACtC,MAAA,IAAI,IAAA,CAAK,KAAA,CAAM,eAAe,CAAA,EAAG,OAAO,aAAA;AACxC,MAAA,IAAI,IAAA,CAAK,KAAA,CAAM,eAAe,CAAA,EAAG,OAAO,aAAA;AACxC,MAAA,OAAO,eAAA;AAAA,IACT;AAEA,IAAA,IAAI,SAAS,OAAA,EAAS;AACpB,MAAA,IAAI,IAAA,CAAK,SAAS,OAAO,CAAA,IAAK,QAAQ,EAAA,CAAG,QAAA,CAAS,OAAO,CAAA,EAAG,OAAO,aAAA;AACnE,MAAA,IAAI,IAAA,CAAK,SAAS,UAAU,CAAA,IAAK,QAAQ,EAAA,CAAG,QAAA,CAAS,UAAU,CAAA,EAAG,OAAO,gBAAA;AACzE,MAAA,IAAI,IAAA,CAAK,SAAS,QAAQ,CAAA,IAAK,QAAQ,EAAA,CAAG,QAAA,CAAS,QAAQ,CAAA,EAAG,OAAO,cAAA;AACrE,MAAA,OAAO,YAAA;AAAA,IACT;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKQ,aAAa,QAAA,EAAkC;AACrD,IAAA,IAAA,CAAK,QAAQ,IAAA,CAAK;AAAA,MAChB,QAAA;AAAA,MACA,SAAA,EAAW,KAAK,GAAA;AAAI,KACrB,CAAA;AAGD,IAAA,IAAI,IAAA,CAAK,OAAA,CAAQ,MAAA,GAAS,IAAA,CAAK,cAAA,EAAgB;AAC7C,MAAA,IAAA,CAAK,UAAU,IAAA,CAAK,OAAA,CAAQ,KAAA,CAAM,CAAC,KAAK,cAAc,CAAA;AAAA,IACxD;AAAA,EACF;AACF,CAAA;;;AClkBO,IAAM,mBAAA,GAA0C;AAAA,EACrD,mBAAA,EAAqB,IAAA;AAAA,EACrB,mBAAmB,CAAC,SAAA,EAAW,WAAW,SAAA,EAAW,SAAA,EAAW,SAAS,aAAa,CAAA;AAAA,EACtF,mBAAA,EAAqB,IAAA;AAAA,EACrB,gBAAA,EAAkB;AACpB,CAAA;AAKA,IAAM,2CAA2B,IAAI,GAAA,CAAI,CAAC,MAAA,EAAQ,gBAAA,EAAkB,WAAW,CAAC,CAAA;AAKzE,SAAS,WAAA,CACd,YAAA,EACA,UAAA,EACA,MAAA,GAAsC,EAAC,EACzB;AACd,EAAA,MAAM,SAAA,GAAY,YAAY,GAAA,EAAI;AAClC,EAAA,MAAM,WAAA,GAAc,EAAE,GAAG,mBAAA,EAAqB,GAAG,MAAA,EAAO;AAGxD,EAAA,MAAM,YAAA,GAAe,IAAI,GAAA,CAAI,YAAA,CAAa,QAAA,CAAS,GAAA,CAAI,CAAC,EAAA,KAAO,CAAC,EAAA,CAAG,EAAA,EAAI,EAAE,CAAC,CAAC,CAAA;AAC3E,EAAA,MAAM,UAAA,GAAa,IAAI,GAAA,CAAI,UAAA,CAAW,QAAA,CAAS,GAAA,CAAI,CAAC,EAAA,KAAO,CAAC,EAAA,CAAG,EAAA,EAAI,EAAE,CAAC,CAAC,CAAA;AAGvE,EAAA,MAAM,WAA4B,EAAC;AACnC,EAAA,KAAA,MAAW,CAAC,EAAA,EAAI,OAAO,CAAA,IAAK,UAAA,EAAY;AACtC,IAAA,IAAI,CAAC,YAAA,CAAa,GAAA,CAAI,EAAE,CAAA,EAAG;AACzB,MAAA,QAAA,CAAS,IAAA,CAAK;AAAA,QACZ,SAAA,EAAW,EAAA;AAAA,QACX,aAAa,OAAA,CAAQ,WAAA;AAAA,QACrB,MAAM,OAAA,CAAQ,IAAA;AAAA,QACd,cAAc,OAAA,CAAQ;AAAA,OACvB,CAAA;AAAA,IACH;AAAA,EACF;AAGA,EAAA,MAAM,cAA+B,EAAC;AACtC,EAAA,KAAA,MAAW,CAAC,EAAA,EAAI,OAAO,CAAA,IAAK,YAAA,EAAc;AACxC,IAAA,IAAI,CAAC,UAAA,CAAW,GAAA,CAAI,EAAE,CAAA,EAAG;AACvB,MAAA,WAAA,CAAY,IAAA,CAAK;AAAA,QACf,SAAA,EAAW,EAAA;AAAA,QACX,aAAa,OAAA,CAAQ,WAAA;AAAA,QACrB,MAAM,OAAA,CAAQ,IAAA;AAAA,QACd,cAAc,OAAA,CAAQ;AAAA,OACvB,CAAA;AAAA,IACH;AAAA,EACF;AAGA,EAAA,MAAM,WAAkC,EAAC;AACzC,EAAA,KAAA,MAAW,CAAC,EAAA,EAAI,SAAS,CAAA,IAAK,UAAA,EAAY;AACxC,IAAA,MAAM,WAAA,GAAc,YAAA,CAAa,GAAA,CAAI,EAAE,CAAA;AACvC,IAAA,IAAI,WAAA,EAAa;AACf,MAAA,MAAM,aAAA,GAAgB,eAAA,CAAgB,WAAA,EAAa,SAAA,EAAW,WAAW,CAAA;AACzE,MAAA,QAAA,CAAS,IAAA,CAAK,GAAG,aAAa,CAAA;AAAA,IAChC;AAAA,EACF;AAGA,EAAA,MAAM,oBAAA,GAAuB,QAAA,CAAS,KAAA,CAAM,CAAA,EAAG,YAAY,gBAAgB,CAAA;AAG3E,EAAA,MAAM,eAAA,GAAkB,aAAA,CAAc,QAAA,EAAU,WAAA,EAAa,oBAAoB,CAAA;AAGjF,EAAA,MAAM,gBAAA,GAAmB,YAAY,mBAAA,GACjC,gCAAA,CAAiC,UAAU,WAAA,EAAa,oBAAA,EAAsB,eAAe,CAAA,GAC7F,MAAA;AAGJ,EAAA,MAAM,WAAA,GAAc,iBAAA,CAAkB,YAAA,EAAc,UAAU,CAAA;AAG9D,EAAA,MAAM,cAAA,GAAiB,oBAAA,CAAqB,YAAA,EAAc,UAAU,CAAA;AAGpE,EAAA,MAAM,OAAA,GAAU,mBAAA;AAAA,IACd,QAAA,CAAS,GAAA,CAAI,CAAC,CAAA,KAAM,EAAE,WAAW,CAAA;AAAA,IACjC,WAAA,CAAY,GAAA,CAAI,CAAC,CAAA,KAAM,EAAE,WAAW,CAAA;AAAA,IACpC;AAAA,GACF;AAEA,EAAA,OAAO;AAAA,IACL,OAAA;AAAA,IACA,gBAAgB,YAAA,CAAa,UAAA;AAAA,IAC7B,cAAc,UAAA,CAAW,UAAA;AAAA,IACzB,OAAA,EAAS;AAAA,MACP,QAAA;AAAA,MACA,WAAA;AAAA,MACA,QAAA,EAAU;AAAA,KACZ;AAAA,IACA,gBAAgB,cAAA,IAAkB,MAAA;AAAA,IAClC,eAAA;AAAA,IACA,gBAAA;AAAA,IACA,WAAA;AAAA,IACA,UAAA,EAAY,WAAA,CAAY,GAAA,EAAI,GAAI,SAAA;AAAA,IAChC,SAAA,EAAW,KAAK,GAAA;AAAI,GACtB;AACF;AAKA,SAAS,eAAA,CACP,WAAA,EACA,SAAA,EACA,MAAA,EACuB;AACvB,EAAA,MAAM,gBAAuC,EAAC;AAE9C,EAAA,KAAA,MAAW,QAAA,IAAY,OAAO,iBAAA,EAAmB;AAC/C,IAAA,MAAM,SAAA,GAAY,gBAAA,CAAiB,WAAA,EAAa,QAAQ,CAAA;AACxD,IAAA,MAAM,OAAA,GAAU,gBAAA,CAAiB,SAAA,EAAW,QAAQ,CAAA;AAEpD,IAAA,IAAI,cAAc,OAAA,EAAS;AAEzB,MAAA,MAAM,aAAA,GAAgB,mBAAA,CAAoB,QAAA,EAAU,SAAA,EAAW,OAAO,CAAA;AAEtE,MAAA,IAAI,CAAC,MAAA,CAAO,mBAAA,IAAuB,aAAA,EAAe;AAChD,QAAA,aAAA,CAAc,IAAA,CAAK;AAAA,UACjB,WAAW,SAAA,CAAU,EAAA;AAAA,UACrB,aAAa,SAAA,CAAU,WAAA;AAAA,UACvB,QAAA;AAAA,UACA,IAAA,EAAM,YAAY,SAAS,CAAA;AAAA,UAC3B,EAAA,EAAI,YAAY,OAAO,CAAA;AAAA,UACvB,WAAA,EAAa;AAAA,SACd,CAAA;AAAA,MACH;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO,aAAA;AACT;AAKA,SAAS,gBAAA,CAAiB,SAA8B,QAAA,EAA2B;AACjF,EAAA,IAAI,QAAA,IAAY,QAAQ,KAAA,EAAO;AAC7B,IAAA,OAAO,OAAA,CAAQ,MAAM,QAAsC,CAAA;AAAA,EAC7D;AACA,EAAA,OAAO,QAAQ,QAAqC,CAAA;AACtD;AAKA,SAAS,mBAAA,CAAoB,QAAA,EAAkB,SAAA,EAAoB,OAAA,EAA2B;AAE5F,EAAA,IAAI,wBAAA,CAAyB,GAAA,CAAI,QAAQ,CAAA,EAAG;AAC1C,IAAA,OAAO,KAAA;AAAA,EACT;AAGA,EAAA,IAAI,aAAa,SAAA,EAAW;AAC1B,IAAA,OAAO,IAAA;AAAA,EACT;AAGA,EAAA,IAAI,aAAa,SAAA,EAAW;AAC1B,IAAA,OAAO,IAAA;AAAA,EACT;AAGA,EAAA,IAAI,aAAa,SAAA,EAAW;AAC1B,IAAA,OAAO,IAAA;AAAA,EACT;AAGA,EAAA,IAAI,aAAa,SAAA,EAAW;AAC1B,IAAA,OAAO,IAAA;AAAA,EACT;AAGA,EAAA,IAAI,aAAa,OAAA,EAAS;AACxB,IAAA,OAAO,OAAA,CAAQ,SAAS,CAAA,IAAK,OAAA,CAAQ,OAAO,CAAA;AAAA,EAC9C;AAGA,EAAA,IAAI,aAAa,aAAA,EAAe;AAC9B,IAAA,MAAM,QAAA,GAAW,MAAA,CAAO,SAAA,IAAa,EAAE,CAAA;AACvC,IAAA,MAAM,MAAA,GAAS,MAAA,CAAO,OAAA,IAAW,EAAE,CAAA;AAEnC,IAAA,OAAO,QAAA,CAAS,IAAA,EAAK,KAAM,MAAA,CAAO,IAAA,EAAK;AAAA,EACzC;AAEA,EAAA,OAAO,IAAA;AACT;AAKA,SAAS,YAAY,KAAA,EAAwB;AAC3C,EAAA,IAAI,KAAA,KAAU,QAAW,OAAO,WAAA;AAChC,EAAA,IAAI,KAAA,KAAU,MAAM,OAAO,MAAA;AAC3B,EAAA,IAAI,OAAO,KAAA,KAAU,SAAA,EAAW,OAAO,QAAQ,MAAA,GAAS,OAAA;AACxD,EAAA,IAAI,OAAO,UAAU,QAAA,EAAU;AAE7B,IAAA,IAAI,KAAA,CAAM,SAAS,EAAA,EAAI;AACrB,MAAA,OAAO,KAAA,CAAM,SAAA,CAAU,CAAA,EAAG,EAAE,CAAA,GAAI,KAAA;AAAA,IAClC;AACA,IAAA,OAAO,KAAA;AAAA,EACT;AACA,EAAA,IAAI,OAAO,UAAU,QAAA,EAAU;AAC7B,IAAA,OAAO,IAAA,CAAK,UAAU,KAAK,CAAA;AAAA,EAC7B;AACA,EAAA,OAAO,OAAO,KAAK,CAAA;AACrB;AAKA,SAAS,aAAA,CACP,QAAA,EACA,WAAA,EACA,QAAA,EACoB;AAEpB,EAAA,MAAM,eAAe,QAAA,CAAS,IAAA;AAAA,IAC5B,CAAC,CAAA,KAAM,CAAA,CAAE,WAAA,CAAY,WAAA,GAAc,QAAA,CAAS,OAAO,CAAA,IAAK,CAAA,CAAE,IAAA,KAAS;AAAA,GACrE;AACA,EAAA,IAAI,YAAA,EAAc;AAChB,IAAA,OAAO,iBAAA;AAAA,EACT;AAGA,EAAA,MAAM,cAAc,QAAA,CAAS,IAAA;AAAA,IAC3B,CAAC,MAAM,CAAA,CAAE,IAAA,KAAS,YAAY,CAAA,CAAE,YAAA,EAAc,SAAS,QAAQ;AAAA,GACjE;AACA,EAAA,IAAI,WAAA,EAAa;AACf,IAAA,OAAO,cAAA;AAAA,EACT;AAGA,EAAA,MAAM,oBAAoB,WAAA,CAAY,IAAA;AAAA,IACpC,CAAC,MAAM,CAAA,CAAE,IAAA,KAAS,YAAY,CAAA,CAAE,YAAA,EAAc,SAAS,QAAQ;AAAA,GACjE;AACA,EAAA,IAAI,iBAAA,EAAmB;AACrB,IAAA,OAAO,cAAA;AAAA,EACT;AAGA,EAAA,MAAM,UAAA,GAAa,QAAA,CAAS,IAAA,CAAK,CAAC,CAAA,KAAM,CAAA,CAAE,WAAA,CAAY,WAAA,EAAY,CAAE,QAAA,CAAS,SAAS,CAAC,CAAA;AACvF,EAAA,IAAI,UAAA,EAAY;AACd,IAAA,OAAO,sBAAA;AAAA,EACT;AAGA,EAAA,MAAM,iBAAiB,QAAA,CAAS,IAAA,CAAK,CAAC,CAAA,KAAM,CAAA,CAAE,aAAa,SAAS,CAAA;AACpE,EAAA,IAAI,cAAA,IAAkB,QAAA,CAAS,MAAA,IAAU,CAAA,EAAG;AAC1C,IAAA,OAAO,eAAA;AAAA,EACT;AAGA,EAAA,MAAM,iBAAiB,QAAA,CAAS,IAAA,CAAK,CAAC,CAAA,KAAM,CAAA,CAAE,aAAa,OAAO,CAAA;AAClE,EAAA,IAAI,cAAA,IAAkB,QAAA,CAAS,MAAA,IAAU,CAAA,EAAG;AAC1C,IAAA,OAAO,YAAA;AAAA,EACT;AAGA,EAAA,MAAM,oBAAoB,QAAA,CAAS,MAAA,CAAO,CAAC,CAAA,KAAM,CAAA,CAAE,aAAa,SAAS,CAAA;AACzE,EAAA,IAAI,iBAAA,CAAkB,MAAA,GAAS,CAAA,IAAK,iBAAA,CAAkB,UAAU,CAAA,EAAG;AACjE,IAAA,OAAO,uBAAA;AAAA,EACT;AAGA,EAAA,IAAI,QAAA,CAAS,SAAS,CAAA,EAAG;AACvB,IAAA,OAAO,iBAAA;AAAA,EACT;AAEA,EAAA,OAAO,MAAA;AACT;AAKA,SAAS,iBAAA,CACP,cACA,UAAA,EACyC;AACzC,EAAA,MAAM,UAAA,GAAa,YAAA,CAAa,IAAA,CAAK,GAAA,KAAQ,WAAW,IAAA,CAAK,GAAA;AAC7D,EAAA,MAAM,YAAA,GAAe,YAAA,CAAa,IAAA,CAAK,KAAA,KAAU,WAAW,IAAA,CAAK,KAAA;AAEjE,EAAA,IAAI,CAAC,UAAA,IAAc,CAAC,YAAA,EAAc;AAChC,IAAA,OAAO,MAAA;AAAA,EACT;AAEA,EAAA,OAAO;AAAA,IACL,UAAA;AAAA,IACA,YAAA;AAAA,IACA,MAAA,EAAQ,UAAA,GAAa,UAAA,CAAW,IAAA,CAAK,GAAA,GAAM,MAAA;AAAA,IAC3C,QAAA,EAAU,YAAA,GAAe,UAAA,CAAW,IAAA,CAAK,KAAA,GAAQ;AAAA,GACnD;AACF;AAKA,SAAS,gCAAA,CACP,QAAA,EACA,WAAA,EACA,QAAA,EACA,OAAA,EACU;AACV,EAAA,MAAM,cAAwB,EAAC;AAG/B,EAAA,IAAI,YAAY,iBAAA,EAAmB;AACjC,IAAA,WAAA,CAAY,KAAK,6CAA6C,CAAA;AAAA,EAChE;AAEA,EAAA,IAAI,YAAY,cAAA,EAAgB;AAC9B,IAAA,MAAM,KAAA,GAAQ,QAAA,CAAS,IAAA,CAAK,CAAC,CAAA,KAAM,CAAA,CAAE,IAAA,KAAS,QAAA,IAAY,CAAA,CAAE,YAAA,EAAc,QAAA,CAAS,QAAQ,CAAC,CAAA;AAC5F,IAAA,IAAI,KAAA,EAAO;AACT,MAAA,WAAA,CAAY,IAAA,CAAK,CAAA,mBAAA,EAAsB,KAAA,CAAM,WAAW,CAAA,QAAA,CAAU,CAAA;AAAA,IACpE;AAAA,EACF;AAEA,EAAA,IAAI,YAAY,cAAA,EAAgB;AAC9B,IAAA,WAAA,CAAY,KAAK,yCAAyC,CAAA;AAAA,EAC5D;AAGA,EAAA,KAAA,MAAW,OAAA,IAAW,QAAA,CAAS,KAAA,CAAM,CAAA,EAAG,CAAC,CAAA,EAAG;AAC1C,IAAA,IAAI,OAAA,CAAQ,IAAA,KAAS,QAAA,IAAY,OAAA,CAAQ,iBAAiB,eAAA,EAAiB;AACzE,MAAA,WAAA,CAAY,IAAA,CAAK,CAAA,WAAA,EAAc,OAAA,CAAQ,WAAW,CAAA,YAAA,CAAc,CAAA;AAAA,IAClE;AACA,IAAA,IAAI,QAAQ,WAAA,CAAY,WAAA,EAAY,CAAE,QAAA,CAAS,OAAO,CAAA,EAAG;AACvD,MAAA,WAAA,CAAY,IAAA,CAAK,CAAA,mBAAA,EAAsB,OAAA,CAAQ,WAAW,CAAA,CAAE,CAAA;AAAA,IAC9D;AAAA,EACF;AAGA,EAAA,KAAA,MAAW,GAAA,IAAO,QAAA,CAAS,KAAA,CAAM,CAAA,EAAG,CAAC,CAAA,EAAG;AACtC,IAAA,IAAI,GAAA,CAAI,QAAA,KAAa,SAAA,IAAa,GAAA,CAAI,OAAO,MAAA,EAAQ;AACnD,MAAA,WAAA,CAAY,IAAA,CAAK,CAAA,CAAA,EAAI,GAAA,CAAI,WAAW,CAAA,gBAAA,CAAkB,CAAA;AAAA,IACxD;AACA,IAAA,IAAI,GAAA,CAAI,QAAA,KAAa,SAAA,IAAa,GAAA,CAAI,OAAO,MAAA,EAAQ;AACnD,MAAA,WAAA,CAAY,IAAA,CAAK,CAAA,CAAA,EAAI,GAAA,CAAI,WAAW,CAAA,gBAAA,CAAkB,CAAA;AAAA,IACxD;AAAA,EACF;AAEA,EAAA,OAAO,WAAA,CAAY,KAAA,CAAM,CAAA,EAAG,CAAC,CAAA;AAC/B;AAKO,IAAM,sBAAN,MAA0B;AAAA,EAI/B,WAAA,CAAY,MAAA,GAAsC,EAAC,EAAG;AAFtD,IAAA,IAAA,CAAQ,YAAA,GAAwC,IAAA;AAG9C,IAAA,IAAA,CAAK,MAAA,GAAS,EAAE,GAAG,mBAAA,EAAqB,GAAG,MAAA,EAAO;AAAA,EACpD;AAAA;AAAA;AAAA;AAAA,EAKA,OAAO,WAAA,EAAoD;AACzD,IAAA,IAAI,CAAC,KAAK,YAAA,EAAc;AACtB,MAAA,IAAA,CAAK,YAAA,GAAe,WAAA;AACpB,MAAA,OAAO,IAAA;AAAA,IACT;AAEA,IAAA,MAAM,OAAO,WAAA,CAAY,IAAA,CAAK,YAAA,EAAc,WAAA,EAAa,KAAK,MAAM,CAAA;AACpE,IAAA,IAAA,CAAK,YAAA,GAAe,WAAA;AACpB,IAAA,OAAO,IAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,SAAS,YAAA,EAAqD;AAC5D,IAAA,IAAI,CAAC,IAAA,CAAK,YAAA,EAAc,OAAO,IAAA;AAC/B,IAAA,OAAO,WAAA,CAAY,YAAA,EAAc,IAAA,CAAK,YAAA,EAAc,KAAK,MAAM,CAAA;AAAA,EACjE;AAAA;AAAA;AAAA;AAAA,EAKA,KAAA,GAAc;AACZ,IAAA,IAAA,CAAK,YAAA,GAAe,IAAA;AAAA,EACtB;AAAA;AAAA;AAAA;AAAA,EAKA,eAAA,GAA2C;AACzC,IAAA,OAAO,IAAA,CAAK,YAAA;AAAA,EACd;AACF,CAAA;AAmEA,IAAM,oBAAA,mBAAuB,IAAI,GAAA,CAAI,CAAC,cAAc,CAAC,CAAA;AAKrD,IAAM,uCAAuB,IAAI,GAAA,CAAI,CAAC,gBAAA,EAAkB,OAAO,CAAC,CAAA;AAKhE,IAAM,qBAAA,mBAAwB,IAAI,GAAA,CAAI,CAAC,SAAS,CAAC,CAAA;AAKjD,SAAS,iBAAiB,OAAA,EAAuC;AAC/D,EAAA,OAAO,OAAA,CAAQ,QAAA,KAAa,SAAA,IAAa,OAAA,CAAQ,eAAA,KAAoB,MAAA;AACvE;AAKA,SAAS,eAAe,OAAA,EAAsC;AAC5D,EAAA,IAAI,OAAA,CAAQ,iBAAiB,WAAA,EAAa;AACxC,IAAA,OAAO,QAAQ,eAAA,CAAgB,WAAA;AAAA,EACjC;AAEA,EAAA,OAAO,OAAA,CAAQ,IAAA;AACjB;AAKA,SAAS,oBAAA,CACP,cACA,UAAA,EACuB;AACvB,EAAA,MAAM,cAA4B,EAAC;AACnC,EAAA,MAAM,gBAAgC,EAAC;AACvC,EAAA,MAAM,gBAAgC,EAAC;AAGvC,EAAA,KAAA,MAAW,CAAC,EAAA,EAAI,SAAS,CAAA,IAAK,UAAA,EAAY;AACxC,IAAA,MAAM,WAAA,GAAc,YAAA,CAAa,GAAA,CAAI,EAAE,CAAA;AAEvC,IAAA,IAAI,WAAA,EAAa;AAEf,MAAA,IAAI,gBAAA,CAAiB,SAAS,CAAA,IAAK,gBAAA,CAAiB,WAAW,CAAA,EAAG;AAChE,QAAA,MAAM,QAAA,GAAA,CAAY,WAAA,CAAY,KAAA,CAAM,WAAA,IAAe,IAAI,IAAA,EAAK;AAC5D,QAAA,MAAM,MAAA,GAAA,CAAU,SAAA,CAAU,KAAA,CAAM,WAAA,IAAe,IAAI,IAAA,EAAK;AAExD,QAAA,IAAI,aAAa,MAAA,EAAQ;AACvB,UAAA,MAAM,WAAA,GAAc,eAAe,SAAS,CAAA;AAC5C,UAAA,MAAM,KAAA,GAAQ,SAAA,CAAU,WAAA,IAAe,SAAA,CAAU,cAAA,IAAkB,EAAA;AAGnE,UAAA,IAAI,oBAAA,CAAqB,GAAA,CAAI,WAAW,CAAA,IAAK,gBAAgB,QAAA,EAAU;AACrE,YAAA,MAAM,MAAA,GAAS,iBAAA,CAAkB,QAAA,EAAU,MAAA,EAAQ,IAAI,KAAK,CAAA;AAC5D,YAAA,IAAI,MAAA,EAAQ;AACV,cAAA,aAAA,CAAc,KAAK,MAAM,CAAA;AAAA,YAC3B;AAAA,UACF,WAAW,oBAAA,CAAqB,GAAA,CAAI,WAAW,CAAA,IAAK,gBAAgB,QAAA,EAAU;AAC5E,YAAA,aAAA,CAAc,IAAA,CAAK;AAAA,cACjB,SAAA,EAAW,EAAA;AAAA,cACX,KAAA;AAAA,cACA,SAAA,EAAW,QAAA;AAAA,cACX,SAAA,EAAW,MAAA;AAAA,cACX,SAAA,EAAW,uBAAA,CAAwB,QAAA,EAAU,MAAM;AAAA,aACpD,CAAA;AAAA,UACH,CAAA,MAAO;AACL,YAAA,WAAA,CAAY,IAAA,CAAK;AAAA,cACf,SAAA,EAAW,EAAA;AAAA,cACX,WAAA;AAAA,cACA,OAAA,EAAS,QAAA;AAAA,cACT,OAAA,EAAS,MAAA;AAAA,cACT,UAAA,EAAY;AAAA,aACb,CAAA;AAAA,UACH;AAAA,QACF;AAAA,MACF;AAAA,IACF,CAAA,MAAO;AAEL,MAAA,IAAI,gBAAA,CAAiB,SAAS,CAAA,EAAG;AAC/B,QAAA,MAAM,MAAA,GAAA,CAAU,SAAA,CAAU,KAAA,CAAM,WAAA,IAAe,IAAI,IAAA,EAAK;AACxD,QAAA,IAAI,MAAA,EAAQ;AACV,UAAA,WAAA,CAAY,IAAA,CAAK;AAAA,YACf,SAAA,EAAW,EAAA;AAAA,YACX,WAAA,EAAa,eAAe,SAAS,CAAA;AAAA,YACrC,OAAA,EAAS,EAAA;AAAA,YACT,OAAA,EAAS,MAAA;AAAA,YACT,UAAA,EAAY;AAAA,WACb,CAAA;AAAA,QACH;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAGA,EAAA,KAAA,MAAW,CAAC,EAAA,EAAI,WAAW,CAAA,IAAK,YAAA,EAAc;AAC5C,IAAA,IAAI,CAAC,UAAA,CAAW,GAAA,CAAI,EAAE,CAAA,IAAK,gBAAA,CAAiB,WAAW,CAAA,EAAG;AACxD,MAAA,MAAM,QAAA,GAAA,CAAY,WAAA,CAAY,KAAA,CAAM,WAAA,IAAe,IAAI,IAAA,EAAK;AAC5D,MAAA,IAAI,QAAA,EAAU;AACZ,QAAA,WAAA,CAAY,IAAA,CAAK;AAAA,UACf,SAAA,EAAW,EAAA;AAAA,UACX,WAAA,EAAa,eAAe,WAAW,CAAA;AAAA,UACvC,OAAA,EAAS,QAAA;AAAA,UACT,OAAA,EAAS,EAAA;AAAA,UACT,UAAA,EAAY;AAAA,SACb,CAAA;AAAA,MACH;AAAA,IACF;AAAA,EACF;AAGA,EAAA,IAAI,WAAA,CAAY,WAAW,CAAA,IAAK,aAAA,CAAc,WAAW,CAAA,IAAK,aAAA,CAAc,WAAW,CAAA,EAAG;AACxF,IAAA,OAAO,IAAA;AAAA,EACT;AAEA,EAAA,OAAO;AAAA,IACL,WAAA;AAAA,IACA,aAAA;AAAA,IACA,aAAA;AAAA,IACA,OAAA,EAAS,4BAAA,CAA6B,WAAA,EAAa,aAAA,EAAe,aAAa;AAAA,GACjF;AACF;AAgBO,SAAS,kBAAkB,IAAA,EAA6B;AAC7D,EAAA,MAAM,OAAA,GAAU,KAAK,IAAA,EAAK;AAC1B,EAAA,IAAI,CAAC,SAAS,OAAO,IAAA;AAGrB,EAAA,IAAI,OAAA,GAAU,OAAA;AACd,EAAA,IAAI,MAAA,GAAS,KAAA;AACb,EAAA,IAAI,QAAQ,UAAA,CAAW,GAAG,KAAK,OAAA,CAAQ,QAAA,CAAS,GAAG,CAAA,EAAG;AACpD,IAAA,OAAA,GAAU,OAAA,CAAQ,KAAA,CAAM,CAAA,EAAG,EAAE,EAAE,IAAA,EAAK;AACpC,IAAA,MAAA,GAAS,IAAA;AAAA,EACX;AAGA,EAAA,IAAI,OAAA,CAAQ,UAAA,CAAW,GAAG,CAAA,EAAG;AAC3B,IAAA,MAAA,GAAS,CAAC,MAAA;AACV,IAAA,OAAA,GAAU,OAAA,CAAQ,KAAA,CAAM,CAAC,CAAA,CAAE,IAAA,EAAK;AAAA,EAClC;AACA,EAAA,IAAI,OAAA,CAAQ,UAAA,CAAW,GAAG,CAAA,EAAG;AAC3B,IAAA,OAAA,GAAU,OAAA,CAAQ,KAAA,CAAM,CAAC,CAAA,CAAE,IAAA,EAAK;AAAA,EAClC;AAGA,EAAA,OAAA,GAAU,OAAA,CAAQ,OAAA,CAAQ,UAAA,EAAY,EAAE,EAAE,IAAA,EAAK;AAG/C,EAAA,MAAM,SAAA,GAAY,OAAA,CAAQ,QAAA,CAAS,GAAG,CAAA;AACtC,EAAA,IAAI,SAAA,EAAW;AACb,IAAA,OAAA,GAAU,OAAA,CAAQ,KAAA,CAAM,CAAA,EAAG,EAAE,EAAE,IAAA,EAAK;AAAA,EACtC;AAGA,EAAA,OAAA,GAAU,OAAA,CAAQ,OAAA,CAAQ,0CAAA,EAA4C,EAAE,EAAE,IAAA,EAAK;AAG/E,EAAA,OAAA,GAAU,OAAA,CAAQ,OAAA,CAAQ,IAAA,EAAM,EAAE,CAAA;AAGlC,EAAA,MAAM,GAAA,GAAM,OAAO,OAAO,CAAA;AAC1B,EAAA,IAAI,KAAA,CAAM,GAAG,CAAA,IAAK,CAAC,SAAS,GAAG,CAAA,IAAK,YAAY,EAAA,EAAI;AAClD,IAAA,OAAO,IAAA;AAAA,EACT;AAEA,EAAA,OAAO,MAAA,GAAS,CAAC,GAAA,GAAM,GAAA;AACzB;AAKA,SAAS,iBAAA,CACP,QAAA,EACA,MAAA,EACA,SAAA,EACA,KAAA,EACqB;AACrB,EAAA,MAAM,OAAA,GAAU,kBAAkB,QAAQ,CAAA;AAC1C,EAAA,MAAM,KAAA,GAAQ,kBAAkB,MAAM,CAAA;AAEtC,EAAA,IAAI,YAAA;AACJ,EAAA,IAAI,aAAA;AACJ,EAAA,IAAI,WAAA,GAAc,KAAA;AAElB,EAAA,IAAI,OAAA,KAAY,IAAA,IAAQ,KAAA,KAAU,IAAA,EAAM;AACtC,IAAA,YAAA,GAAe,KAAA,GAAQ,OAAA;AAEvB,IAAA,IAAI,YAAY,CAAA,EAAG;AACjB,MAAA,aAAA,GAAA,CAAkB,KAAA,GAAQ,OAAA,IAAW,IAAA,CAAK,GAAA,CAAI,OAAO,CAAA,GAAK,GAAA;AAAA,IAC5D;AAGA,IAAA,IAAI,kBAAkB,MAAA,IAAa,IAAA,CAAK,GAAA,CAAI,aAAa,IAAI,EAAA,EAAI;AAC/D,MAAA,WAAA,GAAc,IAAA;AAAA,IAChB;AACA,IAAA,IAAI,OAAA,GAAU,CAAA,IAAK,KAAA,GAAQ,CAAA,EAAG,WAAA,GAAc,IAAA;AAC5C,IAAA,IAAI,OAAA,GAAU,CAAA,IAAK,KAAA,GAAQ,CAAA,EAAG,WAAA,GAAc,IAAA;AAC5C,IAAA,IAAI,OAAA,KAAY,CAAA,IAAK,KAAA,KAAU,CAAA,EAAG,WAAA,GAAc,IAAA;AAChD,IAAA,IAAI,OAAA,KAAY,CAAA,IAAK,KAAA,KAAU,CAAA,EAAG,WAAA,GAAc,IAAA;AAAA,EAClD,CAAA,MAAO;AAEL,IAAA,WAAA,GAAc,QAAA,KAAa,MAAA;AAAA,EAC7B;AAEA,EAAA,OAAO;AAAA,IACL,SAAA;AAAA,IACA,KAAA;AAAA,IACA,QAAA,EAAU,QAAA;AAAA,IACV,QAAA,EAAU,MAAA;AAAA,IACV,YAAA;AAAA,IACA,aAAA,EAAe,kBAAkB,MAAA,GAAY,IAAA,CAAK,MAAM,aAAA,GAAgB,GAAG,IAAI,GAAA,GAAM,MAAA;AAAA,IACrF;AAAA,GACF;AACF;AAUA,IAAM,mBAAA,GAAkC;AAAA,EACtC;AAAA,IACE,QAAA;AAAA,IACA,OAAA;AAAA,IACA,SAAA;AAAA,IACA,QAAA;AAAA,IACA,SAAA;AAAA,IACA,aAAA;AAAA,IACA,WAAA;AAAA,IACA,SAAA;AAAA,IACA;AAAA,GACF;AAAA,EACA,CAAC,cAAA,EAAgB,YAAA,EAAc,WAAW,CAAA;AAAA,EAC1C,CAAC,WAAA,EAAa,UAAA,EAAY,SAAS,CAAA;AAAA,EACnC,CAAC,WAAW,QAAQ,CAAA;AAAA,EACpB,CAAC,YAAY,QAAQ,CAAA;AAAA,EACrB,CAAC,YAAY,SAAS,CAAA;AAAA,EACtB,CAAC,QAAQ,IAAI,CAAA;AAAA,EACb,CAAC,SAAA,EAAW,UAAA,EAAY,SAAA,EAAW,SAAS,CAAA;AAAA,EAC5C,CAAC,UAAU,MAAM,CAAA;AAAA,EACjB,CAAC,WAAW,WAAW,CAAA;AAAA,EACvB,CAAC,UAAA,EAAY,SAAA,EAAW,UAAU,CAAA;AAAA,EAClC,CAAC,UAAA,EAAY,SAAA,EAAW,MAAA,EAAQ,IAAI,CAAA;AAAA,EACpC,CAAC,KAAA,EAAO,QAAA,EAAU,OAAO;AAC3B,CAAA;AAKO,SAAS,uBAAA,CACd,WACA,SAAA,EACqC;AACrC,EAAA,MAAM,QAAA,GAAW,SAAA,CAAU,WAAA,EAAY,CAAE,IAAA,EAAK;AAC9C,EAAA,MAAM,QAAA,GAAW,SAAA,CAAU,WAAA,EAAY,CAAE,IAAA,EAAK;AAE9C,EAAA,KAAA,MAAW,eAAe,mBAAA,EAAqB;AAC7C,IAAA,IAAI,QAAA,GAAW,EAAA;AACf,IAAA,IAAI,QAAA,GAAW,EAAA;AAEf,IAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,WAAA,CAAY,QAAQ,CAAA,EAAA,EAAK;AAC3C,MAAA,IAAI,SAAS,QAAA,CAAS,WAAA,CAAY,CAAC,CAAC,GAAG,QAAA,GAAW,CAAA;AAClD,MAAA,IAAI,SAAS,QAAA,CAAS,WAAA,CAAY,CAAC,CAAC,GAAG,QAAA,GAAW,CAAA;AAAA,IACpD;AAEA,IAAA,IAAI,QAAA,IAAY,CAAA,IAAK,QAAA,IAAY,CAAA,IAAK,aAAa,QAAA,EAAU;AAC3D,MAAA,OAAO,QAAA,GAAW,WAAW,UAAA,GAAa,UAAA;AAAA,IAC5C;AAAA,EACF;AAEA,EAAA,OAAO,SAAA;AACT;AASA,SAAS,4BAAA,CACP,WAAA,EACA,aAAA,EACA,aAAA,EACQ;AACR,EAAA,MAAM,QAAkB,EAAC;AAGzB,EAAA,MAAM,QAAA,GAAW,YAAY,MAAA,CAAO,CAAC,MAAM,CAAA,CAAE,UAAA,KAAe,UAAU,CAAA,CAAE,MAAA;AACxE,EAAA,MAAM,KAAA,GAAQ,YAAY,MAAA,CAAO,CAAC,MAAM,CAAA,CAAE,UAAA,KAAe,OAAO,CAAA,CAAE,MAAA;AAClE,EAAA,MAAM,OAAA,GAAU,YAAY,MAAA,CAAO,CAAC,MAAM,CAAA,CAAE,UAAA,KAAe,SAAS,CAAA,CAAE,MAAA;AAGtE,EAAA,MAAM,iBAAiB,WAAA,CAAY,MAAA;AAAA,IACjC,CAAC,MAAM,qBAAA,CAAsB,GAAA,CAAI,EAAE,WAAW,CAAA,IAAK,EAAE,WAAA,KAAgB;AAAA,GACvE;AACA,EAAA,IAAI,cAAA,CAAe,SAAS,CAAA,EAAG;AAC7B,IAAA,KAAA,CAAM,IAAA,CAAK,CAAA,EAAG,cAAA,CAAe,MAAM,CAAA,QAAA,EAAW,eAAe,MAAA,GAAS,CAAA,GAAI,GAAA,GAAM,EAAE,CAAA,QAAA,CAAU,CAAA;AAAA,EAC9F;AAGA,EAAA,IAAI,aAAA,CAAc,SAAS,CAAA,EAAG;AAC5B,IAAA,MAAM,qBAAqB,aAAA,CAAc,MAAA,CAAO,CAAC,CAAA,KAAM,EAAE,WAAW,CAAA;AACpE,IAAA,IAAI,kBAAA,CAAmB,SAAS,CAAA,EAAG;AACjC,MAAA,KAAA,CAAM,IAAA;AAAA,QACJ,CAAA,EAAG,mBAAmB,MAAM,CAAA,OAAA,EAAU,mBAAmB,MAAA,GAAS,CAAA,GAAI,MAAM,EAAE,CAAA,sBAAA;AAAA,OAChF;AAAA,IACF,CAAA,MAAO;AACL,MAAA,KAAA,CAAM,IAAA,CAAK,CAAA,EAAG,aAAA,CAAc,MAAM,CAAA,OAAA,EAAU,cAAc,MAAA,GAAS,CAAA,GAAI,GAAA,GAAM,EAAE,CAAA,QAAA,CAAU,CAAA;AAAA,IAC3F;AAAA,EACF;AAGA,EAAA,IAAI,aAAA,CAAc,SAAS,CAAA,EAAG;AAC5B,IAAA,MAAM,WAAW,aAAA,CAAc,MAAA,CAAO,CAAC,CAAA,KAAM,CAAA,CAAE,cAAc,UAAU,CAAA;AACvE,IAAA,MAAM,WAAW,aAAA,CAAc,MAAA,CAAO,CAAC,CAAA,KAAM,CAAA,CAAE,cAAc,UAAU,CAAA;AAEvE,IAAA,IAAI,QAAA,CAAS,SAAS,CAAA,EAAG;AACvB,MAAA,KAAA,CAAM,IAAA,CAAK,CAAA,EAAG,QAAA,CAAS,MAAM,CAAA,OAAA,EAAU,SAAS,MAAA,GAAS,CAAA,GAAI,IAAA,GAAO,EAAE,CAAA,SAAA,CAAW,CAAA;AAAA,IACnF;AACA,IAAA,IAAI,QAAA,CAAS,SAAS,CAAA,EAAG;AACvB,MAAA,KAAA,CAAM,IAAA,CAAK,CAAA,EAAG,QAAA,CAAS,MAAM,CAAA,OAAA,EAAU,SAAS,MAAA,GAAS,CAAA,GAAI,IAAA,GAAO,EAAE,CAAA,SAAA,CAAW,CAAA;AAAA,IACnF;AACA,IAAA,MAAM,OAAA,GAAU,aAAA,CAAc,MAAA,GAAS,QAAA,CAAS,SAAS,QAAA,CAAS,MAAA;AAClE,IAAA,IAAI,UAAU,CAAA,IAAK,QAAA,CAAS,WAAW,CAAA,IAAK,QAAA,CAAS,WAAW,CAAA,EAAG;AACjE,MAAA,KAAA,CAAM,IAAA,CAAK,GAAG,OAAO,CAAA,OAAA,EAAU,UAAU,CAAA,GAAI,IAAA,GAAO,EAAE,CAAA,QAAA,CAAU,CAAA;AAAA,IAClE;AAAA,EACF;AAGA,EAAA,MAAM,aAAA,GAAgB,WAAW,cAAA,CAAe,MAAA,CAAO,CAAC,CAAA,KAAM,CAAA,CAAE,UAAA,KAAe,UAAU,CAAA,CAAE,MAAA;AAC3F,EAAA,IAAI,gBAAgB,CAAA,EAAG;AACrB,IAAA,KAAA,CAAM,IAAA,CAAK,GAAG,aAAa,CAAA,KAAA,EAAQ,gBAAgB,CAAA,GAAI,SAAA,GAAY,QAAQ,CAAA,SAAA,CAAW,CAAA;AAAA,EACxF;AAEA,EAAA,IAAI,QAAQ,CAAA,EAAG;AACb,IAAA,KAAA,CAAM,IAAA,CAAK,GAAG,KAAK,CAAA,QAAA,EAAW,QAAQ,CAAA,GAAI,WAAA,GAAc,UAAU,CAAA,MAAA,CAAQ,CAAA;AAAA,EAC5E;AAEA,EAAA,IAAI,UAAU,CAAA,EAAG;AACf,IAAA,KAAA,CAAM,IAAA,CAAK,GAAG,OAAO,CAAA,QAAA,EAAW,UAAU,CAAA,GAAI,WAAA,GAAc,UAAU,CAAA,QAAA,CAAU,CAAA;AAAA,EAClF;AAEA,EAAA,IAAI,KAAA,CAAM,WAAW,CAAA,EAAG;AACtB,IAAA,OAAO,oBAAA;AAAA,EACT;AAEA,EAAA,OAAO,KAAA,CAAM,KAAK,IAAI,CAAA;AACxB;;;ACp1BO,IAAM,8BAAA,GAAuD;AAAA,EAClE,aAAA,EAAe,GAAA;AAAA,EACf,mBAAA,EAAqB;AACvB,CAAA;AAKO,SAAS,iBAAiB,KAAA,EAAuD;AACtF,EAAA,MAAM,OAAA,GAAU,MAAM,IAAA,EAAK;AAC3B,EAAA,IAAI,CAAC,OAAA,EAAS,OAAO,EAAE,IAAA,EAAM,SAAA,EAAW,YAAY,CAAA,EAAE;AAGtD,EAAA,IAAI,+BAAA,CAAgC,IAAA,CAAK,OAAO,CAAA,EAAG;AACjD,IAAA,OAAO,EAAE,IAAA,EAAM,SAAA,EAAW,UAAA,EAAY,IAAA,EAAK;AAAA,EAC7C;AAGA,EAAA,IAAI,4BAAA,CAA6B,IAAA,CAAK,OAAO,CAAA,EAAG;AAC9C,IAAA,OAAO,EAAE,IAAA,EAAM,OAAA,EAAS,UAAA,EAAY,IAAA,EAAK;AAAA,EAC3C;AAGA,EAAA,IAAI,iBAAA,CAAkB,IAAA,CAAK,OAAO,CAAA,EAAG;AACnC,IAAA,OAAO,EAAE,IAAA,EAAM,KAAA,EAAO,UAAA,EAAY,IAAA,EAAK;AAAA,EACzC;AAGA,EAAA,IAAI,0BAA0B,IAAA,CAAK,OAAO,KAAK,QAAA,CAAS,IAAA,CAAK,OAAO,CAAA,EAAG;AACrE,IAAA,OAAO,EAAE,IAAA,EAAM,OAAA,EAAS,UAAA,EAAY,GAAA,EAAI;AAAA,EAC1C;AAGA,EAAA,IAAI,wBAAwB,IAAA,CAAK,OAAO,KAAK,uBAAA,CAAwB,IAAA,CAAK,OAAO,CAAA,EAAG;AAClF,IAAA,OAAO,EAAE,IAAA,EAAM,UAAA,EAAY,UAAA,EAAY,GAAA,EAAI;AAAA,EAC7C;AAGA,EAAA,IAAI,eAAA,CAAgB,IAAA,CAAK,OAAO,CAAA,EAAG;AACjC,IAAA,OAAO,EAAE,IAAA,EAAM,YAAA,EAAc,UAAA,EAAY,IAAA,EAAK;AAAA,EAChD;AAGA,EAAA,IACE,oBAAA,CAAqB,IAAA,CAAK,OAAO,CAAA,IACjC,8BAA8B,IAAA,CAAK,OAAO,CAAA,IAC1C,6BAAA,CAA8B,KAAK,OAAO,CAAA,IAC1C,+BAAA,CAAgC,IAAA,CAAK,OAAO,CAAA,EAC5C;AACA,IAAA,OAAO,EAAE,IAAA,EAAM,MAAA,EAAQ,UAAA,EAAY,IAAA,EAAK;AAAA,EAC1C;AAGA,EAAA,IAAI,kBAAA,CAAmB,IAAA,CAAK,OAAO,CAAA,IAAK,YAAY,EAAA,EAAI;AACtD,IAAA,OAAO,EAAE,IAAA,EAAM,QAAA,EAAU,UAAA,EAAY,GAAA,EAAI;AAAA,EAC3C;AAGA,EAAA,OAAO,EAAE,IAAA,EAAM,MAAA,EAAQ,UAAA,EAAY,GAAA,EAAI;AACzC;AAKO,SAAS,cAAA,CAAe,OAAe,QAAA,EAA4B;AACxE,EAAA,MAAM,OAAA,GAAU,MAAM,IAAA,EAAK;AAE3B,EAAA,QAAQ,QAAA;AAAU,IAChB,KAAK,QAAA;AAAA,IACL,KAAK,UAAA;AAAA,IACL,KAAK,YAAA,EAAc;AAEjB,MAAA,MAAM,OAAA,GAAU,OAAA,CAAQ,OAAA,CAAQ,WAAA,EAAa,EAAE,CAAA;AAC/C,MAAA,MAAM,MAAA,GAAS,WAAW,OAAO,CAAA;AACjC,MAAA,OAAO,MAAM,MAAM,CAAA,GAAI,QAAQ,WAAA,EAAY,GAAI,OAAO,QAAA,EAAS;AAAA,IACjE;AAAA,IACA,KAAK,MAAA,EAAQ;AAEX,MAAA,MAAM,CAAA,GAAI,IAAI,IAAA,CAAK,OAAO,CAAA;AAC1B,MAAA,OAAO,KAAA,CAAM,CAAA,CAAE,OAAA,EAAS,IAAI,OAAA,CAAQ,WAAA,EAAY,GAAI,CAAA,CAAE,WAAA,EAAY,CAAE,KAAA,CAAM,GAAG,EAAE,CAAC,CAAA;AAAA,IAClF;AAAA,IACA,KAAK,SAAA;AACH,MAAA,OAAO,kBAAA,CAAmB,IAAA,CAAK,OAAO,CAAA,GAAI,MAAA,GAAS,OAAA;AAAA,IACrD,KAAK,OAAA;AACH,MAAA,OAAO,QAAQ,WAAA,EAAY;AAAA,IAC7B,KAAK,KAAA;AAEH,MAAA,OAAO,OAAA,CAAQ,OAAA,CAAQ,MAAA,EAAQ,EAAE,EAAE,WAAA,EAAY;AAAA,IACjD,KAAK,OAAA;AAEH,MAAA,OAAO,OAAA,CAAQ,OAAA,CAAQ,SAAA,EAAW,EAAE,CAAA;AAAA,IACtC;AACE,MAAA,OAAO,OAAA,CAAQ,WAAA,EAAY,CAAE,OAAA,CAAQ,QAAQ,GAAG,CAAA;AAAA;AAEtD;AAKA,SAAS,oBAAoB,OAAA,EAAsC;AACjE,EAAA,MAAM,QAAQ,OAAA,CAAQ,KAAA;AACtB,EAAA,IAAI,KAAA,EAAO,KAAA,KAAU,MAAA,IAAa,KAAA,CAAM,UAAU,EAAA,EAAI;AACpD,IAAA,OAAO,MAAA,CAAO,MAAM,KAAK,CAAA;AAAA,EAC3B;AACA,EAAA,IAAI,KAAA,EAAO,WAAA,KAAgB,MAAA,IAAa,KAAA,CAAM,gBAAgB,EAAA,EAAI;AAChE,IAAA,OAAO,MAAA,CAAO,MAAM,WAAW,CAAA;AAAA,EACjC;AACA,EAAA,OAAO,EAAA;AACT;AAKA,SAAS,aAAa,OAAA,EAAsC;AAC1D,EAAA,OACE,OAAA,CAAQ,kBACR,OAAA,CAAQ,SAAA,IACR,QAAQ,KAAA,IACR,OAAA,CAAQ,eACR,OAAA,CAAQ,EAAA;AAEZ;AAKO,SAAS,eAAA,CACd,QAAA,EACA,MAAA,GAA+B,8BAAA,EAClB;AACb,EAAA,MAAM,SAA6C,EAAC;AACpD,EAAA,IAAI,cAAA,GAAiB,CAAA;AAErB,EAAA,KAAA,MAAW,WAAW,QAAA,EAAU;AAC9B,IAAA,MAAM,QAAA,GAAW,oBAAoB,OAAO,CAAA;AAC5C,IAAA,IAAI,CAAC,QAAA,EAAU;AAEf,IAAA,MAAM,KAAA,GAAQ,aAAa,OAAO,CAAA;AAClC,IAAA,MAAM,EAAE,IAAA,EAAM,QAAA,EAAU,UAAA,EAAW,GAAI,iBAAiB,QAAQ,CAAA;AAEhE,IAAA,IAAI,UAAA,GAAa,OAAO,aAAA,EAAe;AAEvC,IAAA,MAAM,eAAA,GAAkB,cAAA,CAAe,QAAA,EAAU,QAAQ,CAAA;AAEzD,IAAA,MAAA,CAAO,KAAK,CAAA,GAAI;AAAA,MACd,WAAW,OAAA,CAAQ,EAAA;AAAA,MACnB,KAAA;AAAA,MACA,QAAA,EAAU,OAAO,mBAAA,GAAsB,QAAA,CAAS,QAAQ,MAAA,EAAQ,GAAG,CAAA,CAAE,IAAA,EAAK,GAAI,QAAA;AAAA,MAC9E,eAAA;AAAA,MACA,QAAA;AAAA,MACA;AAAA,KACF;AACA,IAAA,cAAA,EAAA;AAAA,EACF;AAEA,EAAA,OAAO;AAAA,IACL,MAAA;AAAA,IACA,cAAc,QAAA,CAAS,MAAA;AAAA,IACvB;AAAA,GACF;AACF;;;AC5JO,IAAM,kCAAA,GAA+D;AAAA,EAC1E,iBAAA,EAAmB,CAAA;AAAA,EACnB,cAAA,EAAgB,IAAA;AAAA,EAChB,cAAA,EAAgB,GAAA;AAAA,EAChB,eAAA,EAAiB;AACnB,CAAA;AAUA,SAAS,UAAU,EAAA,EAAgD;AACjE,EAAA,MAAM,IAAA,GAAO,GAAG,KAAA,EAAO,IAAA;AACvB,EAAA,IAAI,CAAC,MAAM,OAAO,IAAA;AAClB,EAAA,OAAO;AAAA,IACL,OAAA,EAAS,EAAA;AAAA,IACT,CAAA,EAAG,KAAK,CAAA,IAAK,CAAA;AAAA,IACb,CAAA,EAAG,KAAK,CAAA,IAAK,CAAA;AAAA,IACb,KAAA,EAAO,KAAK,KAAA,IAAS,CAAA;AAAA,IACrB,MAAA,EAAQ,KAAK,MAAA,IAAU;AAAA,GACzB;AACF;AAKO,SAAS,kBAAA,CACd,EAAA,EACA,SAAA,EACA,SAAA,EACA,SAAmC,kCAAA,EACO;AAC1C,EAAA,MAAM,IAAA,GAAA,CAAQ,EAAA,CAAG,IAAA,IAAQ,EAAA,EAAI,WAAA,EAAY;AACzC,EAAA,MAAM,YAAA,GAAA,CAAgB,EAAA,CAAG,YAAA,IAAgB,EAAA,EAAI,WAAA,EAAY;AACzD,EAAA,MAAM,GAAA,GAAA,CAAO,EAAA,CAAG,OAAA,IAAW,EAAA,EAAI,WAAA,EAAY;AAG3C,EAAA,IAAI,IAAA,KAAS,YAAA,IAAgB,IAAA,KAAS,KAAA,IAAS,QAAQ,KAAA,EAAO;AAC5D,IAAA,OAAO,EAAE,IAAA,EAAM,YAAA,EAAc,UAAA,EAAY,IAAA,EAAK;AAAA,EAChD;AACA,EAAA,IAAI,IAAA,KAAS,QAAA,IAAY,GAAA,KAAQ,QAAA,EAAU;AACzC,IAAA,OAAO,EAAE,IAAA,EAAM,QAAA,EAAU,UAAA,EAAY,IAAA,EAAK;AAAA,EAC5C;AACA,EAAA,IAAI,IAAA,KAAS,aAAA,IAAiB,GAAA,KAAQ,QAAA,EAAU;AAC9C,IAAA,OAAO,EAAE,IAAA,EAAM,QAAA,EAAU,UAAA,EAAY,IAAA,EAAK;AAAA,EAC5C;AACA,EAAA,IAAI,IAAA,KAAS,MAAA,IAAU,GAAA,KAAQ,MAAA,EAAQ;AACrC,IAAA,OAAO,EAAE,IAAA,EAAM,cAAA,EAAgB,UAAA,EAAY,IAAA,EAAK;AAAA,EAClD;AACA,EAAA,IAAI,IAAA,KAAS,eAAA,IAAmB,GAAA,KAAQ,OAAA,EAAS;AAC/C,IAAA,OAAO,EAAE,IAAA,EAAM,SAAA,EAAW,UAAA,EAAY,GAAA,EAAI;AAAA,EAC5C;AACA,EAAA,IAAI,IAAA,KAAS,MAAA,IAAU,GAAA,KAAQ,MAAA,EAAQ;AACrC,IAAA,OAAO,EAAE,IAAA,EAAM,MAAA,EAAQ,UAAA,EAAY,GAAA,EAAI;AAAA,EACzC;AACA,EAAA,IAAI,IAAA,KAAS,OAAA,IAAW,GAAA,KAAQ,OAAA,EAAS;AACvC,IAAA,OAAO,EAAE,IAAA,EAAM,OAAA,EAAS,UAAA,EAAY,GAAA,EAAI;AAAA,EAC1C;AACA,EAAA,IAAI,IAAA,KAAS,QAAA,IAAY,IAAA,KAAS,aAAA,EAAe;AAC/C,IAAA,OAAO,EAAE,IAAA,EAAM,OAAA,EAAS,UAAA,EAAY,IAAA,EAAK;AAAA,EAC3C;AACA,EAAA,IAAI,SAAS,SAAA,EAAW;AACtB,IAAA,OAAO,EAAE,IAAA,EAAM,SAAA,EAAW,UAAA,EAAY,GAAA,EAAI;AAAA,EAC5C;AACA,EAAA,IAAI,YAAA,CAAa,QAAA,CAAS,MAAM,CAAA,EAAG;AACjC,IAAA,OAAO,EAAE,IAAA,EAAM,MAAA,EAAQ,UAAA,EAAY,GAAA,EAAI;AAAA,EACzC;AAGA,EAAA,IAAI,SAAA,GAAY,OAAO,cAAA,EAAgB;AACrC,IAAA,OAAO,EAAE,IAAA,EAAM,QAAA,EAAU,UAAA,EAAY,GAAA,EAAI;AAAA,EAC3C;AACA,EAAA,IAAI,SAAA,GAAY,OAAO,cAAA,EAAgB;AACrC,IAAA,OAAO,EAAE,IAAA,EAAM,QAAA,EAAU,UAAA,EAAY,GAAA,EAAI;AAAA,EAC3C;AACA,EAAA,IAAI,SAAA,GAAY,OAAO,eAAA,EAAiB;AACtC,IAAA,OAAO,EAAE,IAAA,EAAM,SAAA,EAAW,UAAA,EAAY,GAAA,EAAI;AAAA,EAC5C;AAEA,EAAA,OAAO,EAAE,IAAA,EAAM,cAAA,EAAgB,UAAA,EAAY,GAAA,EAAI;AACjD;AAKO,SAAS,kBAAA,CACd,QAAA,EACA,MAAA,GAAmC,kCAAA,EACpB;AACf,EAAA,MAAM,OAAA,GAAU,SAAS,GAAA,CAAI,SAAS,EAAE,MAAA,CAAO,CAAC,CAAA,KAA2B,CAAA,KAAM,IAAI,CAAA;AACrF,EAAA,IAAI,OAAA,CAAQ,WAAW,CAAA,EAAG;AACxB,IAAA,OAAO,EAAE,OAAA,EAAS,EAAC,EAAG,aAAA,EAAe,CAAA,EAAG,aAAA,EAAe,QAAA,CAAS,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,CAAE,EAAE,CAAA,EAAE;AAAA,EACnF;AAGA,EAAA,IAAI,IAAA,GAAO,CAAA;AACX,EAAA,IAAI,IAAA,GAAO,CAAA;AACX,EAAA,KAAA,MAAW,KAAK,OAAA,EAAS;AACvB,IAAA,IAAA,GAAO,KAAK,GAAA,CAAI,IAAA,EAAM,CAAA,CAAE,CAAA,GAAI,EAAE,KAAK,CAAA;AACnC,IAAA,IAAA,GAAO,KAAK,GAAA,CAAI,IAAA,EAAM,CAAA,CAAE,CAAA,GAAI,EAAE,MAAM,CAAA;AAAA,EACtC;AACA,EAAA,IAAI,IAAA,KAAS,GAAG,IAAA,GAAO,CAAA;AACvB,EAAA,IAAI,IAAA,KAAS,GAAG,IAAA,GAAO,CAAA;AAGvB,EAAA,MAAM,YAAA,uBAAmB,GAAA,EAAuE;AAChG,EAAA,MAAM,gBAA0B,EAAC;AAEjC,EAAA,KAAA,MAAW,KAAK,OAAA,EAAS;AACvB,IAAA,MAAM,SAAA,GAAY,EAAE,CAAA,GAAI,IAAA;AACxB,IAAA,MAAM,SAAA,GAAY,EAAE,CAAA,GAAI,IAAA;AACxB,IAAA,MAAM,EAAE,MAAM,UAAA,EAAW,GAAI,mBAAmB,CAAA,CAAE,OAAA,EAAS,SAAA,EAAW,SAAA,EAAW,MAAM,CAAA;AAEvF,IAAA,IAAI,CAAC,YAAA,CAAa,GAAA,CAAI,IAAI,CAAA,EAAG;AAC3B,MAAA,YAAA,CAAa,GAAA,CAAI,MAAM,EAAE,QAAA,EAAU,EAAC,EAAG,WAAA,EAAa,EAAC,EAAG,CAAA;AAAA,IAC1D;AACA,IAAA,YAAA,CAAa,GAAA,CAAI,IAAI,CAAA,CAAG,QAAA,CAAS,KAAK,CAAC,CAAA;AACvC,IAAA,YAAA,CAAa,GAAA,CAAI,IAAI,CAAA,CAAG,WAAA,CAAY,KAAK,UAAU,CAAA;AAAA,EACrD;AAGA,EAAA,MAAM,UAAwB,EAAC;AAC/B,EAAA,IAAI,aAAA,GAAgB,CAAA;AAEpB,EAAA,KAAA,MAAW,CAAC,IAAA,EAAM,KAAK,CAAA,IAAK,YAAA,EAAc;AACxC,IAAA,IAAI,KAAA,CAAM,QAAA,CAAS,MAAA,GAAS,MAAA,CAAO,iBAAA,EAAmB;AACpD,MAAA,KAAA,MAAW,KAAK,KAAA,CAAM,QAAA,gBAAwB,IAAA,CAAK,CAAA,CAAE,QAAQ,EAAE,CAAA;AAC/D,MAAA;AAAA,IACF;AAGA,IAAA,IAAI,OAAO,QAAA,EACT,IAAA,GAAO,QAAA,EACP,KAAA,GAAQ,GACR,KAAA,GAAQ,CAAA;AACV,IAAA,MAAM,aAAuB,EAAC;AAE9B,IAAA,KAAA,MAAW,CAAA,IAAK,MAAM,QAAA,EAAU;AAC9B,MAAA,IAAA,GAAO,IAAA,CAAK,GAAA,CAAI,IAAA,EAAM,CAAA,CAAE,CAAC,CAAA;AACzB,MAAA,IAAA,GAAO,IAAA,CAAK,GAAA,CAAI,IAAA,EAAM,CAAA,CAAE,CAAC,CAAA;AACzB,MAAA,KAAA,GAAQ,KAAK,GAAA,CAAI,KAAA,EAAO,CAAA,CAAE,CAAA,GAAI,EAAE,KAAK,CAAA;AACrC,MAAA,KAAA,GAAQ,KAAK,GAAA,CAAI,KAAA,EAAO,CAAA,CAAE,CAAA,GAAI,EAAE,MAAM,CAAA;AACtC,MAAA,UAAA,CAAW,IAAA,CAAK,CAAA,CAAE,OAAA,CAAQ,EAAE,CAAA;AAAA,IAC9B;AAEA,IAAA,MAAM,aAAA,GAAgB,KAAA,CAAM,WAAA,CAAY,MAAA,CAAO,CAAC,CAAA,EAAG,CAAA,KAAM,CAAA,GAAI,CAAA,EAAG,CAAC,CAAA,GAAI,KAAA,CAAM,WAAA,CAAY,MAAA;AAEvF,IAAA,OAAA,CAAQ,IAAA,CAAK;AAAA,MACX,IAAA;AAAA,MACA,MAAA,EAAQ,EAAE,CAAA,EAAG,IAAA,EAAM,CAAA,EAAG,IAAA,EAAM,KAAA,EAAO,KAAA,GAAQ,IAAA,EAAM,MAAA,EAAQ,KAAA,GAAQ,IAAA,EAAK;AAAA,MACtE,UAAA;AAAA,MACA,KAAA,EAAO,IAAA,CAAK,OAAA,CAAQ,GAAA,EAAK,GAAG,CAAA,CAAE,OAAA,CAAQ,OAAA,EAAS,CAAC,CAAA,KAAM,CAAA,CAAE,WAAA,EAAa,CAAA;AAAA,MACrE,UAAA,EAAY,IAAA,CAAK,KAAA,CAAM,aAAA,GAAgB,GAAG,CAAA,GAAI;AAAA,KAC/C,CAAA;AAED,IAAA,aAAA,IAAiB,UAAA,CAAW,MAAA;AAAA,EAC9B;AAEA,EAAA,OAAO,EAAE,OAAA,EAAS,aAAA,EAAe,aAAA,EAAc;AACjD;;;ACxJO,IAAM,+BAAA,GAAyD;AAAA,EACpE,eAAA,EAAiB,CAAA;AAAA,EACjB,YAAA,EAAc,CAAA;AAAA,EACd,YAAA,EAAc,CAAA;AAAA,EACd,eAAA,EAAiB,EAAA;AAAA,EACjB,YAAA,EAAc;AAChB,CAAA;AAWA,SAAS,iBAAiB,EAAA,EAAmD;AAC3E,EAAA,MAAM,IAAA,GAAO,GAAG,KAAA,EAAO,IAAA;AACvB,EAAA,IAAI,CAAC,IAAA,IAAQ,IAAA,CAAK,KAAA,KAAU,GAAG,OAAO,IAAA;AAEtC,EAAA,MAAM,OAAO,EAAA,CAAG,KAAA,EAAO,WAAA,IAAe,EAAA,CAAG,OAAO,KAAA,IAAS,EAAA;AACzD,EAAA,IAAI,CAAC,MAAM,OAAO,IAAA;AAElB,EAAA,OAAO;AAAA,IACL,OAAA,EAAS,EAAA;AAAA,IACT,CAAA,EAAG,KAAK,CAAA,IAAK,CAAA;AAAA,IACb,CAAA,EAAG,KAAK,CAAA,IAAK,CAAA;AAAA,IACb,KAAA,EAAO,KAAK,KAAA,IAAS,CAAA;AAAA,IACrB,MAAA,EAAQ,KAAK,MAAA,IAAU,CAAA;AAAA,IACvB,IAAA,EAAM,KAAK,IAAA;AAAK,GAClB;AACF;AAMA,SAAS,gBAAA,CAAiB,QAAkB,SAAA,EAA6B;AACvE,EAAA,IAAI,MAAA,CAAO,MAAA,KAAW,CAAA,EAAG,OAAO,EAAC;AACjC,EAAA,MAAM,MAAA,GAAS,CAAC,GAAG,MAAM,CAAA,CAAE,KAAK,CAAC,CAAA,EAAG,CAAA,KAAM,CAAA,GAAI,CAAC,CAAA;AAC/C,EAAA,MAAM,QAAA,GAAqB,CAAC,MAAA,CAAO,CAAC,CAAC,CAAA;AAErC,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AACtC,IAAA,IAAI,MAAA,CAAO,CAAC,CAAA,GAAI,QAAA,CAAS,SAAS,MAAA,GAAS,CAAC,IAAI,SAAA,EAAW;AACzD,MAAA,QAAA,CAAS,IAAA,CAAK,MAAA,CAAO,CAAC,CAAC,CAAA;AAAA,IACzB;AAAA,EACF;AAEA,EAAA,OAAO,QAAA;AACT;AAKA,SAAS,eAAA,CAAgB,KAAA,EAAe,QAAA,EAAoB,SAAA,EAA2B;AACrF,EAAA,IAAI,IAAA,GAAO,CAAA;AACX,EAAA,IAAI,WAAW,IAAA,CAAK,GAAA,CAAI,KAAA,GAAQ,QAAA,CAAS,CAAC,CAAC,CAAA;AAC3C,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,QAAA,CAAS,QAAQ,CAAA,EAAA,EAAK;AACxC,IAAA,MAAM,OAAO,IAAA,CAAK,GAAA,CAAI,KAAA,GAAQ,QAAA,CAAS,CAAC,CAAC,CAAA;AACzC,IAAA,IAAI,OAAO,QAAA,EAAU;AACnB,MAAA,QAAA,GAAW,IAAA;AACX,MAAA,IAAA,GAAO,CAAA;AAAA,IACT;AAAA,EACF;AACA,EAAA,OAAO,QAAA,IAAY,YAAY,IAAA,GAAO,EAAA;AACxC;AAKO,SAAS,WAAA,CACd,QAAA,EACA,MAAA,GAAgC,+BAAA,EACZ;AACpB,EAAA,MAAM,UAAA,GAAa,SAChB,GAAA,CAAI,gBAAgB,EACpB,MAAA,CAAO,CAAC,CAAA,KAA8B,CAAA,KAAM,IAAI,CAAA;AACnD,EAAA,IAAI,WAAW,MAAA,GAAS,MAAA,CAAO,eAAA,GAAkB,MAAA,CAAO,cAAc,OAAO,IAAA;AAG7E,EAAA,MAAM,aAAa,UAAA,CAAW,GAAA,CAAI,CAAC,CAAA,KAAM,EAAE,CAAC,CAAA;AAC5C,EAAA,MAAM,aAAa,UAAA,CAAW,GAAA,CAAI,CAAC,CAAA,KAAM,EAAE,CAAC,CAAA;AAE5C,EAAA,MAAM,cAAA,GAAiB,gBAAA,CAAiB,UAAA,EAAY,MAAA,CAAO,eAAe,CAAA;AAC1E,EAAA,MAAM,WAAA,GAAc,gBAAA,CAAiB,UAAA,EAAY,MAAA,CAAO,YAAY,CAAA;AAEpE,EAAA,IAAI,eAAe,MAAA,GAAS,MAAA,CAAO,mBAAmB,WAAA,CAAY,MAAA,GAAS,OAAO,YAAA,EAAc;AAC9F,IAAA,OAAO,IAAA;AAAA,EACT;AAGA,EAAA,MAAM,OAA4B,KAAA,CAAM,IAAA;AAAA,IAAK,EAAE,MAAA,EAAQ,WAAA,CAAY,MAAA,EAAO;AAAA,IAAG,MAC3E,KAAA,CAAM,cAAA,CAAe,MAAM,CAAA,CAAE,KAAK,IAAI;AAAA,GACxC;AAEA,EAAA,KAAA,MAAW,KAAK,UAAA,EAAY;AAC1B,IAAA,MAAM,MAAM,eAAA,CAAgB,CAAA,CAAE,CAAA,EAAG,cAAA,EAAgB,OAAO,eAAe,CAAA;AACvE,IAAA,MAAM,MAAM,eAAA,CAAgB,CAAA,CAAE,CAAA,EAAG,WAAA,EAAa,OAAO,YAAY,CAAA;AACjE,IAAA,IAAI,GAAA,IAAO,KAAK,GAAA,IAAO,CAAA,IAAK,KAAK,GAAG,CAAA,CAAE,GAAG,CAAA,KAAM,IAAA,EAAM;AACnD,MAAA,IAAA,CAAK,GAAG,CAAA,CAAE,GAAG,CAAA,GAAI,CAAA,CAAE,IAAA;AAAA,IACrB;AAAA,EACF;AAGA,EAAA,MAAM,OAAA,GAAU,KAAK,CAAC,CAAA,CAAE,IAAI,CAAC,CAAA,KAAM,KAAK,EAAE,CAAA;AAC1C,EAAA,MAAM,OAAA,GAAyB,OAAA,CAAQ,GAAA,CAAI,CAAC,QAAQ,KAAA,KAAU;AAE5D,IAAA,MAAM,YAAY,IAAA,CACf,KAAA,CAAM,CAAC,CAAA,CACP,IAAI,CAAC,CAAA,KAAM,CAAA,CAAE,KAAK,CAAC,CAAA,CACnB,MAAA,CAAO,CAAC,CAAA,KAAmB,MAAM,IAAI,CAAA;AACxC,IAAA,MAAM,KAAA,GAAQ,UAAU,GAAA,CAAI,CAAC,MAAM,gBAAA,CAAiB,CAAC,EAAE,IAAI,CAAA;AAC3D,IAAA,MAAM,UAAA,GAAa,IAAA,CAAK,KAAK,CAAA,IAAM,MAAA;AAEnC,IAAA,OAAO,EAAE,MAAA,EAAQ,KAAA,EAAO,QAAA,EAAU,UAAA,EAAW;AAAA,EAC/C,CAAC,CAAA;AAED,EAAA,MAAM,IAAA,GAAO,IAAA,CAAK,KAAA,CAAM,CAAC,EAAE,GAAA,CAAI,CAAC,GAAA,KAAQ,GAAA,CAAI,GAAA,CAAI,CAAC,IAAA,KAAS,IAAA,IAAQ,EAAE,CAAC,CAAA;AAErE,EAAA,OAAO;AAAA,IACL,KAAA,EAAO,OAAA,CAAQ,CAAC,CAAA,IAAK,OAAA;AAAA,IACrB,OAAA;AAAA,IACA;AAAA,GACF;AACF;AAKO,SAAS,UAAA,CACd,QAAA,EACA,MAAA,GAAgC,+BAAA,EACb;AAEnB,EAAA,MAAM,UAAA,GAAa,SAChB,GAAA,CAAI,gBAAgB,EACpB,MAAA,CAAO,CAAC,CAAA,KAA8B,CAAA,KAAM,IAAI,CAAA;AACnD,EAAA,IAAI,UAAA,CAAW,MAAA,GAAS,MAAA,CAAO,YAAA,EAAc,OAAO,IAAA;AAGpD,EAAA,MAAM,MAAA,GAAS,CAAC,GAAG,UAAU,CAAA,CAAE,IAAA,CAAK,CAAC,CAAA,EAAG,CAAA,KAAM,CAAA,CAAE,CAAA,GAAI,CAAA,CAAE,CAAC,CAAA;AAGvD,EAAA,MAAM,aAAa,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA,KAAM,EAAE,CAAC,CAAA;AACxC,EAAA,MAAM,WAAA,GAAc,gBAAA,CAAiB,UAAA,EAAY,MAAA,CAAO,YAAY,CAAA;AAEpE,EAAA,IAAI,WAAA,CAAY,MAAA,GAAS,MAAA,CAAO,YAAA,EAAc,OAAO,IAAA;AAGrD,EAAA,MAAM,SAAA,uBAAkD,GAAA,EAAI;AAC5D,EAAA,KAAA,MAAW,KAAK,MAAA,EAAQ;AACtB,IAAA,MAAM,MAAM,eAAA,CAAgB,CAAA,CAAE,CAAA,EAAG,WAAA,EAAa,OAAO,YAAY,CAAA;AACjE,IAAA,IAAI,OAAO,CAAA,EAAG;AACZ,MAAA,IAAI,CAAC,UAAU,GAAA,CAAI,GAAG,GAAG,SAAA,CAAU,GAAA,CAAI,GAAA,EAAK,EAAE,CAAA;AAC9C,MAAA,SAAA,CAAU,GAAA,CAAI,GAAG,CAAA,CAAG,IAAA,CAAK,CAAC,CAAA;AAAA,IAC5B;AAAA,EACF;AAIA,EAAA,MAAM,QAAkC,EAAC;AACzC,EAAA,MAAM,cAAwB,EAAC;AAC/B,EAAA,IAAI,sBAAA,GAAyB,KAAA;AAE7B,EAAA,KAAA,MAAW,GAAG,WAAW,CAAA,IAAK,CAAC,GAAG,SAAA,CAAU,SAAS,CAAA,CAAE,KAAK,CAAC,CAAC,CAAC,CAAA,EAAG,CAAC,CAAC,CAAA,KAAM,CAAA,GAAI,CAAC,CAAA,EAAG;AAChF,IAAA,MAAM,SAAA,GAAY,CAAC,GAAG,WAAW,CAAA,CAAE,IAAA,CAAK,CAAC,CAAA,EAAG,CAAA,KAAM,CAAA,CAAE,CAAA,GAAI,CAAA,CAAE,CAAC,CAAA;AAC3D,IAAA,MAAM,OAA+B,EAAC;AAEtC,IAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,SAAA,CAAU,QAAQ,CAAA,EAAA,EAAK;AACzC,MAAA,MAAM,KAAA,GAAQ,SAAS,CAAC,CAAA,CAAA;AACxB,MAAA,IAAI,CAAC,sBAAA,EAAwB,WAAA,CAAY,IAAA,CAAK,KAAK,CAAA;AACnD,MAAA,IAAA,CAAK,KAAK,CAAA,GAAI,SAAA,CAAU,CAAC,CAAA,CAAE,IAAA;AAAA,IAC7B;AACA,IAAA,sBAAA,GAAyB,IAAA;AACzB,IAAA,KAAA,CAAM,KAAK,IAAI,CAAA;AAAA,EACjB;AAEA,EAAA,IAAI,KAAA,CAAM,MAAA,GAAS,MAAA,CAAO,YAAA,EAAc,OAAO,IAAA;AAG/C,EAAA,MAAM,MAAA,GAA0B,WAAA,CAAY,GAAA,CAAI,CAAC,KAAA,KAAU;AACzD,IAAA,MAAM,MAAA,GAAS,KAAA,CAAM,GAAA,CAAI,CAAC,IAAA,KAAS,KAAK,KAAK,CAAC,CAAA,CAAE,MAAA,CAAO,OAAO,CAAA;AAC9D,IAAA,MAAM,KAAA,GAAQ,OAAO,GAAA,CAAI,CAAC,MAAM,gBAAA,CAAiB,CAAC,EAAE,IAAI,CAAA;AACxD,IAAA,OAAO,EAAE,KAAA,EAAO,QAAA,EAAU,IAAA,CAAK,KAAK,KAAK,MAAA,EAAO;AAAA,EAClD,CAAC,CAAA;AAED,EAAA,OAAO;AAAA,IACL,KAAA,EAAO,MAAA;AAAA,IACP,MAAA;AAAA,IACA;AAAA,GACF;AACF;AAKO,SAAS,qBAAA,CACd,QAAA,EACA,MAAA,GAAgC,+BAAA,EACN;AAC1B,EAAA,MAAM,SAAwB,EAAC;AAC/B,EAAA,MAAM,QAAsB,EAAC;AAG7B,EAAA,MAAM,KAAA,GAAQ,WAAA,CAAY,QAAA,EAAU,MAAM,CAAA;AAC1C,EAAA,IAAI,KAAA,EAAO;AACT,IAAA,MAAA,CAAO,KAAK,KAAK,CAAA;AAAA,EACnB;AAIA,EAAA,MAAM,cAAA,GAAiB,QAAA,CAAS,MAAA,CAAO,CAAC,EAAA,KAAO;AAC7C,IAAA,MAAM,IAAA,GAAO,EAAA,CAAG,IAAA,IAAQ,EAAA,CAAG,IAAA;AAC3B,IAAA,OAAO,CAAC,YAAY,KAAA,EAAO,QAAA,EAAU,QAAQ,QAAQ,CAAA,CAAE,SAAS,IAAI,CAAA;AAAA,EACtE,CAAC,CAAA;AAED,EAAA,IAAI,cAAA,CAAe,MAAA,IAAU,MAAA,CAAO,YAAA,EAAc;AAChD,IAAA,MAAM,IAAA,GAAO,UAAA,CAAW,cAAA,EAAgB,MAAM,CAAA;AAC9C,IAAA,IAAI,IAAA,EAAM;AACR,MAAA,KAAA,CAAM,KAAK,IAAI,CAAA;AAAA,IACjB;AAAA,EACF;AAEA,EAAA,OAAO,EAAE,QAAQ,KAAA,EAAM;AACzB;AAGA,SAAS,KAAQ,GAAA,EAAyB;AACxC,EAAA,IAAI,GAAA,CAAI,MAAA,KAAW,CAAA,EAAG,OAAO,MAAA;AAC7B,EAAA,MAAM,MAAA,uBAAa,GAAA,EAAe;AAClC,EAAA,IAAI,IAAA,GAAU,IAAI,CAAC,CAAA;AACnB,EAAA,IAAI,SAAA,GAAY,CAAA;AAChB,EAAA,KAAA,MAAW,KAAK,GAAA,EAAK;AACnB,IAAA,MAAM,CAAA,GAAA,CAAK,MAAA,CAAO,GAAA,CAAI,CAAC,KAAK,CAAA,IAAK,CAAA;AACjC,IAAA,MAAA,CAAO,GAAA,CAAI,GAAG,CAAC,CAAA;AACf,IAAA,IAAI,IAAI,SAAA,EAAW;AACjB,MAAA,SAAA,GAAY,CAAA;AACZ,MAAA,IAAA,GAAO,CAAA;AAAA,IACT;AAAA,EACF;AACA,EAAA,OAAO,IAAA;AACT;;;AClQO,IAAM,8BAAA,GAAuD;AAAA,EAClE,iBAAA,EAAmB;AACrB,CAAA;AAKO,SAAS,mBAAA,CAAoB,OAAe,QAAA,EAA4B;AAC7E,EAAA,MAAM,OAAA,GAAU,MAAM,IAAA,EAAK;AAE3B,EAAA,QAAQ,QAAA;AAAU,IAChB,KAAK,UAAA,EAAY;AAEf,MAAA,MAAM,gBAAA,GAAmB,UAAA,CAAW,IAAA,CAAK,OAAO,CAAA;AAChD,MAAA,MAAM,iBAAA,GAAoB,UAAA,CAAW,IAAA,CAAK,OAAO,CAAA;AACjD,MAAA,MAAM,kBAAA,GAAqB,kBAAA,CAAmB,IAAA,CAAK,OAAO,CAAA;AAC1D,MAAA,MAAM,mBAAA,GAAsB,oBAAA,CAAqB,IAAA,CAAK,OAAO,CAAA;AAE7D,MAAA,IAAI,OAAA,GAAU,mBAAmB,GAAA,GAAM,EAAA;AACvC,MAAA,IAAI,oBAAoB,OAAA,IAAW,OAAA;AAAA,WAAA,IAC1B,qBAAqB,OAAA,IAAW,OAAA;AAAA,WACpC,OAAA,IAAW,GAAA;AAEhB,MAAA,IAAI,UAAA,CAAW,IAAA,CAAK,OAAO,CAAA,EAAG,OAAA,IAAW,KAAA;AAAA,WAAA,IAChC,SAAA,CAAU,IAAA,CAAK,OAAO,CAAA,EAAG,OAAA,IAAW,KAAA;AAE7C,MAAA,IAAI,mBAAmB,OAAA,IAAW,GAAA;AAClC,MAAA,OAAO,OAAA;AAAA,IACT;AAAA,IAEA,KAAK,MAAA,EAAQ;AACX,MAAA,IAAI,oBAAA,CAAqB,IAAA,CAAK,OAAO,CAAA,EAAG,OAAO,YAAA;AAC/C,MAAA,IAAI,uBAAA,CAAwB,IAAA,CAAK,OAAO,CAAA,EAAG,OAAO,YAAA;AAClD,MAAA,IAAI,uBAAA,CAAwB,IAAA,CAAK,OAAO,CAAA,EAAG,OAAO,YAAA;AAClD,MAAA,IAAI,2BAAA,CAA4B,IAAA,CAAK,OAAO,CAAA,EAAG,OAAO,QAAA;AACtD,MAAA,IAAI,+BAAA,CAAgC,IAAA,CAAK,OAAO,CAAA,EAAG,OAAO,gBAAA;AAC1D,MAAA,OAAO,MAAA;AAAA,IACT;AAAA,IAEA,KAAK,YAAA;AACH,MAAA,OAAO,MAAA,CAAO,IAAA,CAAK,OAAO,CAAA,GAAI,QAAA,GAAW,OAAA;AAAA,IAE3C,KAAK,QAAA,EAAU;AACb,MAAA,MAAM,SAAA,GAAY,GAAA,CAAI,IAAA,CAAK,OAAO,CAAA;AAClC,MAAA,MAAM,aAAA,GAAgB,OAAA,CAAQ,QAAA,CAAS,GAAG,CAAA,GAAI,OAAA,CAAQ,KAAA,CAAM,GAAG,CAAA,CAAE,CAAC,CAAA,EAAG,MAAA,IAAU,CAAA,GAAI,CAAA;AACnF,MAAA,OAAA,CACG,SAAA,GAAY,UAAU,GAAA,KAAQ,aAAA,GAAgB,IAAI,GAAA,GAAM,GAAA,CAAI,MAAA,CAAO,aAAa,CAAA,GAAI,EAAA,CAAA;AAAA,IAEzF;AAAA,IAEA,KAAK,OAAA,EAAS;AAEZ,MAAA,IAAI,2BAAA,CAA4B,IAAA,CAAK,OAAO,CAAA,EAAG,OAAO,gBAAA;AACtD,MAAA,IAAI,qBAAA,CAAsB,IAAA,CAAK,OAAO,CAAA,EAAG,OAAO,cAAA;AAChD,MAAA,IAAI,OAAA,CAAQ,IAAA,CAAK,OAAO,CAAA,EAAG,OAAO,WAAA;AAClC,MAAA,OAAO,OAAA;AAAA,IACT;AAAA,IAEA;AACE,MAAA,OAAO,QAAA;AAAA;AAEb;AAKO,SAAS,aAAA,CACd,SAAA,EACA,KAAA,EACA,QAAA,EACkB;AAClB,EAAA,MAAM,EAAE,IAAA,EAAM,QAAA,EAAS,GAAI,iBAAiB,QAAQ,CAAA;AACpD,EAAA,MAAM,OAAA,GAAU,mBAAA,CAAoB,QAAA,EAAU,QAAQ,CAAA;AAEtD,EAAA,OAAO;AAAA,IACL,SAAA;AAAA,IACA,KAAA;AAAA,IACA,QAAA;AAAA,IACA,OAAA;AAAA,IACA,OAAA,EAAS,SAAS,IAAA;AAAK,GACzB;AACF;AAKO,SAAS,mBAAmB,QAAA,EAAqD;AACtF,EAAA,MAAM,cAAkC,EAAC;AAEzC,EAAA,KAAA,MAAW,MAAM,QAAA,EAAU;AACzB,IAAA,MAAM,WAAW,EAAA,CAAG,KAAA,EAAO,KAAA,IAAS,EAAA,CAAG,OAAO,WAAA,IAAe,EAAA;AAC7D,IAAA,IAAI,CAAC,QAAA,EAAU;AAEf,IAAA,MAAM,KAAA,GAAQ,GAAG,cAAA,IAAkB,EAAA,CAAG,aAAa,EAAA,CAAG,KAAA,IAAS,EAAA,CAAG,WAAA,IAAe,EAAA,CAAG,EAAA;AACpF,IAAA,WAAA,CAAY,KAAK,aAAA,CAAc,EAAA,CAAG,EAAA,EAAI,KAAA,EAAO,QAAQ,CAAC,CAAA;AAAA,EACxD;AAEA,EAAA,OAAO,WAAA;AACT;AAKO,SAAS,cAAA,CACd,aAAA,EACA,aAAA,EACA,MAAA,GAA+B,8BAAA,EACb;AAClB,EAAA,MAAM,aAA+B,EAAC;AAGtC,EAAA,MAAM,aAAA,uBAAoB,GAAA,EAA8B;AACxD,EAAA,KAAA,MAAW,KAAK,aAAA,EAAe;AAC7B,IAAA,aAAA,CAAc,GAAA,CAAI,CAAA,CAAE,KAAA,CAAM,WAAA,IAAe,CAAC,CAAA;AAAA,EAC5C;AAEA,EAAA,KAAA,MAAW,UAAU,aAAA,EAAe;AAClC,IAAA,MAAM,SAAS,aAAA,CAAc,GAAA,CAAI,MAAA,CAAO,KAAA,CAAM,aAAa,CAAA;AAC3D,IAAA,IAAI,CAAC,MAAA,EAAQ;AAGb,IAAA,IAAI,MAAA,CAAO,QAAA,KAAa,MAAA,CAAO,QAAA,EAAU;AACvC,MAAA,UAAA,CAAW,IAAA,CAAK;AAAA,QACd,OAAO,MAAA,CAAO,KAAA;AAAA,QACd,YAAA,EAAc,MAAA;AAAA,QACd,YAAA,EAAc,MAAA;AAAA,QACd,QAAA,EAAU,OAAA;AAAA,QACV,aAAa,CAAA,8BAAA,EAAiC,MAAA,CAAO,QAAQ,CAAA,YAAA,EAAe,OAAO,QAAQ,CAAA;AAAA,OAC5F,CAAA;AACD,MAAA;AAAA,IACF;AAGA,IAAA,IAAI,MAAA,CAAO,OAAA,KAAY,MAAA,CAAO,OAAA,EAAS;AACrC,MAAA,MAAM,QAAA,GAAW,MAAA,CAAO,iBAAA,GAAoB,SAAA,GAAY,OAAA;AACxD,MAAA,UAAA,CAAW,IAAA,CAAK;AAAA,QACd,OAAO,MAAA,CAAO,KAAA;AAAA,QACd,YAAA,EAAc,MAAA;AAAA,QACd,YAAA,EAAc,MAAA;AAAA,QACd,QAAA;AAAA,QACA,aAAa,CAAA,6BAAA,EAAgC,MAAA,CAAO,OAAO,CAAA,gBAAA,EAAmB,OAAO,OAAO,CAAA,CAAA;AAAA,OAC7F,CAAA;AAAA,IACH;AAAA,EACF;AAEA,EAAA,OAAO,UAAA;AACT;;;ACrIO,IAAM,6BAAA,GAAoD;AAAA,EAC/D,cAAA,EAAgB,GAAA;AAAA,EAChB,oBAAA,EAAsB,CAAA;AAAA,EACtB,UAAA,EAAY,IAAA;AAAA,EACZ,kBAAA,EAAoB;AACtB,CAAA;AAKA,SAAS,eAAe,EAAA,EAAiC;AACvD,EAAA,OACE,EAAA,CAAG,cAAA,IAAkB,EAAA,CAAG,SAAA,IAAa,EAAA,CAAG,SAAS,EAAA,CAAG,KAAA,EAAO,WAAA,IAAe,EAAA,CAAG,WAAA,IAAe,EAAA;AAEhG;AAKA,SAAS,QAAQ,EAAA,EAAiC;AAChD,EAAA,OAAA,CAAQ,EAAA,CAAG,IAAA,IAAQ,EAAA,CAAG,IAAA,IAAQ,IAAI,WAAA,EAAY;AAChD;AAKA,SAAS,UAAU,EAAA,EAA0D;AAC3E,EAAA,MAAM,IAAA,GAAO,GAAG,KAAA,EAAO,IAAA;AACvB,EAAA,IAAI,CAAC,MAAM,OAAO,IAAA;AAClB,EAAA,OAAO;AAAA,IACL,CAAA,EAAG,IAAA,CAAK,CAAA,GAAI,IAAA,CAAK,KAAA,GAAQ,CAAA;AAAA,IACzB,CAAA,EAAG,IAAA,CAAK,CAAA,GAAI,IAAA,CAAK,MAAA,GAAS;AAAA,GAC5B;AACF;AAMA,SAAS,iBAAA,CACP,MAAA,EACA,MAAA,EACA,MAAA,EACqC;AACrC,EAAA,IAAI,SAAA,GAAY,CAAA;AAChB,EAAA,IAAI,YAAA,GAAe,MAAA;AAGnB,EAAA,MAAM,OAAA,GAAA,CAAW,MAAA,CAAO,cAAA,IAAkB,EAAA,EAAI,IAAA,EAAK;AACnD,EAAA,MAAM,OAAA,GAAA,CAAW,MAAA,CAAO,cAAA,IAAkB,EAAA,EAAI,IAAA,EAAK;AACnD,EAAA,IAAI,WAAW,OAAA,IAAW,OAAA,CAAQ,aAAY,KAAM,OAAA,CAAQ,aAAY,EAAG;AACzE,IAAA,OAAO,EAAE,KAAA,EAAO,MAAA,CAAO,oBAAA,EAAsB,UAAU,uBAAA,EAAwB;AAAA,EACjF;AAGA,EAAA,MAAM,OAAA,GAAU,eAAe,MAAM,CAAA;AACrC,EAAA,MAAM,OAAA,GAAU,eAAe,MAAM,CAAA;AACrC,EAAA,IAAI,WAAW,OAAA,IAAW,OAAA,CAAQ,aAAY,KAAM,OAAA,CAAQ,aAAY,EAAG;AACzE,IAAA,MAAM,QAAQ,MAAA,CAAO,UAAA;AACrB,IAAA,IAAI,QAAQ,SAAA,EAAW;AACrB,MAAA,SAAA,GAAY,KAAA;AACZ,MAAA,YAAA,GAAe,YAAA;AAAA,IACjB;AAAA,EACF;AAGA,EAAA,IAAI,WAAW,OAAA,EAAS;AACtB,IAAA,MAAM,OAAA,GAAU,gBAAgB,OAAO,CAAA;AACvC,IAAA,MAAM,OAAA,GAAU,gBAAgB,OAAO,CAAA;AACvC,IAAA,MAAM,UAAA,GAAa,qBAAA,CAAsB,OAAA,EAAS,OAAO,CAAA;AACzD,IAAA,MAAM,QAAQ,UAAA,GAAa,IAAA;AAC3B,IAAA,IAAI,QAAQ,SAAA,EAAW;AACrB,MAAA,SAAA,GAAY,KAAA;AACZ,MAAA,YAAA,GAAe,YAAA;AAAA,IACjB;AAAA,EACF;AAGA,EAAA,MAAM,OAAA,GAAU,QAAQ,MAAM,CAAA;AAC9B,EAAA,MAAM,OAAA,GAAU,QAAQ,MAAM,CAAA;AAC9B,EAAA,IAAI,OAAA,IAAW,YAAY,OAAA,EAAS;AAClC,IAAA,MAAM,SAAA,GAAY,UAAU,MAAM,CAAA;AAClC,IAAA,MAAM,SAAA,GAAY,UAAU,MAAM,CAAA;AAClC,IAAA,IAAI,aAAa,SAAA,EAAW;AAE1B,MAAA,MAAM,KAAK,IAAA,CAAK,GAAA,CAAI,UAAU,CAAA,GAAI,SAAA,CAAU,CAAC,CAAA,GAAI,IAAA;AACjD,MAAA,MAAM,KAAK,IAAA,CAAK,GAAA,CAAI,UAAU,CAAA,GAAI,SAAA,CAAU,CAAC,CAAA,GAAI,IAAA;AACjD,MAAA,MAAM,aAAA,GAAgB,CAAA,GAAI,IAAA,CAAK,GAAA,CAAI,CAAA,EAAG,IAAA,CAAK,IAAA,CAAK,EAAA,GAAK,EAAA,GAAK,EAAA,GAAK,EAAE,CAAC,CAAA;AAClE,MAAA,MAAM,KAAA,GAAQ,OAAO,kBAAA,GAAqB,aAAA;AAC1C,MAAA,IAAI,QAAQ,SAAA,EAAW;AACrB,QAAA,SAAA,GAAY,KAAA;AACZ,QAAA,YAAA,GAAe,eAAA;AAAA,MACjB;AAAA,IACF;AAAA,EACF;AAGA,EAAA,MAAM,SAAS,MAAA,CAAO,KAAA,EAAO,KAAA,IAAS,MAAA,CAAO,OAAO,WAAA,IAAe,EAAA;AACnE,EAAA,MAAM,SAAS,MAAA,CAAO,KAAA,EAAO,KAAA,IAAS,MAAA,CAAO,OAAO,WAAA,IAAe,EAAA;AACnE,EAAA,IAAI,UAAU,MAAA,EAAQ;AACpB,IAAA,MAAM,OAAA,GAAU,gBAAA,CAAiB,MAAM,CAAA,CAAE,IAAA;AACzC,IAAA,MAAM,OAAA,GAAU,gBAAA,CAAiB,MAAM,CAAA,CAAE,IAAA;AACzC,IAAA,MAAM,OAAA,GAAU,cAAA,CAAe,MAAA,EAAQ,OAAO,CAAA;AAC9C,IAAA,MAAM,OAAA,GAAU,cAAA,CAAe,MAAA,EAAQ,OAAO,CAAA;AAC9C,IAAA,IAAI,OAAA,KAAY,OAAA,IAAW,OAAA,KAAY,EAAA,EAAI;AACzC,MAAA,MAAM,KAAA,GAAQ,GAAA;AACd,MAAA,IAAI,QAAQ,SAAA,EAAW;AACrB,QAAA,SAAA,GAAY,KAAA;AACZ,QAAA,YAAA,GAAe,cAAA;AAAA,MACjB;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO,EAAE,KAAA,EAAO,SAAA,EAAW,QAAA,EAAU,YAAA,EAAa;AACpD;AAMO,SAAS,aAAA,CACd,cAAA,EACA,cAAA,EACA,MAAA,GAA6B,6BAAA,EACP;AAEtB,EAAA,MAAM,aAKD,EAAC;AAEN,EAAA,KAAA,IAAS,EAAA,GAAK,CAAA,EAAG,EAAA,GAAK,cAAA,CAAe,QAAQ,EAAA,EAAA,EAAM;AACjD,IAAA,KAAA,IAAS,EAAA,GAAK,CAAA,EAAG,EAAA,GAAK,cAAA,CAAe,QAAQ,EAAA,EAAA,EAAM;AACjD,MAAA,MAAM,EAAE,KAAA,EAAO,QAAA,EAAS,GAAI,iBAAA,CAAkB,cAAA,CAAe,EAAE,CAAA,EAAG,cAAA,CAAe,EAAE,CAAA,EAAG,MAAM,CAAA;AAC5F,MAAA,IAAI,KAAA,IAAS,OAAO,cAAA,EAAgB;AAClC,QAAA,UAAA,CAAW,IAAA,CAAK,EAAE,SAAA,EAAW,EAAA,EAAI,WAAW,EAAA,EAAI,KAAA,EAAO,UAAU,CAAA;AAAA,MACnE;AAAA,IACF;AAAA,EACF;AAGA,EAAA,UAAA,CAAW,KAAK,CAAC,CAAA,EAAG,MAAM,CAAA,CAAE,KAAA,GAAQ,EAAE,KAAK,CAAA;AAE3C,EAAA,MAAM,UAAA,uBAAiB,GAAA,EAAY;AACnC,EAAA,MAAM,UAAA,uBAAiB,GAAA,EAAY;AACnC,EAAA,MAAM,QAA8B,EAAC;AAErC,EAAA,KAAA,MAAW,KAAK,UAAA,EAAY;AAC1B,IAAA,IAAI,UAAA,CAAW,IAAI,CAAA,CAAE,SAAS,KAAK,UAAA,CAAW,GAAA,CAAI,CAAA,CAAE,SAAS,CAAA,EAAG;AAChE,IAAA,UAAA,CAAW,GAAA,CAAI,EAAE,SAAS,CAAA;AAC1B,IAAA,UAAA,CAAW,GAAA,CAAI,EAAE,SAAS,CAAA;AAE1B,IAAA,MAAM,GAAA,GAAM,cAAA,CAAe,CAAA,CAAE,SAAS,CAAA;AACtC,IAAA,MAAM,GAAA,GAAM,cAAA,CAAe,CAAA,CAAE,SAAS,CAAA;AAEtC,IAAA,KAAA,CAAM,IAAA,CAAK;AAAA,MACT,UAAU,GAAA,CAAI,EAAA;AAAA,MACd,UAAU,GAAA,CAAI,EAAA;AAAA,MACd,WAAA,EAAa,cAAA,CAAe,GAAG,CAAA,IAAK,GAAA,CAAI,EAAA;AAAA,MACxC,WAAA,EAAa,cAAA,CAAe,GAAG,CAAA,IAAK,GAAA,CAAI,EAAA;AAAA,MACxC,YAAY,IAAA,CAAK,KAAA,CAAM,CAAA,CAAE,KAAA,GAAQ,GAAG,CAAA,GAAI,GAAA;AAAA,MACxC,eAAe,CAAA,CAAE;AAAA,KAClB,CAAA;AAAA,EACH;AAEA,EAAA,OAAO,KAAA;AACT;AAKO,SAAS,mBAAA,CACd,cAAA,EACA,cAAA,EACA,MAAA,GAA6B,6BAAA,EACf;AAEd,EAAA,MAAM,YAAA,GAAe,aAAA,CAAc,cAAA,EAAgB,cAAA,EAAgB,MAAM,CAAA;AACzE,EAAA,MAAM,gBAAA,GAAmB,IAAI,GAAA,CAAI,YAAA,CAAa,IAAI,CAAC,CAAA,KAAM,CAAA,CAAE,QAAQ,CAAC,CAAA;AACpE,EAAA,MAAM,gBAAA,GAAmB,IAAI,GAAA,CAAI,YAAA,CAAa,IAAI,CAAC,CAAA,KAAM,CAAA,CAAE,QAAQ,CAAC,CAAA;AAEpE,EAAA,MAAM,qBAAqB,cAAA,CACxB,MAAA,CAAO,CAAC,CAAA,KAAM,CAAC,gBAAA,CAAiB,GAAA,CAAI,CAAA,CAAE,EAAE,CAAC,CAAA,CACzC,GAAA,CAAI,CAAC,CAAA,KAAM,EAAE,EAAE,CAAA;AAClB,EAAA,MAAM,qBAAqB,cAAA,CACxB,MAAA,CAAO,CAAC,CAAA,KAAM,CAAC,gBAAA,CAAiB,GAAA,CAAI,CAAA,CAAE,EAAE,CAAC,CAAA,CACzC,GAAA,CAAI,CAAC,CAAA,KAAM,EAAE,EAAE,CAAA;AAGlB,EAAA,MAAM,UAAA,GAAa,gBAAgB,cAAc,CAAA;AACjD,EAAA,MAAM,UAAA,GAAa,gBAAgB,cAAc,CAAA;AAEjD,EAAA,MAAM,kBAAyC,EAAC;AAChD,EAAA,KAAA,MAAW,QAAQ,YAAA,EAAc;AAE/B,IAAA,MAAM,QAAA,GAAW,MAAA,CAAO,MAAA,CAAO,UAAA,CAAW,MAAM,CAAA,CAAE,IAAA,CAAK,CAAC,CAAA,KAAM,CAAA,CAAE,SAAA,KAAc,IAAA,CAAK,QAAQ,CAAA;AAC3F,IAAA,MAAM,QAAA,GAAW,MAAA,CAAO,MAAA,CAAO,UAAA,CAAW,MAAM,CAAA,CAAE,IAAA,CAAK,CAAC,CAAA,KAAM,CAAA,CAAE,SAAA,KAAc,IAAA,CAAK,QAAQ,CAAA;AAE3F,IAAA,IAAI,YAAY,QAAA,EAAU;AACxB,MAAA,eAAA,CAAgB,IAAA,CAAK;AAAA,QACnB,OAAO,IAAA,CAAK,WAAA;AAAA,QACZ,aAAa,QAAA,CAAS,QAAA;AAAA,QACtB,aAAa,QAAA,CAAS,QAAA;AAAA,QACtB,WAAA,EAAa,QAAA,CAAS,eAAA,KAAoB,QAAA,CAAS,eAAA;AAAA,QACnD,YAAA,EAAc,QAAA,CAAS,QAAA,KAAa,QAAA,CAAS;AAAA,OAC9C,CAAA;AAAA,IACH;AAAA,EACF;AAGA,EAAA,MAAM,aAAA,GAAgB,mBAAmB,cAAc,CAAA;AACvD,EAAA,MAAM,aAAA,GAAgB,mBAAmB,cAAc,CAAA;AACvD,EAAA,MAAM,gBAAA,GAAmB,cAAA,CAAe,aAAA,EAAe,aAAa,CAAA;AAEpE,EAAA,OAAO;AAAA,IACL,YAAA;AAAA,IACA,kBAAA;AAAA,IACA,kBAAA;AAAA,IACA,eAAA;AAAA,IACA;AAAA,GACF;AACF;;;AC7OO,IAAM,4BAAA,GAAmD;AAAA,EAC9D,eAAe;AACjB,CAAA;AAKA,SAAS,UAAA,CAAW,IAAyB,aAAA,EAAmC;AAC9E,EAAA,MAAM,OAAA,GAAU,EAAA,CAAG,OAAA,IAAW,EAAA,CAAG,oBAAoB,EAAC;AACtD,EAAA,MAAM,SAAA,GAAY,IAAI,GAAA,CAAI,aAAA,CAAc,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,CAAE,WAAA,EAAa,CAAC,CAAA;AACnE,EAAA,OAAO,OAAA,CACJ,GAAA;AAAA,IAAI,CAAC,MACJ,OAAO,CAAA,KAAM,WAAW,CAAA,GAAI,CAAA,CAAE,MAAA,IAAU,CAAA,CAAE,IAAA,IAAQ;AAAA,GACpD,CACC,MAAA,CAAO,CAAC,CAAA,KAAc,CAAA,IAAK,CAAC,SAAA,CAAU,GAAA,CAAI,CAAA,CAAE,WAAA,EAAa,CAAC,CAAA;AAC/D;AAKO,SAAS,mBAAA,CACd,YAAA,EACA,cAAA,EACA,cAAA,EACA,SAA6B,4BAAA,EACR;AACrB,EAAA,MAAM,UAAA,GAAa,IAAI,GAAA,CAAI,cAAA,CAAe,GAAA,CAAI,CAAC,CAAA,KAAM,CAAC,CAAA,CAAE,EAAA,EAAI,CAAC,CAAC,CAAC,CAAA;AAC/D,EAAA,MAAM,UAAA,GAAa,IAAI,GAAA,CAAI,cAAA,CAAe,GAAA,CAAI,CAAC,CAAA,KAAM,CAAC,CAAA,CAAE,EAAA,EAAI,CAAC,CAAC,CAAC,CAAA;AAE/D,EAAA,MAAM,UAA+B,EAAC;AAEtC,EAAA,KAAA,MAAW,QAAQ,YAAA,EAAc;AAC/B,IAAA,MAAM,GAAA,GAAM,UAAA,CAAW,GAAA,CAAI,IAAA,CAAK,QAAQ,CAAA;AACxC,IAAA,MAAM,GAAA,GAAM,UAAA,CAAW,GAAA,CAAI,IAAA,CAAK,QAAQ,CAAA;AACxC,IAAA,IAAI,CAAC,GAAA,IAAO,CAAC,GAAA,EAAK;AAElB,IAAA,MAAM,aAAA,GAAgB,UAAA,CAAW,GAAA,EAAK,MAAA,CAAO,aAAa,CAAA;AAC1D,IAAA,MAAM,aAAA,GAAgB,UAAA,CAAW,GAAA,EAAK,MAAA,CAAO,aAAa,CAAA;AAE1D,IAAA,MAAM,SAAA,GAAY,IAAI,GAAA,CAAI,aAAA,CAAc,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,CAAE,WAAA,EAAa,CAAC,CAAA;AACnE,IAAA,MAAM,SAAA,GAAY,IAAI,GAAA,CAAI,aAAA,CAAc,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,CAAE,WAAA,EAAa,CAAC,CAAA;AAEnE,IAAA,MAAM,eAAA,GAAkB,aAAA,CAAc,MAAA,CAAO,CAAC,CAAA,KAAM,CAAC,SAAA,CAAU,GAAA,CAAI,CAAA,CAAE,WAAA,EAAa,CAAC,CAAA;AACnF,IAAA,MAAM,eAAA,GAAkB,aAAA,CAAc,MAAA,CAAO,CAAC,CAAA,KAAM,CAAC,SAAA,CAAU,GAAA,CAAI,CAAA,CAAE,WAAA,EAAa,CAAC,CAAA;AAEnF,IAAA,OAAA,CAAQ,IAAA,CAAK;AAAA,MACX,IAAA;AAAA,MACA,aAAA;AAAA,MACA,aAAA;AAAA,MACA,eAAA;AAAA,MACA;AAAA,KACD,CAAA;AAAA,EACH;AAEA,EAAA,OAAO,OAAA;AACT;;;ACtDO,IAAM,6BAAA,GAAqD;AAAA,EAChE,mBAAA,EAAqB;AACvB,CAAA;AAKO,SAAS,oBAAoB,EAAA,EAAkC;AACpE,EAAA,MAAM,IAAA,GAAA,CAAQ,EAAA,CAAG,IAAA,IAAQ,EAAA,EAAI,WAAA,EAAY;AACzC,EAAA,MAAM,IAAA,GAAA,CAAQ,EAAA,CAAG,IAAA,IAAQ,EAAA,EAAI,WAAA,EAAY;AACzC,EAAA,MAAM,YAAA,GAAA,CAAgB,EAAA,CAAG,YAAA,IAAgB,EAAA,EAAI,WAAA,EAAY;AAGzD,EAAA,IAAI,CAAC,QAAQ,UAAA,EAAY,KAAK,EAAE,QAAA,CAAS,IAAI,GAAG,OAAO,IAAA;AAGvD,EAAA,IAAI,CAAC,MAAA,EAAQ,UAAU,EAAE,QAAA,CAAS,IAAI,GAAG,OAAO,IAAA;AAGhD,EAAA,IACE,YAAA,CAAa,QAAA,CAAS,KAAK,CAAA,IAC3B,YAAA,CAAa,QAAA,CAAS,MAAM,CAAA,IAC5B,YAAA,CAAa,QAAA,CAAS,KAAK,CAAA,EAC3B;AACA,IAAA,OAAO,IAAA;AAAA,EACT;AAGA,EAAA,MAAM,OAAA,GAAA,CAAW,EAAA,CAAG,aAAA,IAAiB,EAAA,EAAI,WAAA,EAAY;AACrD,EAAA,IAAI,OAAA,CAAQ,QAAA,CAAS,KAAK,CAAA,IAAK,OAAA,CAAQ,QAAA,CAAS,MAAM,CAAA,IAAK,OAAA,CAAQ,QAAA,CAAS,SAAS,CAAA,EAAG;AACtF,IAAA,IAAI,SAAS,QAAA,IAAY,IAAA,KAAS,YAAY,IAAA,KAAS,MAAA,IAAU,SAAS,MAAA,EAAQ;AAChF,MAAA,OAAO,IAAA;AAAA,IACT;AAAA,EACF;AAEA,EAAA,OAAO,KAAA;AACT;AAKA,SAAS,YAAY,EAAA,EAAiC;AACpD,EAAA,OAAO,EAAA,CAAG,kBAAkB,EAAA,CAAG,SAAA,IAAa,GAAG,KAAA,IAAS,EAAA,CAAG,eAAe,EAAA,CAAG,EAAA;AAC/E;AAKA,SAAS,QAAQ,EAAA,EAA6C;AAE5D,EAAA,MAAM,QAAQ,EAAA,CAAG,KAAA;AACjB,EAAA,OAAQ,OAAO,IAAA,IAAmB,MAAA;AACpC;AAKA,SAAS,UAAA,CAAW,GAAY,CAAA,EAAqB;AACnD,EAAA,IAAI,CAAC,CAAA,IAAK,CAAC,CAAA,EAAG,OAAO,KAAA;AAErB,EAAA,MAAM,YAAY,CAAC,CAAA,KACjB,CAAA,CACG,OAAA,CAAQ,gBAAgB,EAAE,CAAA,CAC1B,OAAA,CAAQ,eAAA,EAAiB,EAAE,CAAA,CAC3B,OAAA,CAAQ,MAAA,EAAQ,EAAE,EAClB,WAAA,EAAY;AACjB,EAAA,OAAO,SAAA,CAAU,CAAC,CAAA,KAAM,SAAA,CAAU,CAAC,CAAA;AACrC;AAKO,SAAS,kBAAA,CACd,cAAA,EACA,cAAA,EACA,MAAA,GAA8B,6BAAA,EACf;AACf,EAAA,MAAM,SAAA,GAAY,cAAA,CAAe,MAAA,CAAO,mBAAmB,CAAA;AAC3D,EAAA,MAAM,SAAA,GAAY,cAAA,CAAe,MAAA,CAAO,mBAAmB,CAAA;AAE3D,EAAA,MAAM,QAA0B,EAAC;AACjC,EAAA,MAAM,gBAAA,uBAAuB,GAAA,EAAY;AAEzC,EAAA,KAAA,MAAW,OAAO,SAAA,EAAW;AAC3B,IAAA,MAAM,QAAA,GAAW,YAAY,GAAG,CAAA;AAChC,IAAA,MAAM,OAAA,GAAU,gBAAgB,QAAQ,CAAA;AACxC,IAAA,IAAI,UAAA,GAAyC,IAAA;AAC7C,IAAA,IAAI,SAAA,GAAY,CAAA;AAEhB,IAAA,KAAA,MAAW,OAAO,SAAA,EAAW;AAC3B,MAAA,IAAI,gBAAA,CAAiB,GAAA,CAAI,GAAA,CAAI,EAAE,CAAA,EAAG;AAElC,MAAA,MAAM,QAAA,GAAW,YAAY,GAAG,CAAA;AAChC,MAAA,MAAM,OAAA,GAAU,gBAAgB,QAAQ,CAAA;AAGxC,MAAA,IAAI,YAAY,OAAA,EAAS;AACvB,QAAA,UAAA,GAAa,GAAA;AACb,QAAA,SAAA,GAAY,CAAA;AACZ,QAAA;AAAA,MACF;AAGA,MAAA,MAAM,UAAA,GAAa,qBAAA,CAAsB,OAAA,EAAS,OAAO,CAAA;AACzD,MAAA,IAAI,UAAA,GAAa,SAAA,IAAa,UAAA,IAAc,MAAA,CAAO,mBAAA,EAAqB;AACtE,QAAA,SAAA,GAAY,UAAA;AACZ,QAAA,UAAA,GAAa,GAAA;AAAA,MACf;AAAA,IACF;AAEA,IAAA,IAAI,UAAA,EAAY;AACd,MAAA,gBAAA,CAAiB,GAAA,CAAI,WAAW,EAAE,CAAA;AAClC,MAAA,MAAM,OAAA,GAAU,QAAQ,GAAG,CAAA;AAC3B,MAAA,MAAM,OAAA,GAAU,QAAQ,UAAU,CAAA;AAClC,MAAA,KAAA,CAAM,IAAA,CAAK;AAAA,QACT,UAAU,GAAA,CAAI,EAAA;AAAA,QACd,UAAU,UAAA,CAAW,EAAA;AAAA,QACrB,KAAA,EAAO,QAAA;AAAA,QACP,UAAA,EAAY,OAAA;AAAA,QACZ,UAAA,EAAY,OAAA;AAAA,QACZ,gBAAA,EAAkB,UAAA,CAAW,OAAA,EAAS,OAAO;AAAA,OAC9C,CAAA;AAAA,IACH;AAAA,EACF;AAEA,EAAA,MAAM,UAAA,GAAa,UAChB,MAAA,CAAO,CAAC,MAAM,CAAC,KAAA,CAAM,KAAK,CAAC,CAAA,KAAM,EAAE,QAAA,KAAa,CAAA,CAAE,EAAE,CAAC,CAAA,CACrD,IAAI,CAAC,CAAA,KAAM,EAAE,EAAE,CAAA;AAClB,EAAA,MAAM,aAAa,SAAA,CAAU,MAAA,CAAO,CAAC,CAAA,KAAM,CAAC,gBAAA,CAAiB,GAAA,CAAI,CAAA,CAAE,EAAE,CAAC,CAAA,CAAE,GAAA,CAAI,CAAC,CAAA,KAAM,EAAE,EAAE,CAAA;AAEvF,EAAA,OAAO,EAAE,KAAA,EAAO,UAAA,EAAY,UAAA,EAAW;AACzC;;;ACnIO,IAAM,mCAAA,GAAiE;AAAA,EAC5E,kBAAA,EAAoB;AACtB,CAAA;AAKA,SAAS,0BAAA,CAA2B,QAAuB,MAAA,EAA+B;AAExF,EAAA,IAAI,MAAA,CAAO,KAAK,WAAA,EAAY,KAAM,OAAO,IAAA,CAAK,WAAA,IAAe,OAAO,CAAA;AAGpE,EAAA,IAAI,KAAA,GAAQ,CAAA;AAEZ,EAAA,IAAI,MAAA,CAAO,IAAA,KAAS,MAAA,CAAO,IAAA,EAAM;AAC/B,IAAA,KAAA,IAAS,GAAA;AAAA,EACX;AAEA,EAAA,MAAM,cAAA,GAAiB,qBAAA;AAAA,IACrB,eAAA,CAAgB,OAAO,IAAI,CAAA;AAAA,IAC3B,eAAA,CAAgB,OAAO,IAAI;AAAA,GAC7B;AACA,EAAA,KAAA,IAAS,cAAA,GAAiB,GAAA;AAE1B,EAAA,OAAO,KAAA;AACT;AAQO,SAAS,iBAAA,CACd,gBAAA,EACA,gBAAA,EACA,MAAA,GAAoC,mCAAA,EACf;AAErB,EAAA,MAAM,aAID,EAAC;AAEN,EAAA,KAAA,IAAS,EAAA,GAAK,CAAA,EAAG,EAAA,GAAK,gBAAA,CAAiB,QAAQ,EAAA,EAAA,EAAM;AACnD,IAAA,KAAA,IAAS,EAAA,GAAK,CAAA,EAAG,EAAA,GAAK,gBAAA,CAAiB,QAAQ,EAAA,EAAA,EAAM;AACnD,MAAA,MAAM,QAAQ,0BAAA,CAA2B,gBAAA,CAAiB,EAAE,CAAA,EAAG,gBAAA,CAAiB,EAAE,CAAC,CAAA;AACnF,MAAA,IAAI,KAAA,IAAS,OAAO,kBAAA,EAAoB;AACtC,QAAA,UAAA,CAAW,KAAK,EAAE,SAAA,EAAW,IAAI,SAAA,EAAW,EAAA,EAAI,OAAO,CAAA;AAAA,MACzD;AAAA,IACF;AAAA,EACF;AAGA,EAAA,UAAA,CAAW,KAAK,CAAC,CAAA,EAAG,MAAM,CAAA,CAAE,KAAA,GAAQ,EAAE,KAAK,CAAA;AAC3C,EAAA,MAAM,UAAA,uBAAiB,GAAA,EAAY;AACnC,EAAA,MAAM,UAAA,uBAAiB,GAAA,EAAY;AACnC,EAAA,MAAM,UAA4B,EAAC;AAEnC,EAAA,KAAA,MAAW,KAAK,UAAA,EAAY;AAC1B,IAAA,IAAI,UAAA,CAAW,IAAI,CAAA,CAAE,SAAS,KAAK,UAAA,CAAW,GAAA,CAAI,CAAA,CAAE,SAAS,CAAA,EAAG;AAChE,IAAA,UAAA,CAAW,GAAA,CAAI,EAAE,SAAS,CAAA;AAC1B,IAAA,UAAA,CAAW,GAAA,CAAI,EAAE,SAAS,CAAA;AAE1B,IAAA,MAAM,GAAA,GAAM,gBAAA,CAAiB,CAAA,CAAE,SAAS,CAAA;AACxC,IAAA,MAAM,GAAA,GAAM,gBAAA,CAAiB,CAAA,CAAE,SAAS,CAAA;AAGxC,IAAA,MAAM,OAAA,GAAU,IAAI,GAAA,CAAI,GAAA,CAAI,SAAS,CAAA;AACrC,IAAA,MAAM,OAAA,GAAU,IAAI,GAAA,CAAI,GAAA,CAAI,SAAS,CAAA;AACrC,IAAA,MAAM,WAAA,GAAc,GAAA,CAAI,SAAA,CAAU,MAAA,CAAO,CAAC,MAAM,CAAC,OAAA,CAAQ,GAAA,CAAI,CAAC,CAAC,CAAA;AAC/D,IAAA,MAAM,SAAA,GAAY,GAAA,CAAI,SAAA,CAAU,MAAA,CAAO,CAAC,MAAM,CAAC,OAAA,CAAQ,GAAA,CAAI,CAAC,CAAC,CAAA;AAG7D,IAAA,MAAM,UAAA,GAAa,IAAI,GAAA,CAAI,GAAA,CAAI,OAAA,CAAQ,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,CAAE,WAAA,EAAa,CAAC,CAAA;AAClE,IAAA,MAAM,UAAA,GAAa,IAAI,GAAA,CAAI,GAAA,CAAI,OAAA,CAAQ,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,CAAE,WAAA,EAAa,CAAC,CAAA;AAClE,IAAA,MAAM,cAAA,GAAiB,GAAA,CAAI,OAAA,CAAQ,MAAA,CAAO,CAAC,CAAA,KAAM,CAAC,UAAA,CAAW,GAAA,CAAI,CAAA,CAAE,WAAA,EAAa,CAAC,CAAA;AACjF,IAAA,MAAM,YAAA,GAAe,GAAA,CAAI,OAAA,CAAQ,MAAA,CAAO,CAAC,CAAA,KAAM,CAAC,UAAA,CAAW,GAAA,CAAI,CAAA,CAAE,WAAA,EAAa,CAAC,CAAA;AAE/E,IAAA,OAAA,CAAQ,IAAA,CAAK;AAAA,MACX,MAAA,EAAQ,GAAA;AAAA,MACR,MAAA,EAAQ,GAAA;AAAA,MACR,YAAY,IAAA,CAAK,KAAA,CAAM,CAAA,CAAE,KAAA,GAAQ,GAAG,CAAA,GAAI,GAAA;AAAA,MACxC,YAAA,EAAc,EAAE,OAAA,EAAS,WAAA,EAAa,OAAO,SAAA,EAAU;AAAA,MACvD,UAAA,EAAY,EAAE,OAAA,EAAS,cAAA,EAAgB,OAAO,YAAA;AAAa,KAC5D,CAAA;AAAA,EACH;AAEA,EAAA,MAAM,UAAA,GAAa,gBAAA,CAAiB,MAAA,CAAO,CAAC,CAAA,EAAG,MAAM,CAAC,UAAA,CAAW,GAAA,CAAI,CAAC,CAAC,CAAA;AACvE,EAAA,MAAM,UAAA,GAAa,gBAAA,CAAiB,MAAA,CAAO,CAAC,CAAA,EAAG,MAAM,CAAC,UAAA,CAAW,GAAA,CAAI,CAAC,CAAC,CAAA;AAEvE,EAAA,OAAO,EAAE,OAAA,EAAS,UAAA,EAAY,UAAA,EAAW;AAC3C;;;ACtFO,IAAM,gCAAA,GAA2D;AAAA,EACtE,aAAA,EAAe;AACjB,CAAA;AASA,SAAS,QAAQ,EAAA,EAAwC;AACvD,EAAA,MAAM,IAAA,GAAO,GAAG,KAAA,EAAO,IAAA;AACvB,EAAA,IAAI,CAAC,IAAA,IAAQ,CAAC,IAAA,CAAK,OAAO,OAAO,IAAA;AACjC,EAAA,OAAO,EAAE,CAAA,EAAG,IAAA,CAAK,CAAA,EAAG,CAAA,EAAG,IAAA,CAAK,CAAA,EAAG,KAAA,EAAO,IAAA,CAAK,KAAA,EAAO,MAAA,EAAQ,IAAA,CAAK,MAAA,EAAO;AACxE;AAKA,SAAS,aAAA,CAAc,QAAkB,SAAA,EAA6B;AACpE,EAAA,IAAI,MAAA,CAAO,MAAA,KAAW,CAAA,EAAG,OAAO,EAAC;AACjC,EAAA,MAAM,MAAA,GAAS,CAAC,GAAG,MAAM,CAAA,CAAE,KAAK,CAAC,CAAA,EAAG,CAAA,KAAM,CAAA,GAAI,CAAC,CAAA;AAC/C,EAAA,MAAM,QAAA,GAAqB,CAAC,MAAA,CAAO,CAAC,CAAC,CAAA;AACrC,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AACtC,IAAA,IAAI,MAAA,CAAO,CAAC,CAAA,GAAI,QAAA,CAAS,SAAS,MAAA,GAAS,CAAC,IAAI,SAAA,EAAW;AACzD,MAAA,QAAA,CAAS,IAAA,CAAK,MAAA,CAAO,CAAC,CAAC,CAAA;AAAA,IACzB;AAAA,EACF;AACA,EAAA,OAAO,QAAA;AACT;AAKO,SAAS,mBAAA,CACd,QAAA,EACA,MAAA,GAAiC,gCAAA,EAClB;AACf,EAAA,MAAM,KAAA,GAAQ,SAAS,GAAA,CAAI,OAAO,EAAE,MAAA,CAAO,CAAC,CAAA,KAAmB,CAAA,KAAM,IAAI,CAAA;AAEzE,EAAA,MAAM,aAAa,KAAA,CAAM,GAAA,CAAI,CAAC,CAAA,KAAM,EAAE,CAAC,CAAA;AACvC,EAAA,MAAM,aAAa,KAAA,CAAM,GAAA,CAAI,CAAC,CAAA,KAAM,EAAE,CAAC,CAAA;AAEvC,EAAA,MAAM,OAAA,GAAU,aAAA,CAAc,UAAA,EAAY,MAAA,CAAO,aAAa,CAAA;AAC9D,EAAA,MAAM,IAAA,GAAO,aAAA,CAAc,UAAA,EAAY,MAAA,CAAO,aAAa,CAAA;AAE3D,EAAA,OAAO;AAAA,IACL,OAAA;AAAA,IACA,IAAA;AAAA,IACA,aAAa,OAAA,CAAQ,MAAA;AAAA,IACrB,UAAU,IAAA,CAAK;AAAA,GACjB;AACF;AAKA,SAAS,gBAAgB,QAAA,EAAyC;AAChE,EAAA,IAAI,QAAA,GAAW,CAAA;AACf,EAAA,KAAA,MAAW,MAAM,QAAA,EAAU;AAEzB,IAAA,MAAM,OAAA,GAAU,GAAG,aAAA,IAAiB,EAAA;AACpC,IAAA,MAAM,QAAQ,OAAA,GAAU,OAAA,CAAQ,KAAA,CAAM,GAAG,EAAE,MAAA,GAAS,CAAA;AACpD,IAAA,QAAA,GAAW,IAAA,CAAK,GAAA,CAAI,QAAA,EAAU,KAAK,CAAA;AAAA,EACrC;AACA,EAAA,OAAO,QAAA;AACT;AAuBO,SAAS,eACd,cAAA,EACA,cAAA,EACA,aAAA,EACA,aAAA,EACA,SAAiC,gCAAA,EACf;AAClB,EAAA,MAAM,UAAA,GAAa,mBAAA,CAAoB,cAAA,EAAgB,MAAM,CAAA;AAC7D,EAAA,MAAM,UAAA,GAAa,mBAAA,CAAoB,cAAA,EAAgB,MAAM,CAAA;AAE7D,EAAA,MAAM,QAAA,GAAqB;AAAA,IACzB,UAAA;AAAA,IACA,UAAA;AAAA,IACA,UAAA,EAAY,UAAA,CAAW,WAAA,GAAc,UAAA,CAAW,WAAA;AAAA,IAChD,OAAA,EAAS,UAAA,CAAW,QAAA,GAAW,UAAA,CAAW;AAAA,GAC5C;AAEA,EAAA,MAAM,WAAA,GAAc,gBAAgB,cAAc,CAAA;AAClD,EAAA,MAAM,WAAA,GAAc,gBAAgB,cAAc,CAAA;AAClD,EAAA,MAAM,aAAA,GAA+B;AAAA,IACnC,WAAA;AAAA,IACA,WAAA;AAAA,IACA,WAAW,WAAA,GAAc;AAAA,GAC3B;AAGA,EAAA,MAAM,iBAAA,GAAoB,aAAA,EAAe,OAAA,CAAQ,MAAA,IAAU,CAAA;AAC3D,EAAA,MAAM,iBAAA,GAAoB,aAAA,EAAe,OAAA,CAAQ,MAAA,IAAU,CAAA;AAC3D,EAAA,MAAM,aAAA,GAAgB,eAAe,MAAA,GAAS,iBAAA;AAC9C,EAAA,MAAM,aAAA,GAAgB,eAAe,MAAA,GAAS,iBAAA;AAE9C,EAAA,MAAM,OAAA,GAA6B;AAAA,IACjC,aAAA,EAAe,IAAA,CAAK,KAAA,CAAM,aAAA,GAAgB,GAAG,CAAA,GAAI,GAAA;AAAA,IACjD,aAAA,EAAe,IAAA,CAAK,KAAA,CAAM,aAAA,GAAgB,GAAG,CAAA,GAAI,GAAA;AAAA,IACjD,KAAA,EAAO,gBAAgB,CAAA,GAAI,IAAA,CAAK,MAAO,aAAA,GAAgB,aAAA,GAAiB,GAAG,CAAA,GAAI,GAAA,GAAM;AAAA,GACvF;AAGA,EAAA,MAAM,cAAA,GACJ,WAAW,WAAA,KAAgB,CAAA,IAAK,WAAW,WAAA,KAAgB,CAAA,GACvD,IACA,CAAA,GACA,IAAA,CAAK,IAAI,QAAA,CAAS,UAAU,IAAI,IAAA,CAAK,GAAA,CAAI,WAAW,WAAA,EAAa,UAAA,CAAW,aAAa,CAAC,CAAA;AAEhG,EAAA,MAAM,sBACJ,WAAA,KAAgB,CAAA,IAAK,WAAA,KAAgB,CAAA,GACjC,IACA,CAAA,GAAI,IAAA,CAAK,GAAA,CAAI,aAAA,CAAc,SAAS,CAAA,GAAI,IAAA,CAAK,GAAA,CAAI,WAAA,EAAa,aAAa,CAAC,CAAA;AAElF,EAAA,MAAM,iBAAA,GAAoB,OAAA,CAAQ,KAAA,GAAQ,CAAA,GAAI,IAAA,CAAK,GAAA,CAAI,OAAA,CAAQ,KAAA,EAAO,CAAA,GAAI,OAAA,CAAQ,KAAK,CAAA,GAAI,CAAA;AAE3F,EAAA,MAAM,UAAA,GACJ,IAAA,CAAK,KAAA,CAAA,CAAO,cAAA,GAAiB,GAAA,GAAM,sBAAsB,GAAA,GAAM,iBAAA,GAAoB,GAAA,IAAO,GAAG,CAAA,GAC7F,GAAA;AAEF,EAAA,OAAO;AAAA,IACL,QAAA;AAAA,IACA,aAAA;AAAA,IACA,OAAA;AAAA,IACA;AAAA,GACF;AACF;;;AC7IO,IAAM,iCAAA,GAA6D;AAAA,EACxE,mBAAA,EAAqB,GAAA;AAAA,EACrB,qBAAA,EAAuB,IAAA;AAAA,EACvB,kBAAA,EAAoB;AACtB,CAAA;AASA,SAASC,gBAAe,EAAA,EAAiC;AACvD,EAAA,OAAA,CACE,EAAA,CAAG,cAAA,IACH,EAAA,CAAG,SAAA,IACH,EAAA,CAAG,KAAA,IACH,EAAA,CAAG,KAAA,EAAO,WAAA,IACV,EAAA,CAAG,WAAA,IACH,EAAA,EACA,IAAA,EAAK;AACT;AAMA,SAAS,eAAe,EAAA,EAAwC;AAC9D,EAAA,IAAI,EAAA,CAAG,iBAAiB,WAAA,EAAa;AACnC,IAAA,OAAO,GAAG,eAAA,CAAgB,WAAA;AAAA,EAC5B;AAEA,EAAA,MAAM,CAAA,GAAA,CAAK,EAAA,CAAG,IAAA,IAAQ,EAAA,EAAI,WAAA,EAAY;AACtC,EAAA,IAAI,CAAA,KAAM,SAAA,IAAc,CAAA,CAAE,UAAA,CAAW,GAAG,KAAK,UAAA,CAAW,IAAA,CAAK,CAAC,CAAA,EAAI,OAAO,SAAA;AACzE,EAAA,IAAI,CAAA,KAAM,cAAA,IAAkB,CAAA,KAAM,QAAA,EAAU,OAAO,QAAA;AACnD,EAAA,IAAI,CAAA,KAAM,gBAAA,IAAoB,CAAA,KAAM,QAAA,EAAU,OAAO,QAAA;AACrD,EAAA,IAAI,CAAA,KAAM,SAAS,OAAO,OAAA;AAC1B,EAAA,IAAI,CAAA,KAAM,SAAS,OAAO,OAAA;AAC1B,EAAA,IAAI,CAAA,KAAM,cAAc,OAAO,YAAA;AAC/B,EAAA,IAAI,CAAA,KAAM,gBAAgB,OAAO,cAAA;AACjC,EAAA,IAAI,CAAA,KAAM,WAAW,OAAO,SAAA;AAC5B,EAAA,OAAO,IAAA;AACT;AAKA,SAAS,gBAAgB,EAAA,EAA6C;AACpE,EAAA,IAAI,EAAA,CAAG,iBAAiB,YAAA,EAAc;AACpC,IAAA,OAAO,GAAG,eAAA,CAAgB,YAAA;AAAA,EAC5B;AAEA,EAAA,MAAM,OAAO,EAAA,CAAG,OAAA,IAAW,EAAA,CAAG,IAAA,IAAQ,IAAI,WAAA,EAAY;AACtD,EAAA,MAAM,KAAA,GAAQ,YAAA,CAAa,IAAA,CAAK,GAAG,CAAA;AACnC,EAAA,IAAI,OAAO,OAAO,QAAA,CAAS,KAAA,CAAM,CAAC,GAAG,EAAE,CAAA;AACvC,EAAA,OAAO,MAAA;AACT;AAKA,SAASC,kBAAiB,EAAA,EAAkC;AAC1D,EAAA,IAAI,EAAA,CAAG,QAAA,KAAa,SAAA,EAAW,OAAO,IAAA;AACtC,EAAA,IAAI,EAAA,CAAG,iBAAiB,OAAO,IAAA;AAC/B,EAAA,MAAM,IAAA,GAAO,eAAe,EAAE,CAAA;AAC9B,EAAA,OAAO,IAAA,KAAS,IAAA;AAClB;AAKA,SAAS,cAAc,IAAA,EAAsB;AAC3C,EAAA,OAAO,gBAAgB,IAAA,EAAM,EAAE,eAAe,KAAA,EAAO,gBAAA,EAAkB,MAAM,CAAA;AAC/E;AAkBA,SAAS,gBAAgB,EAAA,EAA2D;AAClF,EAAA,MAAM,IAAA,GAAOD,gBAAe,EAAE,CAAA;AAE9B,EAAA,MAAM,UAAA,GAAa,IAAA,CAAK,KAAA,CAAM,iBAAiB,CAAA;AAC/C,EAAA,IAAI,UAAA,EAAY;AACd,IAAA,OAAO,EAAE,KAAA,EAAO,UAAA,CAAW,CAAC,CAAA,CAAE,IAAA,EAAK,EAAG,KAAA,EAAO,UAAA,CAAW,CAAC,CAAA,CAAE,IAAA,EAAK,EAAE;AAAA,EACpE;AACA,EAAA,MAAM,SAAA,GAAY,IAAA,CAAK,KAAA,CAAM,sBAAsB,CAAA;AACnD,EAAA,IAAI,SAAA,EAAW;AACb,IAAA,OAAO,EAAE,KAAA,EAAO,SAAA,CAAU,CAAC,CAAA,CAAE,IAAA,EAAK,EAAG,KAAA,EAAO,SAAA,CAAU,CAAC,CAAA,CAAE,IAAA,EAAK,EAAE;AAAA,EAClE;AAEA,EAAA,MAAM,UAAU,EAAA,CAAG,cAAA,IAAkB,GAAG,SAAA,IAAa,EAAA,CAAG,SAAS,EAAA,CAAG,EAAA;AACpE,EAAA,OAAO,EAAE,KAAA,EAAO,OAAA,EAAS,KAAA,EAAO,IAAA,EAAK;AACvC;AAMA,SAAS,eAAe,QAAA,EAAwD;AAC9E,EAAA,OAAO,SAAS,MAAA,CAAO,CAAC,OAAO,cAAA,CAAe,EAAE,MAAM,SAAS,CAAA;AACjE;AAEA,SAAS,cAAc,QAAA,EAAwD;AAC7E,EAAA,OAAO,SAAS,MAAA,CAAO,CAAC,OAAO,cAAA,CAAe,EAAE,MAAM,QAAQ,CAAA;AAChE;AAEA,SAAS,eAAe,QAAA,EAAwD;AAC9E,EAAA,OAAO,QAAA,CAAS,MAAA,CAAO,CAAC,EAAA,KAAO;AAC7B,IAAA,MAAM,IAAA,GAAO,eAAe,EAAE,CAAA;AAC9B,IAAA,OAAO,IAAA,KAAS,YAAY,IAAA,KAAS,OAAA;AAAA,EACvC,CAAC,CAAA;AACH;AAEA,SAAS,aAAa,QAAA,EAAwD;AAC5E,EAAA,OAAO,QAAA,CAAS,MAAA,CAAO,CAAC,EAAA,KAAO;AAC7B,IAAA,MAAM,IAAA,GAAO,eAAe,EAAE,CAAA;AAC9B,IAAA,OAAO,IAAA,KAAS,WAAW,IAAA,KAAS,SAAA;AAAA,EACtC,CAAC,CAAA;AACH;AAgBA,SAAS,UAAA,CACP,WAAA,EACA,WAAA,EACA,SAAA,EAKA;AACA,EAAA,MAAM,aAA+B,EAAC;AAEtC,EAAA,KAAA,IAAS,EAAA,GAAK,CAAA,EAAG,EAAA,GAAK,WAAA,CAAY,QAAQ,EAAA,EAAA,EAAM;AAC9C,IAAA,MAAM,KAAA,GAAQ,aAAA,CAAc,WAAA,CAAY,EAAE,CAAC,CAAA;AAC3C,IAAA,IAAI,CAAC,KAAA,EAAO;AACZ,IAAA,KAAA,IAAS,EAAA,GAAK,CAAA,EAAG,EAAA,GAAK,WAAA,CAAY,QAAQ,EAAA,EAAA,EAAM;AAC9C,MAAA,MAAM,KAAA,GAAQ,aAAA,CAAc,WAAA,CAAY,EAAE,CAAC,CAAA;AAC3C,MAAA,IAAI,CAAC,KAAA,EAAO;AACZ,MAAA,MAAM,QAAQ,KAAA,KAAU,KAAA,GAAQ,CAAA,GAAM,qBAAA,CAAsB,OAAO,KAAK,CAAA;AACxE,MAAA,IAAI,SAAS,SAAA,EAAW;AACtB,QAAA,UAAA,CAAW,KAAK,EAAE,SAAA,EAAW,IAAI,SAAA,EAAW,EAAA,EAAI,OAAO,CAAA;AAAA,MACzD;AAAA,IACF;AAAA,EACF;AAGA,EAAA,UAAA,CAAW,KAAK,CAAC,CAAA,EAAG,MAAM,CAAA,CAAE,KAAA,GAAQ,EAAE,KAAK,CAAA;AAE3C,EAAA,MAAM,UAAA,uBAAiB,GAAA,EAAY;AACnC,EAAA,MAAM,UAAA,uBAAiB,GAAA,EAAY;AACnC,EAAA,MAAM,UAA0E,EAAC;AAEjF,EAAA,KAAA,MAAW,KAAK,UAAA,EAAY;AAC1B,IAAA,IAAI,UAAA,CAAW,IAAI,CAAA,CAAE,SAAS,KAAK,UAAA,CAAW,GAAA,CAAI,CAAA,CAAE,SAAS,CAAA,EAAG;AAChE,IAAA,UAAA,CAAW,GAAA,CAAI,EAAE,SAAS,CAAA;AAC1B,IAAA,UAAA,CAAW,GAAA,CAAI,EAAE,SAAS,CAAA;AAC1B,IAAA,OAAA,CAAQ,KAAK,CAAC,CAAA;AAAA,EAChB;AAEA,EAAA,MAAM,eAAA,GAAkB,WAAA,CAAY,GAAA,CAAI,CAAC,GAAG,CAAA,KAAM,CAAC,CAAA,CAAE,MAAA,CAAO,CAAC,CAAA,KAAM,CAAC,UAAA,CAAW,GAAA,CAAI,CAAC,CAAC,CAAA;AACrF,EAAA,MAAM,eAAA,GAAkB,WAAA,CAAY,GAAA,CAAI,CAAC,GAAG,CAAA,KAAM,CAAC,CAAA,CAAE,MAAA,CAAO,CAAC,CAAA,KAAM,CAAC,UAAA,CAAW,GAAA,CAAI,CAAC,CAAC,CAAA;AAErF,EAAA,OAAO,EAAE,OAAA,EAAS,eAAA,EAAiB,eAAA,EAAgB;AACrD;AAMA,SAAS,eAAA,CACP,cAAA,EACA,cAAA,EACA,MAAA,EAC+B;AAC/B,EAAA,MAAM,WAAA,GAAc,eAAe,cAAc,CAAA;AACjD,EAAA,MAAM,WAAA,GAAc,eAAe,cAAc,CAAA;AAEjD,EAAA,MAAM,QAAA,GAAW,WAAA,CAAY,GAAA,CAAIA,eAAc,CAAA;AAC/C,EAAA,MAAM,QAAA,GAAW,WAAA,CAAY,GAAA,CAAIA,eAAc,CAAA;AAE/C,EAAA,MAAM,EAAE,OAAA,EAAS,eAAA,EAAiB,eAAA,EAAgB,GAAI,UAAA;AAAA,IACpD,QAAA;AAAA,IACA,QAAA;AAAA,IACA,MAAA,CAAO;AAAA,GACT;AAEA,EAAA,MAAM,iBAAiC,EAAC;AACxC,EAAA,MAAM,iBAAkC,EAAC;AAEzC,EAAA,KAAA,MAAW,KAAK,OAAA,EAAS;AACvB,IAAA,MAAM,OAAA,GAAU,QAAA,CAAS,CAAA,CAAE,SAAS,CAAA;AACpC,IAAA,MAAM,OAAA,GAAU,QAAA,CAAS,CAAA,CAAE,SAAS,CAAA;AACpC,IAAA,MAAM,QAAA,GAAW,eAAA,CAAgB,WAAA,CAAY,CAAA,CAAE,SAAS,CAAC,CAAA;AACzD,IAAA,MAAM,QAAA,GAAW,eAAA,CAAgB,WAAA,CAAY,CAAA,CAAE,SAAS,CAAC,CAAA;AAEzD,IAAA,IAAI,aAAA,CAAc,OAAO,CAAA,KAAM,aAAA,CAAc,OAAO,CAAA,EAAG;AACrD,MAAA,cAAA,CAAe,IAAA,CAAK;AAAA,QAClB,MAAA,EAAQ,OAAA;AAAA,QACR,MAAA,EAAQ,OAAA;AAAA,QACR,KAAA,EAAO;AAAA,OACR,CAAA;AAAA,IACH,CAAA,MAAO;AACL,MAAA,cAAA,CAAe,IAAA,CAAK;AAAA,QAClB,MAAA,EAAQ,OAAA;AAAA,QACR,MAAA,EAAQ,OAAA;AAAA,QACR,OAAO,QAAA,IAAY;AAAA,OACpB,CAAA;AAAA,IACH;AAAA,EACF;AAEA,EAAA,OAAO;AAAA,IACL,OAAA,EAAS,cAAA;AAAA,IACT,YAAY,eAAA,CAAgB,GAAA,CAAI,CAAC,CAAA,KAAM,QAAA,CAAS,CAAC,CAAC,CAAA;AAAA,IAClD,YAAY,eAAA,CAAgB,GAAA,CAAI,CAAC,CAAA,KAAM,QAAA,CAAS,CAAC,CAAC,CAAA;AAAA,IAClD,OAAA,EAAS;AAAA,GACX;AACF;AAMA,SAAS,cAAA,CACP,cAAA,EACA,cAAA,EACA,MAAA,EAC8B;AAC9B,EAAA,MAAM,UAAA,GAAa,cAAc,cAAc,CAAA;AAC/C,EAAA,MAAM,UAAA,GAAa,cAAc,cAAc,CAAA;AAE/C,EAAA,MAAM,SAAA,GAAY,UAAA,CAAW,GAAA,CAAI,eAAe,CAAA;AAChD,EAAA,MAAM,SAAA,GAAY,UAAA,CAAW,GAAA,CAAI,eAAe,CAAA;AAEhD,EAAA,MAAM,YAAY,SAAA,CAAU,GAAA,CAAI,CAAC,CAAA,KAAM,EAAE,KAAK,CAAA;AAC9C,EAAA,MAAM,YAAY,SAAA,CAAU,GAAA,CAAI,CAAC,CAAA,KAAM,EAAE,KAAK,CAAA;AAE9C,EAAA,MAAM,EAAE,OAAA,EAAS,eAAA,EAAiB,eAAA,EAAgB,GAAI,UAAA;AAAA,IACpD,SAAA;AAAA,IACA,SAAA;AAAA,IACA,MAAA,CAAO;AAAA,GACT;AAEA,EAAA,MAAM,gBAA+B,EAAC;AACtC,EAAA,MAAM,gBAAwC,EAAC;AAE/C,EAAA,KAAA,MAAW,KAAK,OAAA,EAAS;AACvB,IAAA,MAAM,GAAA,GAAM,SAAA,CAAU,CAAA,CAAE,SAAS,CAAA;AACjC,IAAA,MAAM,GAAA,GAAM,SAAA,CAAU,CAAA,CAAE,SAAS,CAAA;AAEjC,IAAA,IAAI,cAAc,GAAA,CAAI,KAAK,MAAM,aAAA,CAAc,GAAA,CAAI,KAAK,CAAA,EAAG;AACzD,MAAA,aAAA,CAAc,IAAA,CAAK;AAAA,QACjB,OAAO,GAAA,CAAI,KAAA;AAAA,QACX,aAAa,GAAA,CAAI,KAAA;AAAA,QACjB,aAAa,GAAA,CAAI;AAAA,OAClB,CAAA;AAAA,IACH,CAAA,MAAO;AACL,MAAA,aAAA,CAAc,IAAA,CAAK;AAAA,QACjB,OAAO,GAAA,CAAI,KAAA;AAAA,QACX,aAAa,GAAA,CAAI,KAAA;AAAA,QACjB,aAAa,GAAA,CAAI;AAAA,OAClB,CAAA;AAAA,IACH;AAAA,EACF;AAEA,EAAA,OAAO;AAAA,IACL,OAAA,EAAS,aAAA;AAAA,IACT,OAAA,EAAS,aAAA;AAAA,IACT,UAAA,EAAY,gBAAgB,GAAA,CAAI,CAAC,MAAM,SAAA,CAAU,CAAC,EAAE,KAAK,CAAA;AAAA,IACzD,UAAA,EAAY,gBAAgB,GAAA,CAAI,CAAC,MAAM,SAAA,CAAU,CAAC,EAAE,KAAK;AAAA,GAC3D;AACF;AAMA,SAAS,eAAA,CACP,cAAA,EACA,cAAA,EACA,MAAA,EAC+B;AAC/B,EAAA,MAAM,WAAA,GAAc,eAAe,cAAc,CAAA;AACjD,EAAA,MAAM,WAAA,GAAc,eAAe,cAAc,CAAA;AAEjD,EAAA,MAAM,SAAA,GAAY,WAAA,CAAY,GAAA,CAAI,eAAe,CAAA;AACjD,EAAA,MAAM,SAAA,GAAY,WAAA,CAAY,GAAA,CAAI,eAAe,CAAA;AAEjD,EAAA,MAAM,YAAY,SAAA,CAAU,GAAA,CAAI,CAAC,CAAA,KAAM,EAAE,KAAK,CAAA;AAC9C,EAAA,MAAM,YAAY,SAAA,CAAU,GAAA,CAAI,CAAC,CAAA,KAAM,EAAE,KAAK,CAAA;AAE9C,EAAA,MAAM,EAAE,OAAA,EAAQ,GAAI,WAAW,SAAA,EAAW,SAAA,EAAW,OAAO,mBAAmB,CAAA;AAE/E,EAAA,MAAM,gBAA+B,EAAC;AACtC,EAAA,MAAM,gBAAwC,EAAC;AAE/C,EAAA,KAAA,MAAW,KAAK,OAAA,EAAS;AACvB,IAAA,MAAM,GAAA,GAAM,SAAA,CAAU,CAAA,CAAE,SAAS,CAAA;AACjC,IAAA,MAAM,GAAA,GAAM,SAAA,CAAU,CAAA,CAAE,SAAS,CAAA;AAEjC,IAAA,IAAI,cAAc,GAAA,CAAI,KAAK,MAAM,aAAA,CAAc,GAAA,CAAI,KAAK,CAAA,EAAG;AACzD,MAAA,aAAA,CAAc,IAAA,CAAK;AAAA,QACjB,OAAO,GAAA,CAAI,KAAA;AAAA,QACX,cAAc,GAAA,CAAI,KAAA;AAAA,QAClB,cAAc,GAAA,CAAI;AAAA,OACnB,CAAA;AAAA,IACH,CAAA,MAAO;AACL,MAAA,aAAA,CAAc,IAAA,CAAK;AAAA,QACjB,OAAO,GAAA,CAAI,KAAA;AAAA,QACX,cAAc,GAAA,CAAI,KAAA;AAAA,QAClB,cAAc,GAAA,CAAI;AAAA,OACnB,CAAA;AAAA,IACH;AAAA,EACF;AAEA,EAAA,OAAO;AAAA,IACL,OAAA,EAAS,aAAA;AAAA,IACT,OAAA,EAAS;AAAA,GACX;AACF;AAMA,SAAS,aAAA,CACP,cAAA,EACA,cAAA,EACA,MAAA,EAC6B;AAC7B,EAAA,MAAM,SAAA,GAAY,aAAa,cAAc,CAAA;AAC7C,EAAA,MAAM,SAAA,GAAY,aAAa,cAAc,CAAA;AAE7C,EAAA,MAAM,QAAA,GAAW,SAAA,CAAU,GAAA,CAAIA,eAAc,CAAA;AAC7C,EAAA,MAAM,QAAA,GAAW,SAAA,CAAU,GAAA,CAAIA,eAAc,CAAA;AAE7C,EAAA,MAAM,EAAE,OAAA,EAAS,eAAA,EAAiB,eAAA,EAAgB,GAAI,UAAA;AAAA,IACpD,QAAA;AAAA,IACA,QAAA;AAAA,IACA,MAAA,CAAO;AAAA,GACT;AAEA,EAAA,OAAO;AAAA,IACL,OAAA,EAAS,QAAQ,GAAA,CAAI,CAAC,MAAM,QAAA,CAAS,CAAA,CAAE,SAAS,CAAC,CAAA;AAAA,IACjD,YAAY,eAAA,CAAgB,GAAA,CAAI,CAAC,CAAA,KAAM,QAAA,CAAS,CAAC,CAAC,CAAA;AAAA,IAClD,YAAY,eAAA,CAAgB,GAAA,CAAI,CAAC,CAAA,KAAM,QAAA,CAAS,CAAC,CAAC;AAAA,GACpD;AACF;AAMA,SAAS,aAAA,CACP,cAAA,EACA,cAAA,EACA,MAAA,EACmB;AACnB,EAAA,MAAM,OAAA,GAAU,sBAAsB,cAAc,CAAA;AACpD,EAAA,MAAM,OAAA,GAAU,sBAAsB,cAAc,CAAA;AAEpD,EAAA,MAAM,YAAY,OAAA,CAAQ,MAAA;AAC1B,EAAA,MAAM,YAAY,OAAA,CAAQ,MAAA;AAE1B,EAAA,IAAI,SAAA,CAAU,MAAA,KAAW,CAAA,IAAK,SAAA,CAAU,WAAW,CAAA,EAAG;AACpD,IAAA,OAAO,EAAC;AAAA,EACV;AAGA,EAAA,MAAM,iBAAiB,SAAA,CAAU,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,CAAE,SAAS,EAAE,CAAA;AACzD,EAAA,MAAM,iBAAiB,SAAA,CAAU,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,CAAE,SAAS,EAAE,CAAA;AAEzD,EAAA,MAAM,EAAE,OAAA,EAAQ,GAAI,WAAW,cAAA,EAAgB,cAAA,EAAgB,OAAO,mBAAmB,CAAA;AAGzF,EAAA,MAAM,aAAwD,EAAC;AAC/D,EAAA,IAAI,OAAA,CAAQ,SAAS,CAAA,EAAG;AACtB,IAAA,KAAA,MAAW,KAAK,OAAA,EAAS;AACvB,MAAA,UAAA,CAAW,IAAA,CAAK,EAAE,MAAA,EAAQ,CAAA,CAAE,WAAW,MAAA,EAAQ,CAAA,CAAE,WAAW,CAAA;AAAA,IAC9D;AAAA,EACF,WAAW,SAAA,CAAU,MAAA,KAAW,CAAA,IAAK,SAAA,CAAU,WAAW,CAAA,EAAG;AAE3D,IAAA,UAAA,CAAW,KAAK,EAAE,MAAA,EAAQ,CAAA,EAAG,MAAA,EAAQ,GAAG,CAAA;AAAA,EAC1C;AAEA,EAAA,MAAM,cAAiC,EAAC;AAExC,EAAA,KAAA,MAAW,QAAQ,UAAA,EAAY;AAC7B,IAAA,MAAM,QAAA,GAAW,SAAA,CAAU,IAAA,CAAK,MAAM,CAAA;AACtC,IAAA,MAAM,QAAA,GAAW,SAAA,CAAU,IAAA,CAAK,MAAM,CAAA;AAEtC,IAAA,MAAM,aAAa,QAAA,CAAS,OAAA,CAAQ,IAAI,CAAC,CAAA,KAAM,EAAE,MAAM,CAAA;AACvD,IAAA,MAAM,aAAa,QAAA,CAAS,OAAA,CAAQ,IAAI,CAAC,CAAA,KAAM,EAAE,MAAM,CAAA;AAEvD,IAAA,MAAM,eAAe,IAAI,GAAA,CAAI,UAAA,CAAW,GAAA,CAAI,aAAa,CAAC,CAAA;AAC1D,IAAA,MAAM,eAAe,IAAI,GAAA,CAAI,UAAA,CAAW,GAAA,CAAI,aAAa,CAAC,CAAA;AAE1D,IAAA,MAAM,iBAAA,GAAoB,UAAA,CAAW,MAAA,CAAO,CAAC,CAAA,KAAM,CAAC,YAAA,CAAa,GAAA,CAAI,aAAA,CAAc,CAAC,CAAC,CAAC,CAAA;AACtF,IAAA,MAAM,iBAAA,GAAoB,UAAA,CAAW,MAAA,CAAO,CAAC,CAAA,KAAM,CAAC,YAAA,CAAa,GAAA,CAAI,aAAA,CAAc,CAAC,CAAC,CAAC,CAAA;AACtF,IAAA,MAAM,YAAA,GAAe,iBAAA,CAAkB,MAAA,KAAW,CAAA,IAAK,kBAAkB,MAAA,KAAW,CAAA;AAGpF,IAAA,MAAM,kBAAsD,EAAC;AAC7D,IAAA,MAAM,aAAA,GAAgB,UAAA,CAAW,MAAA,CAAO,CAAC,CAAA,KAAM,aAAa,GAAA,CAAI,aAAA,CAAc,CAAC,CAAC,CAAC,CAAA;AAEjF,IAAA,MAAM,OAAA,GAAU,KAAK,GAAA,CAAI,QAAA,CAAS,KAAK,MAAA,EAAQ,QAAA,CAAS,KAAK,MAAM,CAAA;AACnE,IAAA,KAAA,IAAS,GAAA,GAAM,CAAA,EAAG,GAAA,GAAM,OAAA,EAAS,GAAA,EAAA,EAAO;AACtC,MAAA,IAAI,eAAA,CAAgB,MAAA,IAAU,MAAA,CAAO,kBAAA,EAAoB;AAEzD,MAAA,KAAA,MAAW,UAAU,aAAA,EAAe;AAClC,QAAA,MAAM,SAAA,GAAY,UAAA,CAAW,OAAA,CAAQ,MAAM,CAAA;AAC3C,QAAA,MAAM,SAAA,GAAY,UAAA,CAAW,SAAA,CAAU,CAAC,CAAA,KAAM,cAAc,CAAC,CAAA,KAAM,aAAA,CAAc,MAAM,CAAC,CAAA;AAExF,QAAA,IAAI,SAAA,GAAY,CAAA,IAAK,SAAA,GAAY,CAAA,EAAG;AAEpC,QAAA,MAAM,WAAW,QAAA,CAAS,IAAA,CAAK,GAAG,CAAA,GAAI,SAAS,CAAA,IAAK,EAAA;AACpD,QAAA,MAAM,WAAW,QAAA,CAAS,IAAA,CAAK,GAAG,CAAA,GAAI,SAAS,CAAA,IAAK,EAAA;AAEpD,QAAA,IAAI,aAAA,CAAc,QAAQ,CAAA,KAAM,aAAA,CAAc,QAAQ,CAAA,EAAG;AACvD,UAAA,eAAA,CAAgB,IAAA,CAAK;AAAA,YACnB,GAAA;AAAA,YACA,MAAA,EAAQ,MAAA;AAAA,YACR,WAAA,EAAa,QAAA;AAAA,YACb,WAAA,EAAa;AAAA,WACd,CAAA;AAAA,QACH;AAAA,MACF;AAAA,IACF;AAEA,IAAA,WAAA,CAAY,IAAA,CAAK;AAAA,MACf,aAAa,QAAA,CAAS,KAAA;AAAA,MACtB,aAAa,QAAA,CAAS,KAAA;AAAA,MACtB,YAAA;AAAA,MACA,iBAAA;AAAA,MACA,iBAAA;AAAA,MACA,cAAA,EAAgB,SAAS,IAAA,CAAK,MAAA;AAAA,MAC9B,cAAA,EAAgB,SAAS,IAAA,CAAK,MAAA;AAAA,MAC9B;AAAA,KACD,CAAA;AAAA,EACH;AAEA,EAAA,OAAO,WAAA;AACT;AAMA,SAAS,uBAAA,CACP,gBACA,cAAA,EAC0B;AAC1B,EAAA,MAAM,WAAA,GAAc,eAAe,cAAc,CAAA;AACjD,EAAA,MAAM,WAAA,GAAc,eAAe,cAAc,CAAA;AAEjD,EAAA,MAAM,UAAA,uBAAiB,GAAA,EAAoB;AAC3C,EAAA,MAAM,UAAA,uBAAiB,GAAA,EAAoB;AAE3C,EAAA,KAAA,MAAW,MAAM,WAAA,EAAa;AAC5B,IAAA,MAAM,KAAA,GAAQ,eAAA,CAAgB,EAAE,CAAA,IAAK,CAAA;AACrC,IAAA,UAAA,CAAW,IAAI,KAAA,EAAA,CAAQ,UAAA,CAAW,IAAI,KAAK,CAAA,IAAK,KAAK,CAAC,CAAA;AAAA,EACxD;AACA,EAAA,KAAA,MAAW,MAAM,WAAA,EAAa;AAC5B,IAAA,MAAM,KAAA,GAAQ,eAAA,CAAgB,EAAE,CAAA,IAAK,CAAA;AACrC,IAAA,UAAA,CAAW,IAAI,KAAA,EAAA,CAAQ,UAAA,CAAW,IAAI,KAAK,CAAA,IAAK,KAAK,CAAC,CAAA;AAAA,EACxD;AAEA,EAAA,MAAM,SAAA,mBAAY,IAAI,GAAA,CAAI,CAAC,GAAG,UAAA,CAAW,IAAA,EAAK,EAAG,GAAG,UAAA,CAAW,IAAA,EAAM,CAAC,CAAA;AACtE,EAAA,MAAM,SAAmC,EAAC;AAE1C,EAAA,KAAA,MAAW,SAAS,CAAC,GAAG,SAAS,CAAA,CAAE,MAAK,EAAG;AACzC,IAAA,MAAA,CAAO,IAAA,CAAK;AAAA,MACV,KAAA;AAAA,MACA,WAAA,EAAa,UAAA,CAAW,GAAA,CAAI,KAAK,CAAA,IAAK,CAAA;AAAA,MACtC,WAAA,EAAa,UAAA,CAAW,GAAA,CAAI,KAAK,CAAA,IAAK;AAAA,KACvC,CAAA;AAAA,EACH;AAEA,EAAA,OAAO,MAAA;AACT;AAYO,SAAS,cAAA,CACd,cAAA,EACA,cAAA,EACA,MAAA,GAAkC,iCAAA,EACf;AAGnB,EAAA,MAAM,UAAA,GAAa,cAAA,CAAe,MAAA,CAAOC,iBAAgB,CAAA;AACzD,EAAA,MAAM,UAAA,GAAa,cAAA,CAAe,MAAA,CAAOA,iBAAgB,CAAA;AAEzD,EAAA,MAAM,QAAA,GAAW,eAAA,CAAgB,UAAA,EAAY,UAAA,EAAY,MAAM,CAAA;AAC/D,EAAA,MAAM,OAAA,GAAU,cAAA,CAAe,UAAA,EAAY,UAAA,EAAY,MAAM,CAAA;AAC7D,EAAA,MAAM,QAAA,GAAW,eAAA,CAAgB,UAAA,EAAY,UAAA,EAAY,MAAM,CAAA;AAC/D,EAAA,MAAM,MAAA,GAAS,aAAA,CAAc,UAAA,EAAY,UAAA,EAAY,MAAM,CAAA;AAC3D,EAAA,MAAM,MAAA,GAAS,aAAA,CAAc,cAAA,EAAgB,cAAA,EAAgB,MAAM,CAAA;AACnE,EAAA,MAAM,gBAAA,GAAmB,uBAAA,CAAwB,UAAA,EAAY,UAAU,CAAA;AAGvE,EAAA,MAAM,gBAAgB,sBAAA,CAAuB,QAAA,EAAU,OAAA,EAAS,QAAA,EAAU,QAAQ,MAAM,CAAA;AAExF,EAAA,OAAO;AAAA,IACL,QAAA;AAAA,IACA,OAAA;AAAA,IACA,QAAA;AAAA,IACA,MAAA;AAAA,IACA,MAAA;AAAA,IACA,gBAAA;AAAA,IACA;AAAA,GACF;AACF;AAKA,SAAS,sBAAA,CACP,QAAA,EACA,OAAA,EACA,QAAA,EACA,QACA,MAAA,EACQ;AACR,EAAA,MAAM,SAAmB,EAAC;AAG1B,EAAA,MAAM,aAAA,GACJ,QAAA,CAAS,OAAA,CAAQ,MAAA,GACjB,QAAA,CAAS,OAAA,CAAQ,MAAA,GACjB,QAAA,CAAS,UAAA,CAAW,MAAA,GACpB,QAAA,CAAS,UAAA,CAAW,MAAA;AACtB,EAAA,IAAI,gBAAgB,CAAA,EAAG;AACrB,IAAA,MAAA,CAAO,IAAA,CAAK,QAAA,CAAS,OAAA,CAAQ,MAAA,GAAS,aAAa,CAAA;AAAA,EACrD;AAGA,EAAA,MAAM,YAAA,GACJ,OAAA,CAAQ,OAAA,CAAQ,MAAA,GAChB,OAAA,CAAQ,OAAA,CAAQ,MAAA,GAChB,OAAA,CAAQ,UAAA,CAAW,MAAA,GACnB,OAAA,CAAQ,UAAA,CAAW,MAAA;AACrB,EAAA,IAAI,eAAe,CAAA,EAAG;AAEpB,IAAA,MAAM,eAAe,OAAA,CAAQ,OAAA,CAAQ,SAAS,OAAA,CAAQ,OAAA,CAAQ,SAAS,GAAA,IAAO,YAAA;AAC9E,IAAA,MAAA,CAAO,KAAK,WAAW,CAAA;AAAA,EACzB;AAGA,EAAA,MAAM,aAAA,GAAgB,QAAA,CAAS,OAAA,CAAQ,MAAA,GAAS,SAAS,OAAA,CAAQ,MAAA;AACjE,EAAA,IAAI,gBAAgB,CAAA,EAAG;AACrB,IAAA,MAAA,CAAO,IAAA,CAAK,QAAA,CAAS,OAAA,CAAQ,MAAA,GAAS,aAAa,CAAA;AAAA,EACrD;AAGA,EAAA,MAAM,WAAA,GAAc,OAAO,OAAA,CAAQ,MAAA,GAAS,OAAO,UAAA,CAAW,MAAA,GAAS,OAAO,UAAA,CAAW,MAAA;AACzF,EAAA,IAAI,cAAc,CAAA,EAAG;AACnB,IAAA,MAAA,CAAO,IAAA,CAAK,MAAA,CAAO,OAAA,CAAQ,MAAA,GAAS,WAAW,CAAA;AAAA,EACjD;AAGA,EAAA,IAAI,MAAA,CAAO,SAAS,CAAA,EAAG;AACrB,IAAA,IAAI,UAAA,GAAa,CAAA;AACjB,IAAA,KAAA,MAAW,SAAS,MAAA,EAAQ;AAC1B,MAAA,IAAI,MAAA,GAAS,KAAA,CAAM,YAAA,GAAe,GAAA,GAAM,CAAA;AACxC,MAAA,IAAI,KAAA,CAAM,iBAAiB,CAAA,EAAG;AAC5B,QAAA,MAAM,WAAW,IAAA,CAAK,GAAA;AAAA,UACpB,KAAA,CAAM,iBAAiB,KAAA,CAAM,cAAA;AAAA,UAC7B,KAAA,CAAM,iBAAiB,KAAA,CAAM;AAAA,SAC/B;AACA,QAAA,MAAA,IAAU,QAAA,GAAW,GAAA;AAAA,MACvB,CAAA,MAAO;AACL,QAAA,MAAA,IAAU,GAAA;AAAA,MACZ;AAEA,MAAA,MAAM,aACJ,IAAA,CAAK,GAAA,CAAI,MAAM,cAAA,EAAgB,CAAC,IAChC,IAAA,CAAK,GAAA;AAAA,QACH,KAAA,CAAM,kBAAkB,MAAA,GACtB,KAAA,CAAM,kBAAkB,MAAA,IACvB,KAAA,CAAM,eAAe,CAAA,GAAI,CAAA,CAAA;AAAA,QAC5B;AAAA,OACF;AACF,MAAA,MAAM,SAAA,GACJ,UAAA,GAAa,CAAA,GAAI,CAAA,GAAI,IAAA,CAAK,GAAA,CAAI,KAAA,CAAM,eAAA,CAAgB,MAAA,GAAS,UAAA,EAAY,CAAC,CAAA,GAAI,CAAA;AAChF,MAAA,MAAA,IAAU,SAAA,GAAY,GAAA;AACtB,MAAA,UAAA,IAAc,MAAA;AAAA,IAChB;AACA,IAAA,MAAA,CAAO,IAAA,CAAK,UAAA,GAAa,MAAA,CAAO,MAAM,CAAA;AAAA,EACxC;AAEA,EAAA,IAAI,MAAA,CAAO,MAAA,KAAW,CAAA,EAAG,OAAO,CAAA;AAChC,EAAA,OAAO,IAAA,CAAK,KAAA,CAAO,MAAA,CAAO,MAAA,CAAO,CAAC,CAAA,EAAG,CAAA,KAAM,CAAA,GAAI,CAAA,EAAG,CAAC,CAAA,GAAI,MAAA,CAAO,MAAA,GAAU,GAAG,CAAA,GAAI,GAAA;AACjF;;;ACxnBO,IAAM,gCAAA,GAA2D;AAAA,EACtE,iBAAA,EAAmB;AACrB,CAAA;AAUO,SAAS,wBAAA,CACd,MAAA,EACA,MAAA,EACA,OAAA,EAK0B;AAC1B,EAAA,MAAM,SAAA,GAAY,KAAK,GAAA,EAAI;AAC3B,EAAA,MAAM,SAAS,EAAE,GAAG,gCAAA,EAAkC,GAAG,SAAS,MAAA,EAAO;AAEzE,EAAA,MAAM,cAAc,MAAA,CAAO,QAAA;AAC3B,EAAA,MAAM,cAAc,MAAA,CAAO,QAAA;AAG3B,EAAA,MAAM,IAAA,GAAO,mBAAA,CAAoB,WAAA,EAAa,WAAW,CAAA;AAGzD,EAAA,MAAM,UAAA,GAAa,kBAAA,CAAmB,WAAA,EAAa,WAAW,CAAA;AAG9D,EAAA,MAAM,aAAA,GAAgB,mBAAmB,WAAW,CAAA;AACpD,EAAA,MAAM,aAAA,GAAgB,mBAAmB,WAAW,CAAA;AAGpD,EAAA,MAAM,MAAA,GAAS,cAAA,CAAe,WAAA,EAAa,WAAA,EAAa,eAAe,aAAa,CAAA;AAGpF,EAAA,MAAM,mBAAA,GAAsB,mBAAA,CAAoB,IAAA,CAAK,YAAA,EAAc,aAAa,WAAW,CAAA;AAG3F,EAAA,MAAM,mBAAA,GACJ,MAAA,CAAO,iBAAA,IAAqB,OAAA,EAAS,gBAAA,IAAoB,OAAA,EAAS,gBAAA,GAC9D,iBAAA,CAAkB,OAAA,CAAQ,gBAAA,EAAkB,OAAA,CAAQ,gBAAgB,CAAA,GACpE,IAAA;AAGN,EAAA,MAAM,iBAAA,GAAoB,cAAA,CAAe,WAAA,EAAa,WAAW,CAAA;AAKjE,EAAA,MAAM,UAAA,GAAa,gBAAgB,WAAW,CAAA;AAC9C,EAAoB,gBAAgB,WAAW;AAC/C,EAAA,MAAM,gBAAA,GAAmB,MAAA,CAAO,IAAA,CAAK,UAAA,CAAW,MAAM,CAAA,CAAE,MAAA;AACxD,EAAA,MAAM,gBAAA,GAAmB,KAAK,eAAA,CAAgB,MAAA;AAC9C,EAAA,MAAM,gBAAA,GACJ,mBAAmB,CAAA,GAAI,IAAA,CAAK,MAAO,gBAAA,GAAmB,gBAAA,GAAoB,GAAG,CAAA,GAAI,GAAA,GAAM,CAAA;AAGzF,EAAA,MAAM,gBAAA,GAAmB,KAAK,eAAA,CAAgB,MAAA,CAAO,CAAC,CAAA,KAAM,CAAA,CAAE,YAAY,CAAA,CAAE,MAAA;AAC5E,EAAA,MAAM,eAAA,GACJ,mBAAmB,CAAA,GAAI,IAAA,CAAK,MAAO,gBAAA,GAAmB,gBAAA,GAAoB,GAAG,CAAA,GAAI,GAAA,GAAM,CAAA;AAGzF,EAAA,MAAM,wBAAwB,MAAA,CAAO,UAAA;AAGrC,EAAA,MAAM,aAAA,GAAgB,UAAA,CAAW,KAAA,CAAM,MAAA,GAAS,WAAW,UAAA,CAAW,MAAA;AACtE,EAAA,MAAM,gBAAA,GACJ,aAAA,GAAgB,CAAA,GAAI,IAAA,CAAK,KAAA,CAAO,UAAA,CAAW,KAAA,CAAM,MAAA,GAAS,aAAA,GAAiB,GAAG,CAAA,GAAI,GAAA,GAAM,CAAA;AAG1F,EAAA,MAAM,oBAAoB,mBAAA,CAAoB,MAAA;AAC9C,EAAA,MAAM,eAAA,GAAkB,oBAAoB,MAAA,CAAO,CAAC,MAAM,CAAA,CAAE,eAAA,CAAgB,MAAA,KAAW,CAAC,CAAA,CAAE,MAAA;AAC1F,EAAA,MAAM,YAAA,GACJ,oBAAoB,CAAA,GAAI,IAAA,CAAK,MAAO,eAAA,GAAkB,iBAAA,GAAqB,GAAG,CAAA,GAAI,GAAA,GAAM,CAAA;AAG1F,EAAA,MAAM,gBAAgB,iBAAA,CAAkB,aAAA;AAGxC,EAAA,MAAM,eACJ,IAAA,CAAK,KAAA;AAAA,IAAA,CACF,gBAAA,GAAmB,GAAA,GAClB,eAAA,GAAkB,GAAA,GAClB,qBAAA,GAAwB,IAAA,GACxB,gBAAA,GAAmB,IAAA,GACnB,YAAA,GAAe,IAAA,GACf,aAAA,GAAgB,IAAA,IAChB;AAAA,GACJ,GAAI,GAAA;AAIN,EAAA,MAAM,SAA4B,EAAC;AAGnC,EAAA,KAAA,MAAW,KAAA,IAAS,KAAK,kBAAA,EAAoB;AAC3C,IAAA,MAAM,MAAA,GAAS,MAAA,CAAO,MAAA,CAAO,UAAA,CAAW,MAAM,CAAA,CAAE,IAAA,CAAK,CAAC,CAAA,KAAM,CAAA,CAAE,SAAA,KAAc,KAAK,CAAA;AACjF,IAAA,IAAI,MAAA,EAAQ;AACV,MAAA,MAAA,CAAO,IAAA,CAAK;AAAA,QACV,QAAA,EAAU,SAAA;AAAA,QACV,QAAA,EAAU,cAAA;AAAA,QACV,aAAa,CAAA,YAAA,EAAe,MAAA,CAAO,KAAK,CAAA,GAAA,EAAM,OAAO,QAAQ,CAAA,6CAAA,CAAA;AAAA,QAC7D,eAAA,EAAiB;AAAA,OAClB,CAAA;AAAA,IACH;AAAA,EACF;AAGA,EAAA,KAAA,MAAW,IAAA,IAAQ,KAAK,eAAA,EAAiB;AACvC,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,MAAA,CAAO,IAAA,CAAK;AAAA,QACV,QAAA,EAAU,OAAA;AAAA,QACV,QAAA,EAAU,gBAAA;AAAA,QACV,WAAA,EAAa,uBAAuB,IAAA,CAAK,KAAK,cAAc,IAAA,CAAK,WAAW,CAAA,WAAA,EAAc,IAAA,CAAK,WAAW,CAAA,CAAA;AAAA,OAC3G,CAAA;AAAA,IACH;AAAA,EACF;AAGA,EAAA,KAAA,MAAW,EAAA,IAAM,KAAK,gBAAA,EAAkB;AACtC,IAAA,MAAA,CAAO,IAAA,CAAK;AAAA,MACV,UAAU,EAAA,CAAG,QAAA;AAAA,MACb,QAAA,EAAU,iBAAA;AAAA,MACV,aAAa,EAAA,CAAG;AAAA,KACjB,CAAA;AAAA,EACH;AAGA,EAAA,KAAA,MAAW,MAAM,mBAAA,EAAqB;AACpC,IAAA,KAAA,MAAW,MAAA,IAAU,GAAG,eAAA,EAAiB;AACvC,MAAA,MAAA,CAAO,IAAA,CAAK;AAAA,QACV,QAAA,EAAU,SAAA;AAAA,QACV,QAAA,EAAU,gBAAA;AAAA,QACV,aAAa,CAAA,QAAA,EAAW,MAAM,CAAA,+BAAA,EAAkC,EAAA,CAAG,KAAK,WAAW,CAAA,sBAAA,CAAA;AAAA,QACnF,eAAA,EAAiB,GAAG,IAAA,CAAK,QAAA;AAAA,QACzB,eAAA,EAAiB,GAAG,IAAA,CAAK;AAAA,OAC1B,CAAA;AAAA,IACH;AAAA,EACF;AAGA,EAAA,KAAA,MAAW,KAAA,IAAS,WAAW,UAAA,EAAY;AACzC,IAAA,MAAA,CAAO,IAAA,CAAK;AAAA,MACV,QAAA,EAAU,SAAA;AAAA,MACV,QAAA,EAAU,gBAAA;AAAA,MACV,WAAA,EAAa,oBAAoB,KAAK,CAAA,kCAAA,CAAA;AAAA,MACtC,eAAA,EAAiB;AAAA,KAClB,CAAA;AAAA,EACH;AAGA,EAAA,IAAI,MAAA,CAAO,aAAa,GAAA,EAAK;AAC3B,IAAA,MAAA,CAAO,IAAA,CAAK;AAAA,MACV,QAAA,EAAU,SAAA;AAAA,MACV,QAAA,EAAU,mBAAA;AAAA,MACV,WAAA,EAAa,CAAA,0BAAA,EAA6B,MAAA,CAAO,UAAU,CAAA,SAAA,EAAY,MAAA,CAAO,QAAA,CAAS,UAAA,CAAW,WAAW,CAAA,SAAA,EAAY,MAAA,CAAO,QAAA,CAAS,WAAW,WAAW,CAAA,KAAA;AAAA,KAChK,CAAA;AAAA,EACH;AAGA,EAAA,IAAI,mBAAA,EAAqB;AACvB,IAAA,KAAA,MAAW,GAAA,IAAO,oBAAoB,UAAA,EAAY;AAChD,MAAA,MAAA,CAAO,IAAA,CAAK;AAAA,QACV,QAAA,EAAU,MAAA;AAAA,QACV,QAAA,EAAU,oBAAA;AAAA,QACV,aAAa,CAAA,WAAA,EAAc,GAAA,CAAI,IAAI,CAAA,GAAA,EAAM,IAAI,IAAI,CAAA,iCAAA;AAAA,OAClD,CAAA;AAAA,IACH;AACA,IAAA,KAAA,MAAW,KAAA,IAAS,oBAAoB,OAAA,EAAS;AAC/C,MAAA,IAAI,KAAA,CAAM,YAAA,CAAa,OAAA,CAAQ,MAAA,GAAS,CAAA,EAAG;AACzC,QAAA,MAAA,CAAO,IAAA,CAAK;AAAA,UACV,QAAA,EAAU,SAAA;AAAA,UACV,QAAA,EAAU,oBAAA;AAAA,UACV,WAAA,EAAa,CAAA,WAAA,EAAc,KAAA,CAAM,MAAA,CAAO,IAAI,CAAA,iCAAA,EAAoC,KAAA,CAAM,YAAA,CAAa,OAAA,CAAQ,IAAA,CAAK,IAAI,CAAC,CAAA;AAAA,SACtH,CAAA;AAAA,MACH;AAAA,IACF;AAAA,EACF;AAGA,EAAA,KAAA,MAAW,OAAA,IAAW,iBAAA,CAAkB,QAAA,CAAS,UAAA,EAAY;AAC3D,IAAA,MAAA,CAAO,IAAA,CAAK;AAAA,MACV,QAAA,EAAU,SAAA;AAAA,MACV,QAAA,EAAU,oBAAA;AAAA,MACV,WAAA,EAAa,YAAY,OAAO,CAAA,oCAAA;AAAA,KACjC,CAAA;AAAA,EACH;AACA,EAAA,KAAA,MAAW,OAAA,IAAW,iBAAA,CAAkB,QAAA,CAAS,UAAA,EAAY;AAC3D,IAAA,MAAA,CAAO,IAAA,CAAK;AAAA,MACV,QAAA,EAAU,MAAA;AAAA,MACV,QAAA,EAAU,oBAAA;AAAA,MACV,WAAA,EAAa,YAAY,OAAO,CAAA,oCAAA;AAAA,KACjC,CAAA;AAAA,EACH;AACA,EAAA,KAAA,MAAW,MAAA,IAAU,iBAAA,CAAkB,QAAA,CAAS,OAAA,EAAS;AACvD,IAAA,MAAA,CAAO,IAAA,CAAK;AAAA,MACV,QAAA,EAAU,SAAA;AAAA,MACV,QAAA,EAAU,oBAAA;AAAA,MACV,aAAa,CAAA,kBAAA,EAAqB,MAAA,CAAO,MAAM,CAAA,MAAA,EAAS,OAAO,MAAM,CAAA,CAAA;AAAA,KACtE,CAAA;AAAA,EACH;AACA,EAAA,KAAA,MAAW,MAAA,IAAU,iBAAA,CAAkB,OAAA,CAAQ,OAAA,EAAS;AACtD,IAAA,MAAA,CAAO,IAAA,CAAK;AAAA,MACV,QAAA,EAAU,SAAA;AAAA,MACV,QAAA,EAAU,oBAAA;AAAA,MACV,WAAA,EAAa,WAAW,MAAA,CAAO,KAAK,qBAAqB,MAAA,CAAO,WAAW,CAAA,MAAA,EAAS,MAAA,CAAO,WAAW,CAAA,CAAA;AAAA,KACvG,CAAA;AAAA,EACH;AACA,EAAA,KAAA,MAAW,KAAA,IAAS,iBAAA,CAAkB,OAAA,CAAQ,UAAA,EAAY;AACxD,IAAA,MAAA,CAAO,IAAA,CAAK;AAAA,MACV,QAAA,EAAU,SAAA;AAAA,MACV,QAAA,EAAU,oBAAA;AAAA,MACV,WAAA,EAAa,WAAW,KAAK,CAAA,oCAAA;AAAA,KAC9B,CAAA;AAAA,EACH;AACA,EAAA,KAAA,MAAW,MAAA,IAAU,iBAAA,CAAkB,QAAA,CAAS,OAAA,EAAS;AACvD,IAAA,MAAA,CAAO,IAAA,CAAK;AAAA,MACV,QAAA,EAAU,SAAA;AAAA,MACV,QAAA,EAAU,oBAAA;AAAA,MACV,WAAA,EAAa,WAAW,MAAA,CAAO,KAAK,eAAe,MAAA,CAAO,YAAY,CAAA,MAAA,EAAS,MAAA,CAAO,YAAY,CAAA,CAAA;AAAA,KACnG,CAAA;AAAA,EACH;AACA,EAAA,KAAA,MAAW,KAAA,IAAS,kBAAkB,MAAA,EAAQ;AAC5C,IAAA,IAAI,CAAC,MAAM,YAAA,EAAc;AACvB,MAAA,MAAA,CAAO,IAAA,CAAK;AAAA,QACV,QAAA,EAAU,SAAA;AAAA,QACV,QAAA,EAAU,oBAAA;AAAA,QACV,WAAA,EAAa,CAAA,OAAA,EAAU,KAAA,CAAM,WAAW,mCAAmC,KAAA,CAAM,iBAAA,CAAkB,IAAA,CAAK,IAAI,CAAC,CAAA,gBAAA,EAAmB,KAAA,CAAM,iBAAA,CAAkB,IAAA,CAAK,IAAI,CAAC,CAAA,CAAA;AAAA,OACnK,CAAA;AAAA,IACH;AACA,IAAA,IAAI,KAAA,CAAM,cAAA,KAAmB,KAAA,CAAM,cAAA,EAAgB;AACjD,MAAA,MAAA,CAAO,IAAA,CAAK;AAAA,QACV,QAAA,EAAU,MAAA;AAAA,QACV,QAAA,EAAU,oBAAA;AAAA,QACV,WAAA,EAAa,UAAU,KAAA,CAAM,WAAW,wBAAwB,KAAA,CAAM,cAAc,CAAA,IAAA,EAAO,KAAA,CAAM,cAAc,CAAA;AAAA,OAChH,CAAA;AAAA,IACH;AACA,IAAA,IAAI,KAAA,CAAM,eAAA,CAAgB,MAAA,GAAS,CAAA,EAAG;AACpC,MAAA,MAAA,CAAO,IAAA,CAAK;AAAA,QACV,QAAA,EAAU,SAAA;AAAA,QACV,QAAA,EAAU,oBAAA;AAAA,QACV,aAAa,CAAA,OAAA,EAAU,KAAA,CAAM,WAAW,CAAA,MAAA,EAAS,KAAA,CAAM,gBAAgB,MAAM,CAAA,yBAAA;AAAA,OAC9E,CAAA;AAAA,IACH;AAAA,EACF;AAGA,EAAA,MAAM,gBAAgB,EAAE,KAAA,EAAO,GAAG,OAAA,EAAS,CAAA,EAAG,MAAM,CAAA,EAAE;AACtD,EAAA,MAAA,CAAO,IAAA,CAAK,CAAC,CAAA,EAAG,CAAA,KAAM,aAAA,CAAc,CAAA,CAAE,QAAQ,CAAA,GAAI,aAAA,CAAc,CAAA,CAAE,QAAQ,CAAC,CAAA;AAI3E,EAAA,MAAM,UAAA,GAAa,OAAO,MAAA,CAAO,CAAC,MAAM,CAAA,CAAE,QAAA,KAAa,OAAO,CAAA,CAAE,MAAA;AAChE,EAAA,MAAM,YAAA,GAAe,OAAO,MAAA,CAAO,CAAC,MAAM,CAAA,CAAE,QAAA,KAAa,SAAS,CAAA,CAAE,MAAA;AACpE,EAAA,MAAM,SAAA,GAAY,OAAO,MAAA,CAAO,CAAC,MAAM,CAAA,CAAE,QAAA,KAAa,MAAM,CAAA,CAAE,MAAA;AAE9D,EAAA,MAAM,YAAA,GAAe;AAAA,IACnB,yBAAyB,MAAA,CAAO,IAAA,CAAK,GAAG,CAAA,IAAA,EAAO,MAAA,CAAO,KAAK,GAAG,CAAA,CAAA;AAAA,IAC9D,CAAA,eAAA,EAAA,CAAmB,YAAA,GAAe,GAAA,EAAK,OAAA,CAAQ,CAAC,CAAC,CAAA,CAAA,CAAA;AAAA,IACjD,CAAA,kBAAA,EAAqB,IAAA,CAAK,YAAA,CAAa,MAAM,CAAA,CAAA;AAAA,IAC7C,cAAc,IAAA,CAAK,kBAAA,CAAmB,MAAM,CAAA,SAAA,EAAY,IAAA,CAAK,mBAAmB,MAAM,CAAA,OAAA,CAAA;AAAA,IACtF,CAAA,YAAA,EAAe,UAAA,CAAW,KAAA,CAAM,MAAM,CAAA,UAAA,EAAa,UAAA,CAAW,UAAA,CAAW,MAAM,CAAA,cAAA,EAAiB,UAAA,CAAW,UAAA,CAAW,MAAM,CAAA,YAAA;AAAA,GAC9H;AAEA,EAAA,IAAI,mBAAA,EAAqB;AACvB,IAAA,YAAA,CAAa,IAAA;AAAA,MACX,CAAA,YAAA,EAAe,mBAAA,CAAoB,OAAA,CAAQ,MAAM,CAAA,UAAA,EAAa,mBAAA,CAAoB,UAAA,CAAW,MAAM,CAAA,cAAA,EAAiB,mBAAA,CAAoB,UAAA,CAAW,MAAM,CAAA,YAAA;AAAA,KAC3J;AAAA,EACF;AAGA,EAAA,MAAM,QAAA,GAAW,iBAAA,CAAkB,QAAA,CAAS,OAAA,CAAQ,MAAA;AACpD,EAAA,MAAM,QAAA,GAAW,iBAAA,CAAkB,QAAA,CAAS,OAAA,CAAQ,MAAA;AACpD,EAAA,MAAM,QAAA,GAAW,iBAAA,CAAkB,QAAA,CAAS,UAAA,CAAW,MAAA;AACvD,EAAA,MAAM,QAAA,GAAW,iBAAA,CAAkB,QAAA,CAAS,UAAA,CAAW,MAAA;AACvD,EAAA,MAAM,QAAA,GAAW,iBAAA,CAAkB,OAAA,CAAQ,OAAA,CAAQ,MAAA;AACnD,EAAA,MAAM,QAAA,GAAW,iBAAA,CAAkB,OAAA,CAAQ,OAAA,CAAQ,MAAA;AACnD,EAAA,MAAM,QAAA,GAAW,iBAAA,CAAkB,QAAA,CAAS,OAAA,CAAQ,MAAA;AACpD,EAAA,MAAM,QAAA,GAAW,iBAAA,CAAkB,QAAA,CAAS,OAAA,CAAQ,MAAA;AACpD,EAAA,MAAM,eACJ,QAAA,GAAW,QAAA,GAAW,WAAW,QAAA,GAAW,QAAA,GAAW,WAAW,QAAA,GAAW,QAAA;AAE/E,EAAA,IAAI,eAAe,CAAA,EAAG;AACpB,IAAA,YAAA,CAAa,IAAA;AAAA,MACX,CAAA,kBAAA,EAAqB,QAAQ,CAAA,SAAA,EAAY,QAAQ,YAAY,QAAA,GAAW,QAAQ,uBACnE,QAAQ,CAAA,SAAA,EAAY,QAAQ,CAAA,mBAAA,EAC3B,QAAQ,YAAY,QAAQ,CAAA,iBAAA,EAAA,CAC7B,gBAAgB,GAAA,EAAK,OAAA,CAAQ,CAAC,CAAC,CAAA,CAAA;AAAA,KAC9C;AAAA,EACF;AAEA,EAAA,YAAA,CAAa,KAAK,CAAA,QAAA,EAAW,UAAU,YAAY,YAAY,CAAA,WAAA,EAAc,SAAS,CAAA,KAAA,CAAO,CAAA;AAE7F,EAAA,MAAM,OAAA,GAAU,YAAA,CAAa,IAAA,CAAK,IAAI,CAAA;AAEtC,EAAA,MAAM,MAAA,GAAmC;AAAA,IACvC,SAAA,EAAW,OAAO,IAAA,CAAK,GAAA;AAAA,IACvB,SAAA,EAAW,OAAO,IAAA,CAAK,GAAA;AAAA,IACvB,SAAA,EAAW,KAAK,GAAA,EAAI;AAAA,IACpB,UAAA,EAAY,IAAA,CAAK,GAAA,EAAI,GAAI,SAAA;AAAA,IACzB,MAAA,EAAQ;AAAA,MACN,gBAAA;AAAA,MACA,eAAA;AAAA,MACA,qBAAA;AAAA,MACA,gBAAA;AAAA,MACA,YAAA;AAAA,MACA;AAAA,KACF;AAAA,IACA,IAAA;AAAA,IACA,UAAA;AAAA,IACA,MAAA;AAAA,IACA,iBAAA;AAAA,IACA,MAAA;AAAA,IACA;AAAA,GACF;AAEA,EAAA,IAAI,mBAAA,EAAqB;AACvB,IAAA,MAAA,CAAO,UAAA,GAAa,mBAAA;AAAA,EACtB;AAEA,EAAA,OAAO,MAAA;AACT;;;ACnNA,SAAS,QAAW,IAAA,EAAyB;AAC3C,EAAA,OAAO;AAAA,IACL,OAAA,EAAS,IAAA;AAAA,IACT,IAAA;AAAA,IACA,SAAA,EAAW,KAAK,GAAA;AAAI,GACtB;AACF;AAKA,SAAS,KAAA,CAAmB,SAAiB,IAAA,EAA+B;AAC1E,EAAA,OAAO;AAAA,IACL,OAAA,EAAS,KAAA;AAAA,IACT,KAAA,EAAO,OAAA;AAAA,IACP,IAAA;AAAA,IACA,SAAA,EAAW,KAAK,GAAA;AAAI,GACtB;AACF;AAKA,SAAS,uBAAuB,SAAA,EAK7B;AACD,EAAA,QAAQ,SAAA;AAAW,IACjB,KAAK,mBAAA;AACH,MAAA,OAAO;AAAA,QACL;AAAA,UACE,UAAA,EAAY,iCAAA;AAAA,UACZ,OAAA,EAAS,uBAAA;AAAA,UACT,UAAA,EAAY,GAAA;AAAA,UACZ,SAAA,EAAW;AAAA,SACb;AAAA,QACA;AAAA,UACE,UAAA,EAAY,6CAAA;AAAA,UACZ,UAAA,EAAY,GAAA;AAAA,UACZ,SAAA,EAAW;AAAA,SACb;AAAA,QACA;AAAA,UACE,UAAA,EAAY,uCAAA;AAAA,UACZ,OAAA,EAAS,aAAA;AAAA,UACT,UAAA,EAAY,GAAA;AAAA,UACZ,SAAA,EAAW;AAAA;AACb,OACF;AAAA,IACF,KAAK,qBAAA;AACH,MAAA,OAAO;AAAA,QACL;AAAA,UACE,UAAA,EAAY,oCAAA;AAAA,UACZ,OAAA,EAAS,mBAAA;AAAA,UACT,UAAA,EAAY,GAAA;AAAA,UACZ,SAAA,EAAW;AAAA,SACb;AAAA,QACA;AAAA,UACE,UAAA,EAAY,4CAAA;AAAA,UACZ,UAAA,EAAY,GAAA;AAAA,UACZ,SAAA,EAAW;AAAA,SACb;AAAA,QACA;AAAA,UACE,UAAA,EAAY,qCAAA;AAAA,UACZ,OAAA,EAAS,oBAAA;AAAA,UACT,UAAA,EAAY,GAAA;AAAA,UACZ,SAAA,EAAW;AAAA;AACb,OACF;AAAA,IACF,KAAK,qBAAA;AACH,MAAA,OAAO;AAAA,QACL,EAAE,UAAA,EAAY,+BAAA,EAAiC,UAAA,EAAY,GAAA,EAAK,WAAW,KAAA,EAAM;AAAA,QACjF;AAAA,UACE,UAAA,EAAY,yCAAA;AAAA,UACZ,UAAA,EAAY,GAAA;AAAA,UACZ,SAAA,EAAW;AAAA,SACb;AAAA,QACA;AAAA,UACE,UAAA,EAAY,wCAAA;AAAA,UACZ,OAAA,EAAS,gCAAA;AAAA,UACT,UAAA,EAAY,GAAA;AAAA,UACZ,SAAA,EAAW;AAAA;AACb,OACF;AAAA,IACF,KAAK,0BAAA;AACH,MAAA,OAAO;AAAA,QACL;AAAA,UACE,UAAA,EAAY,+CAAA;AAAA,UACZ,OAAA,EAAS,oBAAA;AAAA,UACT,UAAA,EAAY,GAAA;AAAA,UACZ,SAAA,EAAW;AAAA,SACb;AAAA,QACA,EAAE,UAAA,EAAY,iCAAA,EAAmC,UAAA,EAAY,GAAA,EAAK,WAAW,IAAA,EAAK;AAAA,QAClF;AAAA,UACE,UAAA,EAAY,sCAAA;AAAA,UACZ,OAAA,EAAS,mBAAA;AAAA,UACT,UAAA,EAAY,GAAA;AAAA,UACZ,SAAA,EAAW;AAAA;AACb,OACF;AAAA,IACF,KAAK,gBAAA;AACH,MAAA,OAAO;AAAA,QACL,EAAE,UAAA,EAAY,+BAAA,EAAiC,UAAA,EAAY,GAAA,EAAK,WAAW,IAAA,EAAK;AAAA,QAChF,EAAE,UAAA,EAAY,wCAAA,EAA0C,UAAA,EAAY,GAAA,EAAK,WAAW,KAAA,EAAM;AAAA,QAC1F;AAAA,UACE,UAAA,EAAY,+BAAA;AAAA,UACZ,OAAA,EAAS,mBAAA;AAAA,UACT,UAAA,EAAY,GAAA;AAAA,UACZ,SAAA,EAAW;AAAA;AACb,OACF;AAAA,IACF,KAAK,gBAAA;AACH,MAAA,OAAO;AAAA,QACL;AAAA,UACE,UAAA,EAAY,yCAAA;AAAA,UACZ,UAAA,EAAY,GAAA;AAAA,UACZ,SAAA,EAAW;AAAA,SACb;AAAA,QACA;AAAA,UACE,UAAA,EAAY,mEAAA;AAAA,UACZ,UAAA,EAAY,GAAA;AAAA,UACZ,SAAA,EAAW;AAAA,SACb;AAAA,QACA;AAAA,UACE,UAAA,EAAY,wDAAA;AAAA,UACZ,UAAA,EAAY,GAAA;AAAA,UACZ,SAAA,EAAW;AAAA;AACb,OACF;AAAA,IACF,KAAK,iBAAA;AACH,MAAA,OAAO;AAAA,QACL;AAAA,UACE,UAAA,EAAY,+CAAA;AAAA,UACZ,UAAA,EAAY,GAAA;AAAA,UACZ,SAAA,EAAW;AAAA,SACb;AAAA,QACA;AAAA,UACE,UAAA,EAAY,qDAAA;AAAA,UACZ,UAAA,EAAY,GAAA;AAAA,UACZ,SAAA,EAAW;AAAA,SACb;AAAA,QACA,EAAE,UAAA,EAAY,6BAAA,EAA+B,UAAA,EAAY,GAAA,EAAK,WAAW,KAAA;AAAM,OACjF;AAAA,IACF;AACE,MAAA,OAAO;AAAA,QACL;AAAA,UACE,UAAA,EAAY,kDAAA;AAAA,UACZ,UAAA,EAAY,GAAA;AAAA,UACZ,SAAA,EAAW;AAAA;AACb,OACF;AAAA;AAEN;AAKA,SAAS,oBAAA,CACP,SAAA,EACA,OAAA,EACA,OAAA,GAKI,EAAC,EACiB;AACtB,EAAA,MAAM,eAAA,GAAqC;AAAA,IACzC,qBAAA;AAAA,IACA,gBAAA;AAAA,IACA,gBAAA;AAAA,IACA,eAAA;AAAA,IACA;AAAA,GACF;AAEA,EAAA,OAAO;AAAA,IACL,SAAA;AAAA,IACA,OAAA;AAAA,IACA,WAAW,OAAA,CAAQ,SAAA;AAAA,IACnB,gBAAgB,OAAA,CAAQ,cAAA;AAAA,IACxB,gBAAA,EAAkB,uBAAuB,SAAS,CAAA;AAAA,IAClD,gBAAA,EAAkB,eAAA,CAAgB,QAAA,CAAS,SAAS,CAAA;AAAA,IACpD,YAAY,OAAA,CAAQ,UAAA;AAAA,IACpB,WAAW,OAAA,CAAQ;AAAA,GACrB;AACF;AA0BO,SAAS,cAAA,CACd,QAAA,EACA,cAAA,EACA,MAAA,GAA+B,EAAC,EACR;AAExB,EAAA,MAAM,YAAA,GAAe,IAAI,YAAA,EAAa;AACtC,EAAA,MAAM,UAAA,GAAa,IAAI,gBAAA,EAAiB;AACxC,EAAA,MAAM,iBAAA,GAAoB,IAAI,iBAAA,EAAkB;AAChD,EAAA,MAAM,eAAA,GAAkB,IAAI,uBAAA,EAAwB;AACpD,EAAA,MAAM,WAAA,GAAc,IAAI,mBAAA,EAAoB;AAG5C,EAAA,MAAM,cAAA,uBAAqB,GAAA,EAAoB;AAG/C,EAAA,MAAM,cAAA,GAAiB,OAAO,cAAA,IAAkB,IAAA;AAGhD,EAAA,MAAM,eAAA,GAAkB,MAAA,CAAO,eAAA,IAAmB,wBAAA,EAAyB;AAG3E,EAAA,SAAS,eAAA,GAAwB;AAC/B,IAAA,MAAM,QAAA,GAAW,SAAS,cAAA,EAAe;AACzC,IAAA,YAAA,CAAa,eAAe,QAAiB,CAAA;AAC7C,IAAA,UAAA,CAAW,eAAe,QAAiB,CAAA;AAC3C,IAAA,UAAA,CAAW,kBAAkB,cAAqB,CAAA;AAClD,IAAA,iBAAA,CAAkB,eAAe,QAAiB,CAAA;AAAA,EACpD;AAEA,EAAA,OAAO;AAAA;AAAA;AAAA;AAAA,IAKL,YAAA,EAAc,OAAO,KAAA,KAAmE;AACtF,MAAA,IAAI;AACF,QAAA,MAAM,OAAA,GAAU,QAAA,CAAS,YAAA,IAAe,IAAK,EAAC;AAE9C,QAAA,IAAI,QAAA,GAAW,OAAA;AAEf,QAAA,IAAI,OAAO,IAAA,EAAM;AACf,UAAA,QAAA,GAAW,SAAS,MAAA,CAAO,CAAC,MAAM,CAAA,CAAE,IAAA,KAAS,MAAM,IAAI,CAAA;AAAA,QACzD;AACA,QAAA,IAAI,OAAO,KAAA,EAAO;AAChB,UAAA,QAAA,GAAW,SAAS,MAAA,CAAO,CAAC,MAAM,CAAA,CAAE,SAAA,IAAa,MAAM,KAAM,CAAA;AAAA,QAC/D;AACA,QAAA,IAAI,OAAO,KAAA,EAAO;AAChB,UAAA,QAAA,GAAW,SAAS,MAAA,CAAO,CAAC,MAAM,CAAA,CAAE,SAAA,IAAa,MAAM,KAAM,CAAA;AAAA,QAC/D;AACA,QAAA,IAAI,OAAO,KAAA,EAAO;AAChB,UAAA,QAAA,GAAW,QAAA,CAAS,KAAA,CAAM,CAAA,EAAG,KAAA,CAAM,KAAK,CAAA;AAAA,QAC1C;AAEA,QAAA,OAAO,QAAQ,QAAQ,CAAA;AAAA,MACzB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,kBAAkB,CAAA;AAAA,MACzD;AAAA,IACF,CAAA;AAAA,IAEA,gBAAgB,YAAwC;AACtD,MAAA,IAAI;AACF,QAAA,QAAA,CAAS,cAAA,IAAiB;AAC1B,QAAA,OAAO,QAAQ,KAAA,CAAS,CAAA;AAAA,MAC1B,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,kBAAkB,CAAA;AAAA,MACzD;AAAA,IACF,CAAA;AAAA,IAEA,iBAAiB,YAA2C;AAC1D,MAAA,IAAI;AACF,QAAA,MAAM,QAAA,GAAW,SAAS,eAAA,IAAkB;AAC5C,QAAA,OAAO,QAAQ,QAAQ,CAAA;AAAA,MACzB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,gBAAgB,CAAA;AAAA,MACvD;AAAA,IACF,CAAA;AAAA,IAEA,kBAAkB,YAAoD;AACpE,MAAA,OAAO,QAAQ,EAAE,IAAA,EAAM,MAAA,CAAO,aAAA,IAAiB,IAAI,CAAA;AAAA,IACrD,CAAA;AAAA;AAAA;AAAA;AAAA,IAMA,aAAa,YAA+D;AAC1E,MAAA,IAAI;AACF,QAAA,MAAM,QAAA,GAAW,SAAS,cAAA,EAAe;AACzC,QAAA,OAAO,QAAQ,QAAuC,CAAA;AAAA,MACxD,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,gBAAgB,CAAA;AAAA,MACvD;AAAA,IACF,CAAA;AAAA,IAEA,UAAA,EAAY,OAAO,EAAA,KAAqE;AACtF,MAAA,IAAI;AACF,QAAA,MAAM,OAAA,GAAU,QAAA,CAAS,UAAA,CAAW,EAAE,CAAA;AACtC,QAAA,IAAI,CAAC,OAAA,EAAS;AACZ,UAAA,MAAM,cAAA,GAAiB,oBAAA;AAAA,YACrB,mBAAA;AAAA,YACA,sBAAsB,EAAE,CAAA,CAAA;AAAA,YACxB;AAAA,cACE,SAAA,EAAW,EAAA;AAAA,cACX,cAAA,EAAgB,CAAC,EAAE;AAAA;AACrB,WACF;AACA,UAAA,OAAO;AAAA,YACL,OAAA,EAAS,KAAA;AAAA,YACT,KAAA,EAAO,sBAAsB,EAAE,CAAA,CAAA;AAAA,YAC/B,IAAA,EAAM,mBAAA;AAAA,YACN,IAAA,EAAM,EAAE,cAAA,EAAe;AAAA,YACvB,SAAA,EAAW,KAAK,GAAA;AAAI,WACtB;AAAA,QACF;AACA,QAAA,OAAO,QAAQ,OAAyC,CAAA;AAAA,MAC1D,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,eAAe,CAAA;AAAA,MACtD;AAAA,IACF,CAAA;AAAA,IAEA,eAAA,EAAiB,OAAO,EAAA,KAA8C;AACpE,MAAA,IAAI;AACF,QAAA,MAAM,OAAA,GAAU,QAAA,CAAS,UAAA,CAAW,EAAE,CAAA;AACtC,QAAA,IAAI,CAAC,OAAA,EAAS;AACZ,UAAA,OAAO,KAAA,CAAM,CAAA,mBAAA,EAAsB,EAAE,CAAA,CAAA,EAAI,WAAW,CAAA;AAAA,QACtD;AACA,QAAA,OAAO,OAAA,CAAQ,QAAQ,KAAK,CAAA;AAAA,MAC9B,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,qBAAqB,CAAA;AAAA,MAC5D;AAAA,IACF,CAAA;AAAA,IAEA,oBAAA,EAAsB,OACpB,EAAA,EACA,OAAA,KACG;AACH,MAAA,MAAM,SAAA,GAAY,KAAK,GAAA,EAAI;AAC3B,MAAA,IAAI;AAEF,QAAA,MAAM,OAAA,GAAU,QAAA,CAAS,UAAA,CAAW,EAAE,CAAA;AACtC,QAAA,IAAI,CAAC,OAAA,EAAS;AACZ,UAAA,MAAM,cAAA,GAAiB,oBAAA;AAAA,YACrB,mBAAA;AAAA,YACA,sBAAsB,EAAE,CAAA,CAAA;AAAA,YACxB;AAAA,cACE,SAAA,EAAW,EAAA;AAAA,cACX,cAAA,EAAgB,CAAC,EAAE,CAAA;AAAA,cACnB,UAAA,EAAY,IAAA,CAAK,GAAA,EAAI,GAAI;AAAA;AAC3B,WACF;AACA,UAAA,OAAO;AAAA,YACL,OAAA,EAAS,KAAA;AAAA,YACT,KAAA,EAAO,sBAAsB,EAAE,CAAA,CAAA;AAAA,YAC/B,IAAA,EAAM,mBAAA;AAAA,YACN,IAAA,EAAM;AAAA,cACJ,OAAA,EAAS,KAAA;AAAA,cACT,KAAA,EAAO,sBAAsB,EAAE,CAAA,CAAA;AAAA,cAC/B,cAAA;AAAA,cACA,UAAA,EAAY,IAAA,CAAK,GAAA,EAAI,GAAI,SAAA;AAAA,cACzB,SAAA,EAAW,KAAK,GAAA;AAAI,aACtB;AAAA,YACA,SAAA,EAAW,KAAK,GAAA;AAAI,WACtB;AAAA,QACF;AAEA,QAAA,MAAM,MAAA,GAAS,MAAM,cAAA,CAAe,aAAA,CAAc,EAAA,EAAI;AAAA,UACpD,QAAQ,OAAA,CAAQ,MAAA;AAAA,UAChB,QAAQ,OAAA,CAAQ,MAAA;AAAA,UAChB,aAAa,OAAA,CAAQ;AAAA,SACtB,CAAA;AAGD,QAAA,IAAI,MAAA,IAAU,OAAO,MAAA,KAAW,QAAA,IAAY,aAAa,MAAA,IAAU,CAAC,OAAO,OAAA,EAAS;AAClF,UAAA,MAAM,YAAA,GAAe,MAAA;AAMrB,UAAA,IAAI,SAAA,GAA6B,eAAA;AACjC,UAAA,MAAM,QAAA,GAAW,YAAA,CAAa,KAAA,EAAO,WAAA,EAAY,IAAK,EAAA;AAEtD,UAAA,IAAI,QAAA,CAAS,QAAA,CAAS,WAAW,CAAA,EAAG;AAClC,YAAA,SAAA,GAAY,mBAAA;AAAA,UACd,CAAA,MAAA,IAAW,SAAS,QAAA,CAAS,aAAa,KAAK,QAAA,CAAS,QAAA,CAAS,QAAQ,CAAA,EAAG;AAC1E,YAAA,SAAA,GAAY,qBAAA;AAAA,UACd,CAAA,MAAA,IAAW,SAAS,QAAA,CAAS,UAAU,KAAK,QAAA,CAAS,QAAA,CAAS,aAAa,CAAA,EAAG;AAC5E,YAAA,SAAA,GAAY,qBAAA;AAAA,UACd,CAAA,MAAA,IAAW,QAAA,CAAS,QAAA,CAAS,SAAS,CAAA,EAAG;AACvC,YAAA,SAAA,GAAY,gBAAA;AAAA,UACd,CAAA,MAAA,IAAW,SAAS,QAAA,CAAS,SAAS,KAAK,QAAA,CAAS,QAAA,CAAS,cAAc,CAAA,EAAG;AAC5E,YAAA,SAAA,GAAY,0BAAA;AAAA,UACd;AAEA,UAAA,MAAM,cAAA,GAAiB,oBAAA;AAAA,YACrB,SAAA;AAAA,YACA,aAAa,KAAA,IAAS,eAAA;AAAA,YACtB;AAAA,cACE,SAAA,EAAW,EAAA;AAAA,cACX,UAAA,EAAY,IAAA,CAAK,GAAA,EAAI,GAAI;AAAA;AAC3B,WACF;AAEA,UAAA,OAAO,OAAA,CAAQ;AAAA,YACb,GAAG,YAAA;AAAA,YACH;AAAA,WACD,CAAA;AAAA,QACH;AAEA,QAAA,OAAO,QAAQ,MAAM,CAAA;AAAA,MACvB,SAAS,GAAA,EAAK;AACZ,QAAA,MAAM,eAAgB,GAAA,CAAc,OAAA;AACpC,QAAA,IAAI,SAAA,GAA6B,eAAA;AAEjC,QAAA,IAAI,YAAA,CAAa,QAAA,CAAS,WAAW,CAAA,EAAG;AACtC,UAAA,SAAA,GAAY,mBAAA;AAAA,QACd,CAAA,MAAA,IAAW,YAAA,CAAa,QAAA,CAAS,SAAS,CAAA,EAAG;AAC3C,UAAA,SAAA,GAAY,gBAAA;AAAA,QACd,CAAA,MAAA,IAAW,aAAa,QAAA,CAAS,SAAS,KAAK,YAAA,CAAa,QAAA,CAAS,OAAO,CAAA,EAAG;AAC7E,UAAA,SAAA,GAAY,eAAA;AAAA,QACd;AAEA,QAAA,MAAM,cAAA,GAAiB,oBAAA,CAAqB,SAAA,EAAW,YAAA,EAAc;AAAA,UACnE,SAAA,EAAW,EAAA;AAAA,UACX,UAAA,EAAY,IAAA,CAAK,GAAA,EAAI,GAAI;AAAA,SAC1B,CAAA;AAED,QAAA,OAAO;AAAA,UACL,OAAA,EAAS,KAAA;AAAA,UACT,KAAA,EAAO,YAAA;AAAA,UACP,IAAA,EAAM,SAAA;AAAA,UACN,IAAA,EAAM;AAAA,YACJ,OAAA,EAAS,KAAA;AAAA,YACT,KAAA,EAAO,YAAA;AAAA,YACP,cAAA;AAAA,YACA,UAAA,EAAY,IAAA,CAAK,GAAA,EAAI,GAAI,SAAA;AAAA,YACzB,SAAA,EAAW,KAAK,GAAA;AAAI,WACtB;AAAA,UACA,SAAA,EAAW,KAAK,GAAA;AAAI,SACtB;AAAA,MACF;AAAA,IACF,CAAA;AAAA;AAAA;AAAA;AAAA,IAMA,eAAe,YAAiE;AAC9E,MAAA,IAAI;AACF,QAAA,MAAM,UAAA,GAAa,SAAS,gBAAA,EAAiB;AAC7C,QAAA,OAAO,QAAQ,UAA2C,CAAA;AAAA,MAC5D,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,kBAAkB,CAAA;AAAA,MACzD;AAAA,IACF,CAAA;AAAA,IAEA,YAAA,EAAc,OAAO,EAAA,KAAuE;AAC1F,MAAA,IAAI;AACF,QAAA,MAAM,SAAA,GAAY,QAAA,CAAS,YAAA,CAAa,EAAE,CAAA;AAC1C,QAAA,IAAI,CAAC,SAAA,EAAW;AACd,UAAA,OAAO,KAAA,CAAM,CAAA,qBAAA,EAAwB,EAAE,CAAA,CAAA,EAAI,WAAW,CAAA;AAAA,QACxD;AACA,QAAA,OAAO,QAAQ,SAA6C,CAAA;AAAA,MAC9D,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,iBAAiB,CAAA;AAAA,MACxD;AAAA,IACF,CAAA;AAAA,IAEA,iBAAA,EAAmB,OACjB,EAAA,KAOG;AACH,MAAA,IAAI;AAEF,QAAA,MAAM,SAAA,GAAY,QAAA,CAAS,YAAA,CAAa,EAAE,CAAA;AAC1C,QAAA,IAAI,CAAC,SAAA,EAAW;AACd,UAAA,OAAO,KAAA,CAAM,CAAA,qBAAA,EAAwB,EAAE,CAAA,CAAA,EAAI,WAAW,CAAA;AAAA,QACxD;AAGA,QAAA,IAAI,SAAS,iBAAA,EAAmB;AAC9B,UAAA,MAAM,aAAA,GAAgB,QAAA,CAAS,iBAAA,CAAkB,EAAE,CAAA;AACnD,UAAA,IAAI,CAAC,aAAA,EAAe;AAClB,YAAA,OAAO,KAAA,CAAM,CAAA,oCAAA,EAAuC,EAAE,CAAA,CAAA,EAAI,WAAW,CAAA;AAAA,UACvE;AACA,UAAA,OAAO,QAAQ,aAAa,CAAA;AAAA,QAC9B;AAGA,QAAA,MAAM,IAAA,GAAO,SAAA;AAIb,QAAA,OAAO,OAAA,CAAQ;AAAA,UACb,KAAA,EAAO,IAAA,CAAK,QAAA,IAAW,IAAK,EAAC;AAAA,UAC7B,QAAA,EAAU,IAAA,CAAK,WAAA,IAAc,IAAK,EAAC;AAAA,UACnC,SAAA,EAAW,KAAK,GAAA;AAAI,SACrB,CAAA;AAAA,MACH,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,uBAAuB,CAAA;AAAA,MAC9D;AAAA,IACF,CAAA;AAAA,IAEA,sBAAA,EAAwB,OACtB,EAAA,EACA,OAAA,KACG;AACH,MAAA,IAAI;AACF,QAAA,MAAM,MAAA,GAAS,MAAM,cAAA,CAAe,sBAAA,CAAuB,EAAA,EAAI;AAAA,UAC7D,QAAQ,OAAA,CAAQ,MAAA;AAAA,UAChB,QAAQ,OAAA,CAAQ;AAAA,SACjB,CAAA;AACD,QAAA,OAAO,QAAQ,MAAM,CAAA;AAAA,MACvB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,wBAAwB,CAAA;AAAA,MAC/D;AAAA,IACF,CAAA;AAAA;AAAA;AAAA;AAAA,IAMA,IAAA,EAAM,OAAO,OAAA,KAAsB;AACjC,MAAA,IAAI;AACF,QAAA,MAAM,WAAA,GAAc,OAAA;AAGpB,QAAA,MAAM,WAAW,QAAA,CAAS,YAAA,GAAe,WAAW,CAAA,IAAK,SAAS,cAAA,EAAe;AACjF,QAAA,OAAO,OAAA,CAAQ;AAAA,UACb,QAAA;AAAA,UACA,SAAA,EAAW,KAAK,GAAA,EAAI;AAAA,UACpB,OAAQ,QAAA,CAAuB,MAAA;AAAA,UAC/B,UAAA,EAAY;AAAA,SACb,CAAA;AAAA,MACH,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,YAAY,CAAA;AAAA,MACnD;AAAA,IACF,CAAA;AAAA,IAEA,QAAA,EAAU,OAAO,OAAA,KAAsB;AAErC,MAAA,IAAI;AACF,QAAA,MAAM,WAAA,GAAc,OAAA;AAGpB,QAAA,MAAM,WAAW,QAAA,CAAS,YAAA,GAAe,WAAW,CAAA,IAAK,SAAS,cAAA,EAAe;AACjF,QAAA,OAAO,OAAA,CAAQ;AAAA,UACb,QAAA;AAAA,UACA,SAAA,EAAW,KAAK,GAAA,EAAI;AAAA,UACpB,OAAQ,QAAA,CAAuB,MAAA;AAAA,UAC/B,UAAA,EAAY;AAAA,SACb,CAAA;AAAA,MACH,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,gBAAgB,CAAA;AAAA,MACvD;AAAA,IACF,CAAA;AAAA,IAEA,oBAAoB,YAAmD;AACrE,MAAA,IAAI;AACF,QAAA,MAAM,QAAA,GAAW,SAAS,cAAA,EAAe;AACzC,QAAA,OAAO,QAAQ,QAAQ,CAAA;AAAA,MACzB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,gBAAgB,CAAA;AAAA,MACvD;AAAA,IACF,CAAA;AAAA;AAAA;AAAA;AAAA,IAMA,cAAc,YAAgE;AAC5E,MAAA,IAAI;AACF,QAAA,MAAM,SAAA,GAAY,QAAA,CAAS,eAAA,IAAkB,IAAK,EAAC;AACnD,QAAA,OAAO,QAAQ,SAAyC,CAAA;AAAA,MAC1D,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,iBAAiB,CAAA;AAAA,MACxD;AAAA,IACF,CAAA;AAAA,IAEA,WAAA,EAAa,OAAO,EAAA,EAAY,QAAA,KAAuB;AACrD,MAAA,IAAI;AACF,QAAA,MAAM,QAAA,GAAW,QAAA,CAAS,WAAA,GAAc,EAAE,CAAA;AAC1C,QAAA,IAAI,CAAC,QAAA,EAAU;AACb,UAAA,OAAO,KAAA,CAAM,CAAA,oBAAA,EAAuB,EAAE,CAAA,CAAA,EAAI,WAAW,CAAA;AAAA,QACvD;AAEA,QAAA,MAAM,KAAA,GAAQ,CAAA,IAAA,EAAO,IAAA,CAAK,GAAA,EAAK,CAAA,CAAA;AAC/B,QAAA,OAAO,OAAA,CAAQ;AAAA,UACb,KAAA;AAAA,UACA,UAAA,EAAY,EAAA;AAAA,UACZ,MAAA,EAAQ,SAAA;AAAA,UACR,SAAA,EAAW,KAAK,GAAA,EAAI;AAAA,UACpB,OAAO,EAAC;AAAA,UACR,UAAA,EAAY;AAAA,SACb,CAAA;AAAA,MACH,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,gBAAgB,CAAA;AAAA,MACvD;AAAA,IACF,CAAA;AAAA,IAEA,iBAAA,EAAmB,OAAO,KAAA,KAAkB;AAC1C,MAAA,IAAI;AAEF,QAAA,OAAO,OAAA,CAAQ;AAAA,UACb,KAAA;AAAA,UACA,UAAA,EAAY,EAAA;AAAA,UACZ,MAAA,EAAQ,WAAA;AAAA,UACR,WAAA,EAAa,KAAK,GAAA,EAAI;AAAA,UACtB,SAAA,EAAW,KAAK,GAAA,EAAI;AAAA,UACpB,OAAO,EAAC;AAAA,UACR,UAAA,EAAY;AAAA,SACb,CAAA;AAAA,MACH,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,uBAAuB,CAAA;AAAA,MAC9D;AAAA,IACF,CAAA;AAAA;AAAA;AAAA;AAAA,IAMA,gBAAA,EAAkB,OAAO,KAAA,KAAoD;AAC3E,MAAA,IAAI;AACF,QAAA,MAAM,OAAA,GAAU,QAAA,CAAS,gBAAA,IAAmB,IAAK,EAAC;AAClD,QAAA,MAAM,UAAU,KAAA,GAAQ,OAAA,CAAQ,KAAA,CAAM,CAAC,KAAK,CAAA,GAAI,OAAA;AAChD,QAAA,OAAO,QAAQ,OAAO,CAAA;AAAA,MACxB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,sBAAsB,CAAA;AAAA,MAC7D;AAAA,IACF,CAAA;AAAA,IAEA,YAAY,YAA2C;AACrD,MAAA,IAAI;AACF,QAAA,MAAM,OAAA,GAAU,QAAA,CAAS,UAAA,IAAa,IAAK;AAAA,UACzC,YAAA,EAAc,QAAA,CAAS,cAAA,EAAe,CAAE,MAAA;AAAA,UACxC,cAAA,EAAgB,QAAA,CAAS,gBAAA,EAAiB,CAAE;AAAA,SAC9C;AACA,QAAA,OAAO,QAAQ,OAAO,CAAA;AAAA,MACxB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,eAAe,CAAA;AAAA,MACtD;AAAA,IACF,CAAA;AAAA,IAEA,gBAAA,EAAkB,OAAO,EAAA,KAA2C;AAClE,MAAA,IAAI;AACF,QAAA,QAAA,CAAS,mBAAmB,EAAE,CAAA;AAC9B,QAAA,OAAO,QAAQ,KAAA,CAAS,CAAA;AAAA,MAC1B,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,iBAAiB,CAAA;AAAA,MACxD;AAAA,IACF,CAAA;AAAA,IAEA,gBAAgB,YAA2C;AACzD,MAAA,IAAI;AACF,QAAA,MAAM,IAAA,GAAO,SAAS,cAAA,IAAiB,IAAK,EAAE,IAAA,EAAM,IAAA,EAAM,QAAA,EAAU,EAAC,EAAE;AACvE,QAAA,OAAO,QAAQ,IAAI,CAAA;AAAA,MACrB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,oBAAoB,CAAA;AAAA,MAC3D;AAAA,IACF,CAAA;AAAA,IAEA,gBAAA,EAAkB,OAAO,MAAA,KAG+C;AACtE,MAAA,IAAI;AACF,QAAA,IAAI,CAAC,cAAA,EAAgB;AACnB,UAAA,OAAO,QAAQ,EAAE,MAAA,EAAQ,EAAC,EAAG,KAAA,EAAO,GAAG,CAAA;AAAA,QACzC;AACA,QAAA,MAAM,MAAA,GAAS,MAAA,EAAQ,KAAA,GACnB,cAAA,CAAe,eAAA,CAAgB,MAAA,CAAO,KAAK,CAAA,GAC3C,cAAA,CAAe,gBAAA,CAAiB,MAAA,EAAQ,KAAA,IAAS,EAAE,CAAA;AACvD,QAAA,OAAO,QAAQ,EAAE,MAAA,EAAQ,KAAA,EAAO,MAAA,CAAO,QAAQ,CAAA;AAAA,MACjD,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,sBAAsB,CAAA;AAAA,MAC7D;AAAA,IACF,CAAA;AAAA,IAEA,oBAAoB,YAAwD;AAC1E,MAAA,IAAI;AACF,QAAA,IAAI,CAAC,cAAA,EAAgB;AACnB,UAAA,OAAO,OAAA,CAAQ,EAAE,OAAA,EAAS,KAAA,EAAO,CAAA;AAAA,QACnC;AACA,QAAA,cAAA,CAAe,KAAA,EAAM;AACrB,QAAA,OAAO,OAAA,CAAQ,EAAE,OAAA,EAAS,IAAA,EAAM,CAAA;AAAA,MAClC,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,qBAAqB,CAAA;AAAA,MAC5D;AAAA,IACF,CAAA;AAAA;AAAA;AAAA;AAAA,IAMA,QAAA,EAAU,OAAO,QAAA,KAAmE;AAClF,MAAA,IAAI;AAEF,QAAA,eAAA,EAAgB;AAChB,QAAA,MAAM,QAAA,GAAW,YAAA,CAAa,MAAA,CAAO,QAAQ,CAAA;AAC7C,QAAA,OAAO,QAAQ,QAAQ,CAAA;AAAA,MACzB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,iBAAiB,CAAA;AAAA,MACxD;AAAA,IACF,CAAA;AAAA,IAEA,SAAA,EAAW,OAAO,OAAA,KAAqE;AACrF,MAAA,IAAI;AAEF,QAAA,eAAA,EAAgB;AAChB,QAAA,MAAM,QAAA,GAAW,MAAM,UAAA,CAAW,OAAA,CAAQ,OAAO,CAAA;AACjD,QAAA,OAAO,QAAQ,QAAQ,CAAA;AAAA,MACzB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,kBAAkB,CAAA;AAAA,MACzD;AAAA,IACF,CAAA;AAAA,IAEA,QAAA,EAAU,OAAO,OAAA,KAAqE;AACpF,MAAA,IAAI;AAEF,QAAA,eAAA,EAAgB;AAChB,QAAA,MAAM,MAAA,GAAS,MAAM,iBAAA,CAAkB,MAAA,CAAO,OAAO,CAAA;AACrD,QAAA,OAAO,QAAQ,MAAM,CAAA;AAAA,MACvB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,iBAAiB,CAAA;AAAA,MACxD;AAAA,IACF,CAAA;AAAA,IAEA,aAAA,EAAe,OACb,OAAA,KAC+C;AAC/C,MAAA,IAAI;AAEF,QAAA,eAAA,EAAgB;AAChB,QAAA,MAAM,MAAA,GAAS,MAAM,iBAAA,CAAkB,WAAA,CAAY,OAAO,CAAA;AAC1D,QAAA,OAAO,QAAQ,MAAM,CAAA;AAAA,MACvB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,uBAAuB,CAAA;AAAA,MAC9D;AAAA,IACF,CAAA;AAAA,IAEA,qBAAqB,YAAoD;AACvE,MAAA,IAAI;AACF,QAAA,MAAM,eAAA,GAAkB,SAAS,cAAA,EAAe;AAChD,QAAA,MAAM,QAAA,GAAW,eAAA,CAAgB,cAAA,CAAe,eAAe,CAAA;AAC/D,QAAA,OAAO,QAAQ,QAAQ,CAAA;AAAA,MACzB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,yBAAyB,CAAA;AAAA,MAChE;AAAA,IACF,CAAA;AAAA,IAEA,eAAA,EAAiB,OAAO,MAAA,KAA+D;AACrF,MAAA,IAAI;AAEF,QAAA,MAAM,eAAA,GAAkB,SAAS,cAAA,EAAe;AAChD,QAAA,MAAM,eAAA,GAAkB,eAAA,CAAgB,cAAA,CAAe,eAAe,CAAA;AAGtE,QAAA,MAAM,IAAA,GAAO,WAAA,CAAY,MAAA,CAAO,eAAe,CAAA;AAC/C,QAAA,OAAO,QAAQ,IAAI,CAAA;AAAA,MACrB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,qBAAqB,CAAA;AAAA,MAC5D;AAAA,IACF,CAAA;AAAA,IAEA,gBAAgB,YAA0C;AACxD,MAAA,IAAI;AACF,QAAA,MAAM,QAAA,GAAW,SAAS,cAAA,EAAe;AAEzC,QAAA,MAAM,QAAA,GAAW,QAAA,CAAS,QAAA,CAAS,GAAA,CAAI,CAAC,EAAA,MAAQ;AAAA,UAC9C,GAAG,EAAA;AAAA,UACH,WAAA,EAAa,EAAA,CAAG,KAAA,IAAS,EAAA,CAAG,EAAA;AAAA,UAC5B,SAAS,EAAC;AAAA,UACV,kBAAkB,EAAC;AAAA,UACnB,SAAS,EAAA,CAAG,IAAA;AAAA,UACZ,gBAAgB,EAAA,CAAG,KAAA;AAAA,UACnB,UAAA,EAAY;AAAA,SACd,CAAE,CAAA;AACF,QAAA,MAAM,OAAA,GAAU,oBAAoB,QAAQ,CAAA;AAC5C,QAAA,OAAO,QAAQ,OAAO,CAAA;AAAA,MACxB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,oBAAoB,CAAA;AAAA,MAC3D;AAAA,IACF,CAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAUA,aAAa,YAA0D;AACrE,MAAA,IAAI;AACF,QAAA,MAAA,CAAO,SAAS,MAAA,EAAO;AACvB,QAAA,OAAO,OAAA,CAAQ,EAAE,OAAA,EAAS,IAAA,EAAM,GAAA,EAAK,MAAA,CAAO,QAAA,CAAS,IAAA,EAAM,SAAA,EAAW,IAAA,CAAK,GAAA,EAAI,EAAG,CAAA;AAAA,MACpF,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,oBAAoB,CAAA;AAAA,MAC3D;AAAA,IACF,CAAA;AAAA,IAEA,YAAA,EAAc,OACZ,OAAA,KACiD;AACjD,MAAA,IAAI;AACF,QAAA,IAAI,CAAC,QAAQ,GAAA,EAAK;AAChB,UAAA,OAAO,KAAA,CAAM,mBAAmB,iBAAiB,CAAA;AAAA,QACnD;AACA,QAAA,MAAA,CAAO,QAAA,CAAS,OAAO,OAAA,CAAQ,GAAA;AAC/B,QAAA,OAAO,OAAA,CAAQ,EAAE,OAAA,EAAS,IAAA,EAAM,GAAA,EAAK,OAAA,CAAQ,GAAA,EAAK,SAAA,EAAW,IAAA,CAAK,GAAA,EAAI,EAAG,CAAA;AAAA,MAC3E,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,qBAAqB,CAAA;AAAA,MAC5D;AAAA,IACF,CAAA;AAAA,IAEA,YAAY,YAA0D;AACpE,MAAA,IAAI;AACF,QAAA,MAAA,CAAO,QAAQ,IAAA,EAAK;AACpB,QAAA,OAAO,OAAA,CAAQ,EAAE,OAAA,EAAS,IAAA,EAAM,GAAA,EAAK,MAAA,CAAO,QAAA,CAAS,IAAA,EAAM,SAAA,EAAW,IAAA,CAAK,GAAA,EAAI,EAAG,CAAA;AAAA,MACpF,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,oBAAoB,CAAA;AAAA,MAC3D;AAAA,IACF,CAAA;AAAA,IAEA,eAAe,YAA0D;AACvE,MAAA,IAAI;AACF,QAAA,MAAA,CAAO,QAAQ,OAAA,EAAQ;AACvB,QAAA,OAAO,OAAA,CAAQ,EAAE,OAAA,EAAS,IAAA,EAAM,GAAA,EAAK,MAAA,CAAO,QAAA,CAAS,IAAA,EAAM,SAAA,EAAW,IAAA,CAAK,GAAA,EAAI,EAAG,CAAA;AAAA,MACpF,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,uBAAuB,CAAA;AAAA,MAC9D;AAAA,IACF,CAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAeA,gBAAgB,YAAqE;AACnF,MAAA,IAAI;AACF,QAAA,OAAO,OAAA,CAAQ,eAAA,CAAgB,MAAA,EAAQ,CAAA;AAAA,MACzC,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,mBAAmB,CAAA;AAAA,MAC1D;AAAA,IACF,CAAA;AAAA,IAEA,aAAA,EAAe,OAAO,EAAA,KAAwD;AAC5E,MAAA,IAAI;AACF,QAAA,MAAM,UAAA,GAAa,eAAA,CAAgB,GAAA,CAAI,EAAE,CAAA;AACzC,QAAA,IAAI,CAAC,UAAA,EAAY;AACf,UAAA,OAAO,KAAA,CAAM,CAAA,sBAAA,EAAyB,EAAE,CAAA,CAAA,EAAI,WAAW,CAAA;AAAA,QACzD;AACA,QAAA,OAAO,QAAQ,UAAU,CAAA;AAAA,MAC3B,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,kBAAkB,CAAA;AAAA,MACzD;AAAA,IACF,CAAA;AAAA,IAEA,aAAA,EAAe,OACb,EAAA,EACA,UAAA,KAC4C;AAC5C,MAAA,IAAI;AACF,QAAA,eAAA,CAAgB,GAAA,CAAI,IAAI,UAAU,CAAA;AAClC,QAAA,OAAO,OAAA,CAAQ,eAAA,CAAgB,GAAA,CAAI,EAAE,CAAE,CAAA;AAAA,MACzC,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,sBAAsB,CAAA;AAAA,MAC7D;AAAA,IACF,CAAA;AAAA,IAEA,gBAAA,EAAkB,OAAO,EAAA,KAA2C;AAClE,MAAA,IAAI;AACF,QAAA,MAAM,OAAA,GAAU,eAAA,CAAgB,MAAA,CAAO,EAAE,CAAA;AACzC,QAAA,IAAI,CAAC,OAAA,EAAS;AACZ,UAAA,OAAO,KAAA,CAAM,CAAA,sBAAA,EAAyB,EAAE,CAAA,CAAA,EAAI,WAAW,CAAA;AAAA,QACzD;AACA,QAAA,OAAO,QAAQ,KAAA,CAAS,CAAA;AAAA,MAC1B,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,yBAAyB,CAAA;AAAA,MAChE;AAAA,IACF,CAAA;AAAA,IAEA,iBAAA,EAAmB,OACjBC,OAAAA,KAC4C;AAC5C,MAAA,IAAI;AACF,QAAA,MAAM,KAAA,GAAQ,eAAA,CAAgB,YAAA,CAAaA,OAAM,CAAA;AACjD,QAAA,OAAO,OAAA,CAAQ,EAAE,KAAA,EAAO,CAAA;AAAA,MAC1B,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,yBAAyB,CAAA;AAAA,MAChE;AAAA,IACF,CAAA;AAAA,IAEA,mBAAmB,YAAoD;AACrE,MAAA,IAAI;AACF,QAAA,OAAO,OAAA,CAAQ,eAAA,CAAgB,YAAA,EAAc,CAAA;AAAA,MAC/C,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,yBAAyB,CAAA;AAAA,MAChE;AAAA,IACF,CAAA;AAAA,IAEA,uBAAuB,YAAsD;AAC3E,MAAA,IAAI;AACF,QAAA,MAAM,WAAA,GAAc,SAAS,cAAA,EAAe;AAC5C,QAAA,MAAM,SAAS,WAAA,CAAY,GAAA,CAAI,CAAC,EAAA,KAAO,GAAG,EAAE,CAAA;AAC5C,QAAA,OAAO,OAAA,CAAQ,eAAA,CAAgB,WAAA,CAAY,MAAM,CAAC,CAAA;AAAA,MACpD,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,2BAA2B,CAAA;AAAA,MAClE;AAAA,IACF,CAAA;AAAA,IAEA,gBAAA,EAAkB,OAChB,QAAA,KACiD;AACjD,MAAA,MAAM,SAAA,GAAY,YAAY,GAAA,EAAI;AAClC,MAAA,IAAI;AAEF,QAAA,eAAA,EAAgB;AAGhB,QAAA,MAAM,WAAA,GAAc,SAAS,cAAA,EAAe;AAG5C,QAAA,MAAM,aAAoE,WAAA,CAAY,GAAA;AAAA,UACpF,CAAC,EAAA,KAAO;AAEN,YAAA,MAAM,YAAsB,EAAC;AAG7B,YAAA,MAAM,QAAQ,UAAA,IAAc,EAAA,GAAM,EAAA,CAAW,QAAA,KAAa,EAAA,CAAG,KAAA;AAC7D,YAAA,MAAM,WAAA,GAAc,OAAO,WAAA,IAAe,EAAA;AAC1C,YAAA,MAAM,KAAA,GAAQ,GAAG,KAAA,IAAS,EAAA;AAC1B,YAAA,MAAM,cAAA,GAAiB,GAAG,cAAA,IAAkB,EAAA;AAC5C,YAAA,MAAM,WAAA,GAAc,GAAG,WAAA,IAAe,EAAA;AACtC,YAAA,MAAM,KAAA,GAAQ,GAAG,KAAA,IAAS,EAAA;AAE1B,YAAA,IAAI,KAAA,EAAO,SAAA,CAAU,IAAA,CAAK,KAAK,CAAA;AAC/B,YAAA,IAAI,cAAA,IAAkB,cAAA,KAAmB,KAAA,EAAO,SAAA,CAAU,KAAK,cAAc,CAAA;AAC7E,YAAA,IAAI,WAAA,IAAe,WAAA,KAAgB,KAAA,IAAS,WAAA,KAAgB,cAAA,EAAgB;AAC1E,cAAA,SAAA,CAAU,KAAK,WAAW,CAAA;AAAA,YAC5B;AACA,YAAA,IAAI,WAAA,EAAa,SAAA,CAAU,IAAA,CAAK,CAAA,aAAA,EAAgB,WAAW,CAAA,CAAE,CAAA;AAC7D,YAAA,IAAI,KAAA,EAAO,SAAA,CAAU,IAAA,CAAK,KAAK,CAAA;AAE/B,YAAA,MAAM,eAAe,SAAA,CAAU,IAAA,CAAK,GAAG,CAAA,CAAE,IAAA,MAAU,EAAA,CAAG,EAAA;AAEtD,YAAA,OAAO;AAAA,cACL,OAAA,EAAS;AAAA,gBACP,IAAI,EAAA,CAAG,EAAA;AAAA,gBACP,MAAM,EAAA,CAAG,IAAA;AAAA,gBACT,OAAO,EAAA,CAAG,KAAA;AAAA,gBACV,OAAA,EAAS,EAAA,CAAG,OAAA,IAAW,EAAA,CAAG,IAAA;AAAA,gBAC1B,MAAM,EAAA,CAAG,IAAA;AAAA,gBACT,gBAAgB,EAAA,CAAG,cAAA;AAAA,gBACnB,OAAA,EAAS,EAAA,CAAG,OAAA,IAAW,EAAC;AAAA,gBACxB,KAAA,EAAO,SAAS,EAAC;AAAA,gBACjB,UAAA,EAAY,IAAA;AAAA,gBACZ,WAAA,EAAa,SAAS,EAAA,CAAG,EAAA;AAAA,gBACzB,SAAS,EAAC;AAAA,gBACV,kBAAkB;AAAC,eACrB;AAAA,cACA,IAAA,EAAM;AAAA,aACR;AAAA,UACF;AAAA,SACF;AAGA,QAAA,IAAI,gBAAA,GAAmB,UAAA;AACvB,QAAA,IAAI,SAAS,IAAA,EAAM;AACjB,UAAA,gBAAA,GAAmB,gBAAA,CAAiB,MAAA;AAAA,YAClC,CAAC,EAAE,OAAA,EAAQ,KAAM,OAAA,CAAQ,KAAK,WAAA,EAAY,KAAM,QAAA,CAAS,IAAA,CAAM,WAAA;AAAY,WAC7E;AAAA,QACF;AACA,QAAA,IAAI,SAAS,IAAA,EAAM;AACjB,UAAA,gBAAA,GAAmB,gBAAA,CAAiB,MAAA;AAAA,YAClC,CAAC,EAAE,OAAA,EAAQ,KAAM,OAAA,CAAQ,MAAM,WAAA,EAAY,KAAM,QAAA,CAAS,IAAA,CAAM,WAAA;AAAY,WAC9E;AAAA,QACF;AASA,QAAA,MAAM,KAAA,GAAQ,QAAA,CAAS,KAAA,CAAM,WAAA,EAAY;AACzC,QAAA,MAAM,SAAA,GAAY,SAAS,SAAA,IAAa,GAAA;AACxC,QAAA,MAAM,KAAA,GAAQ,SAAS,KAAA,IAAS,EAAA;AAGhC,QAAA,MAAM,gBAAwC,gBAAA,CAAiB,GAAA,CAAI,CAAC,EAAE,OAAA,EAAS,MAAK,KAAM;AAExF,UAAA,MAAM,SAAA,GAAY,KAAK,WAAA,EAAY;AACnC,UAAA,IAAI,UAAA,GAAa,CAAA;AAGjB,UAAA,IAAI,SAAA,CAAU,QAAA,CAAS,KAAK,CAAA,EAAG;AAC7B,YAAA,UAAA,GAAa,GAAA;AAAA,UACf,CAAA,MAAO;AAEL,YAAA,MAAM,UAAA,GAAa,IAAI,GAAA,CAAI,KAAA,CAAM,KAAA,CAAM,KAAK,CAAA,CAAE,MAAA,CAAO,CAAC,CAAA,KAAc,CAAA,CAAE,MAAA,GAAS,CAAC,CAAC,CAAA;AACjF,YAAA,MAAM,SAAA,GAAY,IAAI,GAAA,CAAI,SAAA,CAAU,KAAA,CAAM,KAAK,CAAA,CAAE,MAAA,CAAO,CAAC,CAAA,KAAc,CAAA,CAAE,MAAA,GAAS,CAAC,CAAC,CAAA;AAEpF,YAAA,IAAI,UAAA,CAAW,IAAA,GAAO,CAAA,IAAK,SAAA,CAAU,OAAO,CAAA,EAAG;AAC7C,cAAA,IAAI,UAAA,GAAa,CAAA;AACjB,cAAA,KAAA,MAAW,QAAQ,UAAA,EAAY;AAC7B,gBAAA,KAAA,MAAW,YAAY,SAAA,EAAW;AAChC,kBAAA,IAAI,SAAS,QAAA,CAAS,IAAI,KAAK,IAAA,CAAK,QAAA,CAAS,QAAQ,CAAA,EAAG;AACtD,oBAAA,UAAA,EAAA;AACA,oBAAA;AAAA,kBACF;AAAA,gBACF;AAAA,cACF;AACA,cAAA,UAAA,GAAc,UAAA,GAAa,WAAW,IAAA,GAAQ,GAAA;AAAA,YAChD;AAAA,UACF;AAEA,UAAA,OAAO;AAAA,YACL,OAAA;AAAA,YACA,UAAA;AAAA,YACA,IAAA,EAAM,CAAA;AAAA;AAAA,YACN,YAAA,EAAc;AAAA,WAChB;AAAA,QACF,CAAC,CAAA;AAGD,QAAA,MAAM,eAAA,GAAkB,cACrB,MAAA,CAAO,CAAC,MAAM,CAAA,CAAE,UAAA,IAAc,SAAS,CAAA,CACvC,IAAA,CAAK,CAAC,CAAA,EAAG,CAAA,KAAM,EAAE,UAAA,GAAa,CAAA,CAAE,UAAU,CAAA,CAC1C,KAAA,CAAM,GAAG,KAAK,CAAA;AAGjB,QAAA,eAAA,CAAgB,OAAA,CAAQ,CAAC,MAAA,EAAQ,KAAA,KAAU;AACzC,UAAA,MAAA,CAAO,OAAO,KAAA,GAAQ,CAAA;AAAA,QACxB,CAAC,CAAA;AAED,QAAA,MAAM,QAAA,GAAmC;AAAA,UACvC,OAAA,EAAS,eAAA;AAAA,UACT,WAAW,eAAA,CAAgB,MAAA,GAAS,CAAA,GAAI,eAAA,CAAgB,CAAC,CAAA,GAAI,IAAA;AAAA,UAC7D,cAAc,gBAAA,CAAiB,MAAA;AAAA,UAC/B,UAAA,EAAY,WAAA,CAAY,GAAA,EAAI,GAAI,SAAA;AAAA,UAChC,OAAO,QAAA,CAAS,KAAA;AAAA,UAChB,YAAA,EAAc;AAAA,YACZ,QAAA,EAAU,eAAA;AAAA,YACV,KAAA,EAAO,mBAAA;AAAA,YACP,SAAA,EAAW;AAAA,WACb;AAAA,UACA,SAAA,EAAW,KAAK,GAAA;AAAI,SACtB;AAEA,QAAA,OAAO,QAAQ,QAAQ,CAAA;AAAA,MACzB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,0BAA0B,CAAA;AAAA,MACjE;AAAA,IACF,CAAA;AAAA;AAAA;AAAA;AAAA,IAMA,WAAW,YAA6C;AACtD,MAAA,IAAI;AACF,QAAA,MAAM,MAAA,GAAS,QAAA,CAAS,SAAA,IAAY,IAAK,EAAC;AAC1C,QAAA,OAAO,QAAQ,MAAM,CAAA;AAAA,MACvB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,cAAc,CAAA;AAAA,MACrD;AAAA,IACF,CAAA;AAAA,IAEA,QAAA,EAAU,OAAO,EAAA,KAA8C;AAC7D,MAAA,IAAI;AACF,QAAA,MAAM,KAAA,GAAQ,QAAA,CAAS,QAAA,GAAW,EAAE,CAAA;AACpC,QAAA,IAAI,CAAC,KAAA,EAAO;AACV,UAAA,OAAO,KAAA,CAAM,CAAA,iBAAA,EAAoB,EAAE,CAAA,CAAA,EAAI,WAAW,CAAA;AAAA,QACpD;AACA,QAAA,OAAO,QAAQ,KAAK,CAAA;AAAA,MACtB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,aAAa,CAAA;AAAA,MACpD;AAAA,IACF,CAAA;AAAA,IAEA,iBAAiB,YAA6C;AAC5D,MAAA,IAAI;AACF,QAAA,MAAM,MAAA,GAAS,QAAA,CAAS,eAAA,IAAkB,IAAK,EAAC;AAChD,QAAA,OAAO,QAAQ,MAAM,CAAA;AAAA,MACvB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,qBAAqB,CAAA;AAAA,MAC5D;AAAA,IACF,CAAA;AAAA,IAEA,aAAA,EAAe,OAAO,EAAA,KAA2C;AAC/D,MAAA,IAAI;AACF,QAAA,IAAI,CAAC,SAAS,aAAA,EAAe;AAC3B,UAAA,OAAO,KAAA,CAAM,kCAAkC,iBAAiB,CAAA;AAAA,QAClE;AACA,QAAA,QAAA,CAAS,cAAc,EAAE,CAAA;AACzB,QAAA,OAAO,QAAQ,KAAA,CAAS,CAAA;AAAA,MAC1B,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,sBAAsB,CAAA;AAAA,MAC7D;AAAA,IACF,CAAA;AAAA,IAEA,eAAA,EAAiB,OAAO,EAAA,KAA2C;AACjE,MAAA,IAAI;AACF,QAAA,IAAI,CAAC,SAAS,eAAA,EAAiB;AAC7B,UAAA,OAAO,KAAA,CAAM,kCAAkC,iBAAiB,CAAA;AAAA,QAClE;AACA,QAAA,QAAA,CAAS,gBAAgB,EAAE,CAAA;AAC3B,QAAA,OAAO,QAAQ,KAAA,CAAS,CAAA;AAAA,MAC1B,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,wBAAwB,CAAA;AAAA,MAC/D;AAAA,IACF,CAAA;AAAA,IAEA,gBAAgB,YAAkD;AAChE,MAAA,IAAI;AACF,QAAA,MAAM,MAAA,GAAS,QAAA,CAAS,cAAA,IAAiB,IAAK,EAAC;AAC/C,QAAA,OAAO,QAAQ,MAAM,CAAA;AAAA,MACvB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,oBAAoB,CAAA;AAAA,MAC3D;AAAA,IACF,CAAA;AAAA,IAEA,kBAAA,EAAoB,OAAO,EAAA,KAA2C;AACpE,MAAA,IAAI;AACF,QAAA,IAAI,CAAC,SAAS,kBAAA,EAAoB;AAChC,UAAA,OAAO,KAAA,CAAM,wCAAwC,iBAAiB,CAAA;AAAA,QACxE;AACA,QAAA,QAAA,CAAS,mBAAmB,EAAE,CAAA;AAC9B,QAAA,OAAO,QAAQ,KAAA,CAAS,CAAA;AAAA,MAC1B,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,4BAA4B,CAAA;AAAA,MACnE;AAAA,IACF,CAAA;AAAA,IAEA,oBAAA,EAAsB,OAAO,EAAA,KAA2C;AACtE,MAAA,IAAI;AACF,QAAA,IAAI,CAAC,SAAS,oBAAA,EAAsB;AAClC,UAAA,OAAO,KAAA,CAAM,wCAAwC,iBAAiB,CAAA;AAAA,QACxE;AACA,QAAA,QAAA,CAAS,qBAAqB,EAAE,CAAA;AAChC,QAAA,OAAO,QAAQ,KAAA,CAAS,CAAA;AAAA,MAC1B,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,8BAA8B,CAAA;AAAA,MACrE;AAAA,IACF,CAAA;AAAA,IAEA,gBAAgB,YAAkD;AAChE,MAAA,IAAI;AACF,QAAA,MAAM,WAAA,GAAc,QAAA,CAAS,cAAA,IAAiB,IAAK,EAAC;AACpD,QAAA,OAAO,QAAQ,WAAW,CAAA;AAAA,MAC5B,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,mBAAmB,CAAA;AAAA,MAC1D;AAAA,IACF,CAAA;AAAA,IAEA,oBAAA,EAAsB,OACpB,EAAA,KACmE;AACnE,MAAA,IAAI;AACF,QAAA,IAAI,CAAC,SAAS,oBAAA,EAAsB;AAClC,UAAA,OAAO,KAAA,CAAM,uCAAuC,iBAAiB,CAAA;AAAA,QACvE;AACA,QAAA,MAAM,MAAA,GAAS,QAAA,CAAS,oBAAA,CAAqB,EAAE,CAAA;AAC/C,QAAA,OAAO,QAAQ,MAAM,CAAA;AAAA,MACvB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,8BAA8B,CAAA;AAAA,MACrE;AAAA,IACF,CAAA;AAAA,IAEA,iBAAA,EAAmB,OAAO,EAAA,KAAuD;AAC/E,MAAA,IAAI;AACF,QAAA,IAAI,CAAC,SAAS,iBAAA,EAAmB;AAC/B,UAAA,OAAO,KAAA,CAAM,sCAAsC,iBAAiB,CAAA;AAAA,QACtE;AACA,QAAA,MAAM,MAAA,GAAS,MAAM,QAAA,CAAS,iBAAA,CAAkB,EAAE,CAAA;AAClD,QAAA,OAAO,QAAQ,MAAM,CAAA;AAAA,MACvB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,0BAA0B,CAAA;AAAA,MACjE;AAAA,IACF,CAAA;AAAA,IAEA,QAAA,EAAU,OAAO,OAAA,KAA0E;AACzF,MAAA,IAAI;AACF,QAAA,IAAI,CAAC,SAAS,QAAA,EAAU;AACtB,UAAA,OAAO,KAAA,CAAM,6BAA6B,iBAAiB,CAAA;AAAA,QAC7D;AACA,QAAA,MAAM,MAAA,GAAS,QAAA,CAAS,QAAA,CAAS,OAAA,CAAQ,YAAY,CAAA;AACrD,QAAA,OAAO,QAAQ,MAAM,CAAA;AAAA,MACvB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,iBAAiB,CAAA;AAAA,MACxD;AAAA,IACF,CAAA;AAAA,IAEA,UAAA,EAAY,OAAO,OAAA,KAE2B;AAC5C,MAAA,IAAI;AACF,QAAA,IAAI,CAAC,SAAS,UAAA,EAAY;AACxB,UAAA,OAAO,KAAA,CAAM,4BAA4B,iBAAiB,CAAA;AAAA,QAC5D;AACA,QAAA,MAAM,MAAA,GAAS,MAAM,QAAA,CAAS,UAAA,CAAW,QAAQ,YAAY,CAAA;AAC7D,QAAA,OAAO,QAAQ,MAAM,CAAA;AAAA,MACvB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,mBAAmB,CAAA;AAAA,MAC1D;AAAA,IACF,CAAA;AAAA,IAEA,kBAAkB,YAAiD;AACjE,MAAA,IAAI;AACF,QAAA,IAAI,CAAC,SAAS,gBAAA,EAAkB;AAE9B,UAAA,MAAM,QAAA,GAA0B;AAAA,YAC9B,SAAA,EAAW,KAAK,GAAA,EAAI;AAAA,YACpB,YAAA,EAAA,CAAe,QAAA,CAAS,eAAA,IAAkB,IAAK,IAAI,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,CAAE,EAAE,CAAA;AAAA,YAClE,MAAA,EAAQ,QAAA,CAAS,SAAA,IAAY,IAAK,EAAC;AAAA,YACnC,MAAA,EAAQ,QAAA,CAAS,cAAA,IAAiB,IAAK,EAAC;AAAA,YACxC,WAAA,EAAa,QAAA,CAAS,cAAA,IAAiB,IAAK;AAAC,WAC/C;AACA,UAAA,OAAO,QAAQ,QAAQ,CAAA;AAAA,QACzB;AACA,QAAA,OAAO,OAAA,CAAQ,QAAA,CAAS,gBAAA,EAAkB,CAAA;AAAA,MAC5C,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,sBAAsB,CAAA;AAAA,MAC7D;AAAA,IACF,CAAA;AAAA;AAAA;AAAA;AAAA,IAMA,aAAA,EAAe,OAAO,OAAA,KAG6B;AACjD,MAAA,MAAM,SAAA,GAAY,KAAK,GAAA,EAAI;AAC3B,MAAA,IAAI;AACF,QAAA,eAAA,EAAgB;AAChB,QAAA,MAAM,MAAA,GAAS,cAAA,CAAe,GAAA,CAAI,OAAA,CAAQ,QAAQ,CAAA;AAClD,QAAA,IAAI,CAAC,MAAA,EAAQ;AACX,UAAA,OAAO,KAAA,CAAM,CAAA,kBAAA,EAAqB,OAAA,CAAQ,QAAQ,IAAI,WAAW,CAAA;AAAA,QACnE;AAEA,QAAA,MAAM,UAAA,GAAa,MAAM,UAAA,CAAW,OAAA,CAAQ;AAAA,UAC1C,aAAa,MAAA,CAAO,WAAA;AAAA,UACpB,OAAA,EAAS,CAAA,kBAAA,EAAqB,MAAA,CAAO,IAAI,CAAA;AAAA,SAC1C,CAAA;AACD,QAAA,OAAO,OAAA,CAAQ;AAAA,UACb,SAAS,UAAA,CAAW,OAAA;AAAA,UACpB,UAAU,OAAA,CAAQ,QAAA;AAAA,UAClB,MAAA,EAAQ,UAAA;AAAA,UACR,OAAO,UAAA,CAAW,KAAA;AAAA,UAClB,UAAA,EAAY,IAAA,CAAK,GAAA,EAAI,GAAI;AAAA,SAC1B,CAAA;AAAA,MACH,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,sBAAsB,CAAA;AAAA,MAC7D;AAAA,IACF,CAAA;AAAA,IAEA,UAAA,EAAY,OAAO,OAAA,KAA2E;AAC5F,MAAA,IAAI;AACF,QAAA,MAAM,KAAA,GAAQ,OAAA,CAAQ,KAAA,CAAM,WAAA,EAAY;AACxC,QAAA,MAAM,UAAyD,EAAC;AAEhE,QAAA,KAAA,MAAW,MAAA,IAAU,cAAA,CAAe,MAAA,EAAO,EAAG;AAC5C,UAAA,IAAI,UAAA,GAAa,CAAA;AACjB,UAAA,MAAM,SAAA,GAAY,MAAA,CAAO,IAAA,CAAK,WAAA,EAAY;AAC1C,UAAA,MAAM,SAAA,GAAY,MAAA,CAAO,WAAA,CAAY,WAAA,EAAY;AAEjD,UAAA,IAAI,cAAc,KAAA,EAAO;AACvB,YAAA,UAAA,GAAa,CAAA;AAAA,UACf,CAAA,MAAA,IAAW,UAAU,QAAA,CAAS,KAAK,KAAK,KAAA,CAAM,QAAA,CAAS,SAAS,CAAA,EAAG;AACjE,YAAA,UAAA,GAAa,GAAA;AAAA,UACf,CAAA,MAAA,IAAW,SAAA,CAAU,QAAA,CAAS,KAAK,CAAA,EAAG;AACpC,YAAA,UAAA,GAAa,GAAA;AAAA,UACf,CAAA,MAAA,IAAW,MAAA,CAAO,IAAA,EAAM,IAAA,CAAK,CAAC,CAAA,KAAM,CAAA,CAAE,WAAA,EAAY,CAAE,QAAA,CAAS,KAAK,CAAC,CAAA,EAAG;AACpE,YAAA,UAAA,GAAa,GAAA;AAAA,UACf;AAEA,UAAA,IAAI,aAAa,CAAA,EAAG;AAClB,YAAA,OAAA,CAAQ,IAAA,CAAK,EAAE,MAAA,EAAQ,UAAA,EAAY,CAAA;AAAA,UACrC;AAAA,QACF;AAEA,QAAA,OAAA,CAAQ,KAAK,CAAC,CAAA,EAAG,MAAM,CAAA,CAAE,UAAA,GAAa,EAAE,UAAU,CAAA;AAClD,QAAA,OAAO,OAAA,CAAQ,EAAE,OAAA,EAAS,OAAA,EAAS,CAAA;AAAA,MACrC,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,mBAAmB,CAAA;AAAA,MAC1D;AAAA,IACF,CAAA;AAAA,IAEA,aAAa,YAA4C;AACvD,MAAA,IAAI;AACF,QAAA,OAAO,QAAQ,KAAA,CAAM,IAAA,CAAK,cAAA,CAAe,MAAA,EAAQ,CAAC,CAAA;AAAA,MACpD,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,oBAAoB,CAAA;AAAA,MAC3D;AAAA,IACF,CAAA;AAAA,IAEA,cAAA,EAAgB,OAAO,MAAA,KAAiD;AACtE,MAAA,IAAI;AACF,QAAA,cAAA,CAAe,GAAA,CAAI,MAAA,CAAO,EAAA,EAAI,MAAM,CAAA;AACpC,QAAA,OAAO,QAAQ,MAAM,CAAA;AAAA,MACvB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,uBAAuB,CAAA;AAAA,MAC9D;AAAA,IACF,CAAA;AAAA,IAEA,sBAAA,EAAwB,OAAO,OAAA,KAGoB;AACjD,MAAA,MAAM,SAAA,GAAY,KAAK,GAAA,EAAI;AAC3B,MAAA,IAAI;AACF,QAAA,eAAA,EAAgB;AAEhB,QAAA,MAAM,KAAA,GAAQ,OAAA,CAAQ,KAAA,CAAM,WAAA,EAAY;AACxC,QAAA,IAAI,UAAA,GAA4B,IAAA;AAChC,QAAA,IAAI,cAAA,GAAiB,CAAA;AAErB,QAAA,KAAA,MAAW,MAAA,IAAU,cAAA,CAAe,MAAA,EAAO,EAAG;AAC5C,UAAA,IAAI,UAAA,GAAa,CAAA;AACjB,UAAA,MAAM,SAAA,GAAY,MAAA,CAAO,IAAA,CAAK,WAAA,EAAY;AAC1C,UAAA,MAAM,SAAA,GAAY,MAAA,CAAO,WAAA,CAAY,WAAA,EAAY;AAEjD,UAAA,IAAI,cAAc,KAAA,EAAO;AACvB,YAAA,UAAA,GAAa,CAAA;AAAA,UACf,CAAA,MAAA,IAAW,UAAU,QAAA,CAAS,KAAK,KAAK,KAAA,CAAM,QAAA,CAAS,SAAS,CAAA,EAAG;AACjE,YAAA,UAAA,GAAa,GAAA;AAAA,UACf,CAAA,MAAA,IAAW,SAAA,CAAU,QAAA,CAAS,KAAK,CAAA,EAAG;AACpC,YAAA,UAAA,GAAa,GAAA;AAAA,UACf;AAEA,UAAA,IAAI,aAAa,cAAA,EAAgB;AAC/B,YAAA,cAAA,GAAiB,UAAA;AACjB,YAAA,UAAA,GAAa,MAAA;AAAA,UACf;AAAA,QACF;AAEA,QAAA,IAAI,CAAC,UAAA,EAAY;AACf,UAAA,OAAO,OAAA,CAAQ;AAAA,YACb,OAAA,EAAS,KAAA;AAAA,YACT,QAAA,EAAU,EAAA;AAAA,YACV,KAAA,EAAO,CAAA,gCAAA,EAAmC,OAAA,CAAQ,KAAK,CAAA,CAAA;AAAA,YACvD,UAAA,EAAY,IAAA,CAAK,GAAA,EAAI,GAAI;AAAA,WAC1B,CAAA;AAAA,QACH;AAEA,QAAA,MAAM,UAAA,GAAa,MAAM,UAAA,CAAW,OAAA,CAAQ;AAAA,UAC1C,aAAa,UAAA,CAAW,WAAA;AAAA,UACxB,OAAA,EAAS,CAAA,6BAAA,EAAgC,OAAA,CAAQ,KAAK,CAAA;AAAA,SACvD,CAAA;AAED,QAAA,OAAO,OAAA,CAAQ;AAAA,UACb,SAAS,UAAA,CAAW,OAAA;AAAA,UACpB,UAAU,UAAA,CAAW,EAAA;AAAA,UACrB,MAAA,EAAQ,UAAA;AAAA,UACR,OAAO,UAAA,CAAW,KAAA;AAAA,UAClB,UAAA,EAAY,IAAA,CAAK,GAAA,EAAI,GAAI;AAAA,SAC1B,CAAA;AAAA,MACH,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,iCAAiC,CAAA;AAAA,MACxE;AAAA,IACF,CAAA;AAAA;AAAA;AAAA;AAAA,IAMA,eAAA,EAAiB,OACf,OAAA,KACgD;AAChD,MAAA,MAAM,SAAA,GAAY,KAAK,GAAA,EAAI;AAC3B,MAAA,IAAI;AACF,QAAA,eAAA,EAAgB;AAChB,QAAA,MAAM,sBAAgC,EAAC;AACvC,QAAA,IAAI,UAAA;AAGJ,QAAA,MAAM,WAAA,GAAc,OAAA,CAAQ,OAAA,CAAQ,gBAAA,IAAoB,EAAC;AAEzD,QAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,IAAA,CAAK,GAAA,CAAI,YAAY,MAAA,EAAQ,OAAA,CAAQ,UAAU,CAAA,EAAG,CAAA,EAAA,EAAK;AACzE,UAAA,MAAM,UAAA,GAAa,YAAY,CAAC,CAAA;AAChC,UAAA,mBAAA,CAAoB,IAAA,CAAK,UAAA,CAAW,UAAA,IAAc,CAAA,SAAA,EAAY,CAAC,CAAA,CAAE,CAAA;AAGjE,UAAA,MAAM,WAAA,GAAc,UAAA,CAAW,OAAA,IAAW,OAAA,CAAQ,WAAA;AAClD,UAAA,IAAI;AACF,YAAA,MAAM,MAAA,GAAS,MAAM,UAAA,CAAW,OAAA,CAAQ;AAAA,cACtC,WAAA;AAAA,cACA,SAAS,CAAA,iBAAA,EAAoB,CAAA,GAAI,CAAC,CAAA,EAAA,EAAK,WAAW,UAAU,CAAA;AAAA,aAC7D,CAAA;AACD,YAAA,UAAA,GAAa,MAAA;AAEb,YAAA,IAAI,OAAO,OAAA,EAAS;AAClB,cAAA,OAAO,OAAA,CAAQ;AAAA,gBACb,SAAA,EAAW,IAAA;AAAA,gBACX,mBAAA;AAAA,gBACA,WAAA,EAAa,MAAA;AAAA,gBACb,UAAA,EAAY,IAAA,CAAK,GAAA,EAAI,GAAI;AAAA,eAC1B,CAAA;AAAA,YACH;AAAA,UACF,CAAA,CAAA,MAAQ;AAAA,UAER;AAAA,QACF;AAGA,QAAA,IAAI,mBAAA,CAAoB,MAAA,KAAW,CAAA,IAAK,CAAC,YAAY,OAAA,EAAS;AAC5D,UAAA,mBAAA,CAAoB,KAAK,oBAAoB,CAAA;AAC7C,UAAA,IAAI;AACF,YAAA,MAAM,MAAA,GAAS,MAAM,UAAA,CAAW,OAAA,CAAQ;AAAA,cACtC,aAAa,OAAA,CAAQ,WAAA;AAAA,cACrB,OAAA,EAAS;AAAA,aACV,CAAA;AACD,YAAA,UAAA,GAAa,MAAA;AAEb,YAAA,IAAI,OAAO,OAAA,EAAS;AAClB,cAAA,OAAO,OAAA,CAAQ;AAAA,gBACb,SAAA,EAAW,IAAA;AAAA,gBACX,mBAAA;AAAA,gBACA,WAAA,EAAa,MAAA;AAAA,gBACb,UAAA,EAAY,IAAA,CAAK,GAAA,EAAI,GAAI;AAAA,eAC1B,CAAA;AAAA,YACH;AAAA,UACF,CAAA,CAAA,MAAQ;AAAA,UAER;AAAA,QACF;AAEA,QAAA,OAAO,OAAA,CAAQ;AAAA,UACb,SAAA,EAAW,KAAA;AAAA,UACX,mBAAA;AAAA,UACA,WAAA,EAAa,UAAA;AAAA,UACb,KAAA,EAAO,mCAAA;AAAA,UACP,UAAA,EAAY,IAAA,CAAK,GAAA,EAAI,GAAI;AAAA,SAC1B,CAAA;AAAA,MACH,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,gBAAgB,CAAA;AAAA,MACvD;AAAA,IACF,CAAA;AAAA;AAAA;AAAA;AAAA,IAMA,iBAAiB,YAA+C;AAC9D,MAAA,IAAI;AACF,QAAA,MAAM,eAAA,GAAkB,SAAS,cAAA,EAAe;AAChD,QAAA,MAAM,QAAA,GAAW,eAAA,CAAgB,cAAA,CAAe,eAAe,CAAA;AAC/D,QAAA,MAAM,MAAA,GAAS,eAAA,CAAgB,QAAA,CAAS,QAAQ,CAAA;AAChD,QAAA,OAAO,QAAQ,MAAM,CAAA;AAAA,MACvB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,oBAAoB,CAAA;AAAA,MAC3D;AAAA,IACF,CAAA;AAAA,IAEA,oBAAoB,YAAiD;AACnE,MAAA,IAAI;AACF,QAAA,MAAM,eAAA,GAAkB,SAAS,cAAA,EAAe;AAChD,QAAA,MAAM,QAAA,GAAW,eAAA,CAAgB,cAAA,CAAe,eAAe,CAAA;AAC/D,QAAA,MAAM,MAAA,GAAS,kBAAA,CAAmB,QAAA,CAAS,QAAQ,CAAA;AACnD,QAAA,OAAO,QAAQ,MAAM,CAAA;AAAA,MACvB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,uBAAuB,CAAA;AAAA,MAC9D;AAAA,IACF,CAAA;AAAA,IAEA,uBAAuB,YAA4D;AACjF,MAAA,IAAI;AACF,QAAA,MAAM,eAAA,GAAkB,SAAS,cAAA,EAAe;AAChD,QAAA,MAAM,QAAA,GAAW,eAAA,CAAgB,cAAA,CAAe,eAAe,CAAA;AAC/D,QAAA,MAAM,MAAA,GAAS,qBAAA,CAAsB,QAAA,CAAS,QAAQ,CAAA;AACtD,QAAA,OAAO,QAAQ,MAAM,CAAA;AAAA,MACvB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,+BAA+B,CAAA;AAAA,MACtE;AAAA,IACF,CAAA;AAAA,IAEA,eAAA,EAAiB,OAAO,OAAA,KAK8B;AACpD,MAAA,IAAI;AACF,QAAA,MAAM,aAAA,GAAgB,OAAA,CAAQ,gBAAA,IAAoB,OAAA,CAAQ,gBAAA;AAC1D,QAAA,MAAM,MAAA,GAAS,wBAAA;AAAA,UACb,OAAA,CAAQ,cAAA;AAAA,UACR,OAAA,CAAQ,cAAA;AAAA,UACR,aAAA,GACI;AAAA,YACE,MAAA,EAAQ,EAAE,iBAAA,EAAmB,IAAA,EAAK;AAAA,YAClC,kBAAkB,OAAA,CAAQ,gBAAA;AAAA,YAC1B,kBAAkB,OAAA,CAAQ;AAAA,WAC5B,GACA,KAAA;AAAA,SACN;AACA,QAAA,OAAO,QAAQ,MAAM,CAAA;AAAA,MACvB,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO,KAAA,CAAO,GAAA,CAAc,OAAA,EAAS,yBAAyB,CAAA;AAAA,MAChE;AAAA,IACF,CAAA;AAAA;AAAA;AAAA;AAAA,IAMA,uBAAuB,YAA2C;AAGhE,MAAA,OAAO;AAAA,QACL,OAAA,EAAS,IAAA;AAAA,QACT,IAAA,EAAM,EAAE,UAAA,EAAY,IAAA,EAAM,WAAW,EAAC,EAAG,KAAA,EAAO,EAAC,EAAE;AAAA,QACnD,SAAA,EAAW,KAAK,GAAA;AAAI,OACtB;AAAA,IACF,CAAA;AAAA,IAEA,yBAAyB,YAAwD;AAC/E,MAAA,OAAO,EAAE,OAAA,EAAS,IAAA,EAAM,IAAA,EAAM,EAAE,OAAA,EAAS,IAAA,EAAK,EAAG,SAAA,EAAW,IAAA,CAAK,GAAA,EAAI,EAAE;AAAA,IACzE,CAAA;AAAA,IAEA,gBAAA,EAAkB,OAAO,OAAA,KAIyC;AAChE,MAAA,OAAO,EAAE,OAAA,EAAS,IAAA,EAAM,IAAA,EAAM,EAAE,MAAA,EAAQ,EAAC,EAAG,KAAA,EAAO,CAAA,EAAE,EAAG,SAAA,EAAW,IAAA,CAAK,KAAI,EAAE;AAAA,IAChF;AAAA,GACF;AACF;AAOO,SAAS,gBAAA,CACd,UACA,cAAA,EAUA;AACA,EAAA,MAAM,YAAA,GAAe,IAAI,YAAA,EAAa;AACtC,EAAA,MAAM,UAAA,GAAa,IAAI,gBAAA,EAAiB;AACxC,EAAA,MAAM,iBAAA,GAAoB,IAAI,iBAAA,EAAkB;AAChD,EAAA,MAAM,eAAA,GAAkB,IAAI,uBAAA,EAAwB;AACpD,EAAA,MAAM,WAAA,GAAc,IAAI,mBAAA,EAAoB;AAE5C,EAAA,SAAS,eAAA,GAAwB;AAC/B,IAAA,MAAM,QAAA,GAAW,SAAS,cAAA,EAAe;AACzC,IAAA,YAAA,CAAa,eAAe,QAAiB,CAAA;AAC7C,IAAA,UAAA,CAAW,eAAe,QAAiB,CAAA;AAC3C,IAAA,UAAA,CAAW,kBAAkB,cAAqB,CAAA;AAClD,IAAA,iBAAA,CAAkB,eAAe,QAAiB,CAAA;AAAA,EACpD;AAEA,EAAA,OAAO;AAAA,IACL,QAAA,EAAU,OAAO,QAAA,KAAmE;AAClF,MAAA,IAAI;AACF,QAAA,eAAA,EAAgB;AAChB,QAAA,MAAM,QAAA,GAAW,YAAA,CAAa,MAAA,CAAO,QAAQ,CAAA;AAC7C,QAAA,OAAO,EAAE,SAAS,IAAA,EAAM,IAAA,EAAM,UAAU,SAAA,EAAW,IAAA,CAAK,KAAI,EAAE;AAAA,MAChE,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO;AAAA,UACL,OAAA,EAAS,KAAA;AAAA,UACT,OAAQ,GAAA,CAAc,OAAA;AAAA,UACtB,IAAA,EAAM,iBAAA;AAAA,UACN,SAAA,EAAW,KAAK,GAAA;AAAI,SACtB;AAAA,MACF;AAAA,IACF,CAAA;AAAA,IAEA,SAAA,EAAW,OAAO,OAAA,KAAqE;AACrF,MAAA,IAAI;AACF,QAAA,eAAA,EAAgB;AAChB,QAAA,MAAM,QAAA,GAAW,MAAM,UAAA,CAAW,OAAA,CAAQ,OAAO,CAAA;AACjD,QAAA,OAAO,EAAE,SAAS,IAAA,EAAM,IAAA,EAAM,UAAU,SAAA,EAAW,IAAA,CAAK,KAAI,EAAE;AAAA,MAChE,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO;AAAA,UACL,OAAA,EAAS,KAAA;AAAA,UACT,OAAQ,GAAA,CAAc,OAAA;AAAA,UACtB,IAAA,EAAM,kBAAA;AAAA,UACN,SAAA,EAAW,KAAK,GAAA;AAAI,SACtB;AAAA,MACF;AAAA,IACF,CAAA;AAAA,IAEA,QAAA,EAAU,OAAO,OAAA,KAAqE;AACpF,MAAA,IAAI;AACF,QAAA,eAAA,EAAgB;AAChB,QAAA,MAAM,MAAA,GAAS,MAAM,iBAAA,CAAkB,MAAA,CAAO,OAAO,CAAA;AACrD,QAAA,OAAO,EAAE,SAAS,IAAA,EAAM,IAAA,EAAM,QAAQ,SAAA,EAAW,IAAA,CAAK,KAAI,EAAE;AAAA,MAC9D,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO;AAAA,UACL,OAAA,EAAS,KAAA;AAAA,UACT,OAAQ,GAAA,CAAc,OAAA;AAAA,UACtB,IAAA,EAAM,iBAAA;AAAA,UACN,SAAA,EAAW,KAAK,GAAA;AAAI,SACtB;AAAA,MACF;AAAA,IACF,CAAA;AAAA,IAEA,aAAA,EAAe,OACb,OAAA,KAC+C;AAC/C,MAAA,IAAI;AACF,QAAA,eAAA,EAAgB;AAChB,QAAA,MAAM,MAAA,GAAS,MAAM,iBAAA,CAAkB,WAAA,CAAY,OAAO,CAAA;AAC1D,QAAA,OAAO,EAAE,SAAS,IAAA,EAAM,IAAA,EAAM,QAAQ,SAAA,EAAW,IAAA,CAAK,KAAI,EAAE;AAAA,MAC9D,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO;AAAA,UACL,OAAA,EAAS,KAAA;AAAA,UACT,OAAQ,GAAA,CAAc,OAAA;AAAA,UACtB,IAAA,EAAM,uBAAA;AAAA,UACN,SAAA,EAAW,KAAK,GAAA;AAAI,SACtB;AAAA,MACF;AAAA,IACF,CAAA;AAAA,IAEA,qBAAqB,YAAoD;AACvE,MAAA,IAAI;AACF,QAAA,MAAM,eAAA,GAAkB,SAAS,cAAA,EAAe;AAChD,QAAA,MAAM,QAAA,GAAW,eAAA,CAAgB,cAAA,CAAe,eAAe,CAAA;AAC/D,QAAA,OAAO,EAAE,SAAS,IAAA,EAAM,IAAA,EAAM,UAAU,SAAA,EAAW,IAAA,CAAK,KAAI,EAAE;AAAA,MAChE,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO;AAAA,UACL,OAAA,EAAS,KAAA;AAAA,UACT,OAAQ,GAAA,CAAc,OAAA;AAAA,UACtB,IAAA,EAAM,yBAAA;AAAA,UACN,SAAA,EAAW,KAAK,GAAA;AAAI,SACtB;AAAA,MACF;AAAA,IACF,CAAA;AAAA,IAEA,eAAA,EAAiB,OAAO,MAAA,KAA+D;AACrF,MAAA,IAAI;AACF,QAAA,MAAM,eAAA,GAAkB,SAAS,cAAA,EAAe;AAChD,QAAA,MAAM,eAAA,GAAkB,eAAA,CAAgB,cAAA,CAAe,eAAe,CAAA;AACtE,QAAA,MAAM,IAAA,GAAO,WAAA,CAAY,MAAA,CAAO,eAAe,CAAA;AAC/C,QAAA,OAAO,EAAE,SAAS,IAAA,EAAM,IAAA,EAAM,MAAM,SAAA,EAAW,IAAA,CAAK,KAAI,EAAE;AAAA,MAC5D,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO;AAAA,UACL,OAAA,EAAS,KAAA;AAAA,UACT,OAAQ,GAAA,CAAc,OAAA;AAAA,UACtB,IAAA,EAAM,qBAAA;AAAA,UACN,SAAA,EAAW,KAAK,GAAA;AAAI,SACtB;AAAA,MACF;AAAA,IACF,CAAA;AAAA,IAEA,gBAAgB,YAA0C;AACxD,MAAA,IAAI;AACF,QAAA,MAAM,QAAA,GAAW,SAAS,cAAA,EAAe;AAEzC,QAAA,MAAM,QAAA,GAAW,QAAA,CAAS,QAAA,CAAS,GAAA,CAAI,CAAC,EAAA,MAAQ;AAAA,UAC9C,GAAG,EAAA;AAAA,UACH,WAAA,EAAa,EAAA,CAAG,KAAA,IAAS,EAAA,CAAG,EAAA;AAAA,UAC5B,SAAS,EAAC;AAAA,UACV,kBAAkB,EAAC;AAAA,UACnB,SAAS,EAAA,CAAG,IAAA;AAAA,UACZ,gBAAgB,EAAA,CAAG,KAAA;AAAA,UACnB,UAAA,EAAY;AAAA,SACd,CAAE,CAAA;AACF,QAAA,MAAM,OAAA,GAAU,oBAAoB,QAAQ,CAAA;AAC5C,QAAA,OAAO,EAAE,SAAS,IAAA,EAAM,IAAA,EAAM,SAAS,SAAA,EAAW,IAAA,CAAK,KAAI,EAAE;AAAA,MAC/D,SAAS,GAAA,EAAK;AACZ,QAAA,OAAO;AAAA,UACL,OAAA,EAAS,KAAA;AAAA,UACT,OAAQ,GAAA,CAAc,OAAA;AAAA,UACtB,IAAA,EAAM,oBAAA;AAAA,UACN,SAAA,EAAW,KAAK,GAAA;AAAI,SACtB;AAAA,MACF;AAAA,IACF;AAAA,GACF;AACF","file":"handlers.js","sourcesContent":["/**\n * Fuzzy Matcher\n *\n * Provides fuzzy text matching utilities for finding elements by natural language descriptions.\n * Implements multiple matching algorithms with configurable thresholds.\n */\n\n/**\n * Configuration for fuzzy matching\n */\nexport interface FuzzyMatchConfig {\n /** Minimum similarity threshold (0-1) */\n threshold: number;\n /** Weight for Levenshtein distance */\n levenshteinWeight: number;\n /** Weight for Jaro-Winkler similarity */\n jaroWinklerWeight: number;\n /** Weight for N-gram matching */\n ngramWeight: number;\n /** N-gram size */\n ngramSize: number;\n /** Case sensitive matching */\n caseSensitive: boolean;\n /** Ignore whitespace differences */\n ignoreWhitespace: boolean;\n}\n\n/**\n * Default fuzzy match configuration\n */\nexport const DEFAULT_FUZZY_CONFIG: FuzzyMatchConfig = {\n threshold: 0.7,\n levenshteinWeight: 0.3,\n jaroWinklerWeight: 0.4,\n ngramWeight: 0.3,\n ngramSize: 2,\n caseSensitive: false,\n ignoreWhitespace: true,\n};\n\n/**\n * Result from a fuzzy match operation\n */\nexport interface FuzzyMatchResult {\n /** Overall similarity score (0-1) */\n similarity: number;\n /** Whether the match passes the threshold */\n isMatch: boolean;\n /** Individual algorithm scores */\n scores: {\n levenshtein: number;\n jaroWinkler: number;\n ngram: number;\n };\n /** Normalized source string */\n normalizedSource: string;\n /** Normalized target string */\n normalizedTarget: string;\n}\n\n/**\n * Calculate Levenshtein distance between two strings\n */\nexport function levenshteinDistance(s1: string, s2: string): number {\n const len1 = s1.length;\n const len2 = s2.length;\n\n // Create distance matrix\n const matrix: number[][] = Array(len1 + 1)\n .fill(null)\n .map(() => Array(len2 + 1).fill(0));\n\n // Initialize first column and row\n for (let i = 0; i <= len1; i++) matrix[i][0] = i;\n for (let j = 0; j <= len2; j++) matrix[0][j] = j;\n\n // Fill in the rest of the matrix\n for (let i = 1; i <= len1; i++) {\n for (let j = 1; j <= len2; j++) {\n const cost = s1[i - 1] === s2[j - 1] ? 0 : 1;\n matrix[i][j] = Math.min(\n matrix[i - 1][j] + 1, // deletion\n matrix[i][j - 1] + 1, // insertion\n matrix[i - 1][j - 1] + cost // substitution\n );\n }\n }\n\n return matrix[len1][len2];\n}\n\n/**\n * Calculate Levenshtein similarity (0-1)\n */\nexport function levenshteinSimilarity(s1: string, s2: string): number {\n if (s1.length === 0 && s2.length === 0) return 1;\n if (s1.length === 0 || s2.length === 0) return 0;\n\n const distance = levenshteinDistance(s1, s2);\n const maxLength = Math.max(s1.length, s2.length);\n\n return 1 - distance / maxLength;\n}\n\n/**\n * Calculate Jaro similarity between two strings\n */\nexport function jaroSimilarity(s1: string, s2: string): number {\n if (s1.length === 0 && s2.length === 0) return 1;\n if (s1.length === 0 || s2.length === 0) return 0;\n\n const matchDistance = Math.floor(Math.max(s1.length, s2.length) / 2) - 1;\n const s1Matches = new Array(s1.length).fill(false);\n const s2Matches = new Array(s2.length).fill(false);\n\n let matches = 0;\n let transpositions = 0;\n\n // Find matches\n for (let i = 0; i < s1.length; i++) {\n const start = Math.max(0, i - matchDistance);\n const end = Math.min(i + matchDistance + 1, s2.length);\n\n for (let j = start; j < end; j++) {\n if (s2Matches[j] || s1[i] !== s2[j]) continue;\n s1Matches[i] = true;\n s2Matches[j] = true;\n matches++;\n break;\n }\n }\n\n if (matches === 0) return 0;\n\n // Count transpositions\n let k = 0;\n for (let i = 0; i < s1.length; i++) {\n if (!s1Matches[i]) continue;\n while (!s2Matches[k]) k++;\n if (s1[i] !== s2[k]) transpositions++;\n k++;\n }\n\n return (matches / s1.length + matches / s2.length + (matches - transpositions / 2) / matches) / 3;\n}\n\n/**\n * Calculate Jaro-Winkler similarity\n * Gives more weight to strings that match from the beginning\n */\nexport function jaroWinklerSimilarity(s1: string, s2: string, prefixScale: number = 0.1): number {\n const jaroSim = jaroSimilarity(s1, s2);\n\n // Find common prefix (up to 4 characters)\n let prefixLength = 0;\n const maxPrefix = Math.min(4, Math.min(s1.length, s2.length));\n\n for (let i = 0; i < maxPrefix; i++) {\n if (s1[i] === s2[i]) {\n prefixLength++;\n } else {\n break;\n }\n }\n\n return jaroSim + prefixLength * prefixScale * (1 - jaroSim);\n}\n\n/**\n * Generate N-grams from a string\n */\nexport function generateNgrams(s: string, n: number): Set<string> {\n const ngrams = new Set<string>();\n\n if (s.length < n) {\n ngrams.add(s);\n return ngrams;\n }\n\n for (let i = 0; i <= s.length - n; i++) {\n ngrams.add(s.substring(i, i + n));\n }\n\n return ngrams;\n}\n\n/**\n * Calculate N-gram similarity (Jaccard coefficient)\n */\nexport function ngramSimilarity(s1: string, s2: string, n: number = 2): number {\n if (s1.length === 0 && s2.length === 0) return 1;\n if (s1.length === 0 || s2.length === 0) return 0;\n\n const ngrams1 = generateNgrams(s1, n);\n const ngrams2 = generateNgrams(s2, n);\n\n // Calculate intersection\n let intersection = 0;\n for (const ngram of ngrams1) {\n if (ngrams2.has(ngram)) {\n intersection++;\n }\n }\n\n // Jaccard coefficient: |A ∩ B| / |A ∪ B|\n const union = ngrams1.size + ngrams2.size - intersection;\n\n return union === 0 ? 0 : intersection / union;\n}\n\n/**\n * Normalize a string for comparison\n */\nexport function normalizeString(s: string, config: Partial<FuzzyMatchConfig> = {}): string {\n let normalized = s;\n\n // Handle case sensitivity\n if (!config.caseSensitive) {\n normalized = normalized.toLowerCase();\n }\n\n // Handle whitespace\n if (config.ignoreWhitespace !== false) {\n normalized = normalized.replace(/\\s+/g, ' ').trim();\n }\n\n return normalized;\n}\n\n/**\n * Main fuzzy match function\n * Combines multiple algorithms for robust matching\n */\nexport function fuzzyMatch(\n source: string,\n target: string,\n config: Partial<FuzzyMatchConfig> = {}\n): FuzzyMatchResult {\n const finalConfig = { ...DEFAULT_FUZZY_CONFIG, ...config };\n\n // Normalize strings\n const normalizedSource = normalizeString(source, finalConfig);\n const normalizedTarget = normalizeString(target, finalConfig);\n\n // Calculate individual scores\n const levenshteinScore = levenshteinSimilarity(normalizedSource, normalizedTarget);\n const jaroWinklerScore = jaroWinklerSimilarity(normalizedSource, normalizedTarget);\n const ngramScore = ngramSimilarity(normalizedSource, normalizedTarget, finalConfig.ngramSize);\n\n // Weighted combination\n const similarity =\n levenshteinScore * finalConfig.levenshteinWeight +\n jaroWinklerScore * finalConfig.jaroWinklerWeight +\n ngramScore * finalConfig.ngramWeight;\n\n return {\n similarity,\n isMatch: similarity >= finalConfig.threshold,\n scores: {\n levenshtein: levenshteinScore,\n jaroWinkler: jaroWinklerScore,\n ngram: ngramScore,\n },\n normalizedSource,\n normalizedTarget,\n };\n}\n\n/**\n * Find the best match from a list of candidates\n */\nexport function findBestMatch(\n source: string,\n candidates: string[],\n config: Partial<FuzzyMatchConfig> = {}\n): { match: string | null; index: number; result: FuzzyMatchResult | null } {\n if (candidates.length === 0) {\n return { match: null, index: -1, result: null };\n }\n\n let bestMatch: string | null = null;\n let bestIndex = -1;\n let bestResult: FuzzyMatchResult | null = null;\n\n for (let i = 0; i < candidates.length; i++) {\n const result = fuzzyMatch(source, candidates[i], config);\n\n if (result.isMatch && (!bestResult || result.similarity > bestResult.similarity)) {\n bestMatch = candidates[i];\n bestIndex = i;\n bestResult = result;\n }\n }\n\n return { match: bestMatch, index: bestIndex, result: bestResult };\n}\n\n/**\n * Find all matches above threshold\n */\nexport function findAllMatches(\n source: string,\n candidates: string[],\n config: Partial<FuzzyMatchConfig> = {}\n): Array<{ candidate: string; index: number; result: FuzzyMatchResult }> {\n const matches: Array<{ candidate: string; index: number; result: FuzzyMatchResult }> = [];\n\n for (let i = 0; i < candidates.length; i++) {\n const result = fuzzyMatch(source, candidates[i], config);\n\n if (result.isMatch) {\n matches.push({ candidate: candidates[i], index: i, result });\n }\n }\n\n // Sort by similarity descending\n matches.sort((a, b) => b.result.similarity - a.result.similarity);\n\n return matches;\n}\n\n/**\n * Check if source contains target (fuzzy)\n */\nexport function fuzzyContains(\n source: string,\n target: string,\n config: Partial<FuzzyMatchConfig> = {}\n): boolean {\n const finalConfig = { ...DEFAULT_FUZZY_CONFIG, ...config };\n const normalizedSource = normalizeString(source, finalConfig);\n const normalizedTarget = normalizeString(target, finalConfig);\n\n // Exact contains check\n if (normalizedSource.includes(normalizedTarget)) {\n return true;\n }\n\n // Word-by-word fuzzy check\n const sourceWords = normalizedSource.split(/\\s+/);\n const targetWords = normalizedTarget.split(/\\s+/);\n\n // All target words must have a fuzzy match in source\n for (const targetWord of targetWords) {\n const hasMatch = sourceWords.some((sourceWord) => {\n const result = fuzzyMatch(sourceWord, targetWord, { ...finalConfig, threshold: 0.8 });\n return result.isMatch;\n });\n\n if (!hasMatch) {\n return false;\n }\n }\n\n return true;\n}\n\n/**\n * Calculate word-level similarity\n * Useful for comparing phrases\n */\nexport function wordSimilarity(\n s1: string,\n s2: string,\n config: Partial<FuzzyMatchConfig> = {}\n): number {\n const finalConfig = { ...DEFAULT_FUZZY_CONFIG, ...config };\n const words1 = normalizeString(s1, finalConfig).split(/\\s+/);\n const words2 = normalizeString(s2, finalConfig).split(/\\s+/);\n\n if (words1.length === 0 && words2.length === 0) return 1;\n if (words1.length === 0 || words2.length === 0) return 0;\n\n let totalSimilarity = 0;\n let matchCount = 0;\n\n // For each word in s1, find best match in s2\n for (const word1 of words1) {\n let bestSim = 0;\n for (const word2 of words2) {\n const result = fuzzyMatch(word1, word2, finalConfig);\n if (result.similarity > bestSim) {\n bestSim = result.similarity;\n }\n }\n totalSimilarity += bestSim;\n if (bestSim >= finalConfig.threshold) {\n matchCount++;\n }\n }\n\n // Return combination of average similarity and match ratio\n const avgSimilarity = totalSimilarity / words1.length;\n const matchRatio = matchCount / Math.max(words1.length, words2.length);\n\n return avgSimilarity * 0.5 + matchRatio * 0.5;\n}\n\n/**\n * Tokenize a string for matching\n * Handles camelCase, PascalCase, snake_case, kebab-case\n */\nexport function tokenize(s: string): string[] {\n return (\n s\n // Split camelCase and PascalCase\n .replace(/([a-z])([A-Z])/g, '$1 $2')\n // Split snake_case and kebab-case\n .replace(/[_-]/g, ' ')\n // Normalize whitespace\n .replace(/\\s+/g, ' ')\n .trim()\n .toLowerCase()\n .split(' ')\n .filter((token) => token.length > 0)\n );\n}\n\n/**\n * Calculate token-based similarity\n * Better for matching identifiers and labels\n */\nexport function tokenSimilarity(s1: string, s2: string): number {\n const tokens1 = tokenize(s1);\n const tokens2 = tokenize(s2);\n\n if (tokens1.length === 0 && tokens2.length === 0) return 1;\n if (tokens1.length === 0 || tokens2.length === 0) return 0;\n\n const set1 = new Set(tokens1);\n const set2 = new Set(tokens2);\n\n // Calculate Jaccard similarity on tokens\n let intersection = 0;\n for (const token of set1) {\n if (set2.has(token)) {\n intersection++;\n }\n }\n\n const union = set1.size + set2.size - intersection;\n return union === 0 ? 0 : intersection / union;\n}\n","/**\n * Alias Generator\n *\n * Auto-generates element aliases from visible text, aria-label, placeholders,\n * titles, and common synonyms for natural language matching.\n */\n\nimport { tokenize } from './fuzzy-matcher';\n\n/**\n * Configuration for alias generation\n */\nexport interface AliasGeneratorConfig {\n /** Include text content as alias */\n includeText: boolean;\n /** Include aria-label as alias */\n includeAriaLabel: boolean;\n /** Include placeholder text as alias */\n includePlaceholder: boolean;\n /** Include title attribute as alias */\n includeTitle: boolean;\n /** Include common synonyms */\n includeSynonyms: boolean;\n /** Maximum number of aliases to generate */\n maxAliases: number;\n /** Minimum alias length */\n minLength: number;\n /** Maximum alias length */\n maxLength: number;\n}\n\n/**\n * Default alias generator configuration\n */\nexport const DEFAULT_ALIAS_CONFIG: AliasGeneratorConfig = {\n includeText: true,\n includeAriaLabel: true,\n includePlaceholder: true,\n includeTitle: true,\n includeSynonyms: true,\n maxAliases: 20,\n minLength: 2,\n maxLength: 50,\n};\n\n/**\n * Common synonyms for UI actions and elements\n */\nconst SYNONYMS: Record<string, string[]> = {\n // Submit-related\n submit: ['send', 'go', 'confirm', 'ok', 'apply', 'save', 'done', 'finish'],\n send: ['submit', 'deliver', 'post'],\n save: ['submit', 'store', 'keep', 'apply'],\n cancel: ['close', 'dismiss', 'abort', 'back', 'exit', 'quit', 'nevermind'],\n close: ['cancel', 'dismiss', 'exit', 'x'],\n delete: ['remove', 'trash', 'erase', 'clear', 'destroy'],\n remove: ['delete', 'clear', 'discard'],\n edit: ['modify', 'change', 'update', 'alter'],\n update: ['edit', 'modify', 'save', 'refresh'],\n add: ['create', 'new', 'plus', 'insert'],\n create: ['add', 'new', 'make'],\n search: ['find', 'lookup', 'query', 'filter'],\n find: ['search', 'locate', 'lookup'],\n login: ['signin', 'sign in', 'log in', 'authenticate', 'enter'],\n logout: ['signout', 'sign out', 'log out', 'exit'],\n register: ['signup', 'sign up', 'join', 'create account'],\n next: ['continue', 'forward', 'proceed', 'advance'],\n previous: ['back', 'backward', 'return', 'prior'],\n back: ['previous', 'return', 'backward'],\n start: ['begin', 'launch', 'initiate', 'run', 'execute'],\n stop: ['end', 'halt', 'pause', 'terminate'],\n enable: ['activate', 'turn on', 'switch on'],\n disable: ['deactivate', 'turn off', 'switch off'],\n show: ['display', 'reveal', 'view', 'open'],\n hide: ['conceal', 'collapse', 'close'],\n expand: ['open', 'show', 'unfold', 'reveal'],\n collapse: ['close', 'hide', 'fold', 'minimize'],\n yes: ['ok', 'confirm', 'agree', 'accept'],\n no: ['cancel', 'decline', 'reject', 'deny'],\n help: ['support', 'assistance', 'info', 'information', 'faq'],\n settings: ['preferences', 'options', 'config', 'configuration'],\n profile: ['account', 'user', 'me'],\n download: ['export', 'save', 'get'],\n upload: ['import', 'load', 'attach'],\n refresh: ['reload', 'update', 'sync'],\n copy: ['duplicate', 'clone'],\n paste: ['insert'],\n select: ['choose', 'pick'],\n toggle: ['switch', 'flip'],\n\n // Form fields\n email: ['e-mail', 'mail'],\n password: ['pass', 'pwd', 'secret'],\n username: ['user', 'login', 'account', 'name'],\n firstname: ['first name', 'given name', 'forename'],\n lastname: ['last name', 'surname', 'family name'],\n fullname: ['full name', 'name', 'complete name'],\n phone: ['telephone', 'tel', 'mobile', 'cell'],\n address: ['location', 'street'],\n city: ['town'],\n country: ['nation'],\n zip: ['zipcode', 'postal', 'postal code', 'postcode'],\n\n // Navigation\n home: ['main', 'start', 'dashboard'],\n menu: ['navigation', 'nav'],\n sidebar: ['side bar', 'side panel', 'side menu'],\n};\n\n/**\n * Element type to action word mappings\n */\nconst ELEMENT_ACTION_WORDS: Record<string, string[]> = {\n button: ['button', 'btn', 'click'],\n input: ['input', 'field', 'textbox', 'box'],\n textarea: ['textarea', 'text area', 'text field', 'multiline'],\n select: ['select', 'dropdown', 'combo', 'picker', 'chooser'],\n checkbox: ['checkbox', 'check', 'tick'],\n radio: ['radio', 'option', 'choice'],\n link: ['link', 'anchor', 'href'],\n form: ['form'],\n menu: ['menu'],\n menuitem: ['menu item', 'option'],\n tab: ['tab'],\n dialog: ['dialog', 'modal', 'popup'],\n switch: ['switch', 'toggle'],\n slider: ['slider', 'range'],\n};\n\n/**\n * Normalize text for alias comparison\n */\nfunction normalizeAlias(text: string): string {\n return text\n .toLowerCase()\n .replace(/[^\\w\\s]/g, ' ')\n .replace(/\\s+/g, ' ')\n .trim();\n}\n\n/**\n * Extract words from text, handling various naming conventions\n */\nfunction extractWords(text: string): string[] {\n const tokens = tokenize(text);\n return tokens.filter((t) => t.length >= 2);\n}\n\n/**\n * Generate aliases from text content\n */\nfunction generateTextAliases(\n text: string | null | undefined,\n config: AliasGeneratorConfig\n): string[] {\n if (!text || !config.includeText) return [];\n\n const aliases: string[] = [];\n const normalized = normalizeAlias(text);\n\n // Add full normalized text\n if (normalized.length >= config.minLength && normalized.length <= config.maxLength) {\n aliases.push(normalized);\n }\n\n // Add individual words\n const words = extractWords(text);\n for (const word of words) {\n if (word.length >= config.minLength) {\n aliases.push(word);\n }\n }\n\n // Add word combinations\n if (words.length >= 2 && words.length <= 4) {\n // First two words\n const twoWords = words.slice(0, 2).join(' ');\n if (twoWords.length <= config.maxLength) {\n aliases.push(twoWords);\n }\n\n // Last two words\n if (words.length > 2) {\n const lastTwo = words.slice(-2).join(' ');\n if (lastTwo.length <= config.maxLength) {\n aliases.push(lastTwo);\n }\n }\n }\n\n return aliases;\n}\n\n/**\n * Generate synonyms for given aliases\n */\nfunction generateSynonyms(aliases: string[], config: AliasGeneratorConfig): string[] {\n if (!config.includeSynonyms) return [];\n\n const synonyms: string[] = [];\n\n for (const alias of aliases) {\n const words = alias.toLowerCase().split(/\\s+/);\n\n for (const word of words) {\n if (SYNONYMS[word]) {\n for (const synonym of SYNONYMS[word]) {\n // Replace word with synonym in the alias\n const newAlias = alias.toLowerCase().replace(word, synonym);\n if (newAlias !== alias.toLowerCase()) {\n synonyms.push(newAlias);\n }\n\n // Also add standalone synonym\n if (synonym.length >= config.minLength) {\n synonyms.push(synonym);\n }\n }\n }\n }\n }\n\n return synonyms;\n}\n\n/**\n * Generate element type aliases\n */\nfunction generateTypeAliases(elementType: string): string[] {\n const type = elementType.toLowerCase();\n return ELEMENT_ACTION_WORDS[type] || [type];\n}\n\n/**\n * Interface for element information used in alias generation\n */\nexport interface AliasGeneratorInput {\n /** Element text content */\n textContent?: string | null;\n /** ARIA label */\n ariaLabel?: string | null;\n /** ARIA labelledby resolved text */\n ariaLabelledBy?: string | null;\n /** Placeholder text */\n placeholder?: string | null;\n /** Title attribute */\n title?: string | null;\n /** Element type */\n elementType?: string;\n /** Element tag name */\n tagName?: string;\n /** Input type */\n inputType?: string;\n /** Element ID */\n id?: string | null;\n /** Element name attribute */\n name?: string | null;\n /** Associated label text */\n labelText?: string | null;\n /** Value attribute */\n value?: string | null;\n}\n\n/**\n * Generate aliases for an element\n */\nexport function generateAliases(\n input: AliasGeneratorInput,\n config: Partial<AliasGeneratorConfig> = {}\n): string[] {\n const finalConfig = { ...DEFAULT_ALIAS_CONFIG, ...config };\n const aliasSet = new Set<string>();\n\n // Helper to add alias with deduplication and length checks\n const addAlias = (alias: string) => {\n const normalized = normalizeAlias(alias);\n if (normalized.length >= finalConfig.minLength && normalized.length <= finalConfig.maxLength) {\n aliasSet.add(normalized);\n }\n };\n\n // Helper to add multiple aliases\n const addAliases = (aliases: string[]) => {\n for (const alias of aliases) {\n addAlias(alias);\n }\n };\n\n // Generate from text content\n if (finalConfig.includeText && input.textContent) {\n addAliases(generateTextAliases(input.textContent, finalConfig));\n }\n\n // Generate from ARIA label\n if (finalConfig.includeAriaLabel && input.ariaLabel) {\n addAliases(generateTextAliases(input.ariaLabel, finalConfig));\n }\n\n // Generate from ARIA labelledby\n if (finalConfig.includeAriaLabel && input.ariaLabelledBy) {\n addAliases(generateTextAliases(input.ariaLabelledBy, finalConfig));\n }\n\n // Generate from placeholder\n if (finalConfig.includePlaceholder && input.placeholder) {\n addAliases(generateTextAliases(input.placeholder, finalConfig));\n }\n\n // Generate from title\n if (finalConfig.includeTitle && input.title) {\n addAliases(generateTextAliases(input.title, finalConfig));\n }\n\n // Generate from label text\n if (input.labelText) {\n addAliases(generateTextAliases(input.labelText, finalConfig));\n }\n\n // Generate from element ID (often meaningful)\n if (input.id) {\n addAliases(extractWords(input.id));\n }\n\n // Generate from name attribute\n if (input.name) {\n addAliases(extractWords(input.name));\n }\n\n // Generate from value for buttons/submit inputs\n if (\n input.value &&\n (input.elementType === 'button' || input.inputType === 'submit' || input.inputType === 'button')\n ) {\n addAliases(generateTextAliases(input.value, finalConfig));\n }\n\n // Generate type aliases\n if (input.elementType) {\n addAliases(generateTypeAliases(input.elementType));\n }\n\n // Generate input type aliases\n if (input.inputType) {\n addAlias(input.inputType);\n\n // Common input type patterns\n if (input.inputType === 'email') {\n addAliases(['email', 'e-mail', 'email address']);\n } else if (input.inputType === 'password') {\n addAliases(['password', 'pass', 'pwd']);\n } else if (input.inputType === 'tel') {\n addAliases(['phone', 'telephone', 'mobile']);\n } else if (input.inputType === 'url') {\n addAliases(['url', 'website', 'link', 'address']);\n } else if (input.inputType === 'search') {\n addAliases(['search', 'find', 'query']);\n }\n }\n\n // Generate synonyms for all collected aliases\n if (finalConfig.includeSynonyms) {\n const currentAliases = Array.from(aliasSet);\n addAliases(generateSynonyms(currentAliases, finalConfig));\n }\n\n // Convert to array and limit\n let aliases = Array.from(aliasSet);\n\n // Sort by length (shorter = more likely to be useful)\n aliases.sort((a, b) => a.length - b.length);\n\n // Limit number of aliases\n if (aliases.length > finalConfig.maxAliases) {\n aliases = aliases.slice(0, finalConfig.maxAliases);\n }\n\n return aliases;\n}\n\n/**\n * Generate a human-readable description for an element\n */\nexport function generateDescription(input: AliasGeneratorInput): string {\n const parts: string[] = [];\n\n // Determine the best name for the element\n let name =\n input.ariaLabel ||\n input.labelText ||\n input.textContent ||\n input.placeholder ||\n input.title ||\n input.id ||\n input.name;\n\n if (name) {\n name = name.trim();\n // Truncate if too long\n if (name.length > 30) {\n name = name.substring(0, 27) + '...';\n }\n parts.push(`\"${name}\"`);\n }\n\n // Add element type\n const typeWords = ELEMENT_ACTION_WORDS[input.elementType || ''] || [\n input.elementType || 'element',\n ];\n parts.push(typeWords[0]);\n\n // Add input type for inputs\n if (input.inputType && input.inputType !== 'text') {\n parts.push(`(${input.inputType})`);\n }\n\n return parts.join(' ');\n}\n\n/**\n * Content type strings for purpose/action generation\n */\nconst CONTENT_TYPES = new Set([\n 'heading',\n 'paragraph',\n 'list-item',\n 'table-cell',\n 'table-header',\n 'label',\n 'caption',\n 'blockquote',\n 'code-block',\n 'badge',\n 'status-message',\n 'metric-value',\n 'description-text',\n 'nav-text',\n 'content-generic',\n]);\n\n/**\n * Generate a purpose statement for an element\n */\nexport function generatePurpose(input: AliasGeneratorInput): string | undefined {\n const text = (input.textContent || input.ariaLabel || input.title || '').toLowerCase();\n const type = input.elementType?.toLowerCase() || '';\n const inputType = input.inputType?.toLowerCase() || '';\n\n // Content-specific purposes\n if (CONTENT_TYPES.has(type)) {\n switch (type) {\n case 'heading':\n return 'Section heading';\n case 'paragraph':\n return 'Body text content';\n case 'list-item':\n return 'List item';\n case 'table-cell':\n return 'Table data cell';\n case 'table-header':\n return 'Table column header';\n case 'label':\n return 'Field label or definition term';\n case 'caption':\n return 'Figure or table caption';\n case 'blockquote':\n return 'Quoted content';\n case 'code-block':\n return 'Code or preformatted text';\n case 'badge':\n return 'Status badge or tag';\n case 'status-message':\n return 'Dynamic status indicator';\n case 'metric-value':\n return 'Metric or statistic value';\n case 'description-text':\n return 'Description or definition';\n case 'nav-text':\n return 'Navigation label';\n case 'content-generic':\n return 'Text content';\n default:\n return 'Static content';\n }\n }\n\n // Check for common patterns\n if (type === 'button' || inputType === 'submit') {\n if (text.match(/submit|send|save|confirm|ok|done|finish|apply/)) {\n return 'Submits the form';\n }\n if (text.match(/cancel|close|dismiss|back|exit/)) {\n return 'Cancels or closes the current action';\n }\n if (text.match(/delete|remove|trash|clear/)) {\n return 'Deletes or removes an item';\n }\n if (text.match(/edit|modify|change|update/)) {\n return 'Edits or modifies an item';\n }\n if (text.match(/add|create|new|\\+/)) {\n return 'Creates or adds a new item';\n }\n if (text.match(/search|find|lookup/)) {\n return 'Performs a search';\n }\n if (text.match(/login|sign.?in/)) {\n return 'Signs the user in';\n }\n if (text.match(/logout|sign.?out/)) {\n return 'Signs the user out';\n }\n if (text.match(/register|sign.?up|join/)) {\n return 'Creates a new account';\n }\n if (text.match(/next|continue|proceed/)) {\n return 'Proceeds to the next step';\n }\n if (text.match(/previous|back|return/)) {\n return 'Returns to the previous step';\n }\n }\n\n if (type === 'input' || type === 'textarea') {\n if (inputType === 'email') return 'Accepts email address input';\n if (inputType === 'password') return 'Accepts password input';\n if (inputType === 'search') return 'Accepts search query input';\n if (inputType === 'tel') return 'Accepts phone number input';\n if (inputType === 'url') return 'Accepts URL input';\n if (inputType === 'number') return 'Accepts numeric input';\n if (inputType === 'date') return 'Accepts date input';\n if (inputType === 'file') return 'Accepts file upload';\n }\n\n if (type === 'checkbox') {\n return 'Toggles an option on or off';\n }\n\n if (type === 'radio') {\n return 'Selects one option from a group';\n }\n\n if (type === 'select') {\n return 'Selects an option from a dropdown';\n }\n\n if (type === 'link') {\n return 'Navigates to another page';\n }\n\n return undefined;\n}\n\n/**\n * Generate suggested actions for an element\n */\nexport function generateSuggestedActions(input: AliasGeneratorInput): string[] {\n const type = input.elementType?.toLowerCase() || '';\n const inputType = input.inputType?.toLowerCase() || '';\n const text = (input.textContent || input.ariaLabel || '').toLowerCase();\n const actions: string[] = [];\n\n // Content elements get read-only actions\n if (CONTENT_TYPES.has(type)) {\n actions.push('read text content', 'verify text matches expected');\n return actions;\n }\n\n switch (type) {\n case 'button':\n actions.push(`click \"${text || 'this button'}\"`);\n break;\n case 'input':\n if (inputType === 'checkbox') {\n actions.push('check to enable', 'uncheck to disable');\n } else if (inputType === 'radio') {\n actions.push('select this option');\n } else {\n actions.push(`type into \"${text || 'this field'}\"`);\n actions.push('clear the field');\n }\n break;\n case 'textarea':\n actions.push(`type into \"${text || 'this text area'}\"`);\n actions.push('clear the content');\n break;\n case 'select':\n actions.push(`select an option from \"${text || 'this dropdown'}\"`);\n break;\n case 'checkbox':\n actions.push('check to enable', 'uncheck to disable');\n break;\n case 'radio':\n actions.push('select this option');\n break;\n case 'link':\n actions.push(`click to navigate to \"${text || 'the linked page'}\"`);\n break;\n case 'switch':\n actions.push('toggle on', 'toggle off');\n break;\n default:\n actions.push('click');\n }\n\n return actions;\n}\n\n/**\n * Get synonyms for a word\n */\nexport function getSynonyms(word: string): string[] {\n const normalized = word.toLowerCase().trim();\n return SYNONYMS[normalized] || [];\n}\n\n/**\n * Check if two words are synonyms\n */\nexport function areSynonyms(word1: string, word2: string): boolean {\n const w1 = word1.toLowerCase().trim();\n const w2 = word2.toLowerCase().trim();\n\n if (w1 === w2) return true;\n\n const synonyms1 = SYNONYMS[w1] || [];\n const synonyms2 = SYNONYMS[w2] || [];\n\n return synonyms1.includes(w2) || synonyms2.includes(w1);\n}\n","/**\n * Annotation Types\n *\n * Types for the semantic annotation system that allows developers\n * to attach rich human-authored context to UI elements.\n */\n\n/**\n * Annotation for a single UI element.\n *\n * All fields are optional - annotate only what's useful.\n * Annotations provide human-authored semantic context that enriches\n * the UI Bridge's understanding of elements beyond what can be\n * inferred from the DOM alone.\n *\n * @example Basic annotation for a button\n * ```ts\n * const annotation: ElementAnnotation = {\n * description: 'Primary login button',\n * purpose: 'Submits the login form and authenticates the user',\n * tags: ['auth', 'primary-action'],\n * };\n * store.set('login-btn', annotation);\n * ```\n *\n * @example Detailed annotation with relationships and metadata\n * ```ts\n * const annotation: ElementAnnotation = {\n * description: 'Email input field',\n * purpose: 'Collects the user email for authentication',\n * notes: 'Validates email format on blur. Shows inline error below the field.',\n * tags: ['auth', 'form-input', 'required'],\n * relatedElements: ['email-label', 'email-error', 'login-btn'],\n * metadata: { validationPattern: '^[^@]+@[^@]+\\\\.[^@]+$' },\n * author: 'design-team',\n * };\n * ```\n */\nexport interface ElementAnnotation {\n /** Human-readable description of what this element is */\n description?: string;\n /** Why this element exists / what it's for */\n purpose?: string;\n /** Behavioral notes, edge cases, or caveats */\n notes?: string;\n /** Searchable tags for categorization */\n tags?: string[];\n /** IDs of related elements (e.g., a label and its input) */\n relatedElements?: string[];\n /** Arbitrary key-value metadata */\n metadata?: Record<string, unknown>;\n /** Timestamp of last update (auto-set by store) */\n updatedAt?: number;\n /** Author of this annotation */\n author?: string;\n}\n\n/**\n * Annotation configuration file format.\n *\n * This is the import/export format - a JSON file with version and annotations map.\n * Use `AnnotationStore.exportConfig()` to generate this object, and\n * `AnnotationStore.importConfig()` to load it back.\n *\n * @example JSON file format (`annotations.json`)\n * ```json\n * {\n * \"version\": \"1.0.0\",\n * \"annotations\": {\n * \"login-btn\": {\n * \"description\": \"Primary login button\",\n * \"purpose\": \"Submits the login form\",\n * \"tags\": [\"auth\", \"primary-action\"]\n * },\n * \"email-input\": {\n * \"description\": \"Email address input\",\n * \"purpose\": \"Collects user email for authentication\",\n * \"relatedElements\": [\"email-label\", \"email-error\"]\n * }\n * },\n * \"metadata\": {\n * \"appName\": \"MyApp\",\n * \"description\": \"Annotations for the login page\"\n * }\n * }\n * ```\n */\nexport interface AnnotationConfig {\n /** Config format version */\n version: string;\n /** Map of element ID to annotation */\n annotations: Record<string, ElementAnnotation>;\n /** Optional file-level metadata */\n metadata?: {\n appName?: string;\n exportedAt?: number;\n description?: string;\n };\n}\n\n/**\n * Annotation coverage statistics.\n */\nexport interface AnnotationCoverage {\n /** Total elements known to the system */\n totalElements: number;\n /** Elements that have annotations */\n annotatedElements: number;\n /** Coverage as a percentage (0-100) */\n coveragePercent: number;\n /** IDs of annotated elements */\n annotatedIds: string[];\n /** IDs of unannotated elements */\n unannotatedIds: string[];\n /** When this coverage was computed */\n timestamp: number;\n}\n\n/**\n * Event types emitted by the annotation store.\n */\nexport type AnnotationEventType =\n | 'annotation:set'\n | 'annotation:deleted'\n | 'annotation:imported'\n | 'annotation:cleared';\n\n/**\n * Event payload for annotation store events.\n */\nexport interface AnnotationEvent {\n type: AnnotationEventType;\n elementId?: string;\n annotation?: ElementAnnotation;\n count?: number;\n timestamp: number;\n}\n\n/** Current annotation config version */\nexport const ANNOTATION_CONFIG_VERSION = '1.0.0';\n","/**\n * Annotation Store\n *\n * In-memory store for element annotations with CRUD operations,\n * import/export, coverage tracking, and event emission.\n */\n\nimport type {\n ElementAnnotation,\n AnnotationConfig,\n AnnotationCoverage,\n AnnotationEvent,\n} from './types';\nimport { ANNOTATION_CONFIG_VERSION } from './types';\n\n/**\n * Listener function for annotation events.\n */\nexport type AnnotationListener = (event: AnnotationEvent) => void;\n\n/**\n * Annotation Store\n *\n * Stores element annotations in memory with event-driven updates.\n * Provides CRUD operations, import/export, coverage tracking, and\n * an event system for reacting to annotation changes.\n *\n * @example Basic CRUD usage\n * ```ts\n * const store = new AnnotationStore();\n *\n * // Set an annotation\n * store.set('login-btn', {\n * description: 'Primary login button',\n * purpose: 'Submits the login form',\n * tags: ['auth', 'primary-action'],\n * });\n *\n * // Read it back\n * const annotation = store.get('login-btn');\n * console.log(annotation?.description); // 'Primary login button'\n *\n * // Check existence\n * store.has('login-btn'); // true\n *\n * // Delete it\n * store.delete('login-btn'); // true\n * ```\n *\n * @example Import/export workflow\n * ```ts\n * const store = new AnnotationStore();\n *\n * // Import from a config file\n * const config = JSON.parse(fs.readFileSync('annotations.json', 'utf-8'));\n * const count = store.importConfig(config);\n * console.log(`Imported ${count} annotations`);\n *\n * // Export current state\n * const exported = store.exportConfig({ appName: 'MyApp' });\n * fs.writeFileSync('annotations.json', JSON.stringify(exported, null, 2));\n * ```\n *\n * @example Listening for changes\n * ```ts\n * const store = new AnnotationStore();\n *\n * const unsubscribe = store.on((event) => {\n * switch (event.type) {\n * case 'annotation:set':\n * console.log(`Updated: ${event.elementId}`);\n * break;\n * case 'annotation:deleted':\n * console.log(`Deleted: ${event.elementId}`);\n * break;\n * case 'annotation:imported':\n * console.log(`Imported ${event.count} annotations`);\n * break;\n * case 'annotation:cleared':\n * console.log('All annotations cleared');\n * break;\n * }\n * });\n *\n * // Later, stop listening\n * unsubscribe();\n * ```\n */\nexport class AnnotationStore {\n private store = new Map<string, ElementAnnotation>();\n private listeners = new Set<AnnotationListener>();\n\n /**\n * Get an annotation by element ID.\n */\n get(elementId: string): ElementAnnotation | undefined {\n return this.store.get(elementId);\n }\n\n /**\n * Get all annotations as a record.\n */\n getAll(): Record<string, ElementAnnotation> {\n const result: Record<string, ElementAnnotation> = {};\n for (const [id, annotation] of this.store) {\n result[id] = annotation;\n }\n return result;\n }\n\n /**\n * Set an annotation for an element. Auto-sets `updatedAt`.\n */\n set(elementId: string, annotation: ElementAnnotation): void {\n const updated: ElementAnnotation = {\n ...annotation,\n updatedAt: Date.now(),\n };\n this.store.set(elementId, updated);\n this.emit({\n type: 'annotation:set',\n elementId,\n annotation: updated,\n timestamp: Date.now(),\n });\n }\n\n /**\n * Delete an annotation by element ID.\n *\n * @returns true if the annotation existed and was deleted\n */\n delete(elementId: string): boolean {\n const existed = this.store.delete(elementId);\n if (existed) {\n this.emit({\n type: 'annotation:deleted',\n elementId,\n timestamp: Date.now(),\n });\n }\n return existed;\n }\n\n /**\n * Check if an annotation exists for an element.\n */\n has(elementId: string): boolean {\n return this.store.has(elementId);\n }\n\n /**\n * Get the number of stored annotations.\n */\n get count(): number {\n return this.store.size;\n }\n\n /**\n * Clear all annotations.\n */\n clear(): void {\n this.store.clear();\n this.emit({\n type: 'annotation:cleared',\n timestamp: Date.now(),\n });\n }\n\n /**\n * Import annotations from a config object.\n *\n * Merges with existing annotations (new values overwrite per element ID).\n *\n * @returns Number of annotations imported\n *\n * @example\n * ```ts\n * const config: AnnotationConfig = {\n * version: '1.0.0',\n * annotations: {\n * 'btn-1': { description: 'Submit button', tags: ['form'] },\n * 'input-1': { description: 'Name field' },\n * },\n * };\n * const count = store.importConfig(config); // 2\n * ```\n */\n importConfig(config: AnnotationConfig): number {\n let count = 0;\n for (const [id, annotation] of Object.entries(config.annotations)) {\n this.store.set(id, {\n ...annotation,\n updatedAt: annotation.updatedAt ?? Date.now(),\n });\n count++;\n }\n this.emit({\n type: 'annotation:imported',\n count,\n timestamp: Date.now(),\n });\n return count;\n }\n\n /**\n * Export all annotations as a config object.\n *\n * The returned object can be serialized to JSON and saved to a file,\n * then later re-imported with {@link importConfig}.\n *\n * @param metadata - Optional metadata to include (appName, description, etc.)\n * @returns AnnotationConfig with all current annotations\n *\n * @example\n * ```ts\n * const config = store.exportConfig({ appName: 'MyApp' });\n * // config.version === '1.0.0'\n * // config.annotations === { 'btn-1': { ... }, 'input-1': { ... } }\n * // config.metadata === { appName: 'MyApp', exportedAt: 1706900000000 }\n *\n * // Save to file\n * fs.writeFileSync('annotations.json', JSON.stringify(config, null, 2));\n * ```\n */\n exportConfig(metadata?: AnnotationConfig['metadata']): AnnotationConfig {\n return {\n version: ANNOTATION_CONFIG_VERSION,\n annotations: this.getAll(),\n metadata: {\n ...metadata,\n exportedAt: Date.now(),\n },\n };\n }\n\n /**\n * Compute annotation coverage against a set of known element IDs.\n *\n * Compares the store's annotations against the provided list of element IDs\n * to determine what percentage of elements have been annotated.\n *\n * @param allElementIds - Array of all known element IDs in the UI\n * @returns Coverage statistics including percentages and lists of annotated/unannotated IDs\n *\n * @example\n * ```ts\n * store.set('btn-1', { description: 'Submit' });\n * store.set('input-1', { description: 'Name' });\n *\n * const coverage = store.getCoverage(['btn-1', 'input-1', 'input-2', 'link-1']);\n * // coverage.totalElements === 4\n * // coverage.annotatedElements === 2\n * // coverage.coveragePercent === 50\n * // coverage.annotatedIds === ['btn-1', 'input-1']\n * // coverage.unannotatedIds === ['input-2', 'link-1']\n * ```\n */\n getCoverage(allElementIds: string[]): AnnotationCoverage {\n const annotatedIds: string[] = [];\n const unannotatedIds: string[] = [];\n\n for (const id of allElementIds) {\n if (this.store.has(id)) {\n annotatedIds.push(id);\n } else {\n unannotatedIds.push(id);\n }\n }\n\n const total = allElementIds.length;\n return {\n totalElements: total,\n annotatedElements: annotatedIds.length,\n coveragePercent: total > 0 ? (annotatedIds.length / total) * 100 : 0,\n annotatedIds,\n unannotatedIds,\n timestamp: Date.now(),\n };\n }\n\n /**\n * Subscribe to annotation events.\n *\n * The listener is called whenever annotations are set, deleted, imported,\n * or cleared. Returns an unsubscribe function to stop listening.\n *\n * @param listener - Callback function receiving {@link AnnotationEvent} objects\n * @returns Unsubscribe function - call it to remove the listener\n *\n * @example\n * ```ts\n * const unsubscribe = store.on((event) => {\n * if (event.type === 'annotation:set') {\n * console.log(`Element ${event.elementId} annotated:`, event.annotation);\n * }\n * });\n *\n * store.set('btn-1', { description: 'Submit' });\n * // Logs: \"Element btn-1 annotated: { description: 'Submit', updatedAt: ... }\"\n *\n * unsubscribe(); // Stop listening\n * ```\n */\n on(listener: AnnotationListener): () => void {\n this.listeners.add(listener);\n return () => {\n this.listeners.delete(listener);\n };\n }\n\n /**\n * Emit an event to all listeners.\n */\n private emit(event: AnnotationEvent): void {\n for (const listener of this.listeners) {\n try {\n listener(event);\n } catch {\n // Don't let listener errors break the store\n }\n }\n }\n}\n\n// Global singleton\nlet globalStore: AnnotationStore | null = null;\n\n/**\n * Get the global annotation store singleton.\n */\nexport function getGlobalAnnotationStore(): AnnotationStore {\n if (!globalStore) {\n globalStore = new AnnotationStore();\n }\n return globalStore;\n}\n\n/**\n * Reset the global annotation store (primarily for testing).\n */\nexport function resetGlobalAnnotationStore(): void {\n globalStore = null;\n}\n","/**\n * Search Engine\n *\n * Multi-strategy element search using text, role, accessibility,\n * spatial proximity, and fuzzy matching.\n */\n\nimport type { RegisteredElement, ElementState } from '../core/types';\nimport type { DiscoveredElement } from '../control/types';\nimport type { SearchCriteria, SearchResult, SearchResponse, AIDiscoveredElement } from './types';\nimport {\n fuzzyMatch,\n fuzzyContains,\n wordSimilarity,\n tokenSimilarity,\n DEFAULT_FUZZY_CONFIG,\n} from './fuzzy-matcher';\nimport {\n generateAliases,\n generateDescription,\n generatePurpose,\n generateSuggestedActions,\n areSynonyms,\n} from './alias-generator';\nimport { getGlobalAnnotationStore } from '../annotations';\n\n/**\n * Configuration for the search engine\n */\nexport interface SearchEngineConfig {\n /** Default fuzzy threshold */\n fuzzyThreshold: number;\n /** Weight for text matching */\n textWeight: number;\n /** Weight for accessibility matching */\n accessibilityWeight: number;\n /** Weight for role matching */\n roleWeight: number;\n /** Weight for spatial matching */\n spatialWeight: number;\n /** Weight for alias matching */\n aliasWeight: number;\n /** Maximum results to return */\n maxResults: number;\n /** Include hidden elements */\n includeHidden: boolean;\n}\n\n/**\n * Default search engine configuration\n */\nexport const DEFAULT_SEARCH_CONFIG: SearchEngineConfig = {\n fuzzyThreshold: 0.7,\n textWeight: 0.35,\n accessibilityWeight: 0.25,\n roleWeight: 0.15,\n spatialWeight: 0.1,\n aliasWeight: 0.15,\n maxResults: 20,\n includeHidden: false,\n};\n\n/**\n * Internal element representation for search\n */\ninterface SearchableElement {\n id: string;\n element: DiscoveredElement | RegisteredElement;\n state: ElementState;\n textContent?: string;\n ariaLabel?: string;\n ariaLabelledBy?: string;\n placeholder?: string;\n title?: string;\n role?: string;\n tagName: string;\n type: string;\n aliases: string[];\n description: string;\n rect: ElementState['rect'];\n labelText?: string;\n value?: string;\n}\n\n/**\n * Search Engine class\n */\nexport class SearchEngine {\n private config: SearchEngineConfig;\n private cachedElements: SearchableElement[] = [];\n private cacheTimestamp: number = 0;\n private readonly cacheValidityMs = 100; // Cache valid for 100ms\n\n constructor(config: Partial<SearchEngineConfig> = {}) {\n this.config = { ...DEFAULT_SEARCH_CONFIG, ...config };\n }\n\n /**\n * Update cached elements from various sources\n */\n updateElements(\n elements: Array<DiscoveredElement | RegisteredElement>,\n getState?: (el: RegisteredElement) => ElementState\n ): void {\n this.cachedElements = elements.map((el) => this.toSearchable(el, getState));\n this.cacheTimestamp = Date.now();\n }\n\n /**\n * Convert an element to searchable format\n */\n private toSearchable(\n element: DiscoveredElement | RegisteredElement,\n getState?: (el: RegisteredElement) => ElementState\n ): SearchableElement {\n // Get state depending on element type\n let state: ElementState;\n let textContent: string | undefined;\n let tagName: string;\n let role: string | undefined;\n let ariaLabel: string | undefined;\n let placeholder: string | undefined;\n let title: string | undefined;\n let labelText: string | undefined;\n let value: string | undefined;\n\n if ('getState' in element && typeof element.getState === 'function') {\n // RegisteredElement — prefer getState() data over direct DOM queries\n // to be resilient when DOM refs are stale or inaccessible\n state = getState ? getState(element) : element.getState();\n textContent = state.textContent || undefined;\n\n // Safely extract DOM attributes with fallbacks\n try {\n tagName = element.element.tagName.toLowerCase();\n } catch {\n tagName = element.type || 'unknown';\n }\n\n try {\n role = element.element.getAttribute('role') || undefined;\n ariaLabel = element.element.getAttribute('aria-label') || undefined;\n placeholder = element.element.getAttribute('placeholder') || undefined;\n title = element.element.getAttribute('title') || undefined;\n } catch {\n // DOM access failed — use fallbacks from RegisteredElement metadata\n }\n\n // Use registered label as labelText\n if (!ariaLabel && element.label) {\n ariaLabel = element.label;\n }\n\n try {\n if (element.element.id) {\n const labelEl = document.querySelector(`label[for=\"${element.element.id}\"]`);\n labelText = labelEl?.textContent?.trim() || undefined;\n }\n } catch {\n // label query failed\n }\n if (!labelText && element.label) {\n labelText = element.label;\n }\n\n // Use label as textContent fallback — ensures search can match by label\n if (!textContent && element.label) {\n textContent = element.label;\n }\n\n // Get value for inputs\n try {\n if (\n element.element instanceof HTMLInputElement ||\n element.element instanceof HTMLTextAreaElement ||\n element.element instanceof HTMLSelectElement\n ) {\n value = (element.element as HTMLInputElement).value || undefined;\n }\n } catch {\n value = state.value || undefined;\n }\n } else {\n // DiscoveredElement\n const discovered = element as DiscoveredElement;\n state = discovered.state;\n textContent = state.textContent || undefined;\n tagName = discovered.tagName;\n role = discovered.role || undefined;\n ariaLabel = discovered.accessibleName || undefined;\n // Use label property if available and no other label source\n if (!labelText && (element as { label?: string }).label) {\n labelText = (element as { label?: string }).label;\n }\n }\n\n // Generate aliases and description\n let aliases = generateAliases({\n textContent,\n ariaLabel,\n placeholder,\n title,\n elementType: element.type,\n tagName,\n id: element.id,\n labelText,\n value,\n });\n\n // Merge pre-computed aliases from RegisteredElement if available\n if ('aliases' in element && Array.isArray(element.aliases) && element.aliases.length > 0) {\n const aliasSet = new Set([\n ...aliases,\n ...element.aliases.map((a: string) => a.toLowerCase()),\n ]);\n aliases = [...aliasSet];\n }\n\n let description = generateDescription({\n textContent,\n ariaLabel,\n placeholder,\n title,\n elementType: element.type,\n tagName,\n id: element.id,\n labelText,\n });\n\n // Use pre-computed description from RegisteredElement if available\n if (!description && 'description' in element && element.description) {\n description = element.description as string;\n }\n\n // Merge annotation overrides into searchable data\n const annotation = getGlobalAnnotationStore().get(element.id);\n if (annotation) {\n if (annotation.description) {\n description = annotation.description;\n }\n if (annotation.tags && annotation.tags.length > 0) {\n // Merge tags into aliases\n const tagSet = new Set([...aliases, ...annotation.tags.map((t) => t.toLowerCase())]);\n aliases = [...tagSet];\n }\n if (annotation.notes) {\n // Make notes searchable by adding as an alias\n aliases.push(annotation.notes.toLowerCase());\n }\n }\n\n return {\n id: element.id,\n element,\n state,\n textContent,\n ariaLabel,\n placeholder,\n title,\n role,\n tagName,\n type: element.type,\n aliases,\n description,\n rect: state.rect,\n labelText,\n value,\n };\n }\n\n /**\n * Search for elements matching the criteria\n */\n search(\n criteria: SearchCriteria,\n elements?: Array<DiscoveredElement | RegisteredElement>\n ): SearchResponse {\n const startTime = performance.now();\n\n // Update cache if elements provided or cache expired\n if (elements) {\n this.updateElements(elements);\n }\n\n // Filter visible elements if needed\n let searchableElements = this.cachedElements;\n if (!this.config.includeHidden && !criteria.fuzzy) {\n searchableElements = searchableElements.filter((el) => el.state.visible);\n }\n\n // Score each element\n const results: SearchResult[] = [];\n\n for (const searchable of searchableElements) {\n const result = this.scoreElement(searchable, criteria);\n if (result.confidence >= (criteria.fuzzyThreshold ?? this.config.fuzzyThreshold)) {\n results.push(result);\n }\n }\n\n // Sort by confidence\n results.sort((a, b) => b.confidence - a.confidence);\n\n // Limit results\n const limitedResults = results.slice(0, this.config.maxResults);\n\n return {\n results: limitedResults,\n bestMatch: limitedResults.length > 0 ? limitedResults[0] : null,\n scannedCount: searchableElements.length,\n durationMs: performance.now() - startTime,\n criteria,\n timestamp: Date.now(),\n };\n }\n\n /**\n * Find the best matching element\n */\n findBest(\n criteria: SearchCriteria,\n elements?: Array<DiscoveredElement | RegisteredElement>\n ): SearchResult | null {\n const response = this.search(criteria, elements);\n return response.bestMatch;\n }\n\n /**\n * Find elements by text content\n */\n findByText(\n text: string,\n fuzzy: boolean = true,\n elements?: Array<DiscoveredElement | RegisteredElement>\n ): SearchResult[] {\n return this.search({ text, fuzzy }, elements).results;\n }\n\n /**\n * Find elements by role\n */\n findByRole(\n role: string,\n name?: string,\n elements?: Array<DiscoveredElement | RegisteredElement>\n ): SearchResult[] {\n const criteria: SearchCriteria = { role };\n if (name) {\n criteria.accessibleName = name;\n }\n return this.search(criteria, elements).results;\n }\n\n /**\n * Find elements by accessible name\n */\n findByAccessibleName(\n name: string,\n elements?: Array<DiscoveredElement | RegisteredElement>\n ): SearchResult[] {\n return this.search({ accessibleName: name, fuzzy: true }, elements).results;\n }\n\n /**\n * Find elements near another element\n */\n findNear(\n referenceId: string,\n criteria?: SearchCriteria,\n elements?: Array<DiscoveredElement | RegisteredElement>\n ): SearchResult[] {\n return this.search({ ...criteria, near: referenceId }, elements).results;\n }\n\n /**\n * Find elements within a container\n */\n findWithin(\n containerId: string,\n criteria?: SearchCriteria,\n elements?: Array<DiscoveredElement | RegisteredElement>\n ): SearchResult[] {\n return this.search({ ...criteria, within: containerId }, elements).results;\n }\n\n /**\n * Score an element against search criteria\n */\n private scoreElement(searchable: SearchableElement, criteria: SearchCriteria): SearchResult {\n const scores: SearchResult['scores'] = {};\n const matchReasons: string[] = [];\n let totalWeight = 0;\n let weightedScore = 0;\n\n const fuzzyConfig = {\n ...DEFAULT_FUZZY_CONFIG,\n threshold: criteria.fuzzyThreshold ?? this.config.fuzzyThreshold,\n };\n\n // Text matching\n if (criteria.text) {\n const textScore = this.scoreTextMatch(\n searchable,\n criteria.text,\n criteria.fuzzy !== false,\n fuzzyConfig.threshold\n );\n scores.text = textScore.score;\n if (textScore.score > 0) {\n matchReasons.push(...textScore.reasons);\n }\n weightedScore += textScore.score * this.config.textWeight;\n totalWeight += this.config.textWeight;\n }\n\n // textContent uses both exact and contains matching (best score wins)\n // This is more intuitive for spec assertions where textContent checks\n // if the text is present in the element, not necessarily the entire text.\n // Supports pipe-separated alternatives: \"Connected|Disconnected\" matches either.\n if (criteria.textContent && !criteria.text) {\n // Split on pipe to support alternatives (e.g., \"Connected|Disconnected\")\n const alternatives = criteria.textContent.includes('|')\n ? criteria.textContent\n .split('|')\n .map((s) => s.trim())\n .filter(Boolean)\n : [criteria.textContent];\n\n let bestScore = 0;\n let bestReasons: string[] = [];\n\n for (const alt of alternatives) {\n const exactScore = this.scoreTextMatch(\n searchable,\n alt,\n criteria.fuzzy !== false,\n fuzzyConfig.threshold\n );\n const containsScore = this.scoreContainsMatch(searchable, alt, criteria.fuzzy !== false);\n const altBest = Math.max(exactScore.score, containsScore.score);\n if (altBest > bestScore) {\n bestScore = altBest;\n bestReasons =\n exactScore.score >= containsScore.score ? exactScore.reasons : containsScore.reasons;\n }\n }\n\n scores.text = bestScore;\n if (bestScore > 0) {\n matchReasons.push(...bestReasons);\n }\n weightedScore += bestScore * this.config.textWeight;\n totalWeight += this.config.textWeight;\n }\n\n // Partial text matching (contains)\n if (criteria.textContains) {\n const containsScore = this.scoreContainsMatch(\n searchable,\n criteria.textContains,\n criteria.fuzzy !== false\n );\n scores.text = Math.max(scores.text || 0, containsScore.score);\n if (containsScore.score > 0 && containsScore.reasons.length > 0) {\n matchReasons.push(...containsScore.reasons);\n }\n weightedScore += containsScore.score * this.config.textWeight;\n totalWeight += this.config.textWeight;\n }\n\n // Accessible name matching\n if (criteria.accessibleName) {\n const accessibilityScore = this.scoreAccessibilityMatch(\n searchable,\n criteria.accessibleName,\n criteria.fuzzy !== false,\n fuzzyConfig.threshold\n );\n scores.accessibility = accessibilityScore.score;\n if (accessibilityScore.score > 0) {\n matchReasons.push(...accessibilityScore.reasons);\n }\n weightedScore += accessibilityScore.score * this.config.accessibilityWeight;\n totalWeight += this.config.accessibilityWeight;\n }\n\n // Role matching\n if (criteria.role) {\n const roleScore = this.scoreRoleMatch(searchable, criteria.role);\n scores.role = roleScore.score;\n if (roleScore.score > 0) {\n matchReasons.push(...roleScore.reasons);\n }\n weightedScore += roleScore.score * this.config.roleWeight;\n totalWeight += this.config.roleWeight;\n }\n\n // Type matching\n if (criteria.type) {\n const typeMatch = searchable.type.toLowerCase() === criteria.type.toLowerCase();\n if (typeMatch) {\n matchReasons.push(`type: ${criteria.type}`);\n weightedScore += 1.0 * this.config.roleWeight;\n totalWeight += this.config.roleWeight;\n }\n }\n\n // Spatial matching (near)\n if (criteria.near) {\n const spatialScore = this.scoreSpatialMatch(searchable, criteria.near);\n scores.spatial = spatialScore.score;\n if (spatialScore.score > 0) {\n matchReasons.push(...spatialScore.reasons);\n }\n weightedScore += spatialScore.score * this.config.spatialWeight;\n totalWeight += this.config.spatialWeight;\n }\n\n // Placeholder matching\n if (criteria.placeholder && searchable.placeholder) {\n const placeholderResult = fuzzyMatch(\n searchable.placeholder,\n criteria.placeholder,\n fuzzyConfig\n );\n if (placeholderResult.isMatch) {\n matchReasons.push(`placeholder matches`);\n weightedScore += placeholderResult.similarity * this.config.textWeight;\n totalWeight += this.config.textWeight;\n }\n }\n\n // Title matching\n if (criteria.title && searchable.title) {\n const titleResult = fuzzyMatch(searchable.title, criteria.title, fuzzyConfig);\n if (titleResult.isMatch) {\n matchReasons.push(`title matches`);\n weightedScore += titleResult.similarity * this.config.textWeight;\n totalWeight += this.config.textWeight;\n }\n }\n\n // ID pattern matching\n if (criteria.idPattern) {\n const idMatch = this.matchPattern(searchable.id, criteria.idPattern);\n if (idMatch) {\n matchReasons.push(`id matches pattern`);\n weightedScore += 1.0 * this.config.textWeight;\n totalWeight += this.config.textWeight;\n }\n }\n\n // Alias matching (always applied as a bonus)\n const aliasScore = this.scoreAliasMatch(searchable, criteria, fuzzyConfig.threshold);\n if (aliasScore.score > 0) {\n scores.fuzzy = aliasScore.score;\n matchReasons.push(...aliasScore.reasons);\n weightedScore += aliasScore.score * this.config.aliasWeight;\n totalWeight += this.config.aliasWeight;\n }\n\n // Calculate final confidence\n const confidence = totalWeight > 0 ? weightedScore / totalWeight : 0;\n\n // Convert to AIDiscoveredElement\n const aiElement = this.toAIDiscoveredElement(searchable);\n\n return {\n element: aiElement,\n confidence,\n matchReasons,\n scores,\n };\n }\n\n /**\n * Score text match\n */\n private scoreTextMatch(\n searchable: SearchableElement,\n text: string,\n fuzzy: boolean,\n threshold: number\n ): { score: number; reasons: string[] } {\n const reasons: string[] = [];\n let maxScore = 0;\n\n const textsToMatch = [searchable.textContent, searchable.labelText, searchable.value].filter(\n Boolean\n ) as string[];\n\n for (const targetText of textsToMatch) {\n // Exact match\n if (targetText.toLowerCase() === text.toLowerCase()) {\n maxScore = Math.max(maxScore, 1.0);\n reasons.push('exact text match');\n continue;\n }\n\n // Fuzzy match\n if (fuzzy) {\n const result = fuzzyMatch(targetText, text, { threshold });\n if (result.isMatch && result.similarity > maxScore) {\n maxScore = result.similarity;\n reasons.push(`text similarity: ${(result.similarity * 100).toFixed(0)}%`);\n }\n\n // Word-level match\n const wordSim = wordSimilarity(targetText, text, { threshold });\n if (wordSim > maxScore && wordSim >= threshold) {\n maxScore = wordSim;\n reasons.push(`word match: ${(wordSim * 100).toFixed(0)}%`);\n }\n }\n }\n\n return { score: maxScore, reasons };\n }\n\n /**\n * Score contains match\n */\n private scoreContainsMatch(\n searchable: SearchableElement,\n text: string,\n fuzzy: boolean\n ): { score: number; reasons: string[] } {\n const reasons: string[] = [];\n let maxScore = 0;\n\n const textsToMatch = [\n searchable.textContent,\n searchable.labelText,\n searchable.ariaLabel,\n ].filter(Boolean) as string[];\n\n for (const targetText of textsToMatch) {\n // Exact contains\n if (targetText.toLowerCase().includes(text.toLowerCase())) {\n maxScore = Math.max(maxScore, 0.9);\n reasons.push('text contains match');\n continue;\n }\n\n // Fuzzy contains\n if (fuzzy && fuzzyContains(targetText, text)) {\n maxScore = Math.max(maxScore, 0.7);\n reasons.push('fuzzy contains match');\n }\n }\n\n return { score: maxScore, reasons };\n }\n\n /**\n * Score accessibility match\n */\n private scoreAccessibilityMatch(\n searchable: SearchableElement,\n name: string,\n fuzzy: boolean,\n threshold: number\n ): { score: number; reasons: string[] } {\n const reasons: string[] = [];\n let maxScore = 0;\n\n const accessibleNames = [\n searchable.ariaLabel,\n searchable.ariaLabelledBy,\n searchable.labelText,\n searchable.title,\n ].filter(Boolean) as string[];\n\n for (const accessibleName of accessibleNames) {\n // Exact match\n if (accessibleName.toLowerCase() === name.toLowerCase()) {\n maxScore = Math.max(maxScore, 1.0);\n reasons.push('exact accessible name match');\n continue;\n }\n\n // Fuzzy match\n if (fuzzy) {\n const result = fuzzyMatch(accessibleName, name, { threshold });\n if (result.isMatch && result.similarity > maxScore) {\n maxScore = result.similarity;\n reasons.push(`accessible name similarity: ${(result.similarity * 100).toFixed(0)}%`);\n }\n }\n }\n\n return { score: maxScore, reasons };\n }\n\n /**\n * Score role match\n */\n private scoreRoleMatch(\n searchable: SearchableElement,\n role: string\n ): { score: number; reasons: string[] } {\n const reasons: string[] = [];\n const normalizedRole = role.toLowerCase();\n\n // Direct role match\n if (searchable.role?.toLowerCase() === normalizedRole) {\n return { score: 1.0, reasons: [`role: ${role}`] };\n }\n\n // Tag-based role inference\n const tagRoleMap: Record<string, string[]> = {\n button: ['button', 'input[type=button]', 'input[type=submit]'],\n textbox: ['input', 'textarea'],\n checkbox: ['input[type=checkbox]'],\n radio: ['input[type=radio]'],\n link: ['a'],\n listbox: ['select'],\n combobox: ['select', 'input[list]'],\n navigation: ['nav'],\n main: ['main'],\n heading: ['h1', 'h2', 'h3', 'h4', 'h5', 'h6'],\n };\n\n const inferredRoles = tagRoleMap[normalizedRole] || [];\n if (\n inferredRoles.some(\n (r) => searchable.tagName === r || searchable.type.toLowerCase() === normalizedRole\n )\n ) {\n return { score: 0.8, reasons: [`inferred role: ${role}`] };\n }\n\n return { score: 0, reasons };\n }\n\n /**\n * Score spatial match (proximity to another element)\n */\n private scoreSpatialMatch(\n searchable: SearchableElement,\n nearId: string\n ): { score: number; reasons: string[] } {\n // Find the reference element\n const reference = this.cachedElements.find((el) => el.id === nearId);\n if (!reference) {\n return { score: 0, reasons: [] };\n }\n\n // Calculate distance between elements\n const distance = this.calculateDistance(searchable.rect, reference.rect);\n\n // Score based on distance (closer = higher score)\n // Assuming 200px as \"near\" threshold\n const nearThreshold = 200;\n if (distance > nearThreshold * 3) {\n return { score: 0, reasons: [] };\n }\n\n const score = Math.max(0, 1 - distance / (nearThreshold * 3));\n return {\n score,\n reasons: [`${distance.toFixed(0)}px from ${nearId}`],\n };\n }\n\n /**\n * Calculate distance between two element rectangles\n */\n private calculateDistance(rect1: ElementState['rect'], rect2: ElementState['rect']): number {\n const center1 = {\n x: rect1.x + rect1.width / 2,\n y: rect1.y + rect1.height / 2,\n };\n const center2 = {\n x: rect2.x + rect2.width / 2,\n y: rect2.y + rect2.height / 2,\n };\n\n return Math.sqrt(Math.pow(center1.x - center2.x, 2) + Math.pow(center1.y - center2.y, 2));\n }\n\n /**\n * Score alias match\n */\n private scoreAliasMatch(\n searchable: SearchableElement,\n criteria: SearchCriteria,\n threshold: number\n ): { score: number; reasons: string[] } {\n const reasons: string[] = [];\n let maxScore = 0;\n\n // Build search terms from criteria\n const searchTerms: string[] = [];\n if (criteria.text) searchTerms.push(criteria.text);\n if (criteria.textContains) searchTerms.push(criteria.textContains);\n if (criteria.accessibleName) searchTerms.push(criteria.accessibleName);\n\n for (const searchTerm of searchTerms) {\n const termLower = searchTerm.toLowerCase();\n\n for (const alias of searchable.aliases) {\n // Exact alias match\n if (alias === termLower) {\n maxScore = Math.max(maxScore, 1.0);\n reasons.push(`alias match: \"${alias}\"`);\n continue;\n }\n\n // Synonym match\n const searchWords = termLower.split(/\\s+/);\n const aliasWords = alias.split(/\\s+/);\n\n for (const searchWord of searchWords) {\n for (const aliasWord of aliasWords) {\n if (areSynonyms(searchWord, aliasWord)) {\n maxScore = Math.max(maxScore, 0.85);\n reasons.push(`synonym match: \"${searchWord}\" ~ \"${aliasWord}\"`);\n }\n }\n }\n\n // Fuzzy alias match\n const result = fuzzyMatch(alias, termLower, { threshold });\n if (result.isMatch && result.similarity > maxScore) {\n maxScore = result.similarity;\n reasons.push(`fuzzy alias: \"${alias}\" (${(result.similarity * 100).toFixed(0)}%)`);\n }\n\n // Token similarity\n const tokenSim = tokenSimilarity(alias, termLower);\n if (tokenSim > maxScore && tokenSim >= threshold) {\n maxScore = tokenSim;\n reasons.push(`token match: \"${alias}\"`);\n }\n }\n }\n\n return { score: maxScore, reasons };\n }\n\n /**\n * Match a string against a pattern (supports * wildcard)\n */\n private matchPattern(str: string, pattern: string): boolean {\n const regexPattern = pattern.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&').replace(/\\\\\\*/g, '.*');\n return new RegExp(`^${regexPattern}$`, 'i').test(str);\n }\n\n /**\n * Convert searchable element to AI discovered element\n */\n private toAIDiscoveredElement(searchable: SearchableElement): AIDiscoveredElement {\n const discoveredBase: DiscoveredElement =\n 'getState' in searchable.element\n ? {\n id: searchable.id,\n type: searchable.type,\n label: (searchable.element as RegisteredElement).label,\n tagName: searchable.tagName,\n role: searchable.role,\n accessibleName: searchable.ariaLabel,\n actions: (searchable.element as RegisteredElement).actions,\n state: searchable.state,\n registered: true,\n }\n : (searchable.element as DiscoveredElement);\n\n return {\n ...discoveredBase,\n description: searchable.description,\n aliases: searchable.aliases,\n purpose: generatePurpose({\n textContent: searchable.textContent,\n ariaLabel: searchable.ariaLabel,\n elementType: searchable.type,\n tagName: searchable.tagName,\n }),\n parentContext: undefined, // Would need DOM traversal\n suggestedActions: generateSuggestedActions({\n textContent: searchable.textContent,\n ariaLabel: searchable.ariaLabel,\n elementType: searchable.type,\n tagName: searchable.tagName,\n }),\n semanticType: this.inferSemanticType(searchable),\n labelText: searchable.labelText,\n placeholder: searchable.placeholder,\n title: searchable.title,\n };\n }\n\n /**\n * Infer a semantic type for the element\n */\n private inferSemanticType(searchable: SearchableElement): string {\n const text = (searchable.textContent || searchable.ariaLabel || '').toLowerCase();\n const type = searchable.type.toLowerCase();\n\n // Form-related\n if (type === 'input' || type === 'textarea') {\n if (searchable.placeholder?.toLowerCase().includes('email') || text.includes('email')) {\n return 'email-input';\n }\n if (searchable.placeholder?.toLowerCase().includes('password') || text.includes('password')) {\n return 'password-input';\n }\n if (searchable.placeholder?.toLowerCase().includes('search') || text.includes('search')) {\n return 'search-input';\n }\n return 'text-input';\n }\n\n // Button types\n if (type === 'button') {\n if (text.match(/submit|save|confirm|ok|done|apply/)) return 'submit-button';\n if (text.match(/cancel|close|dismiss/)) return 'cancel-button';\n if (text.match(/delete|remove|trash/)) return 'delete-button';\n if (text.match(/add|create|new|\\+/)) return 'add-button';\n if (text.match(/edit|modify/)) return 'edit-button';\n if (text.match(/next|continue/)) return 'next-button';\n if (text.match(/back|previous/)) return 'back-button';\n return 'action-button';\n }\n\n // Navigation\n if (type === 'link') {\n if (text.match(/home|dashboard/)) return 'home-link';\n if (text.match(/login|sign.?in/)) return 'login-link';\n if (text.match(/logout|sign.?out/)) return 'logout-link';\n return 'navigation-link';\n }\n\n return type;\n }\n}\n\n/**\n * Create a default search engine instance\n */\nexport function createSearchEngine(config?: Partial<SearchEngineConfig>): SearchEngine {\n return new SearchEngine(config);\n}\n","/**\n * Summary Generator\n *\n * Generates LLM-friendly text summaries of pages and elements\n * for AI agents to understand the current UI state.\n */\n\nimport type {\n AIDiscoveredElement,\n FormAnalysis,\n FormState,\n PageContext,\n SemanticSnapshot,\n} from './types';\n\n/**\n * Configuration for summary generation\n */\nexport interface SummaryConfig {\n /** Maximum summary length in characters */\n maxLength: number;\n /** Include form details */\n includeForms: boolean;\n /** Include element counts */\n includeElementCounts: boolean;\n /** Include active modals */\n includeModals: boolean;\n /** Include focused element */\n includeFocused: boolean;\n /** Verbosity level */\n verbosity: 'brief' | 'normal' | 'detailed';\n}\n\n/**\n * Default summary configuration\n */\nexport const DEFAULT_SUMMARY_CONFIG: SummaryConfig = {\n maxLength: 2000,\n includeForms: true,\n includeElementCounts: true,\n includeModals: true,\n includeFocused: true,\n verbosity: 'normal',\n};\n\n/**\n * Generate a page summary from elements\n */\nexport function generatePageSummary(\n elements: AIDiscoveredElement[],\n pageContext?: Partial<PageContext>,\n config: Partial<SummaryConfig> = {}\n): string {\n const finalConfig = { ...DEFAULT_SUMMARY_CONFIG, ...config };\n const lines: string[] = [];\n\n // Page context\n if (pageContext) {\n if (pageContext.title) {\n lines.push(`Page: \"${pageContext.title}\"`);\n }\n if (pageContext.pageType && pageContext.pageType !== 'unknown') {\n lines.push(`Type: ${formatPageType(pageContext.pageType)}`);\n }\n }\n\n // Element counts\n if (finalConfig.includeElementCounts) {\n const counts = countElementTypes(elements);\n const countParts: string[] = [];\n\n if (counts.button > 0)\n countParts.push(`${counts.button} button${counts.button > 1 ? 's' : ''}`);\n if (counts.input > 0) countParts.push(`${counts.input} input${counts.input > 1 ? 's' : ''}`);\n if (counts.link > 0) countParts.push(`${counts.link} link${counts.link > 1 ? 's' : ''}`);\n if (counts.select > 0)\n countParts.push(`${counts.select} dropdown${counts.select > 1 ? 's' : ''}`);\n if (counts.checkbox > 0)\n countParts.push(`${counts.checkbox} checkbox${counts.checkbox > 1 ? 'es' : ''}`);\n\n if (countParts.length > 0) {\n lines.push(`Contains: ${countParts.join(', ')}`);\n }\n }\n\n // Forms\n if (finalConfig.includeForms) {\n const forms = detectForms(elements);\n if (forms.length > 0) {\n lines.push('');\n lines.push('Forms:');\n for (const form of forms) {\n lines.push(generateFormSummary(form, finalConfig.verbosity));\n }\n }\n }\n\n // Active modals\n if (\n finalConfig.includeModals &&\n pageContext?.activeModals &&\n pageContext.activeModals.length > 0\n ) {\n lines.push('');\n lines.push(`Active modals: ${pageContext.activeModals.join(', ')}`);\n }\n\n // Focused element\n if (finalConfig.includeFocused && pageContext?.focusedElement) {\n lines.push(`Focus: ${pageContext.focusedElement}`);\n }\n\n // Key interactive elements\n const keyElements = getKeyElements(elements);\n if (keyElements.length > 0) {\n lines.push('');\n lines.push('Key elements:');\n for (const el of keyElements) {\n lines.push(` - ${el.description}${el.state.enabled ? '' : ' (disabled)'}`);\n }\n }\n\n // Build final summary\n let summary = lines.join('\\n');\n\n // Truncate if needed\n if (summary.length > finalConfig.maxLength) {\n summary = summary.substring(0, finalConfig.maxLength - 3) + '...';\n }\n\n return summary;\n}\n\n/**\n * Generate an element description\n */\nexport function generateElementDescription(element: AIDiscoveredElement): string {\n const parts: string[] = [];\n\n // Element type and name\n const name = element.accessibleName || element.label || element.state.textContent?.trim();\n if (name) {\n parts.push(`\"${truncate(name, 30)}\"`);\n }\n\n // Type\n parts.push(formatElementType(element.type));\n\n // State indicators\n const stateIndicators: string[] = [];\n if (!element.state.visible) stateIndicators.push('hidden');\n if (!element.state.enabled) stateIndicators.push('disabled');\n if (element.state.focused) stateIndicators.push('focused');\n if (element.state.checked) stateIndicators.push('checked');\n\n if (stateIndicators.length > 0) {\n parts.push(`(${stateIndicators.join(', ')})`);\n }\n\n // Value for inputs\n if (element.state.value && element.type !== 'button') {\n const valuePreview = truncate(element.state.value, 20);\n parts.push(`value: \"${valuePreview}\"`);\n }\n\n return parts.join(' ');\n}\n\n/**\n * Generate a form summary\n */\nfunction generateFormSummary(form: FormAnalysis, verbosity: SummaryConfig['verbosity']): string {\n const lines: string[] = [];\n const formName = form.name || form.purpose || form.id;\n\n lines.push(` ${formName}:`);\n\n if (verbosity === 'brief') {\n const fieldCount = form.fields.length;\n const filledCount = form.fields.filter((f) => f.value).length;\n lines.push(\n ` ${filledCount}/${fieldCount} fields filled, ${form.isValid ? 'valid' : 'has errors'}`\n );\n } else {\n // List fields\n for (const field of form.fields) {\n let fieldLine = ` - ${field.label || field.id}`;\n\n if (field.value) {\n fieldLine += ` = \"${truncate(field.value, 15)}\"`;\n } else if (field.placeholder) {\n fieldLine += ` (${field.placeholder})`;\n } else {\n fieldLine += ' (empty)';\n }\n\n if (!field.valid && field.error) {\n fieldLine += ` [ERROR: ${field.error}]`;\n } else if (field.required && !field.value) {\n fieldLine += ' [required]';\n }\n\n lines.push(fieldLine);\n }\n\n // Submit button\n if (form.submitButton) {\n lines.push(` Submit: ${form.submitButton}`);\n }\n }\n\n return lines.join('\\n');\n}\n\n/**\n * Generate a snapshot summary\n */\nexport function generateSnapshotSummary(\n snapshot: SemanticSnapshot,\n config: Partial<SummaryConfig> = {}\n): string {\n const finalConfig = { ...DEFAULT_SUMMARY_CONFIG, ...config };\n const lines: string[] = [];\n\n // Page info\n lines.push(`Page: \"${snapshot.page.title}\"`);\n lines.push(`URL: ${snapshot.page.url}`);\n if (snapshot.page.pageType) {\n lines.push(`Type: ${formatPageType(snapshot.page.pageType)}`);\n }\n\n // Element counts\n if (finalConfig.includeElementCounts) {\n const countParts: string[] = [];\n for (const [type, count] of Object.entries(snapshot.elementCounts)) {\n if (count > 0) {\n countParts.push(`${count} ${type}${count > 1 ? 's' : ''}`);\n }\n }\n if (countParts.length > 0) {\n lines.push(`Elements: ${countParts.join(', ')}`);\n }\n }\n\n // Forms\n if (finalConfig.includeForms && snapshot.forms.length > 0) {\n lines.push('');\n lines.push('Forms:');\n for (const form of snapshot.forms) {\n lines.push(generateFormStateSummary(form));\n }\n }\n\n // Modals\n if (finalConfig.includeModals && snapshot.activeModals.length > 0) {\n lines.push('');\n lines.push('Active dialogs:');\n for (const modal of snapshot.activeModals) {\n lines.push(` - ${modal.title || modal.id} (${modal.type})`);\n }\n }\n\n // Focused element\n if (finalConfig.includeFocused && snapshot.focusedElement) {\n const focused = snapshot.elements.find((e) => e.id === snapshot.focusedElement);\n if (focused) {\n lines.push(`Focused: ${generateElementDescription(focused)}`);\n }\n }\n\n return lines.join('\\n');\n}\n\n/**\n * Generate form state summary\n */\nfunction generateFormStateSummary(form: FormState): string {\n const lines: string[] = [];\n const formName = form.name || form.purpose || form.id;\n\n const filledCount = form.fields.filter((f) => f.value).length;\n const errorCount = form.fields.filter((f) => !f.valid).length;\n\n let statusLine = ` ${formName}: ${filledCount}/${form.fields.length} filled`;\n if (errorCount > 0) {\n statusLine += `, ${errorCount} error${errorCount > 1 ? 's' : ''}`;\n }\n if (form.isDirty) {\n statusLine += ' (modified)';\n }\n\n lines.push(statusLine);\n\n // List errors\n for (const field of form.fields) {\n if (!field.valid && field.error) {\n lines.push(` ERROR: ${field.label}: ${field.error}`);\n }\n }\n\n return lines.join('\\n');\n}\n\n/**\n * Generate diff summary\n */\nexport function generateDiffSummary(\n appeared: string[],\n disappeared: string[],\n modified: Array<{ description: string; property: string; from: string; to: string }>\n): string {\n const lines: string[] = [];\n\n if (appeared.length > 0) {\n lines.push(`Appeared: ${appeared.join(', ')}`);\n }\n\n if (disappeared.length > 0) {\n lines.push(`Disappeared: ${disappeared.join(', ')}`);\n }\n\n if (modified.length > 0) {\n lines.push('Changed:');\n for (const mod of modified.slice(0, 5)) {\n lines.push(\n ` - ${mod.description}: ${mod.property} changed from \"${mod.from}\" to \"${mod.to}\"`\n );\n }\n if (modified.length > 5) {\n lines.push(` ... and ${modified.length - 5} more changes`);\n }\n }\n\n if (lines.length === 0) {\n return 'No changes detected';\n }\n\n return lines.join('\\n');\n}\n\n// ============================================================================\n// Helper Functions\n// ============================================================================\n\n/**\n * Count elements by type\n */\nfunction countElementTypes(elements: AIDiscoveredElement[]): Record<string, number> {\n const counts: Record<string, number> = {};\n\n for (const el of elements) {\n const type = el.type.toLowerCase();\n counts[type] = (counts[type] || 0) + 1;\n }\n\n return counts;\n}\n\n/**\n * Detect forms from elements\n */\nfunction detectForms(elements: AIDiscoveredElement[]): FormAnalysis[] {\n // Group inputs by common patterns (this is a simplified heuristic)\n const formElements = elements.filter(\n (el) =>\n el.type === 'input' ||\n el.type === 'textarea' ||\n el.type === 'select' ||\n el.type === 'checkbox'\n );\n\n if (formElements.length === 0) return [];\n\n // For simplicity, treat all inputs as one form if no explicit forms\n const forms: FormAnalysis[] = [];\n\n // Find submit buttons\n const submitButtons = elements.filter(\n (el) =>\n el.type === 'button' &&\n (el.state.textContent?.toLowerCase().includes('submit') ||\n el.state.textContent?.toLowerCase().includes('save') ||\n el.state.textContent?.toLowerCase().includes('send') ||\n el.semanticType === 'submit-button')\n );\n\n // Create a default form\n const defaultForm: FormAnalysis = {\n id: 'detected-form',\n purpose: inferFormPurpose(formElements),\n fields: formElements.map((el) => ({\n id: el.id,\n label: el.labelText || el.accessibleName || el.placeholder || el.id,\n type: el.type,\n value: el.state.value || '',\n valid: true, // Can't determine without validation state\n required: false, // Can't determine without DOM access\n placeholder: el.placeholder,\n })),\n isValid: true,\n submitButton: submitButtons[0]?.id,\n };\n\n if (defaultForm.fields.length > 0) {\n forms.push(defaultForm);\n }\n\n return forms;\n}\n\n/**\n * Infer form purpose from fields\n */\nfunction inferFormPurpose(fields: AIDiscoveredElement[]): string {\n const labels = fields.map((f) =>\n (f.labelText || f.accessibleName || f.placeholder || '').toLowerCase()\n );\n const allLabels = labels.join(' ');\n\n if (allLabels.includes('email') && allLabels.includes('password')) {\n if (allLabels.includes('confirm') || allLabels.includes('name')) {\n return 'Registration form';\n }\n return 'Login form';\n }\n\n if (allLabels.includes('search')) {\n return 'Search form';\n }\n\n if (allLabels.includes('address') || allLabels.includes('city') || allLabels.includes('zip')) {\n return 'Address form';\n }\n\n if (allLabels.includes('card') || allLabels.includes('cvv') || allLabels.includes('expir')) {\n return 'Payment form';\n }\n\n if (allLabels.includes('contact') || allLabels.includes('message')) {\n return 'Contact form';\n }\n\n return 'Form';\n}\n\n/**\n * Get key interactive elements for summary\n */\nfunction getKeyElements(elements: AIDiscoveredElement[]): AIDiscoveredElement[] {\n const keyElements: AIDiscoveredElement[] = [];\n\n // Prioritize submit/action buttons\n const actionButtons = elements.filter(\n (el) =>\n el.type === 'button' &&\n el.state.visible &&\n (el.semanticType?.includes('submit') ||\n el.semanticType?.includes('action') ||\n el.semanticType?.includes('next'))\n );\n keyElements.push(...actionButtons.slice(0, 2));\n\n // Add primary inputs\n const primaryInputs = elements.filter(\n (el) => (el.type === 'input' || el.type === 'textarea') && el.state.visible\n );\n keyElements.push(...primaryInputs.slice(0, 3));\n\n // Add visible links\n const links = elements.filter((el) => el.type === 'link' && el.state.visible);\n keyElements.push(...links.slice(0, 2));\n\n // Deduplicate and limit\n const unique = [...new Map(keyElements.map((e) => [e.id, e])).values()];\n return unique.slice(0, 8);\n}\n\n/**\n * Format page type for display\n */\nfunction formatPageType(pageType: PageContext['pageType']): string {\n const typeLabels: Record<NonNullable<PageContext['pageType']>, string> = {\n login: 'Login page',\n dashboard: 'Dashboard',\n form: 'Form page',\n list: 'List/table page',\n detail: 'Detail page',\n search: 'Search page',\n checkout: 'Checkout page',\n settings: 'Settings page',\n unknown: 'Unknown',\n };\n\n return typeLabels[pageType || 'unknown'] || 'Page';\n}\n\n/**\n * Format element type for display\n */\nfunction formatElementType(type: string): string {\n const typeLabels: Record<string, string> = {\n button: 'button',\n input: 'input field',\n textarea: 'text area',\n select: 'dropdown',\n checkbox: 'checkbox',\n radio: 'radio button',\n link: 'link',\n form: 'form',\n menu: 'menu',\n menuitem: 'menu item',\n tab: 'tab',\n dialog: 'dialog',\n switch: 'switch',\n slider: 'slider',\n };\n\n return typeLabels[type.toLowerCase()] || type;\n}\n\n/**\n * Truncate string with ellipsis\n */\nfunction truncate(str: string, maxLength: number): string {\n if (str.length <= maxLength) return str;\n return str.substring(0, maxLength - 3) + '...';\n}\n\n/**\n * Infer page type from URL and elements\n */\nexport function inferPageType(\n url: string,\n title: string,\n elements: AIDiscoveredElement[]\n): PageContext['pageType'] {\n const urlLower = url.toLowerCase();\n const titleLower = title.toLowerCase();\n\n // URL-based detection\n if (urlLower.includes('login') || urlLower.includes('signin')) return 'login';\n if (urlLower.includes('dashboard')) return 'dashboard';\n if (urlLower.includes('search')) return 'search';\n if (urlLower.includes('checkout') || urlLower.includes('payment')) return 'checkout';\n if (urlLower.includes('settings') || urlLower.includes('preferences')) return 'settings';\n\n // Title-based detection\n if (titleLower.includes('login') || titleLower.includes('sign in')) return 'login';\n if (titleLower.includes('dashboard')) return 'dashboard';\n if (titleLower.includes('search')) return 'search';\n\n // Element-based detection\n const hasLoginForm =\n elements.some((el) => el.type === 'input' && el.semanticType === 'email-input') &&\n elements.some((el) => el.type === 'input' && el.semanticType === 'password-input');\n if (hasLoginForm) return 'login';\n\n const hasSearchInput = elements.some(\n (el) => el.type === 'input' && el.semanticType === 'search-input'\n );\n if (hasSearchInput) return 'search';\n\n // Check for form presence\n const inputCount = elements.filter(\n (el) => el.type === 'input' || el.type === 'textarea' || el.type === 'select'\n ).length;\n if (inputCount >= 3) return 'form';\n\n // Check for list/table\n const hasTable = elements.some((el) => el.tagName === 'table');\n const hasMany = elements.length > 20;\n if (hasTable || hasMany) return 'list';\n\n return 'unknown';\n}\n","/**\n * Natural Language Action Parser\n *\n * Parses natural language instructions into structured action requests.\n * Handles patterns like \"click the Submit button\" or \"type 'hello' in the search box\".\n */\n\nimport type { ParsedAction, AssertionType } from './types';\n\n/**\n * Action pattern definition\n */\ninterface ActionPattern {\n /** Regex pattern to match */\n regex: RegExp;\n /** Action type */\n action: ParsedAction['action'];\n /** Capture group index for target */\n targetGroup: number;\n /** Capture group index for value (optional) */\n valueGroup?: number;\n /** Extract modifiers from match */\n modifierExtractor?: (match: RegExpMatchArray) => ParsedAction['modifiers'];\n /** Confidence level for this pattern */\n confidence: number;\n}\n\n/**\n * Action patterns for natural language parsing\n */\nconst ACTION_PATTERNS: ActionPattern[] = [\n // Click patterns\n {\n regex: /^click\\s+(?:on\\s+)?(?:the\\s+)?(.+?)(?:\\s+button)?$/i,\n action: 'click',\n targetGroup: 1,\n confidence: 0.95,\n },\n {\n regex: /^press\\s+(?:the\\s+)?(.+?)(?:\\s+button)?$/i,\n action: 'click',\n targetGroup: 1,\n confidence: 0.9,\n },\n {\n regex: /^tap\\s+(?:on\\s+)?(?:the\\s+)?(.+)$/i,\n action: 'click',\n targetGroup: 1,\n confidence: 0.85,\n },\n {\n regex: /^activate\\s+(?:the\\s+)?(.+)$/i,\n action: 'click',\n targetGroup: 1,\n confidence: 0.8,\n },\n\n // Double click patterns\n {\n regex: /^double[\\s-]?click\\s+(?:on\\s+)?(?:the\\s+)?(.+)$/i,\n action: 'doubleClick',\n targetGroup: 1,\n confidence: 0.95,\n },\n\n // Right click patterns\n {\n regex: /^right[\\s-]?click\\s+(?:on\\s+)?(?:the\\s+)?(.+)$/i,\n action: 'rightClick',\n targetGroup: 1,\n confidence: 0.95,\n },\n {\n regex: /^context\\s+click\\s+(?:on\\s+)?(?:the\\s+)?(.+)$/i,\n action: 'rightClick',\n targetGroup: 1,\n confidence: 0.9,\n },\n\n // Type patterns - \"type X in Y\"\n {\n regex: /^type\\s+[\"'](.+?)[\"']\\s+(?:in(?:to)?|on)\\s+(?:the\\s+)?(.+)$/i,\n action: 'type',\n targetGroup: 2,\n valueGroup: 1,\n confidence: 0.95,\n },\n {\n regex: /^type\\s+(.+?)\\s+(?:in(?:to)?|on)\\s+(?:the\\s+)?(.+)$/i,\n action: 'type',\n targetGroup: 2,\n valueGroup: 1,\n confidence: 0.85,\n },\n\n // Type patterns - \"enter X in Y\"\n {\n regex: /^enter\\s+[\"'](.+?)[\"']\\s+(?:in(?:to)?|on)\\s+(?:the\\s+)?(.+)$/i,\n action: 'type',\n targetGroup: 2,\n valueGroup: 1,\n confidence: 0.95,\n },\n {\n regex: /^enter\\s+(.+?)\\s+(?:in(?:to)?|on)\\s+(?:the\\s+)?(.+)$/i,\n action: 'type',\n targetGroup: 2,\n valueGroup: 1,\n confidence: 0.85,\n },\n\n // Type patterns - \"input X into Y\"\n {\n regex: /^input\\s+[\"'](.+?)[\"']\\s+(?:in(?:to)?)\\s+(?:the\\s+)?(.+)$/i,\n action: 'type',\n targetGroup: 2,\n valueGroup: 1,\n confidence: 0.9,\n },\n\n // Type patterns - \"fill Y with X\"\n {\n regex: /^fill\\s+(?:in\\s+)?(?:the\\s+)?(.+?)\\s+with\\s+[\"'](.+?)[\"']$/i,\n action: 'type',\n targetGroup: 1,\n valueGroup: 2,\n confidence: 0.95,\n },\n {\n regex: /^fill\\s+(?:in\\s+)?(?:the\\s+)?(.+?)\\s+with\\s+(.+)$/i,\n action: 'type',\n targetGroup: 1,\n valueGroup: 2,\n confidence: 0.85,\n },\n\n // Type patterns - \"set Y to X\"\n {\n regex: /^set\\s+(?:the\\s+)?(.+?)\\s+to\\s+[\"'](.+?)[\"']$/i,\n action: 'type',\n targetGroup: 1,\n valueGroup: 2,\n confidence: 0.9,\n },\n\n // Select patterns\n {\n regex: /^select\\s+[\"'](.+?)[\"']\\s+(?:from|in)\\s+(?:the\\s+)?(.+)$/i,\n action: 'select',\n targetGroup: 2,\n valueGroup: 1,\n confidence: 0.95,\n },\n {\n regex: /^choose\\s+[\"'](.+?)[\"']\\s+(?:from|in)\\s+(?:the\\s+)?(.+)$/i,\n action: 'select',\n targetGroup: 2,\n valueGroup: 1,\n confidence: 0.9,\n },\n {\n regex: /^pick\\s+[\"'](.+?)[\"']\\s+(?:from|in)\\s+(?:the\\s+)?(.+)$/i,\n action: 'select',\n targetGroup: 2,\n valueGroup: 1,\n confidence: 0.85,\n },\n\n // Check patterns\n {\n regex: /^check\\s+(?:the\\s+)?(.+?)(?:\\s+checkbox)?$/i,\n action: 'check',\n targetGroup: 1,\n confidence: 0.9,\n },\n {\n regex: /^enable\\s+(?:the\\s+)?(.+)$/i,\n action: 'check',\n targetGroup: 1,\n confidence: 0.8,\n },\n {\n regex: /^tick\\s+(?:the\\s+)?(.+)$/i,\n action: 'check',\n targetGroup: 1,\n confidence: 0.85,\n },\n\n // Uncheck patterns\n {\n regex: /^uncheck\\s+(?:the\\s+)?(.+?)(?:\\s+checkbox)?$/i,\n action: 'uncheck',\n targetGroup: 1,\n confidence: 0.9,\n },\n {\n regex: /^disable\\s+(?:the\\s+)?(.+)$/i,\n action: 'uncheck',\n targetGroup: 1,\n confidence: 0.8,\n },\n {\n regex: /^untick\\s+(?:the\\s+)?(.+)$/i,\n action: 'uncheck',\n targetGroup: 1,\n confidence: 0.85,\n },\n\n // Clear patterns\n {\n regex: /^clear\\s+(?:the\\s+)?(.+)$/i,\n action: 'clear',\n targetGroup: 1,\n confidence: 0.9,\n },\n {\n regex: /^erase\\s+(?:the\\s+)?(.+)$/i,\n action: 'clear',\n targetGroup: 1,\n confidence: 0.85,\n },\n {\n regex: /^empty\\s+(?:the\\s+)?(.+)$/i,\n action: 'clear',\n targetGroup: 1,\n confidence: 0.8,\n },\n\n // Hover patterns\n {\n regex: /^hover\\s+(?:over\\s+)?(?:the\\s+)?(.+)$/i,\n action: 'hover',\n targetGroup: 1,\n confidence: 0.9,\n },\n {\n regex: /^mouse\\s+over\\s+(?:the\\s+)?(.+)$/i,\n action: 'hover',\n targetGroup: 1,\n confidence: 0.85,\n },\n\n // Focus patterns\n {\n regex: /^focus\\s+(?:on\\s+)?(?:the\\s+)?(.+)$/i,\n action: 'focus',\n targetGroup: 1,\n confidence: 0.9,\n },\n\n // Scroll patterns\n {\n regex: /^scroll\\s+(up|down|left|right)$/i,\n action: 'scroll',\n targetGroup: 1,\n confidence: 0.9,\n },\n {\n regex: /^scroll\\s+(?:the\\s+)?(.+?)\\s+(up|down|left|right)$/i,\n action: 'scroll',\n targetGroup: 1,\n confidence: 0.85,\n },\n {\n regex: /^scroll\\s+to\\s+(?:the\\s+)?(.+)$/i,\n action: 'scroll',\n targetGroup: 1,\n confidence: 0.85,\n },\n\n // Wait patterns\n {\n regex: /^wait\\s+(?:for\\s+)?(?:the\\s+)?(.+?)(?:\\s+to\\s+(?:be\\s+)?(.+))?$/i,\n action: 'wait',\n targetGroup: 1,\n confidence: 0.85,\n },\n {\n regex: /^wait\\s+until\\s+(?:the\\s+)?(.+?)(?:\\s+(?:is|becomes)\\s+(.+))?$/i,\n action: 'wait',\n targetGroup: 1,\n confidence: 0.85,\n },\n\n // Assert patterns\n {\n regex:\n /^(?:assert|verify|check)\\s+(?:that\\s+)?(?:the\\s+)?(.+?)\\s+(?:is\\s+)?(visible|hidden|enabled|disabled|checked|unchecked|focused)$/i,\n action: 'assert',\n targetGroup: 1,\n confidence: 0.9,\n },\n {\n regex:\n /^(?:assert|verify|check)\\s+(?:that\\s+)?(?:the\\s+)?(.+?)\\s+(?:contains|has)\\s+[\"'](.+?)[\"']$/i,\n action: 'assert',\n targetGroup: 1,\n valueGroup: 2,\n confidence: 0.9,\n },\n {\n regex:\n /^(?:the\\s+)?(.+?)\\s+should\\s+(?:be\\s+)?(visible|hidden|enabled|disabled|checked|unchecked|focused)$/i,\n action: 'assert',\n targetGroup: 1,\n confidence: 0.85,\n },\n];\n\n/**\n * Assertion type mappings\n */\nconst ASSERTION_TYPE_MAP: Record<string, AssertionType> = {\n visible: 'visible',\n hidden: 'hidden',\n enabled: 'enabled',\n disabled: 'disabled',\n checked: 'checked',\n unchecked: 'unchecked',\n focused: 'focused',\n contains: 'containsText',\n has: 'hasText',\n};\n\n/**\n * Parse a natural language instruction into a structured action\n */\nexport function parseNLInstruction(instruction: string): ParsedAction | null {\n const trimmed = instruction.trim();\n if (!trimmed) return null;\n\n // Try each pattern\n for (const pattern of ACTION_PATTERNS) {\n const match = trimmed.match(pattern.regex);\n if (match) {\n const parsed: ParsedAction = {\n action: pattern.action,\n targetDescription: cleanTargetDescription(match[pattern.targetGroup] || ''),\n rawInstruction: instruction,\n parseConfidence: pattern.confidence,\n };\n\n // Extract value if present\n if (pattern.valueGroup && match[pattern.valueGroup]) {\n parsed.value = match[pattern.valueGroup];\n }\n\n // Extract modifiers if extractor provided\n if (pattern.modifierExtractor) {\n parsed.modifiers = pattern.modifierExtractor(match);\n }\n\n // Handle scroll direction\n if (pattern.action === 'scroll') {\n const directionMatch = trimmed.match(/(up|down|left|right)/i);\n if (directionMatch) {\n parsed.scrollDirection =\n directionMatch[1].toLowerCase() as ParsedAction['scrollDirection'];\n }\n }\n\n // Handle assertion type\n if (pattern.action === 'assert') {\n const assertMatch = trimmed.match(\n /(visible|hidden|enabled|disabled|checked|unchecked|focused|contains|has)/i\n );\n if (assertMatch) {\n parsed.assertionType = ASSERTION_TYPE_MAP[assertMatch[1].toLowerCase()];\n }\n }\n\n // Handle wait condition\n if (pattern.action === 'wait') {\n const waitCondition = match[2];\n if (waitCondition) {\n parsed.waitCondition = waitCondition;\n }\n }\n\n return parsed;\n }\n }\n\n // Try to infer action from common words as fallback\n return inferAction(trimmed);\n}\n\n/**\n * Clean up target description\n */\nfunction cleanTargetDescription(target: string): string {\n return (\n target\n .trim()\n // Remove leading articles\n .replace(/^(the|a|an)\\s+/i, '')\n // Remove trailing type indicators\n .replace(/\\s+(button|field|input|link|dropdown|checkbox|radio)$/i, '')\n .trim()\n );\n}\n\n/**\n * Infer action from instruction as fallback\n */\nfunction inferAction(instruction: string): ParsedAction | null {\n const lower = instruction.toLowerCase();\n\n // Simple click inference\n if (lower.includes('click') || lower.includes('press') || lower.includes('tap')) {\n const target = instruction.replace(/click|press|tap|on|the/gi, '').trim();\n if (target) {\n return {\n action: 'click',\n targetDescription: cleanTargetDescription(target),\n rawInstruction: instruction,\n parseConfidence: 0.6,\n };\n }\n }\n\n // Simple type inference\n if (lower.includes('type') || lower.includes('enter') || lower.includes('input')) {\n // Try to extract quoted value\n const quotedMatch = instruction.match(/[\"'](.+?)[\"']/);\n if (quotedMatch) {\n const target = instruction.replace(/type|enter|input|into|in|the|[\"'].*?[\"']/gi, '').trim();\n return {\n action: 'type',\n targetDescription: cleanTargetDescription(target),\n value: quotedMatch[1],\n rawInstruction: instruction,\n parseConfidence: 0.5,\n };\n }\n }\n\n // Could not parse\n return null;\n}\n\n/**\n * Parse multiple instructions\n */\nexport function parseNLInstructions(instructions: string[]): ParsedAction[] {\n const parsed: ParsedAction[] = [];\n\n for (const instruction of instructions) {\n const result = parseNLInstruction(instruction);\n if (result) {\n parsed.push(result);\n }\n }\n\n return parsed;\n}\n\n/**\n * Split a complex instruction into simple ones\n * e.g., \"click Login and type 'admin' in username\" -> [\"click Login\", \"type 'admin' in username\"]\n */\nexport function splitCompoundInstruction(instruction: string): string[] {\n // Split on common conjunctions\n const parts = instruction.split(/\\s+(?:and|then|,\\s*then|,\\s*and|,)\\s+/i);\n\n return parts.map((p) => p.trim()).filter((p) => p.length > 0);\n}\n\n/**\n * Extract modifiers from instruction\n */\nexport function extractModifiers(instruction: string): ParsedAction['modifiers'] {\n const modifiers: ParsedAction['modifiers'] = [];\n const lower = instruction.toLowerCase();\n\n if (lower.includes('shift') || lower.includes('with shift')) {\n modifiers.push('shift');\n }\n if (lower.includes('ctrl') || lower.includes('control') || lower.includes('with ctrl')) {\n modifiers.push('ctrl');\n }\n if (lower.includes('alt') || lower.includes('with alt') || lower.includes('option')) {\n modifiers.push('alt');\n }\n if (\n lower.includes('meta') ||\n lower.includes('command') ||\n lower.includes('cmd') ||\n lower.includes('windows')\n ) {\n modifiers.push('meta');\n }\n\n return modifiers.length > 0 ? modifiers : undefined;\n}\n\n/**\n * Validate a parsed action\n */\nexport function validateParsedAction(action: ParsedAction): { valid: boolean; errors: string[] } {\n const errors: string[] = [];\n\n if (!action.targetDescription && action.action !== 'scroll') {\n errors.push('No target element specified');\n }\n\n if ((action.action === 'type' || action.action === 'select') && !action.value) {\n errors.push(`No value specified for ${action.action} action`);\n }\n\n if (action.parseConfidence < 0.5) {\n errors.push('Low confidence parsing - instruction may be ambiguous');\n }\n\n return {\n valid: errors.length === 0,\n errors,\n };\n}\n\n/**\n * Generate a human-readable description of a parsed action\n */\nexport function describeAction(action: ParsedAction): string {\n switch (action.action) {\n case 'click':\n return `Click on \"${action.targetDescription}\"`;\n case 'doubleClick':\n return `Double-click on \"${action.targetDescription}\"`;\n case 'rightClick':\n return `Right-click on \"${action.targetDescription}\"`;\n case 'type':\n return `Type \"${action.value}\" into \"${action.targetDescription}\"`;\n case 'select':\n return `Select \"${action.value}\" from \"${action.targetDescription}\"`;\n case 'check':\n return `Check \"${action.targetDescription}\"`;\n case 'uncheck':\n return `Uncheck \"${action.targetDescription}\"`;\n case 'clear':\n return `Clear \"${action.targetDescription}\"`;\n case 'hover':\n return `Hover over \"${action.targetDescription}\"`;\n case 'focus':\n return `Focus on \"${action.targetDescription}\"`;\n case 'scroll':\n if (action.scrollDirection) {\n return `Scroll ${action.scrollDirection}`;\n }\n return `Scroll to \"${action.targetDescription}\"`;\n case 'wait':\n return `Wait for \"${action.targetDescription}\"${action.waitCondition ? ` to be ${action.waitCondition}` : ''}`;\n case 'assert':\n return `Assert \"${action.targetDescription}\" is ${action.assertionType || 'valid'}`;\n default:\n return `${action.action} on \"${action.targetDescription}\"`;\n }\n}\n","/**\n * Error Context\n *\n * Creates rich error context for AI agents to understand and recover\n * from failures during UI automation.\n */\n\nimport type { RegisteredElement, ElementState } from '../core/types';\nimport type { DiscoveredElement } from '../control/types';\nimport type {\n AIErrorContext,\n RecoverySuggestion,\n SearchCriteria,\n SearchResult,\n AIDiscoveredElement,\n} from './types';\n\n/**\n * Any element type that can be used with error context\n */\ntype AnyElement = DiscoveredElement | AIDiscoveredElement | RegisteredElement;\n\n/**\n * Helper to get element state from any element type\n * DiscoveredElement has a `state` property, RegisteredElement has a `getState()` method\n */\nfunction getElementState(el: AnyElement): ElementState | undefined {\n if ('state' in el && el.state) {\n return el.state;\n }\n if ('getState' in el && typeof el.getState === 'function') {\n try {\n return el.getState();\n } catch {\n return undefined;\n }\n }\n return undefined;\n}\n\n/**\n * Standard error codes\n */\nexport const ErrorCodes = {\n // Parsing errors\n PARSE_ERROR: 'PARSE_ERROR',\n VALIDATION_ERROR: 'VALIDATION_ERROR',\n\n // Element errors\n ELEMENT_NOT_FOUND: 'ELEMENT_NOT_FOUND',\n ELEMENT_NOT_VISIBLE: 'ELEMENT_NOT_VISIBLE',\n ELEMENT_DISABLED: 'ELEMENT_DISABLED',\n ELEMENT_BLOCKED: 'ELEMENT_BLOCKED',\n MULTIPLE_ELEMENTS: 'MULTIPLE_ELEMENTS',\n\n // Search errors\n LOW_CONFIDENCE: 'LOW_CONFIDENCE',\n AMBIGUOUS_MATCH: 'AMBIGUOUS_MATCH',\n\n // Action errors\n ACTION_FAILED: 'ACTION_FAILED',\n ACTION_TIMEOUT: 'ACTION_TIMEOUT',\n UNSUPPORTED_ACTION: 'UNSUPPORTED_ACTION',\n\n // State errors\n UNEXPECTED_STATE: 'UNEXPECTED_STATE',\n STALE_ELEMENT: 'STALE_ELEMENT',\n\n // Page errors\n PAGE_LOAD_ERROR: 'PAGE_LOAD_ERROR',\n NAVIGATION_ERROR: 'NAVIGATION_ERROR',\n} as const;\n\nexport type ErrorCode = (typeof ErrorCodes)[keyof typeof ErrorCodes];\n\n/**\n * Error messages for each error code\n */\nconst ERROR_MESSAGES: Record<ErrorCode, string> = {\n PARSE_ERROR: 'Could not parse the natural language instruction',\n VALIDATION_ERROR: 'The parsed action failed validation',\n ELEMENT_NOT_FOUND: 'No element matching the description could be found',\n ELEMENT_NOT_VISIBLE: 'The element exists but is not visible',\n ELEMENT_DISABLED: 'The element is disabled and cannot be interacted with',\n ELEMENT_BLOCKED: 'The element is blocked by another element',\n MULTIPLE_ELEMENTS: 'Multiple elements match the description',\n LOW_CONFIDENCE: 'The best match has low confidence',\n AMBIGUOUS_MATCH: 'Multiple elements match with similar confidence',\n ACTION_FAILED: 'The action could not be completed',\n ACTION_TIMEOUT: 'The action timed out waiting for a condition',\n UNSUPPORTED_ACTION: 'The requested action is not supported',\n UNEXPECTED_STATE: 'The element is in an unexpected state',\n STALE_ELEMENT: 'The element is no longer attached to the DOM',\n PAGE_LOAD_ERROR: 'The page failed to load correctly',\n NAVIGATION_ERROR: 'Navigation to the target page failed',\n};\n\n/**\n * Recovery suggestions for each error code\n */\nconst ERROR_SUGGESTIONS: Record<ErrorCode, RecoverySuggestion[]> = {\n PARSE_ERROR: [\n {\n action: 'Use a simpler instruction format like \"click Submit button\"',\n confidence: 0.8,\n priority: 1,\n },\n {\n action: 'Use specific element names visible on the page',\n confidence: 0.7,\n priority: 2,\n },\n ],\n VALIDATION_ERROR: [\n {\n action: 'Provide required parameters for the action',\n confidence: 0.9,\n priority: 1,\n },\n {\n action: 'Check the instruction format',\n confidence: 0.7,\n priority: 2,\n },\n ],\n ELEMENT_NOT_FOUND: [\n {\n action: 'Wait for the page to fully load',\n command: 'wait for page to load',\n confidence: 0.7,\n priority: 1,\n },\n {\n action: 'Use a different description for the element',\n confidence: 0.8,\n priority: 2,\n },\n {\n action: 'Scroll the page to reveal the element',\n command: 'scroll down',\n confidence: 0.6,\n priority: 3,\n },\n ],\n ELEMENT_NOT_VISIBLE: [\n {\n action: 'Scroll to make the element visible',\n command: 'scroll to element',\n confidence: 0.9,\n priority: 1,\n },\n {\n action: 'Close any overlaying elements',\n confidence: 0.7,\n priority: 2,\n },\n {\n action: 'Wait for loading to complete',\n command: 'wait for loading',\n confidence: 0.6,\n priority: 3,\n },\n ],\n ELEMENT_DISABLED: [\n {\n action: 'Fill in required fields first',\n confidence: 0.8,\n priority: 1,\n },\n {\n action: 'Complete prerequisite steps',\n confidence: 0.7,\n priority: 2,\n },\n {\n action: 'Wait for the element to become enabled',\n command: 'wait for element to be enabled',\n confidence: 0.6,\n priority: 3,\n },\n ],\n ELEMENT_BLOCKED: [\n {\n action: 'Close the modal or popup',\n command: 'click close button',\n confidence: 0.9,\n priority: 1,\n },\n {\n action: 'Dismiss the overlay',\n confidence: 0.8,\n priority: 2,\n },\n {\n action: 'Wait for the blocking element to disappear',\n confidence: 0.6,\n priority: 3,\n },\n ],\n MULTIPLE_ELEMENTS: [\n {\n action: 'Use a more specific description',\n confidence: 0.9,\n priority: 1,\n },\n {\n action: 'Include the element position (first, second, etc.)',\n confidence: 0.8,\n priority: 2,\n },\n {\n action: 'Use the element ID directly',\n confidence: 0.7,\n priority: 3,\n },\n ],\n LOW_CONFIDENCE: [\n {\n action: 'Use the exact text shown on the element',\n confidence: 0.9,\n priority: 1,\n },\n {\n action: 'Lower the confidence threshold if the match is correct',\n confidence: 0.7,\n priority: 2,\n },\n {\n action: 'Try a different way to describe the element',\n confidence: 0.6,\n priority: 3,\n },\n ],\n AMBIGUOUS_MATCH: [\n {\n action: 'Be more specific about which element you mean',\n confidence: 0.9,\n priority: 1,\n },\n {\n action: 'Include the section or form name',\n confidence: 0.8,\n priority: 2,\n },\n ],\n ACTION_FAILED: [\n {\n action: 'Check if the element is interactable',\n confidence: 0.7,\n priority: 1,\n },\n {\n action: 'Wait and retry the action',\n command: 'wait 1 second then retry',\n confidence: 0.6,\n priority: 2,\n },\n ],\n ACTION_TIMEOUT: [\n {\n action: 'Increase the timeout duration',\n confidence: 0.8,\n priority: 1,\n },\n {\n action: 'Check if the condition can ever be met',\n confidence: 0.7,\n priority: 2,\n },\n ],\n UNSUPPORTED_ACTION: [\n {\n action: 'Use a different action type',\n confidence: 0.9,\n priority: 1,\n },\n {\n action: 'Break down into simpler actions',\n confidence: 0.7,\n priority: 2,\n },\n ],\n UNEXPECTED_STATE: [\n {\n action: 'Refresh the page state',\n command: 'refresh',\n confidence: 0.7,\n priority: 1,\n },\n {\n action: 'Wait for state to stabilize',\n command: 'wait 2 seconds',\n confidence: 0.6,\n priority: 2,\n },\n ],\n STALE_ELEMENT: [\n {\n action: 'Re-find the element',\n confidence: 0.9,\n priority: 1,\n },\n {\n action: 'Wait for page to stabilize',\n command: 'wait 1 second',\n confidence: 0.7,\n priority: 2,\n },\n ],\n PAGE_LOAD_ERROR: [\n {\n action: 'Refresh the page',\n command: 'refresh page',\n confidence: 0.8,\n priority: 1,\n },\n {\n action: 'Check network connectivity',\n confidence: 0.6,\n priority: 2,\n },\n ],\n NAVIGATION_ERROR: [\n {\n action: 'Try the navigation again',\n confidence: 0.7,\n priority: 1,\n },\n {\n action: 'Check if the URL is correct',\n confidence: 0.6,\n priority: 2,\n },\n ],\n};\n\n/**\n * Create a rich error context\n */\nexport function createErrorContext(\n errorCode: ErrorCode,\n attemptedAction: string,\n availableElements: AnyElement[],\n searchCriteria?: SearchCriteria,\n nearestMatch?: SearchResult\n): AIErrorContext {\n // Get base message and suggestions\n const message = ERROR_MESSAGES[errorCode] || 'An unknown error occurred';\n const baseSuggestions = ERROR_SUGGESTIONS[errorCode] || [];\n\n // Detect possible blockers\n const possibleBlockers = detectPossibleBlockers(availableElements);\n\n // Count visible elements\n const visibleElements = availableElements.filter((el) => {\n const state = getElementState(el);\n return state?.visible ?? false;\n }).length;\n\n // Build enhanced suggestions\n const suggestions = enhanceSuggestions(\n baseSuggestions,\n errorCode,\n nearestMatch,\n possibleBlockers\n );\n\n return {\n code: errorCode,\n message,\n attemptedAction,\n searchCriteria,\n searchResults: {\n candidatesFound: availableElements.length,\n nearestMatch: nearestMatch\n ? {\n element: nearestMatch.element,\n confidence: nearestMatch.confidence,\n whyNotSelected: determineWhyNotSelected(errorCode, nearestMatch),\n }\n : undefined,\n },\n pageContext: {\n url: typeof window !== 'undefined' ? window.location.href : '',\n title: typeof document !== 'undefined' ? document.title : '',\n visibleElements,\n possibleBlockers,\n },\n suggestions,\n timestamp: Date.now(),\n };\n}\n\n/**\n * Detect possible blocking elements\n */\nfunction detectPossibleBlockers(elements: AnyElement[]): string[] {\n const blockers: string[] = [];\n\n for (const el of elements) {\n const state = getElementState(el);\n if (!state) continue;\n\n // Check for modals\n if (el.type === 'dialog' && state.visible) {\n blockers.push(`Modal dialog: ${el.id}`);\n }\n\n // Check for overlays (heuristic based on computed styles)\n if (state.computedStyles?.pointerEvents === 'none') {\n continue; // Non-blocking overlay\n }\n\n // Check for full-screen elements (would need rect comparison)\n }\n\n return blockers;\n}\n\n/**\n * Enhance suggestions based on context\n */\nfunction enhanceSuggestions(\n baseSuggestions: RecoverySuggestion[],\n errorCode: ErrorCode,\n nearestMatch?: SearchResult,\n possibleBlockers?: string[]\n): RecoverySuggestion[] {\n const suggestions = [...baseSuggestions];\n\n // Add blocker-specific suggestions\n if (possibleBlockers && possibleBlockers.length > 0) {\n suggestions.unshift({\n action: `Close the blocking element: ${possibleBlockers[0]}`,\n command: 'click close button',\n confidence: 0.85,\n priority: 0,\n });\n }\n\n // Add nearest match suggestion\n if (nearestMatch && errorCode === 'LOW_CONFIDENCE') {\n suggestions.unshift({\n action: `Did you mean: \"${nearestMatch.element.description}\"?`,\n command: `click \"${nearestMatch.element.description}\"`,\n confidence: nearestMatch.confidence,\n priority: 0,\n });\n }\n\n // Sort by priority\n suggestions.sort((a, b) => a.priority - b.priority);\n\n return suggestions;\n}\n\n/**\n * Determine why the nearest match was not selected\n */\nfunction determineWhyNotSelected(errorCode: ErrorCode, nearestMatch: SearchResult): string {\n switch (errorCode) {\n case 'LOW_CONFIDENCE':\n return `Confidence (${(nearestMatch.confidence * 100).toFixed(0)}%) below threshold`;\n\n case 'ELEMENT_NOT_VISIBLE':\n return 'Element is not visible';\n\n case 'ELEMENT_DISABLED':\n return 'Element is disabled';\n\n case 'AMBIGUOUS_MATCH':\n return 'Multiple elements with similar confidence';\n\n default:\n return 'Did not meet selection criteria';\n }\n}\n\n/**\n * Format error context for display\n */\nexport function formatErrorContext(context: AIErrorContext): string {\n const lines: string[] = [];\n\n lines.push(`Error: ${context.code}`);\n lines.push(`Message: ${context.message}`);\n lines.push(`Attempted: ${context.attemptedAction}`);\n lines.push('');\n\n if (context.searchResults.nearestMatch) {\n const match = context.searchResults.nearestMatch;\n lines.push(\n `Nearest match: \"${match.element.description}\" (${(match.confidence * 100).toFixed(0)}% confidence)`\n );\n lines.push(`Why not used: ${match.whyNotSelected}`);\n lines.push('');\n }\n\n lines.push(`Page: ${context.pageContext.title || context.pageContext.url}`);\n lines.push(`Visible elements: ${context.pageContext.visibleElements}`);\n\n if (context.pageContext.possibleBlockers.length > 0) {\n lines.push(`Possible blockers: ${context.pageContext.possibleBlockers.join(', ')}`);\n }\n\n lines.push('');\n lines.push('Suggestions:');\n for (const suggestion of context.suggestions.slice(0, 3)) {\n lines.push(` - ${suggestion.action}`);\n if (suggestion.command) {\n lines.push(` Command: ${suggestion.command}`);\n }\n }\n\n return lines.join('\\n');\n}\n\n/**\n * Create a simple error response\n */\nexport function createSimpleError(\n code: ErrorCode,\n message?: string\n): { code: string; message: string } {\n return {\n code,\n message: message || ERROR_MESSAGES[code] || 'Unknown error',\n };\n}\n\n/**\n * Check if an error is recoverable\n */\nexport function isRecoverableError(code: ErrorCode): boolean {\n const unrecoverableErrors: ErrorCode[] = [\n 'UNSUPPORTED_ACTION',\n 'PAGE_LOAD_ERROR',\n 'NAVIGATION_ERROR',\n ];\n\n return !unrecoverableErrors.includes(code);\n}\n\n/**\n * Get the best recovery suggestion for an error\n */\nexport function getBestRecoverySuggestion(context: AIErrorContext): RecoverySuggestion | null {\n if (context.suggestions.length === 0) return null;\n\n // Return highest confidence suggestion\n const sorted = [...context.suggestions].sort((a, b) => b.confidence - a.confidence);\n return sorted[0];\n}\n","/**\n * Natural Language Action Executor\n *\n * Executes parsed natural language actions by searching for elements\n * and performing the requested actions with confidence scoring.\n */\n\nimport type { RegisteredElement, ElementState, StandardAction } from '../core/types';\nimport type { DiscoveredElement, ActionExecutor } from '../control/types';\nimport type {\n NLActionRequest,\n NLActionResponse,\n ParsedAction,\n SearchCriteria,\n AIDiscoveredElement,\n AIErrorContext,\n SearchResult,\n} from './types';\nimport { parseNLInstruction, describeAction, validateParsedAction } from './nl-action-parser';\nimport { SearchEngine, type SearchEngineConfig } from './search-engine';\nimport { createErrorContext, ErrorCodes } from './error-context';\n\n/**\n * Configuration for the NL action executor\n */\nexport interface NLActionExecutorConfig {\n /** Default confidence threshold for element matching */\n defaultConfidenceThreshold: number;\n /** Default timeout for actions */\n defaultTimeout: number;\n /** Maximum alternatives to return on failure */\n maxAlternatives: number;\n /** Search engine configuration */\n searchConfig?: Partial<SearchEngineConfig>;\n /** Enable verbose logging */\n verbose: boolean;\n}\n\n/**\n * Default executor configuration\n */\nexport const DEFAULT_EXECUTOR_CONFIG: NLActionExecutorConfig = {\n defaultConfidenceThreshold: 0.7,\n defaultTimeout: 5000,\n maxAlternatives: 3,\n verbose: false,\n};\n\n/**\n * Natural Language Action Executor\n */\nexport class NLActionExecutor {\n private config: NLActionExecutorConfig;\n private searchEngine: SearchEngine;\n private actionExecutor: ActionExecutor | null = null;\n private elements: Array<DiscoveredElement | RegisteredElement> = [];\n\n constructor(config: Partial<NLActionExecutorConfig> = {}) {\n this.config = { ...DEFAULT_EXECUTOR_CONFIG, ...config };\n this.searchEngine = new SearchEngine(this.config.searchConfig);\n }\n\n /**\n * Set the action executor for performing DOM actions\n */\n setActionExecutor(executor: ActionExecutor): void {\n this.actionExecutor = executor;\n }\n\n /**\n * Update available elements for search\n */\n updateElements(elements: Array<DiscoveredElement | RegisteredElement>): void {\n this.elements = elements;\n this.searchEngine.updateElements(elements);\n }\n\n /**\n * Execute a natural language instruction\n */\n async execute(request: NLActionRequest): Promise<NLActionResponse> {\n const startTime = performance.now();\n const threshold = request.confidenceThreshold ?? this.config.defaultConfidenceThreshold;\n\n // Parse the instruction\n const parsed = parseNLInstruction(request.instruction);\n\n if (!parsed) {\n return this.createFailureResponse(\n startTime,\n 'PARSE_ERROR',\n `Could not parse instruction: \"${request.instruction}\"`,\n request.instruction,\n [],\n threshold\n );\n }\n\n // Validate the parsed action\n const validation = validateParsedAction(parsed);\n if (!validation.valid) {\n return this.createFailureResponse(\n startTime,\n 'VALIDATION_ERROR',\n validation.errors.join('; '),\n request.instruction,\n [],\n threshold\n );\n }\n\n // Build search criteria from parsed action\n const searchCriteria = this.buildSearchCriteria(parsed);\n\n // Search for the target element\n const searchResponse = this.searchEngine.search(searchCriteria);\n\n if (!searchResponse.bestMatch) {\n return this.createFailureResponse(\n startTime,\n 'ELEMENT_NOT_FOUND',\n `Could not find element matching: \"${parsed.targetDescription}\"`,\n request.instruction,\n searchResponse.results,\n threshold,\n searchCriteria\n );\n }\n\n // Check confidence threshold\n if (searchResponse.bestMatch.confidence < threshold) {\n const alternatives = searchResponse.results.slice(0, this.config.maxAlternatives);\n return this.createFailureResponse(\n startTime,\n 'LOW_CONFIDENCE',\n `Best match confidence (${(searchResponse.bestMatch.confidence * 100).toFixed(0)}%) is below threshold (${(threshold * 100).toFixed(0)}%)`,\n request.instruction,\n alternatives,\n threshold,\n searchCriteria,\n searchResponse.bestMatch\n );\n }\n\n // Execute the action\n try {\n const result = await this.performAction(\n parsed,\n searchResponse.bestMatch.element,\n request.timeout ?? this.config.defaultTimeout\n );\n\n return {\n success: true,\n executedAction: describeAction(parsed),\n elementUsed: searchResponse.bestMatch.element,\n confidence: searchResponse.bestMatch.confidence,\n elementState: result.elementState,\n durationMs: performance.now() - startTime,\n timestamp: Date.now(),\n };\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n const alternatives = searchResponse.results\n .filter((r) => r !== searchResponse.bestMatch)\n .slice(0, this.config.maxAlternatives);\n\n return this.createFailureResponse(\n startTime,\n 'ACTION_FAILED',\n errorMessage,\n request.instruction,\n alternatives,\n threshold,\n searchCriteria,\n searchResponse.bestMatch\n );\n }\n }\n\n /**\n * Execute a parsed action directly (skip parsing)\n */\n async executeParsed(parsed: ParsedAction, threshold?: number): Promise<NLActionResponse> {\n const startTime = performance.now();\n const confidenceThreshold = threshold ?? this.config.defaultConfidenceThreshold;\n\n // Build search criteria\n const searchCriteria = this.buildSearchCriteria(parsed);\n\n // Search for element\n const searchResponse = this.searchEngine.search(searchCriteria);\n\n if (!searchResponse.bestMatch) {\n return this.createFailureResponse(\n startTime,\n 'ELEMENT_NOT_FOUND',\n `Could not find element: \"${parsed.targetDescription}\"`,\n parsed.rawInstruction,\n [],\n confidenceThreshold,\n searchCriteria\n );\n }\n\n if (searchResponse.bestMatch.confidence < confidenceThreshold) {\n return this.createFailureResponse(\n startTime,\n 'LOW_CONFIDENCE',\n `Best match confidence too low`,\n parsed.rawInstruction,\n searchResponse.results.slice(0, this.config.maxAlternatives),\n confidenceThreshold,\n searchCriteria,\n searchResponse.bestMatch\n );\n }\n\n // Execute\n try {\n const result = await this.performAction(\n parsed,\n searchResponse.bestMatch.element,\n this.config.defaultTimeout\n );\n\n return {\n success: true,\n executedAction: describeAction(parsed),\n elementUsed: searchResponse.bestMatch.element,\n confidence: searchResponse.bestMatch.confidence,\n elementState: result.elementState,\n durationMs: performance.now() - startTime,\n timestamp: Date.now(),\n };\n } catch (error) {\n return this.createFailureResponse(\n startTime,\n 'ACTION_FAILED',\n error instanceof Error ? error.message : String(error),\n parsed.rawInstruction,\n searchResponse.results\n .filter((r) => r !== searchResponse.bestMatch)\n .slice(0, this.config.maxAlternatives),\n confidenceThreshold,\n searchCriteria,\n searchResponse.bestMatch\n );\n }\n }\n\n /**\n * Build search criteria from a parsed action\n */\n private buildSearchCriteria(parsed: ParsedAction): SearchCriteria {\n const criteria: SearchCriteria = {\n text: parsed.targetDescription,\n fuzzy: true,\n fuzzyThreshold: this.config.defaultConfidenceThreshold,\n };\n\n // Add type hints based on action\n switch (parsed.action) {\n case 'click':\n case 'doubleClick':\n case 'rightClick':\n // Could be button or link\n break;\n case 'type':\n case 'clear':\n // Should be an input\n criteria.type = 'input';\n break;\n case 'select':\n criteria.type = 'select';\n break;\n case 'check':\n case 'uncheck':\n criteria.type = 'checkbox';\n break;\n }\n\n return criteria;\n }\n\n /**\n * Perform the actual action on an element\n */\n private async performAction(\n parsed: ParsedAction,\n element: AIDiscoveredElement,\n timeout: number\n ): Promise<{ elementState: ElementState }> {\n if (!this.actionExecutor) {\n throw new Error('No action executor configured');\n }\n\n // Map parsed action to standard action\n const actionMap: Record<ParsedAction['action'], StandardAction | null> = {\n click: 'click',\n doubleClick: 'doubleClick',\n rightClick: 'rightClick',\n type: 'type',\n select: 'select',\n check: 'check',\n uncheck: 'uncheck',\n scroll: 'scroll',\n wait: null, // Special handling\n assert: null, // Special handling\n hover: 'hover',\n focus: 'focus',\n clear: 'clear',\n };\n\n const standardAction = actionMap[parsed.action];\n\n if (!standardAction) {\n // Handle special actions\n if (parsed.action === 'wait') {\n const waitResult = await this.actionExecutor.waitFor(element.id, {\n visible: true,\n timeout,\n });\n if (!waitResult.met) {\n throw new Error(waitResult.error || 'Wait condition not met');\n }\n return { elementState: waitResult.state! };\n }\n\n if (parsed.action === 'assert') {\n // Assertions are handled by the assertions module\n throw new Error('Use the assertions module for assert actions');\n }\n\n throw new Error(`Unsupported action: ${parsed.action}`);\n }\n\n // Build action request\n const actionRequest: {\n action: StandardAction;\n params?: Record<string, unknown>;\n waitOptions?: { visible?: boolean; enabled?: boolean; timeout?: number };\n } = {\n action: standardAction,\n waitOptions: {\n visible: true,\n enabled: true,\n timeout,\n },\n };\n\n // Add action-specific params\n if (standardAction === 'type' && parsed.value) {\n actionRequest.params = { text: parsed.value };\n } else if (standardAction === 'select' && parsed.value) {\n actionRequest.params = { value: parsed.value };\n } else if (standardAction === 'scroll' && parsed.scrollDirection) {\n actionRequest.params = { direction: parsed.scrollDirection };\n }\n\n // Execute the action\n const response = await this.actionExecutor.executeAction(element.id, actionRequest);\n\n if (!response.success) {\n throw new Error(response.error || 'Action failed');\n }\n\n return { elementState: response.elementState! };\n }\n\n /**\n * Create a failure response with suggestions\n */\n private createFailureResponse(\n startTime: number,\n errorCode: string,\n errorMessage: string,\n instruction: string,\n alternatives: SearchResult[],\n threshold: number,\n searchCriteria?: SearchCriteria,\n nearestMatch?: SearchResult\n ): NLActionResponse {\n // Generate suggestions\n const suggestions = this.generateSuggestions(\n errorCode,\n instruction,\n alternatives,\n nearestMatch\n );\n\n // Create a dummy element for the response\n const dummyElement: AIDiscoveredElement = nearestMatch?.element || {\n id: 'not-found',\n type: 'unknown',\n tagName: 'unknown',\n actions: [],\n state: {\n visible: false,\n enabled: false,\n focused: false,\n rect: { x: 0, y: 0, width: 0, height: 0, top: 0, right: 0, bottom: 0, left: 0 },\n },\n registered: false,\n description: 'Element not found',\n aliases: [],\n suggestedActions: [],\n };\n\n return {\n success: false,\n executedAction: instruction,\n elementUsed: dummyElement,\n confidence: nearestMatch?.confidence || 0,\n elementState: dummyElement.state,\n durationMs: performance.now() - startTime,\n timestamp: Date.now(),\n error: errorMessage,\n errorCode,\n suggestions,\n alternatives: alternatives.slice(0, this.config.maxAlternatives),\n };\n }\n\n /**\n * Generate recovery suggestions\n */\n private generateSuggestions(\n errorCode: string,\n instruction: string,\n alternatives: SearchResult[],\n nearestMatch?: SearchResult\n ): string[] {\n const suggestions: string[] = [];\n\n switch (errorCode) {\n case 'PARSE_ERROR':\n suggestions.push('Try using a simpler phrase like \"click Submit button\"');\n suggestions.push(\n 'Ensure the instruction follows patterns like \"click X\" or \"type Y into X\"'\n );\n break;\n\n case 'ELEMENT_NOT_FOUND':\n if (alternatives.length > 0) {\n suggestions.push(`Did you mean: \"${alternatives[0].element.description}\"?`);\n }\n suggestions.push('Check if the element is visible on the page');\n suggestions.push('Try using a more specific description');\n break;\n\n case 'LOW_CONFIDENCE':\n if (nearestMatch) {\n suggestions.push(\n `Found \"${nearestMatch.element.description}\" with ${(nearestMatch.confidence * 100).toFixed(0)}% confidence`\n );\n }\n suggestions.push('Try using the exact text shown on the element');\n suggestions.push('Lower the confidence threshold if this match is correct');\n break;\n\n case 'ACTION_FAILED':\n suggestions.push('Check if the element is enabled');\n suggestions.push('Wait for any loading to complete');\n suggestions.push('Ensure no modal or overlay is blocking the element');\n break;\n\n default:\n suggestions.push('Try a different approach or check the page state');\n }\n\n return suggestions;\n }\n\n /**\n * Get rich error context for debugging\n */\n getErrorContext(\n errorCode: string,\n instruction: string,\n searchCriteria?: SearchCriteria,\n nearestMatch?: SearchResult\n ): AIErrorContext {\n return createErrorContext(\n errorCode as keyof typeof ErrorCodes,\n instruction,\n this.elements,\n searchCriteria,\n nearestMatch\n );\n }\n}\n\n/**\n * Create a default NL action executor\n */\nexport function createNLActionExecutor(config?: Partial<NLActionExecutorConfig>): NLActionExecutor {\n return new NLActionExecutor(config);\n}\n","/**\n * Assertions Module\n *\n * Provides verification/assertion API for AI agents to validate\n * page state without writing Playwright tests.\n */\n\nimport type { ElementState } from '../core/types';\nimport type { DiscoveredElement } from '../control/types';\nimport type {\n AssertionRequest,\n AssertionResult,\n BatchAssertionRequest,\n BatchAssertionResult,\n SearchCriteria,\n SearchResult,\n AIDiscoveredElement,\n} from './types';\nimport { SearchEngine } from './search-engine';\n\n/**\n * Configuration for assertions\n */\nexport interface AssertionConfig {\n /** Default timeout for wait-based assertions */\n defaultTimeout: number;\n /** Polling interval for wait-based assertions */\n pollInterval: number;\n /** Default fuzzy threshold for element search */\n fuzzyThreshold: number;\n /** Include suggestions in failure messages */\n includeSuggestions: boolean;\n}\n\n/**\n * Default assertion configuration\n */\nexport const DEFAULT_ASSERTION_CONFIG: AssertionConfig = {\n defaultTimeout: 5000,\n pollInterval: 100,\n fuzzyThreshold: 0.7,\n includeSuggestions: true,\n};\n\n/**\n * Assertion executor class\n */\nexport class AssertionExecutor {\n private config: AssertionConfig;\n private searchEngine: SearchEngine;\n private elements: Array<DiscoveredElement | AIDiscoveredElement> = [];\n\n constructor(config: Partial<AssertionConfig> = {}) {\n this.config = { ...DEFAULT_ASSERTION_CONFIG, ...config };\n this.searchEngine = new SearchEngine({ fuzzyThreshold: this.config.fuzzyThreshold });\n }\n\n /**\n * Update available elements for assertions\n */\n updateElements(elements: Array<DiscoveredElement | AIDiscoveredElement>): void {\n this.elements = elements;\n this.searchEngine.updateElements(elements);\n }\n\n /**\n * Execute a single assertion\n */\n async assert(request: AssertionRequest): Promise<AssertionResult> {\n const startTime = performance.now();\n const timeout = request.timeout ?? this.config.defaultTimeout;\n\n // Find the target element with full search metadata\n const searchResult = this.findElementDetailed(request.target, request.fuzzy !== false);\n const element = searchResult?.element ?? null;\n const searchDetails = searchResult\n ? {\n confidence: searchResult.confidence,\n matchReasons: searchResult.matchReasons,\n candidateCount: this.elements.length,\n }\n : undefined;\n\n if (!element && request.type !== 'notExists') {\n const result = this.createResult(\n false,\n typeof request.target === 'string' ? request.target : JSON.stringify(request.target),\n 'element not found',\n request.type === 'exists' ? true : request.expected,\n null,\n 'Element could not be found',\n this.config.includeSuggestions\n ? 'Check if the element exists and is properly labeled'\n : undefined,\n startTime\n );\n // Attach search details even for not-found (candidateCount helps AI understand scope)\n if (searchDetails) {\n result.searchDetails = searchDetails;\n }\n return result;\n }\n\n // Execute the assertion based on type\n const result = await this.executeAssertion(request, element, timeout, startTime);\n // Attach search details to the result\n if (searchDetails) {\n result.searchDetails = searchDetails;\n }\n return result;\n }\n\n /**\n * Execute multiple assertions\n */\n async assertBatch(request: BatchAssertionRequest): Promise<BatchAssertionResult> {\n const startTime = performance.now();\n const results: AssertionResult[] = [];\n let passedCount = 0;\n let failedCount = 0;\n\n for (const assertion of request.assertions) {\n const result = await this.assert(assertion);\n results.push(result);\n\n if (result.passed) {\n passedCount++;\n } else {\n failedCount++;\n\n // Stop on first failure if configured\n if (request.stopOnFailure) {\n // Mark remaining assertions as skipped\n break;\n }\n }\n }\n\n // Determine overall pass/fail\n const passed = request.mode === 'all' ? failedCount === 0 : passedCount > 0;\n\n return {\n passed,\n results,\n passedCount,\n failedCount,\n durationMs: performance.now() - startTime,\n timestamp: Date.now(),\n };\n }\n\n /**\n * Convenience method: assert element is visible\n */\n async assertVisible(target: string | SearchCriteria, timeout?: number): Promise<AssertionResult> {\n return this.assert({ target, type: 'visible', timeout });\n }\n\n /**\n * Convenience method: assert element is hidden\n */\n async assertHidden(target: string | SearchCriteria, timeout?: number): Promise<AssertionResult> {\n return this.assert({ target, type: 'hidden', timeout });\n }\n\n /**\n * Convenience method: assert element is enabled\n */\n async assertEnabled(target: string | SearchCriteria, timeout?: number): Promise<AssertionResult> {\n return this.assert({ target, type: 'enabled', timeout });\n }\n\n /**\n * Convenience method: assert element is disabled\n */\n async assertDisabled(\n target: string | SearchCriteria,\n timeout?: number\n ): Promise<AssertionResult> {\n return this.assert({ target, type: 'disabled', timeout });\n }\n\n /**\n * Convenience method: assert element has text\n */\n async assertHasText(\n target: string | SearchCriteria,\n text: string,\n timeout?: number\n ): Promise<AssertionResult> {\n return this.assert({ target, type: 'hasText', expected: text, timeout });\n }\n\n /**\n * Convenience method: assert element contains text\n */\n async assertContainsText(\n target: string | SearchCriteria,\n text: string,\n timeout?: number\n ): Promise<AssertionResult> {\n return this.assert({ target, type: 'containsText', expected: text, timeout });\n }\n\n /**\n * Convenience method: assert element has value\n */\n async assertHasValue(\n target: string | SearchCriteria,\n value: string,\n timeout?: number\n ): Promise<AssertionResult> {\n return this.assert({ target, type: 'hasValue', expected: value, timeout });\n }\n\n /**\n * Convenience method: assert element exists\n */\n async assertExists(target: string | SearchCriteria, timeout?: number): Promise<AssertionResult> {\n return this.assert({ target, type: 'exists', timeout });\n }\n\n /**\n * Convenience method: assert element does not exist\n */\n async assertNotExists(\n target: string | SearchCriteria,\n timeout?: number\n ): Promise<AssertionResult> {\n return this.assert({ target, type: 'notExists', timeout });\n }\n\n /**\n * Convenience method: assert checkbox is checked\n */\n async assertChecked(target: string | SearchCriteria, timeout?: number): Promise<AssertionResult> {\n return this.assert({ target, type: 'checked', timeout });\n }\n\n /**\n * Convenience method: assert checkbox is unchecked\n */\n async assertUnchecked(\n target: string | SearchCriteria,\n timeout?: number\n ): Promise<AssertionResult> {\n return this.assert({ target, type: 'unchecked', timeout });\n }\n\n /**\n * Convenience method: assert element count\n */\n async assertCount(\n target: SearchCriteria,\n expectedCount: number,\n timeout?: number\n ): Promise<AssertionResult> {\n return this.assert({ target, type: 'count', expected: expectedCount, timeout });\n }\n\n /**\n * Find element by target with full search metadata.\n * Returns the SearchResult (including confidence, matchReasons, scores)\n * or null if no match above the fuzzy threshold.\n */\n private findElementDetailed(\n target: string | SearchCriteria,\n fuzzy: boolean = true\n ): SearchResult | null {\n const criteria: SearchCriteria =\n typeof target === 'string' ? { text: target, fuzzy } : { ...target, fuzzy };\n\n const searchResult = this.searchEngine.findBest(criteria, this.elements);\n\n if (searchResult && searchResult.confidence >= this.config.fuzzyThreshold) {\n return searchResult;\n }\n\n return null;\n }\n\n /**\n * Find element by target (string or criteria).\n * Public for use by condition evaluation in SpecExecutor.\n */\n public async findElement(\n target: string | SearchCriteria,\n fuzzy: boolean = true\n ): Promise<AIDiscoveredElement | null> {\n const result = this.findElementDetailed(target, fuzzy);\n return result?.element ?? null;\n }\n\n /**\n * Execute the actual assertion\n */\n private async executeAssertion(\n request: AssertionRequest,\n element: AIDiscoveredElement | null,\n timeout: number,\n startTime: number\n ): Promise<AssertionResult> {\n const targetStr =\n typeof request.target === 'string' ? request.target : JSON.stringify(request.target);\n\n const elementDescription = element?.description || targetStr;\n\n switch (request.type) {\n case 'visible':\n return this.assertVisibility(\n element!,\n true,\n elementDescription,\n request.message,\n startTime\n );\n\n case 'hidden':\n return this.assertVisibility(\n element!,\n false,\n elementDescription,\n request.message,\n startTime\n );\n\n case 'enabled':\n return this.assertEnabledState(\n element!,\n true,\n elementDescription,\n request.message,\n startTime\n );\n\n case 'disabled':\n return this.assertEnabledState(\n element!,\n false,\n elementDescription,\n request.message,\n startTime\n );\n\n case 'focused':\n return this.assertFocused(element!, elementDescription, request.message, startTime);\n\n case 'checked':\n return this.assertCheckedState(\n element!,\n true,\n elementDescription,\n request.message,\n startTime\n );\n\n case 'unchecked':\n return this.assertCheckedState(\n element!,\n false,\n elementDescription,\n request.message,\n startTime\n );\n\n case 'hasText':\n return this.assertTextMatch(\n element!,\n request.expected as string,\n true,\n elementDescription,\n request.message,\n startTime\n );\n\n case 'containsText':\n return this.assertTextMatch(\n element!,\n request.expected as string,\n false,\n elementDescription,\n request.message,\n startTime\n );\n\n case 'hasValue':\n return this.assertValue(\n element!,\n request.expected as string,\n elementDescription,\n request.message,\n startTime\n );\n\n case 'exists':\n return this.createResult(\n element !== null,\n targetStr,\n elementDescription,\n true,\n element !== null,\n element === null ? 'Element does not exist' : undefined,\n undefined,\n startTime,\n element?.state\n );\n\n case 'notExists':\n return this.createResult(\n element === null,\n targetStr,\n elementDescription,\n false,\n element === null,\n element !== null ? 'Element exists but should not' : undefined,\n undefined,\n startTime,\n element?.state\n );\n\n case 'count':\n return this.assertElementCount(\n request.target as SearchCriteria,\n request.expected as number,\n targetStr,\n request.message,\n startTime\n );\n\n case 'attribute':\n return this.assertAttribute(\n element!,\n request.attributeName!,\n request.expected,\n elementDescription,\n request.message,\n startTime\n );\n\n case 'hasClass':\n return this.assertHasClass(\n element!,\n request.expected as string,\n elementDescription,\n request.message,\n startTime\n );\n\n case 'cssProperty':\n return this.assertCssProperty(\n element!,\n request.propertyName!,\n request.expected,\n elementDescription,\n request.message,\n startTime\n );\n\n default:\n return this.createResult(\n false,\n targetStr,\n elementDescription,\n undefined,\n undefined,\n `Unknown assertion type: ${request.type}`,\n undefined,\n startTime\n );\n }\n }\n\n /**\n * Assert visibility state\n */\n private assertVisibility(\n element: AIDiscoveredElement,\n expectedVisible: boolean,\n description: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n const isVisible = element.state.visible;\n const passed = isVisible === expectedVisible;\n\n return this.createResult(\n passed,\n element.id,\n description,\n expectedVisible,\n isVisible,\n passed\n ? undefined\n : message ||\n `Element is ${isVisible ? 'visible' : 'hidden'} but expected ${expectedVisible ? 'visible' : 'hidden'}`,\n passed ? undefined : 'Check if element is covered by another element or has display:none',\n startTime,\n element.state\n );\n }\n\n /**\n * Assert enabled state\n */\n private assertEnabledState(\n element: AIDiscoveredElement,\n expectedEnabled: boolean,\n description: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n const isEnabled = element.state.enabled;\n const passed = isEnabled === expectedEnabled;\n\n return this.createResult(\n passed,\n element.id,\n description,\n expectedEnabled,\n isEnabled,\n passed\n ? undefined\n : message ||\n `Element is ${isEnabled ? 'enabled' : 'disabled'} but expected ${expectedEnabled ? 'enabled' : 'disabled'}`,\n passed ? undefined : 'Check if the element has a disabled attribute or aria-disabled',\n startTime,\n element.state\n );\n }\n\n /**\n * Assert focused state\n */\n private assertFocused(\n element: AIDiscoveredElement,\n description: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n const isFocused = element.state.focused;\n\n return this.createResult(\n isFocused,\n element.id,\n description,\n true,\n isFocused,\n isFocused ? undefined : message || 'Element is not focused',\n isFocused ? undefined : 'Click or focus the element first',\n startTime,\n element.state\n );\n }\n\n /**\n * Assert checked state\n */\n private assertCheckedState(\n element: AIDiscoveredElement,\n expectedChecked: boolean,\n description: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n const isChecked = element.state.checked ?? false;\n const passed = isChecked === expectedChecked;\n\n return this.createResult(\n passed,\n element.id,\n description,\n expectedChecked,\n isChecked,\n passed\n ? undefined\n : message ||\n `Element is ${isChecked ? 'checked' : 'unchecked'} but expected ${expectedChecked ? 'checked' : 'unchecked'}`,\n passed ? undefined : 'Click the checkbox to change its state',\n startTime,\n element.state\n );\n }\n\n /**\n * Assert text content\n */\n private assertTextMatch(\n element: AIDiscoveredElement,\n expectedText: string,\n exact: boolean,\n description: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n const actualText = element.state.textContent || '';\n const passed = exact ? actualText === expectedText : actualText.includes(expectedText);\n\n return this.createResult(\n passed,\n element.id,\n description,\n expectedText,\n actualText,\n passed\n ? undefined\n : message ||\n (exact\n ? `Text \"${actualText}\" does not match expected \"${expectedText}\"`\n : `Text \"${actualText}\" does not contain \"${expectedText}\"`),\n passed ? undefined : 'Verify the element contains the expected text',\n startTime,\n element.state\n );\n }\n\n /**\n * Assert input value\n */\n private assertValue(\n element: AIDiscoveredElement,\n expectedValue: string,\n description: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n const actualValue = element.state.value || '';\n const passed = actualValue === expectedValue;\n\n return this.createResult(\n passed,\n element.id,\n description,\n expectedValue,\n actualValue,\n passed\n ? undefined\n : message || `Value \"${actualValue}\" does not match expected \"${expectedValue}\"`,\n passed ? undefined : 'Type the expected value into the input',\n startTime,\n element.state\n );\n }\n\n /**\n * Assert element count\n */\n private assertElementCount(\n criteria: SearchCriteria,\n expectedCount: number,\n targetStr: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n const searchResponse = this.searchEngine.search(criteria);\n const actualCount = searchResponse.results.length;\n const passed = actualCount === expectedCount;\n\n return this.createResult(\n passed,\n targetStr,\n `${actualCount} elements matching criteria`,\n expectedCount,\n actualCount,\n passed ? undefined : message || `Found ${actualCount} elements but expected ${expectedCount}`,\n passed ? undefined : 'Adjust search criteria or wait for elements to load',\n startTime\n );\n }\n\n /**\n * Assert attribute value (placeholder for DOM attribute assertions)\n */\n private assertAttribute(\n element: AIDiscoveredElement,\n attributeName: string,\n expectedValue: unknown,\n description: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n // Note: Would need DOM access for actual attribute checking\n // For now, handle known attributes from state\n let actualValue: unknown;\n\n switch (attributeName.toLowerCase()) {\n case 'placeholder':\n actualValue = element.placeholder;\n break;\n case 'title':\n actualValue = element.title;\n break;\n default:\n return this.createResult(\n false,\n element.id,\n description,\n expectedValue,\n undefined,\n `Cannot check attribute \"${attributeName}\" without DOM access`,\n 'Use the server API to check element attributes',\n startTime,\n element.state\n );\n }\n\n const passed = actualValue === expectedValue;\n\n return this.createResult(\n passed,\n element.id,\n description,\n expectedValue,\n actualValue,\n passed\n ? undefined\n : message ||\n `Attribute \"${attributeName}\" is \"${actualValue}\" but expected \"${expectedValue}\"`,\n undefined,\n startTime,\n element.state\n );\n }\n\n /**\n * Assert element has CSS class\n */\n private assertHasClass(\n element: AIDiscoveredElement,\n className: string,\n description: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n // Note: Would need DOM access for actual class checking\n return this.createResult(\n false,\n element.id,\n description,\n className,\n undefined,\n 'Cannot check CSS classes without DOM access',\n 'Use the server API to check element classes',\n startTime,\n element.state\n );\n }\n\n /**\n * Assert CSS property value\n */\n private assertCssProperty(\n element: AIDiscoveredElement,\n propertyName: string,\n expectedValue: unknown,\n description: string,\n message?: string,\n startTime: number = performance.now()\n ): AssertionResult {\n const computedStyles = element.state.computedStyles;\n if (!computedStyles) {\n return this.createResult(\n false,\n element.id,\n description,\n expectedValue,\n undefined,\n 'Computed styles not available',\n 'Request element state with computed styles',\n startTime,\n element.state\n );\n }\n\n const styleKey = propertyName as keyof typeof computedStyles;\n const actualValue = computedStyles[styleKey];\n const passed = actualValue === expectedValue;\n\n return this.createResult(\n passed,\n element.id,\n description,\n expectedValue,\n actualValue,\n passed\n ? undefined\n : message ||\n `CSS property \"${propertyName}\" is \"${actualValue}\" but expected \"${expectedValue}\"`,\n undefined,\n startTime,\n element.state\n );\n }\n\n /**\n * Create an assertion result\n */\n private createResult(\n passed: boolean,\n target: string,\n targetDescription: string,\n expected: unknown,\n actual: unknown,\n failureReason?: string,\n suggestion?: string,\n startTime: number = performance.now(),\n elementState?: ElementState\n ): AssertionResult {\n return {\n passed,\n target,\n targetDescription,\n expected,\n actual,\n failureReason,\n suggestion: this.config.includeSuggestions ? suggestion : undefined,\n elementState,\n durationMs: performance.now() - startTime,\n timestamp: Date.now(),\n };\n }\n}\n\n/**\n * Create a default assertion executor\n */\nexport function createAssertionExecutor(config?: Partial<AssertionConfig>): AssertionExecutor {\n return new AssertionExecutor(config);\n}\n","/**\n * Semantic Snapshot\n *\n * Creates enhanced state snapshots with AI-friendly element descriptions,\n * form analysis, and modal detection.\n */\n\nimport type { ControlSnapshot } from '../control/types';\nimport type {\n SemanticSnapshot,\n AIDiscoveredElement,\n PageContext,\n FormState,\n FormFieldState,\n ModalState,\n} from './types';\nimport { SearchEngine } from './search-engine';\nimport { generatePageSummary, inferPageType } from './summary-generator';\nimport {\n generateAliases,\n generateDescription,\n generatePurpose,\n generateSuggestedActions,\n} from './alias-generator';\nimport { getGlobalAnnotationStore } from '../annotations';\n\n/**\n * Configuration for semantic snapshots\n */\nexport interface SemanticSnapshotConfig {\n /** Include form analysis */\n analyzeForms: boolean;\n /** Include modal detection */\n detectModals: boolean;\n /** Include page type inference */\n inferPageType: boolean;\n /** Generate element descriptions */\n generateDescriptions: boolean;\n /** Maximum elements to include */\n maxElements: number;\n /** Merge annotations from the annotation store (default: true) */\n useAnnotations: boolean;\n}\n\n/**\n * Default snapshot configuration\n */\nexport const DEFAULT_SNAPSHOT_CONFIG: SemanticSnapshotConfig = {\n analyzeForms: true,\n detectModals: true,\n inferPageType: true,\n generateDescriptions: true,\n maxElements: 500,\n useAnnotations: true,\n};\n\n/**\n * Snapshot history for diffing\n */\ninterface SnapshotHistory {\n snapshot: SemanticSnapshot;\n timestamp: number;\n}\n\n/**\n * Semantic Snapshot Manager\n */\nexport class SemanticSnapshotManager {\n private config: SemanticSnapshotConfig;\n private searchEngine: SearchEngine;\n private history: SnapshotHistory[] = [];\n private readonly maxHistorySize = 10;\n private snapshotCounter = 0;\n\n constructor(config: Partial<SemanticSnapshotConfig> = {}) {\n this.config = { ...DEFAULT_SNAPSHOT_CONFIG, ...config };\n this.searchEngine = new SearchEngine();\n }\n\n /**\n * Create a semantic snapshot from a control snapshot\n */\n createSnapshot(\n controlSnapshot: ControlSnapshot,\n pageContext?: Partial<PageContext>\n ): SemanticSnapshot {\n const snapshotId = `snapshot-${++this.snapshotCounter}-${Date.now()}`;\n\n // Convert elements to AI elements\n const aiElements = this.convertElements(controlSnapshot.elements);\n\n // Update search engine\n this.searchEngine.updateElements(aiElements);\n\n // Build page context\n const fullPageContext = this.buildPageContext(aiElements, pageContext);\n\n // Analyze forms\n const forms = this.config.analyzeForms ? this.analyzeForms(aiElements) : [];\n\n // Detect modals\n const modals = this.config.detectModals ? this.detectModals(aiElements) : [];\n\n // Count elements by type\n const elementCounts = this.countElementTypes(aiElements);\n\n // Generate summary\n const summary = generatePageSummary(aiElements, fullPageContext);\n\n // Find focused element\n const focusedElement = aiElements.find((el) => el.state.focused)?.id;\n\n const snapshot: SemanticSnapshot = {\n timestamp: Date.now(),\n snapshotId,\n page: fullPageContext,\n elements: aiElements.slice(0, this.config.maxElements),\n forms,\n activeModals: modals,\n focusedElement,\n summary,\n elementCounts,\n };\n\n // Add to history\n this.addToHistory(snapshot);\n\n return snapshot;\n }\n\n /**\n * Get the last snapshot\n */\n getLastSnapshot(): SemanticSnapshot | null {\n if (this.history.length === 0) return null;\n return this.history[this.history.length - 1].snapshot;\n }\n\n /**\n * Get snapshot by ID\n */\n getSnapshot(snapshotId: string): SemanticSnapshot | null {\n const entry = this.history.find((h) => h.snapshot.snapshotId === snapshotId);\n return entry?.snapshot || null;\n }\n\n /**\n * Get snapshot history\n */\n getHistory(): SemanticSnapshot[] {\n return this.history.map((h) => h.snapshot);\n }\n\n /**\n * Clear history\n */\n clearHistory(): void {\n this.history = [];\n }\n\n /**\n * Convert control snapshot elements to AI elements\n */\n private convertElements(elements: ControlSnapshot['elements']): AIDiscoveredElement[] {\n return elements.map((el) => this.convertElement(el));\n }\n\n /**\n * Convert a single element to AI element\n */\n private convertElement(element: ControlSnapshot['elements'][0]): AIDiscoveredElement {\n const isContent = element.category === 'content';\n\n const aliases = generateAliases({\n textContent: element.state.textContent,\n elementType: element.type,\n id: element.id,\n labelText: element.label,\n });\n\n // Generate content-specific descriptions\n let description: string;\n if (isContent && element.contentMetadata) {\n description = this.generateContentDescription(element);\n } else if (this.config.generateDescriptions) {\n description = generateDescription({\n textContent: element.state.textContent,\n elementType: element.type,\n id: element.id,\n labelText: element.label,\n });\n } else {\n description = element.label || element.id;\n }\n\n const purpose = isContent\n ? generatePurpose({ textContent: element.state.textContent, elementType: element.type })\n : generatePurpose({ textContent: element.state.textContent, elementType: element.type });\n\n const suggestedActions = isContent\n ? generateSuggestedActions({\n textContent: element.state.textContent,\n elementType: element.type,\n })\n : generateSuggestedActions({\n textContent: element.state.textContent,\n elementType: element.type,\n });\n\n // Merge annotation overrides (explicit > inferred)\n let finalDescription = description;\n let finalPurpose = purpose;\n let finalAliases = aliases;\n\n if (this.config.useAnnotations) {\n const annotation = getGlobalAnnotationStore().get(element.id);\n if (annotation) {\n if (annotation.description) {\n finalDescription = annotation.description;\n }\n if (annotation.purpose) {\n finalPurpose = annotation.purpose;\n }\n if (annotation.tags && annotation.tags.length > 0) {\n // Merge tags into aliases additively\n const tagSet = new Set([...finalAliases, ...annotation.tags.map((t) => t.toLowerCase())]);\n finalAliases = [...tagSet];\n }\n }\n }\n\n return {\n id: element.id,\n type: element.type,\n label: element.label,\n tagName: this.inferTagName(element.type),\n role: this.inferRole(element.type),\n accessibleName: element.label || element.state.textContent?.trim(),\n actions: element.actions,\n state: element.state,\n registered: true,\n description: finalDescription,\n aliases: finalAliases,\n purpose: finalPurpose,\n suggestedActions,\n semanticType: this.inferSemanticType(element),\n category: element.category,\n contentMetadata: element.contentMetadata,\n };\n }\n\n /**\n * Generate a content-specific description\n */\n private generateContentDescription(element: ControlSnapshot['elements'][0]): string {\n const meta = element.contentMetadata;\n const text = element.state.textContent?.trim() || '';\n const truncatedText = text.length > 60 ? text.substring(0, 57) + '...' : text;\n\n if (!meta) return `\"${truncatedText}\"`;\n\n switch (meta.contentRole) {\n case 'heading':\n return `Level ${meta.headingLevel || '?'} heading: '${truncatedText}'`;\n case 'table-cell':\n return `Table cell${meta.structuralContext ? ` (${meta.structuralContext})` : ''}: '${truncatedText}'`;\n case 'table-header':\n return `Table header${meta.structuralContext ? ` (${meta.structuralContext})` : ''}: '${truncatedText}'`;\n case 'status':\n return `Status message: '${truncatedText}'`;\n case 'badge':\n return `Badge: '${truncatedText}'`;\n case 'metric':\n return `Metric value: '${truncatedText}'`;\n case 'body-text':\n return `Text: '${truncatedText}'`;\n case 'list-item':\n return `List item: '${truncatedText}'`;\n case 'quote':\n return `Blockquote: '${truncatedText}'`;\n case 'code':\n return `Code block: '${truncatedText}'`;\n case 'caption':\n return `Caption: '${truncatedText}'`;\n case 'label':\n return `Label: '${truncatedText}'`;\n case 'description':\n return `Description: '${truncatedText}'`;\n case 'navigation':\n return `Navigation text: '${truncatedText}'`;\n default:\n return `Content: '${truncatedText}'`;\n }\n }\n\n /**\n * Build full page context\n */\n private buildPageContext(\n elements: AIDiscoveredElement[],\n partial?: Partial<PageContext>\n ): PageContext {\n const url = partial?.url || (typeof window !== 'undefined' ? window.location.href : '');\n const title = partial?.title || (typeof document !== 'undefined' ? document.title : '');\n\n const pageType = this.config.inferPageType\n ? inferPageType(url, title, elements)\n : partial?.pageType || 'unknown';\n\n // Detect active modals from elements\n const activeModals = elements\n .filter((el) => el.type === 'dialog' && el.state.visible)\n .map((el) => el.id);\n\n return {\n url,\n title,\n pageType,\n activeModals: partial?.activeModals || activeModals,\n focusedElement: partial?.focusedElement || elements.find((el) => el.state.focused)?.id,\n navigation: partial?.navigation,\n };\n }\n\n /**\n * Analyze forms in the snapshot\n */\n private analyzeForms(elements: AIDiscoveredElement[]): FormState[] {\n const forms: FormState[] = [];\n\n // Find form elements\n const formElements = elements.filter((el) => el.type === 'form');\n\n // If no explicit forms, try to detect implicit forms\n if (formElements.length === 0) {\n const implicitForm = this.detectImplicitForm(elements);\n if (implicitForm) {\n forms.push(implicitForm);\n }\n } else {\n for (const form of formElements) {\n const formState = this.analyzeForm(form, elements);\n if (formState) {\n forms.push(formState);\n }\n }\n }\n\n return forms;\n }\n\n /**\n * Detect implicit form from inputs\n */\n private detectImplicitForm(elements: AIDiscoveredElement[]): FormState | null {\n const inputs = elements.filter(\n (el) =>\n el.type === 'input' ||\n el.type === 'textarea' ||\n el.type === 'select' ||\n el.type === 'checkbox'\n );\n\n if (inputs.length === 0) return null;\n\n // Find potential submit button\n const submitButton = elements.find(\n (el) =>\n el.type === 'button' &&\n el.state.visible &&\n (el.semanticType === 'submit-button' ||\n el.state.textContent?.toLowerCase().match(/submit|save|send|continue/))\n );\n\n const fields = this.analyzeFormFields(inputs);\n const hasErrors = fields.some((f) => !f.valid);\n\n return {\n id: 'implicit-form',\n purpose: this.inferFormPurpose(inputs),\n fields,\n isValid: !hasErrors,\n submitButton: submitButton?.id,\n isDirty: fields.some((f) => f.value !== '' && f.touched),\n };\n }\n\n /**\n * Analyze a specific form\n */\n private analyzeForm(\n form: AIDiscoveredElement,\n allElements: AIDiscoveredElement[]\n ): FormState | null {\n // Find form fields (simplified - would need DOM relationship data)\n const inputs = allElements.filter(\n (el) =>\n (el.type === 'input' || el.type === 'textarea' || el.type === 'select') && el.state.visible\n );\n\n const fields = this.analyzeFormFields(inputs);\n const hasErrors = fields.some((f) => !f.valid);\n\n // Find submit button\n const submitButton = allElements.find(\n (el) => el.type === 'button' && el.state.visible && el.semanticType === 'submit-button'\n );\n\n return {\n id: form.id,\n name: form.label,\n purpose: form.purpose,\n fields,\n isValid: !hasErrors,\n submitButton: submitButton?.id,\n isDirty: fields.some((f) => f.value !== ''),\n };\n }\n\n /**\n * Analyze form fields\n */\n private analyzeFormFields(inputs: AIDiscoveredElement[]): FormFieldState[] {\n return inputs.map((input) => ({\n id: input.id,\n label: input.accessibleName || input.label || input.id,\n type: input.type,\n value: input.state.value || '',\n valid: true, // Would need validation state\n required: false, // Would need DOM access\n touched: input.state.focused || (input.state.value?.length || 0) > 0,\n }));\n }\n\n /**\n * Detect modal dialogs\n */\n private detectModals(elements: AIDiscoveredElement[]): ModalState[] {\n const modals: ModalState[] = [];\n\n // Find dialog elements\n const dialogElements = elements.filter((el) => el.type === 'dialog' && el.state.visible);\n\n for (const dialog of dialogElements) {\n // Try to find close button within dialog context\n const closeButton = elements.find(\n (el) =>\n el.type === 'button' &&\n el.state.visible &&\n (el.semanticType === 'cancel-button' ||\n el.state.textContent?.toLowerCase().match(/close|cancel|x|dismiss/))\n );\n\n // Try to find primary action\n const primaryAction = elements.find(\n (el) => el.type === 'button' && el.state.visible && el.semanticType === 'submit-button'\n );\n\n modals.push({\n id: dialog.id,\n title: dialog.accessibleName || dialog.label,\n type: this.inferModalType(dialog),\n blocking: true, // Assume dialogs are blocking\n closeButton: closeButton?.id,\n primaryAction: primaryAction?.id,\n });\n }\n\n return modals;\n }\n\n /**\n * Infer modal type\n */\n private inferModalType(dialog: AIDiscoveredElement): ModalState['type'] {\n const text = (dialog.accessibleName || dialog.state.textContent || '').toLowerCase();\n\n if (text.includes('alert') || text.includes('warning') || text.includes('error')) {\n return 'alert';\n }\n if (text.includes('confirm') || text.includes('are you sure')) {\n return 'confirm';\n }\n if (text.includes('prompt') || text.includes('enter')) {\n return 'prompt';\n }\n\n return 'dialog';\n }\n\n /**\n * Count elements by type\n */\n private countElementTypes(elements: AIDiscoveredElement[]): Record<string, number> {\n const counts: Record<string, number> = {};\n\n for (const el of elements) {\n const type = el.type.toLowerCase();\n counts[type] = (counts[type] || 0) + 1;\n }\n\n return counts;\n }\n\n /**\n * Infer form purpose from fields\n */\n private inferFormPurpose(fields: AIDiscoveredElement[]): string {\n const labels = fields.map((f) => (f.accessibleName || f.label || '').toLowerCase());\n const allLabels = labels.join(' ');\n\n if (allLabels.includes('email') && allLabels.includes('password')) {\n if (allLabels.includes('confirm') || allLabels.includes('name')) {\n return 'Registration';\n }\n return 'Login';\n }\n\n if (allLabels.includes('search')) return 'Search';\n if (allLabels.includes('address') || allLabels.includes('city')) return 'Address';\n if (allLabels.includes('card') || allLabels.includes('payment')) return 'Payment';\n if (allLabels.includes('contact') || allLabels.includes('message')) return 'Contact';\n\n return 'Form';\n }\n\n /**\n * Infer tag name from element type\n */\n private inferTagName(type: string): string {\n const typeMap: Record<string, string> = {\n button: 'button',\n input: 'input',\n textarea: 'textarea',\n select: 'select',\n checkbox: 'input',\n radio: 'input',\n link: 'a',\n form: 'form',\n dialog: 'dialog',\n };\n return typeMap[type] || 'div';\n }\n\n /**\n * Infer ARIA role from element type\n */\n private inferRole(type: string): string | undefined {\n const roleMap: Record<string, string> = {\n button: 'button',\n input: 'textbox',\n textarea: 'textbox',\n select: 'combobox',\n checkbox: 'checkbox',\n radio: 'radio',\n link: 'link',\n dialog: 'dialog',\n menu: 'menu',\n menuitem: 'menuitem',\n tab: 'tab',\n };\n return roleMap[type];\n }\n\n /**\n * Infer semantic type\n */\n private inferSemanticType(element: ControlSnapshot['elements'][0]): string {\n // Content elements use their contentRole as semantic type\n if (element.category === 'content' && element.contentMetadata) {\n const role = element.contentMetadata.contentRole;\n if (role === 'heading' && element.contentMetadata.headingLevel) {\n return `heading-${element.contentMetadata.headingLevel}`;\n }\n return role;\n }\n\n const text = (element.state.textContent || element.label || '').toLowerCase();\n const type = element.type.toLowerCase();\n\n if (type === 'button') {\n if (text.match(/submit|save|confirm|ok|done|apply/)) return 'submit-button';\n if (text.match(/cancel|close|dismiss/)) return 'cancel-button';\n if (text.match(/delete|remove|trash/)) return 'delete-button';\n if (text.match(/add|create|new|\\+/)) return 'add-button';\n if (text.match(/edit|modify/)) return 'edit-button';\n if (text.match(/next|continue/)) return 'next-button';\n if (text.match(/back|previous/)) return 'back-button';\n return 'action-button';\n }\n\n if (type === 'input') {\n if (text.includes('email') || element.id.includes('email')) return 'email-input';\n if (text.includes('password') || element.id.includes('password')) return 'password-input';\n if (text.includes('search') || element.id.includes('search')) return 'search-input';\n return 'text-input';\n }\n\n return type;\n }\n\n /**\n * Add snapshot to history\n */\n private addToHistory(snapshot: SemanticSnapshot): void {\n this.history.push({\n snapshot,\n timestamp: Date.now(),\n });\n\n // Trim history if needed\n if (this.history.length > this.maxHistorySize) {\n this.history = this.history.slice(-this.maxHistorySize);\n }\n }\n}\n\n/**\n * Create a semantic snapshot manager\n */\nexport function createSnapshotManager(\n config?: Partial<SemanticSnapshotConfig>\n): SemanticSnapshotManager {\n return new SemanticSnapshotManager(config);\n}\n","/**\n * Semantic Diff\n *\n * Tracks and describes semantic changes between snapshots\n * with LLM-friendly summaries and suggested actions.\n */\n\nimport type {\n SemanticSnapshot,\n SemanticDiff,\n ElementChange,\n ElementModification,\n AIDiscoveredElement,\n ContentChanges,\n TextChange,\n MetricChange,\n StatusChange,\n} from './types';\nimport { generateDiffSummary } from './summary-generator';\n\n/**\n * Configuration for semantic diff\n */\nexport interface SemanticDiffConfig {\n /** Ignore insignificant changes */\n ignoreInsignificant: boolean;\n /** Properties to track for modifications */\n trackedProperties: string[];\n /** Generate suggested actions */\n generateSuggestions: boolean;\n /** Maximum modifications to report */\n maxModifications: number;\n}\n\n/**\n * Default diff configuration\n */\nexport const DEFAULT_DIFF_CONFIG: SemanticDiffConfig = {\n ignoreInsignificant: true,\n trackedProperties: ['visible', 'enabled', 'focused', 'checked', 'value', 'textContent'],\n generateSuggestions: true,\n maxModifications: 20,\n};\n\n/**\n * Properties that are considered insignificant\n */\nconst INSIGNIFICANT_PROPERTIES = new Set(['rect', 'computedStyles', 'innerHTML']);\n\n/**\n * Compute semantic diff between two snapshots\n */\nexport function computeDiff(\n fromSnapshot: SemanticSnapshot,\n toSnapshot: SemanticSnapshot,\n config: Partial<SemanticDiffConfig> = {}\n): SemanticDiff {\n const startTime = performance.now();\n const finalConfig = { ...DEFAULT_DIFF_CONFIG, ...config };\n\n // Build element maps for comparison\n const fromElements = new Map(fromSnapshot.elements.map((el) => [el.id, el]));\n const toElements = new Map(toSnapshot.elements.map((el) => [el.id, el]));\n\n // Find appeared elements\n const appeared: ElementChange[] = [];\n for (const [id, element] of toElements) {\n if (!fromElements.has(id)) {\n appeared.push({\n elementId: id,\n description: element.description,\n type: element.type,\n semanticType: element.semanticType,\n });\n }\n }\n\n // Find disappeared elements\n const disappeared: ElementChange[] = [];\n for (const [id, element] of fromElements) {\n if (!toElements.has(id)) {\n disappeared.push({\n elementId: id,\n description: element.description,\n type: element.type,\n semanticType: element.semanticType,\n });\n }\n }\n\n // Find modified elements\n const modified: ElementModification[] = [];\n for (const [id, toElement] of toElements) {\n const fromElement = fromElements.get(id);\n if (fromElement) {\n const modifications = compareElements(fromElement, toElement, finalConfig);\n modified.push(...modifications);\n }\n }\n\n // Limit modifications\n const limitedModifications = modified.slice(0, finalConfig.maxModifications);\n\n // Detect probable trigger\n const probableTrigger = detectTrigger(appeared, disappeared, limitedModifications);\n\n // Generate suggested actions\n const suggestedActions = finalConfig.generateSuggestions\n ? generateSuggestedActionsFromDiff(appeared, disappeared, limitedModifications, probableTrigger)\n : undefined;\n\n // Detect page changes\n const pageChanges = detectPageChanges(fromSnapshot, toSnapshot);\n\n // Detect content changes\n const contentChanges = detectContentChanges(fromElements, toElements);\n\n // Generate summary\n const summary = generateDiffSummary(\n appeared.map((e) => e.description),\n disappeared.map((e) => e.description),\n limitedModifications\n );\n\n return {\n summary,\n fromSnapshotId: fromSnapshot.snapshotId,\n toSnapshotId: toSnapshot.snapshotId,\n changes: {\n appeared,\n disappeared,\n modified: limitedModifications,\n },\n contentChanges: contentChanges || undefined,\n probableTrigger,\n suggestedActions,\n pageChanges,\n durationMs: performance.now() - startTime,\n timestamp: Date.now(),\n };\n}\n\n/**\n * Compare two elements and return modifications\n */\nfunction compareElements(\n fromElement: AIDiscoveredElement,\n toElement: AIDiscoveredElement,\n config: SemanticDiffConfig\n): ElementModification[] {\n const modifications: ElementModification[] = [];\n\n for (const property of config.trackedProperties) {\n const fromValue = getPropertyValue(fromElement, property);\n const toValue = getPropertyValue(toElement, property);\n\n if (fromValue !== toValue) {\n // Check significance\n const isSignificant = isSignificantChange(property, fromValue, toValue);\n\n if (!config.ignoreInsignificant || isSignificant) {\n modifications.push({\n elementId: toElement.id,\n description: toElement.description,\n property,\n from: formatValue(fromValue),\n to: formatValue(toValue),\n significant: isSignificant,\n });\n }\n }\n }\n\n return modifications;\n}\n\n/**\n * Get a property value from an element\n */\nfunction getPropertyValue(element: AIDiscoveredElement, property: string): unknown {\n if (property in element.state) {\n return element.state[property as keyof typeof element.state];\n }\n return element[property as keyof AIDiscoveredElement];\n}\n\n/**\n * Check if a change is significant\n */\nfunction isSignificantChange(property: string, fromValue: unknown, toValue: unknown): boolean {\n // Insignificant properties\n if (INSIGNIFICANT_PROPERTIES.has(property)) {\n return false;\n }\n\n // Visibility changes are always significant\n if (property === 'visible') {\n return true;\n }\n\n // Enabled state changes are significant\n if (property === 'enabled') {\n return true;\n }\n\n // Focus changes are significant\n if (property === 'focused') {\n return true;\n }\n\n // Checked state changes are significant\n if (property === 'checked') {\n return true;\n }\n\n // Value changes are significant if non-empty\n if (property === 'value') {\n return Boolean(fromValue) || Boolean(toValue);\n }\n\n // Text content changes are significant if substantial\n if (property === 'textContent') {\n const fromText = String(fromValue || '');\n const toText = String(toValue || '');\n // Significant if more than whitespace changes\n return fromText.trim() !== toText.trim();\n }\n\n return true;\n}\n\n/**\n * Format a value for display\n */\nfunction formatValue(value: unknown): string {\n if (value === undefined) return 'undefined';\n if (value === null) return 'null';\n if (typeof value === 'boolean') return value ? 'true' : 'false';\n if (typeof value === 'string') {\n // Truncate long strings\n if (value.length > 50) {\n return value.substring(0, 47) + '...';\n }\n return value;\n }\n if (typeof value === 'object') {\n return JSON.stringify(value);\n }\n return String(value);\n}\n\n/**\n * Detect the probable trigger for the changes\n */\nfunction detectTrigger(\n appeared: ElementChange[],\n disappeared: ElementChange[],\n modified: ElementModification[]\n): string | undefined {\n // Check for form validation\n const hasNewErrors = appeared.some(\n (e) => e.description.toLowerCase().includes('error') || e.type === 'error'\n );\n if (hasNewErrors) {\n return 'Form validation';\n }\n\n // Check for modal appearance\n const hasNewModal = appeared.some(\n (e) => e.type === 'dialog' || e.semanticType?.includes('dialog')\n );\n if (hasNewModal) {\n return 'Modal opened';\n }\n\n // Check for modal dismissal\n const hasModalDismissed = disappeared.some(\n (e) => e.type === 'dialog' || e.semanticType?.includes('dialog')\n );\n if (hasModalDismissed) {\n return 'Modal closed';\n }\n\n // Check for loading state\n const hasLoading = modified.some((m) => m.description.toLowerCase().includes('loading'));\n if (hasLoading) {\n return 'Loading state change';\n }\n\n // Check for focus change\n const hasFocusChange = modified.some((m) => m.property === 'focused');\n if (hasFocusChange && modified.length <= 2) {\n return 'Focus changed';\n }\n\n // Check for value change (user input)\n const hasValueChange = modified.some((m) => m.property === 'value');\n if (hasValueChange && modified.length <= 2) {\n return 'User input';\n }\n\n // Check for visibility changes (dropdown, accordion)\n const visibilityChanges = modified.filter((m) => m.property === 'visible');\n if (visibilityChanges.length > 0 && visibilityChanges.length <= 5) {\n return 'UI expansion/collapse';\n }\n\n // Multiple elements appeared (navigation)\n if (appeared.length > 5) {\n return 'Page navigation';\n }\n\n return undefined;\n}\n\n/**\n * Detect page-level changes\n */\nfunction detectPageChanges(\n fromSnapshot: SemanticSnapshot,\n toSnapshot: SemanticSnapshot\n): SemanticDiff['pageChanges'] | undefined {\n const urlChanged = fromSnapshot.page.url !== toSnapshot.page.url;\n const titleChanged = fromSnapshot.page.title !== toSnapshot.page.title;\n\n if (!urlChanged && !titleChanged) {\n return undefined;\n }\n\n return {\n urlChanged,\n titleChanged,\n newUrl: urlChanged ? toSnapshot.page.url : undefined,\n newTitle: titleChanged ? toSnapshot.page.title : undefined,\n };\n}\n\n/**\n * Generate suggested actions based on the diff\n */\nfunction generateSuggestedActionsFromDiff(\n appeared: ElementChange[],\n disappeared: ElementChange[],\n modified: ElementModification[],\n trigger?: string\n): string[] {\n const suggestions: string[] = [];\n\n // Suggestions based on trigger\n if (trigger === 'Form validation') {\n suggestions.push('Fix the validation errors before submitting');\n }\n\n if (trigger === 'Modal opened') {\n const modal = appeared.find((e) => e.type === 'dialog' || e.semanticType?.includes('dialog'));\n if (modal) {\n suggestions.push(`Interact with the \"${modal.description}\" dialog`);\n }\n }\n\n if (trigger === 'Modal closed') {\n suggestions.push('Continue with the main page interaction');\n }\n\n // Suggestions based on appeared elements\n for (const element of appeared.slice(0, 3)) {\n if (element.type === 'button' && element.semanticType === 'submit-button') {\n suggestions.push(`Click the \"${element.description}\" to proceed`);\n }\n if (element.description.toLowerCase().includes('error')) {\n suggestions.push(`Address the error: ${element.description}`);\n }\n }\n\n // Suggestions based on modifications\n for (const mod of modified.slice(0, 3)) {\n if (mod.property === 'enabled' && mod.to === 'true') {\n suggestions.push(`\"${mod.description}\" is now enabled`);\n }\n if (mod.property === 'visible' && mod.to === 'true') {\n suggestions.push(`\"${mod.description}\" is now visible`);\n }\n }\n\n return suggestions.slice(0, 5);\n}\n\n/**\n * Create a diff manager for tracking changes over time\n */\nexport class SemanticDiffManager {\n private config: SemanticDiffConfig;\n private lastSnapshot: SemanticSnapshot | null = null;\n\n constructor(config: Partial<SemanticDiffConfig> = {}) {\n this.config = { ...DEFAULT_DIFF_CONFIG, ...config };\n }\n\n /**\n * Update with new snapshot and get diff\n */\n update(newSnapshot: SemanticSnapshot): SemanticDiff | null {\n if (!this.lastSnapshot) {\n this.lastSnapshot = newSnapshot;\n return null;\n }\n\n const diff = computeDiff(this.lastSnapshot, newSnapshot, this.config);\n this.lastSnapshot = newSnapshot;\n return diff;\n }\n\n /**\n * Get diff from a specific snapshot to current\n */\n diffFrom(fromSnapshot: SemanticSnapshot): SemanticDiff | null {\n if (!this.lastSnapshot) return null;\n return computeDiff(fromSnapshot, this.lastSnapshot, this.config);\n }\n\n /**\n * Reset the manager\n */\n reset(): void {\n this.lastSnapshot = null;\n }\n\n /**\n * Get the last known snapshot\n */\n getLastSnapshot(): SemanticSnapshot | null {\n return this.lastSnapshot;\n }\n}\n\n/**\n * Create a semantic diff manager\n */\nexport function createDiffManager(config?: Partial<SemanticDiffConfig>): SemanticDiffManager {\n return new SemanticDiffManager(config);\n}\n\n/**\n * Utility: Check if any significant changes occurred\n */\nexport function hasSignificantChanges(diff: SemanticDiff): boolean {\n if (diff.changes.appeared.length > 0) return true;\n if (diff.changes.disappeared.length > 0) return true;\n if (diff.changes.modified.some((m) => m.significant)) return true;\n if (diff.pageChanges?.urlChanged) return true;\n if (diff.contentChanges) {\n const cc = diff.contentChanges;\n if (cc.textChanges.length > 0) return true;\n if (cc.metricChanges.some((m) => m.significant)) return true;\n if (cc.statusChanges.length > 0) return true;\n }\n return false;\n}\n\n/**\n * Utility: Get a brief description of what changed\n */\nexport function describeDiff(diff: SemanticDiff): string {\n const parts: string[] = [];\n\n if (diff.changes.appeared.length > 0) {\n parts.push(`${diff.changes.appeared.length} elements appeared`);\n }\n\n if (diff.changes.disappeared.length > 0) {\n parts.push(`${diff.changes.disappeared.length} elements disappeared`);\n }\n\n const significantMods = diff.changes.modified.filter((m) => m.significant);\n if (significantMods.length > 0) {\n parts.push(`${significantMods.length} elements modified`);\n }\n\n if (diff.pageChanges?.urlChanged) {\n parts.push('URL changed');\n }\n\n if (diff.contentChanges) {\n parts.push(diff.contentChanges.summary);\n }\n\n if (parts.length === 0) {\n return 'No significant changes';\n }\n\n return parts.join(', ');\n}\n\n// ============================================================================\n// Content Change Detection\n// ============================================================================\n\n/**\n * Content types that represent metric values\n */\nconst METRIC_CONTENT_TYPES = new Set(['metric-value']);\n\n/**\n * Content types that represent status indicators\n */\nconst STATUS_CONTENT_TYPES = new Set(['status-message', 'badge']);\n\n/**\n * Content types that represent headings\n */\nconst HEADING_CONTENT_TYPES = new Set(['heading']);\n\n/**\n * Check if an element is a content element based on its category or contentMetadata\n */\nfunction isContentElement(element: AIDiscoveredElement): boolean {\n return element.category === 'content' || element.contentMetadata !== undefined;\n}\n\n/**\n * Get the content type from an element's metadata or type field\n */\nfunction getContentType(element: AIDiscoveredElement): string {\n if (element.contentMetadata?.contentRole) {\n return element.contentMetadata.contentRole;\n }\n // Fall back to element type for content elements\n return element.type;\n}\n\n/**\n * Detect content-specific changes between two snapshots\n */\nfunction detectContentChanges(\n fromElements: Map<string, AIDiscoveredElement>,\n toElements: Map<string, AIDiscoveredElement>\n): ContentChanges | null {\n const textChanges: TextChange[] = [];\n const metricChanges: MetricChange[] = [];\n const statusChanges: StatusChange[] = [];\n\n // Check content elements that exist in both snapshots (modified)\n for (const [id, toElement] of toElements) {\n const fromElement = fromElements.get(id);\n\n if (fromElement) {\n // Both exist - check for text content changes on content elements\n if (isContentElement(toElement) || isContentElement(fromElement)) {\n const fromText = (fromElement.state.textContent || '').trim();\n const toText = (toElement.state.textContent || '').trim();\n\n if (fromText !== toText) {\n const contentType = getContentType(toElement);\n const label = toElement.description || toElement.accessibleName || id;\n\n // Classify by content type\n if (METRIC_CONTENT_TYPES.has(contentType) || contentType === 'metric') {\n const parsed = parseMetricChange(fromText, toText, id, label);\n if (parsed) {\n metricChanges.push(parsed);\n }\n } else if (STATUS_CONTENT_TYPES.has(contentType) || contentType === 'status') {\n statusChanges.push({\n elementId: id,\n label,\n oldStatus: fromText,\n newStatus: toText,\n direction: classifyStatusDirection(fromText, toText),\n });\n } else {\n textChanges.push({\n elementId: id,\n contentType,\n oldText: fromText,\n newText: toText,\n changeType: 'modified',\n });\n }\n }\n }\n } else {\n // New content element appeared\n if (isContentElement(toElement)) {\n const toText = (toElement.state.textContent || '').trim();\n if (toText) {\n textChanges.push({\n elementId: id,\n contentType: getContentType(toElement),\n oldText: '',\n newText: toText,\n changeType: 'added',\n });\n }\n }\n }\n }\n\n // Check for content elements that disappeared\n for (const [id, fromElement] of fromElements) {\n if (!toElements.has(id) && isContentElement(fromElement)) {\n const fromText = (fromElement.state.textContent || '').trim();\n if (fromText) {\n textChanges.push({\n elementId: id,\n contentType: getContentType(fromElement),\n oldText: fromText,\n newText: '',\n changeType: 'removed',\n });\n }\n }\n }\n\n // If no content changes detected, return null\n if (textChanges.length === 0 && metricChanges.length === 0 && statusChanges.length === 0) {\n return null;\n }\n\n return {\n textChanges,\n metricChanges,\n statusChanges,\n summary: generateContentChangeSummary(textChanges, metricChanges, statusChanges),\n };\n}\n\n// ============================================================================\n// Metric Value Parsing\n// ============================================================================\n\n/**\n * Parse a numeric value from a string, handling common formats:\n * - Plain numbers: \"42\", \"1,234\", \"1234.56\"\n * - Percentages: \"95%\", \"12.5%\"\n * - Currency: \"$1,234\", \"$1,234.56\", \"-$50\"\n * - Duration: \"2h 30m\", \"1.5s\", \"100ms\"\n * - Negative values: \"-42\", \"($500)\"\n *\n * Returns the numeric value or null if not parseable.\n */\nexport function parseNumericValue(text: string): number | null {\n const trimmed = text.trim();\n if (!trimmed) return null;\n\n // Handle parenthesized negatives: ($500) -> -500\n let working = trimmed;\n let negate = false;\n if (working.startsWith('(') && working.endsWith(')')) {\n working = working.slice(1, -1).trim();\n negate = true;\n }\n\n // Strip leading negative sign\n if (working.startsWith('-')) {\n negate = !negate;\n working = working.slice(1).trim();\n }\n if (working.startsWith('+')) {\n working = working.slice(1).trim();\n }\n\n // Strip currency symbols\n working = working.replace(/^[£€¥₹$]/, '').trim();\n\n // Strip trailing percent sign\n const isPercent = working.endsWith('%');\n if (isPercent) {\n working = working.slice(0, -1).trim();\n }\n\n // Strip trailing duration units (we parse just the numeric part)\n working = working.replace(/\\s*(ms|s|m|h|d|hrs?|mins?|secs?|days?)$/i, '').trim();\n\n // Remove thousands separators (commas)\n working = working.replace(/,/g, '');\n\n // Try to parse as a number\n const num = Number(working);\n if (isNaN(num) || !isFinite(num) || working === '') {\n return null;\n }\n\n return negate ? -num : num;\n}\n\n/**\n * Parse a metric change between two text values\n */\nfunction parseMetricChange(\n fromText: string,\n toText: string,\n elementId: string,\n label: string\n): MetricChange | null {\n const fromNum = parseNumericValue(fromText);\n const toNum = parseNumericValue(toText);\n\n let numericDelta: number | undefined;\n let percentChange: number | undefined;\n let significant = false;\n\n if (fromNum !== null && toNum !== null) {\n numericDelta = toNum - fromNum;\n\n if (fromNum !== 0) {\n percentChange = ((toNum - fromNum) / Math.abs(fromNum)) * 100;\n }\n\n // Significant if >10% change, sign flip, or from/to zero\n if (percentChange !== undefined && Math.abs(percentChange) > 10) {\n significant = true;\n }\n if (fromNum > 0 && toNum < 0) significant = true;\n if (fromNum < 0 && toNum > 0) significant = true;\n if (fromNum === 0 && toNum !== 0) significant = true;\n if (fromNum !== 0 && toNum === 0) significant = true;\n } else {\n // Text changed but not parseable as numbers - still a change\n significant = fromText !== toText;\n }\n\n return {\n elementId,\n label,\n oldValue: fromText,\n newValue: toText,\n numericDelta,\n percentChange: percentChange !== undefined ? Math.round(percentChange * 100) / 100 : undefined,\n significant,\n };\n}\n\n// ============================================================================\n// Status Classification\n// ============================================================================\n\n/**\n * Status progressions where later states are \"better\" (improved direction).\n * Each array is ordered from worst to best.\n */\nconst STATUS_PROGRESSIONS: string[][] = [\n [\n 'failed',\n 'error',\n 'pending',\n 'queued',\n 'running',\n 'in progress',\n 'completed',\n 'success',\n 'done',\n ],\n ['disconnected', 'connecting', 'connected'],\n ['unhealthy', 'degraded', 'healthy'],\n ['offline', 'online'],\n ['inactive', 'active'],\n ['disabled', 'enabled'],\n ['down', 'up'],\n ['stopped', 'starting', 'started', 'running'],\n ['closed', 'open'],\n ['blocked', 'unblocked'],\n ['rejected', 'pending', 'approved'],\n ['critical', 'warning', 'info', 'ok'],\n ['red', 'yellow', 'green'],\n];\n\n/**\n * Classify whether a status change is an improvement, degradation, or neutral\n */\nexport function classifyStatusDirection(\n oldStatus: string,\n newStatus: string\n): 'improved' | 'degraded' | 'neutral' {\n const oldLower = oldStatus.toLowerCase().trim();\n const newLower = newStatus.toLowerCase().trim();\n\n for (const progression of STATUS_PROGRESSIONS) {\n let oldIndex = -1;\n let newIndex = -1;\n\n for (let i = 0; i < progression.length; i++) {\n if (oldLower.includes(progression[i])) oldIndex = i;\n if (newLower.includes(progression[i])) newIndex = i;\n }\n\n if (oldIndex >= 0 && newIndex >= 0 && oldIndex !== newIndex) {\n return newIndex > oldIndex ? 'improved' : 'degraded';\n }\n }\n\n return 'neutral';\n}\n\n// ============================================================================\n// Content Change Summary\n// ============================================================================\n\n/**\n * Generate a concise, actionable summary of content changes\n */\nfunction generateContentChangeSummary(\n textChanges: TextChange[],\n metricChanges: MetricChange[],\n statusChanges: StatusChange[]\n): string {\n const parts: string[] = [];\n\n // Count text changes by type\n const modified = textChanges.filter((t) => t.changeType === 'modified').length;\n const added = textChanges.filter((t) => t.changeType === 'added').length;\n const removed = textChanges.filter((t) => t.changeType === 'removed').length;\n\n // Heading changes\n const headingChanges = textChanges.filter(\n (t) => HEADING_CONTENT_TYPES.has(t.contentType) || t.contentType === 'heading'\n );\n if (headingChanges.length > 0) {\n parts.push(`${headingChanges.length} heading${headingChanges.length > 1 ? 's' : ''} changed`);\n }\n\n // Metric changes\n if (metricChanges.length > 0) {\n const significantMetrics = metricChanges.filter((m) => m.significant);\n if (significantMetrics.length > 0) {\n parts.push(\n `${significantMetrics.length} metric${significantMetrics.length > 1 ? 's' : ''} changed significantly`\n );\n } else {\n parts.push(`${metricChanges.length} metric${metricChanges.length > 1 ? 's' : ''} changed`);\n }\n }\n\n // Status changes\n if (statusChanges.length > 0) {\n const degraded = statusChanges.filter((s) => s.direction === 'degraded');\n const improved = statusChanges.filter((s) => s.direction === 'improved');\n\n if (degraded.length > 0) {\n parts.push(`${degraded.length} status${degraded.length > 1 ? 'es' : ''} degraded`);\n }\n if (improved.length > 0) {\n parts.push(`${improved.length} status${improved.length > 1 ? 'es' : ''} improved`);\n }\n const neutral = statusChanges.length - degraded.length - improved.length;\n if (neutral > 0 && degraded.length === 0 && improved.length === 0) {\n parts.push(`${neutral} status${neutral > 1 ? 'es' : ''} changed`);\n }\n }\n\n // General text changes (excluding headings already counted)\n const otherModified = modified - headingChanges.filter((h) => h.changeType === 'modified').length;\n if (otherModified > 0) {\n parts.push(`${otherModified} text${otherModified > 1 ? ' values' : ' value'} modified`);\n }\n\n if (added > 0) {\n parts.push(`${added} content${added > 1 ? ' elements' : ' element'} added`);\n }\n\n if (removed > 0) {\n parts.push(`${removed} content${removed > 1 ? ' elements' : ' element'} removed`);\n }\n\n if (parts.length === 0) {\n return 'No content changes';\n }\n\n return parts.join(', ');\n}\n","/**\n * Data Extraction\n *\n * Extracts labeled data values from page elements, classifies their types,\n * and normalizes values for cross-app comparison.\n */\n\nimport type { AIDiscoveredElement, DataType, ExtractedDataValue, PageDataMap } from './types';\n\nexport interface DataExtractionConfig {\n /** Minimum confidence to include a value */\n minConfidence: number;\n /** Whether to normalize whitespace */\n normalizeWhitespace: boolean;\n}\n\nexport const DEFAULT_DATA_EXTRACTION_CONFIG: DataExtractionConfig = {\n minConfidence: 0.3,\n normalizeWhitespace: true,\n};\n\n/**\n * Classify the data type of a raw string value.\n */\nexport function classifyDataType(value: string): { type: DataType; confidence: number } {\n const trimmed = value.trim();\n if (!trimmed) return { type: 'unknown', confidence: 0 };\n\n // Boolean\n if (/^(true|false|yes|no|on|off)$/i.test(trimmed)) {\n return { type: 'boolean', confidence: 0.95 };\n }\n\n // Email\n if (/^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/.test(trimmed)) {\n return { type: 'email', confidence: 0.95 };\n }\n\n // URL\n if (/^https?:\\/\\/\\S+/.test(trimmed)) {\n return { type: 'url', confidence: 0.95 };\n }\n\n // Phone (various formats)\n if (/^[+]?[\\d\\s\\-().]{7,20}$/.test(trimmed) && /\\d{3,}/.test(trimmed)) {\n return { type: 'phone', confidence: 0.7 };\n }\n\n // Currency ($1,234.56 or €1.234,56 etc.)\n if (/^[£$€¥₹][\\s]?[\\d,.]+$/.test(trimmed) || /^[\\d,.]+[\\s]?[£$€¥₹]$/.test(trimmed)) {\n return { type: 'currency', confidence: 0.9 };\n }\n\n // Percentage\n if (/^[\\d,.]+\\s?%$/.test(trimmed)) {\n return { type: 'percentage', confidence: 0.95 };\n }\n\n // Date (ISO, US, EU formats)\n if (\n /^\\d{4}-\\d{2}-\\d{2}/.test(trimmed) ||\n /^\\d{1,2}\\/\\d{1,2}\\/\\d{2,4}$/.test(trimmed) ||\n /^\\d{1,2}\\.\\d{1,2}\\.\\d{2,4}$/.test(trimmed) ||\n /^\\w{3,9}\\s+\\d{1,2},?\\s+\\d{4}$/.test(trimmed)\n ) {\n return { type: 'date', confidence: 0.85 };\n }\n\n // Number (plain)\n if (/^-?[\\d,]+\\.?\\d*$/.test(trimmed) && trimmed !== '') {\n return { type: 'number', confidence: 0.9 };\n }\n\n // Default to text\n return { type: 'text', confidence: 0.5 };\n}\n\n/**\n * Normalize a value for comparison by stripping formatting differences.\n */\nexport function normalizeValue(value: string, dataType: DataType): string {\n const trimmed = value.trim();\n\n switch (dataType) {\n case 'number':\n case 'currency':\n case 'percentage': {\n // Strip currency symbols, commas, percent signs; keep digits and decimal\n const numeric = trimmed.replace(/[^0-9.-]/g, '');\n const parsed = parseFloat(numeric);\n return isNaN(parsed) ? trimmed.toLowerCase() : parsed.toString();\n }\n case 'date': {\n // Try to parse into ISO date for comparison\n const d = new Date(trimmed);\n return isNaN(d.getTime()) ? trimmed.toLowerCase() : d.toISOString().split('T')[0];\n }\n case 'boolean':\n return /^(true|yes|on)$/i.test(trimmed) ? 'true' : 'false';\n case 'email':\n return trimmed.toLowerCase();\n case 'url':\n // Strip trailing slash for comparison\n return trimmed.replace(/\\/+$/, '').toLowerCase();\n case 'phone':\n // Keep only digits\n return trimmed.replace(/[^\\d+]/g, '');\n default:\n return trimmed.toLowerCase().replace(/\\s+/g, ' ');\n }\n}\n\n/**\n * Extract the displayable text/value from an element.\n */\nfunction extractElementValue(element: AIDiscoveredElement): string {\n const state = element.state;\n if (state?.value !== undefined && state.value !== '') {\n return String(state.value);\n }\n if (state?.textContent !== undefined && state.textContent !== '') {\n return String(state.textContent);\n }\n return '';\n}\n\n/**\n * Extract a label for an element.\n */\nfunction extractLabel(element: AIDiscoveredElement): string {\n return (\n element.accessibleName ||\n element.labelText ||\n element.label ||\n element.description ||\n element.id\n );\n}\n\n/**\n * Extract labeled data values from all page elements.\n */\nexport function extractPageData(\n elements: AIDiscoveredElement[],\n config: DataExtractionConfig = DEFAULT_DATA_EXTRACTION_CONFIG\n): PageDataMap {\n const values: Record<string, ExtractedDataValue> = {};\n let extractedCount = 0;\n\n for (const element of elements) {\n const rawValue = extractElementValue(element);\n if (!rawValue) continue;\n\n const label = extractLabel(element);\n const { type: dataType, confidence } = classifyDataType(rawValue);\n\n if (confidence < config.minConfidence) continue;\n\n const normalizedValue = normalizeValue(rawValue, dataType);\n\n values[label] = {\n elementId: element.id,\n label,\n rawValue: config.normalizeWhitespace ? rawValue.replace(/\\s+/g, ' ').trim() : rawValue,\n normalizedValue,\n dataType,\n confidence,\n };\n extractedCount++;\n }\n\n return {\n values,\n scannedCount: elements.length,\n extractedCount,\n };\n}\n","/**\n * Region Segmentation\n *\n * Segments a page into semantic regions (header, nav, sidebar, main, footer, etc.)\n * based on element positions, roles, and spatial clustering.\n */\n\nimport type { AIDiscoveredElement, RegionType, PageRegion, PageRegionMap } from './types';\n\nexport interface RegionSegmentationConfig {\n /** Minimum elements for a region to be valid */\n minRegionElements: number;\n /** Top portion of viewport considered \"header\" (fraction 0-1) */\n headerFraction: number;\n /** Bottom portion considered \"footer\" (fraction 0-1) */\n footerFraction: number;\n /** Left portion considered \"sidebar\" (fraction 0-1) */\n sidebarFraction: number;\n}\n\nexport const DEFAULT_REGION_SEGMENTATION_CONFIG: RegionSegmentationConfig = {\n minRegionElements: 1,\n headerFraction: 0.12,\n footerFraction: 0.9,\n sidebarFraction: 0.2,\n};\n\ninterface BoundedElement {\n element: AIDiscoveredElement;\n x: number;\n y: number;\n width: number;\n height: number;\n}\n\nfunction toBounded(el: AIDiscoveredElement): BoundedElement | null {\n const rect = el.state?.rect;\n if (!rect) return null;\n return {\n element: el,\n x: rect.x ?? 0,\n y: rect.y ?? 0,\n width: rect.width ?? 0,\n height: rect.height ?? 0,\n };\n}\n\n/**\n * Classify the region type of an element based on its role, position, and context.\n */\nexport function classifyRegionType(\n el: AIDiscoveredElement,\n relativeY: number,\n relativeX: number,\n config: RegionSegmentationConfig = DEFAULT_REGION_SEGMENTATION_CONFIG\n): { type: RegionType; confidence: number } {\n const role = (el.role || '').toLowerCase();\n const semanticType = (el.semanticType || '').toLowerCase();\n const tag = (el.tagName || '').toLowerCase();\n\n // Role-based classification (highest confidence)\n if (role === 'navigation' || role === 'nav' || tag === 'nav') {\n return { type: 'navigation', confidence: 0.95 };\n }\n if (role === 'banner' || tag === 'header') {\n return { type: 'header', confidence: 0.95 };\n }\n if (role === 'contentinfo' || tag === 'footer') {\n return { type: 'footer', confidence: 0.95 };\n }\n if (role === 'main' || tag === 'main') {\n return { type: 'main-content', confidence: 0.95 };\n }\n if (role === 'complementary' || tag === 'aside') {\n return { type: 'sidebar', confidence: 0.9 };\n }\n if (role === 'form' || tag === 'form') {\n return { type: 'form', confidence: 0.9 };\n }\n if (role === 'table' || tag === 'table') {\n return { type: 'table', confidence: 0.9 };\n }\n if (role === 'dialog' || role === 'alertdialog') {\n return { type: 'modal', confidence: 0.95 };\n }\n if (role === 'toolbar') {\n return { type: 'toolbar', confidence: 0.9 };\n }\n if (semanticType.includes('card')) {\n return { type: 'card', confidence: 0.8 };\n }\n\n // Position-based fallback\n if (relativeY < config.headerFraction) {\n return { type: 'header', confidence: 0.6 };\n }\n if (relativeY > config.footerFraction) {\n return { type: 'footer', confidence: 0.6 };\n }\n if (relativeX < config.sidebarFraction) {\n return { type: 'sidebar', confidence: 0.5 };\n }\n\n return { type: 'main-content', confidence: 0.3 };\n}\n\n/**\n * Segment all page elements into semantic regions.\n */\nexport function segmentPageRegions(\n elements: AIDiscoveredElement[],\n config: RegionSegmentationConfig = DEFAULT_REGION_SEGMENTATION_CONFIG\n): PageRegionMap {\n const bounded = elements.map(toBounded).filter((b): b is BoundedElement => b !== null);\n if (bounded.length === 0) {\n return { regions: [], assignedCount: 0, unassignedIds: elements.map((e) => e.id) };\n }\n\n // Compute page bounds\n let maxX = 0;\n let maxY = 0;\n for (const b of bounded) {\n maxX = Math.max(maxX, b.x + b.width);\n maxY = Math.max(maxY, b.y + b.height);\n }\n if (maxX === 0) maxX = 1;\n if (maxY === 0) maxY = 1;\n\n // Classify each element\n const regionGroups = new Map<RegionType, { elements: BoundedElement[]; confidences: number[] }>();\n const unassignedIds: string[] = [];\n\n for (const b of bounded) {\n const relativeX = b.x / maxX;\n const relativeY = b.y / maxY;\n const { type, confidence } = classifyRegionType(b.element, relativeY, relativeX, config);\n\n if (!regionGroups.has(type)) {\n regionGroups.set(type, { elements: [], confidences: [] });\n }\n regionGroups.get(type)!.elements.push(b);\n regionGroups.get(type)!.confidences.push(confidence);\n }\n\n // Build regions\n const regions: PageRegion[] = [];\n let assignedCount = 0;\n\n for (const [type, group] of regionGroups) {\n if (group.elements.length < config.minRegionElements) {\n for (const b of group.elements) unassignedIds.push(b.element.id);\n continue;\n }\n\n // Compute bounding box of the group\n let minX = Infinity,\n minY = Infinity,\n maxRX = 0,\n maxRY = 0;\n const elementIds: string[] = [];\n\n for (const b of group.elements) {\n minX = Math.min(minX, b.x);\n minY = Math.min(minY, b.y);\n maxRX = Math.max(maxRX, b.x + b.width);\n maxRY = Math.max(maxRY, b.y + b.height);\n elementIds.push(b.element.id);\n }\n\n const avgConfidence = group.confidences.reduce((a, b) => a + b, 0) / group.confidences.length;\n\n regions.push({\n type,\n bounds: { x: minX, y: minY, width: maxRX - minX, height: maxRY - minY },\n elementIds,\n label: type.replace('-', ' ').replace(/\\b\\w/g, (c) => c.toUpperCase()),\n confidence: Math.round(avgConfidence * 100) / 100,\n });\n\n assignedCount += elementIds.length;\n }\n\n return { regions, assignedCount, unassignedIds };\n}\n","/**\n * Table & List Extraction\n *\n * Detects and extracts structured data (tables and lists) from page elements\n * based on spatial layout and semantic roles.\n */\n\nimport type {\n AIDiscoveredElement,\n TableSchema,\n TableColumn,\n ListSchema,\n ListItemField,\n StructuredDataExtraction,\n DataType,\n} from './types';\nimport { classifyDataType } from './data-extraction';\n\nexport interface TableExtractionConfig {\n /** Minimum columns to consider a group a table */\n minTableColumns: number;\n /** Minimum rows to consider a group a table */\n minTableRows: number;\n /** Minimum items to consider a group a list */\n minListItems: number;\n /** Position tolerance for column alignment (px) */\n columnTolerance: number;\n /** Position tolerance for row alignment (px) */\n rowTolerance: number;\n}\n\nexport const DEFAULT_TABLE_EXTRACTION_CONFIG: TableExtractionConfig = {\n minTableColumns: 2,\n minTableRows: 2,\n minListItems: 2,\n columnTolerance: 20,\n rowTolerance: 10,\n};\n\ninterface ElementWithBounds {\n element: AIDiscoveredElement;\n x: number;\n y: number;\n width: number;\n height: number;\n text: string;\n}\n\nfunction getElementBounds(el: AIDiscoveredElement): ElementWithBounds | null {\n const rect = el.state?.rect;\n if (!rect || rect.width === 0) return null;\n\n const text = el.state?.textContent ?? el.state?.value ?? '';\n if (!text) return null;\n\n return {\n element: el,\n x: rect.x ?? 0,\n y: rect.y ?? 0,\n width: rect.width ?? 0,\n height: rect.height ?? 0,\n text: text.trim(),\n };\n}\n\n/**\n * Cluster numeric values with a given tolerance.\n * Returns sorted unique cluster centers.\n */\nfunction clusterPositions(values: number[], tolerance: number): number[] {\n if (values.length === 0) return [];\n const sorted = [...values].sort((a, b) => a - b);\n const clusters: number[] = [sorted[0]];\n\n for (let i = 1; i < sorted.length; i++) {\n if (sorted[i] - clusters[clusters.length - 1] > tolerance) {\n clusters.push(sorted[i]);\n }\n }\n\n return clusters;\n}\n\n/**\n * Assign a value to the nearest cluster center.\n */\nfunction assignToCluster(value: number, clusters: number[], tolerance: number): number {\n let best = 0;\n let bestDist = Math.abs(value - clusters[0]);\n for (let i = 1; i < clusters.length; i++) {\n const dist = Math.abs(value - clusters[i]);\n if (dist < bestDist) {\n bestDist = dist;\n best = i;\n }\n }\n return bestDist <= tolerance ? best : -1;\n}\n\n/**\n * Detect a table structure from elements with grid-like spatial arrangement.\n */\nexport function detectTable(\n elements: AIDiscoveredElement[],\n config: TableExtractionConfig = DEFAULT_TABLE_EXTRACTION_CONFIG\n): TableSchema | null {\n const withBounds = elements\n .map(getElementBounds)\n .filter((b): b is ElementWithBounds => b !== null);\n if (withBounds.length < config.minTableColumns * config.minTableRows) return null;\n\n // Cluster x-positions for columns, y-positions for rows\n const xPositions = withBounds.map((b) => b.x);\n const yPositions = withBounds.map((b) => b.y);\n\n const columnClusters = clusterPositions(xPositions, config.columnTolerance);\n const rowClusters = clusterPositions(yPositions, config.rowTolerance);\n\n if (columnClusters.length < config.minTableColumns || rowClusters.length < config.minTableRows) {\n return null;\n }\n\n // Build a grid: grid[row][col] = text\n const grid: (string | null)[][] = Array.from({ length: rowClusters.length }, () =>\n Array(columnClusters.length).fill(null)\n );\n\n for (const b of withBounds) {\n const col = assignToCluster(b.x, columnClusters, config.columnTolerance);\n const row = assignToCluster(b.y, rowClusters, config.rowTolerance);\n if (col >= 0 && row >= 0 && grid[row][col] === null) {\n grid[row][col] = b.text;\n }\n }\n\n // First row = headers\n const headers = grid[0].map((h) => h ?? '');\n const columns: TableColumn[] = headers.map((header, index) => {\n // Determine column data type from body cells\n const bodyCells = grid\n .slice(1)\n .map((r) => r[index])\n .filter((c): c is string => c !== null);\n const types = bodyCells.map((c) => classifyDataType(c).type);\n const mostCommon = mode(types) ?? ('text' as DataType);\n\n return { header, index, dataType: mostCommon };\n });\n\n const rows = grid.slice(1).map((row) => row.map((cell) => cell ?? ''));\n\n return {\n label: headers[0] || 'Table',\n columns,\n rows,\n };\n}\n\n/**\n * Detect a list structure from repeating element patterns.\n */\nexport function detectList(\n elements: AIDiscoveredElement[],\n config: TableExtractionConfig = DEFAULT_TABLE_EXTRACTION_CONFIG\n): ListSchema | null {\n // Group elements by similar roles/types that repeat vertically\n const withBounds = elements\n .map(getElementBounds)\n .filter((b): b is ElementWithBounds => b !== null);\n if (withBounds.length < config.minListItems) return null;\n\n // Sort by y-position\n const sorted = [...withBounds].sort((a, b) => a.y - b.y);\n\n // Cluster y-positions to find item rows\n const yPositions = sorted.map((b) => b.y);\n const rowClusters = clusterPositions(yPositions, config.rowTolerance);\n\n if (rowClusters.length < config.minListItems) return null;\n\n // Group elements by their row cluster\n const rowGroups: Map<number, ElementWithBounds[]> = new Map();\n for (const b of sorted) {\n const row = assignToCluster(b.y, rowClusters, config.rowTolerance);\n if (row >= 0) {\n if (!rowGroups.has(row)) rowGroups.set(row, []);\n rowGroups.get(row)!.push(b);\n }\n }\n\n // Each row becomes a list item\n // Use x-position ordering within each row to determine fields\n const items: Record<string, string>[] = [];\n const fieldLabels: string[] = [];\n let fieldLabelsInitialized = false;\n\n for (const [, rowElements] of [...rowGroups.entries()].sort(([a], [b]) => a - b)) {\n const sortedRow = [...rowElements].sort((a, b) => a.x - b.x);\n const item: Record<string, string> = {};\n\n for (let i = 0; i < sortedRow.length; i++) {\n const label = `field_${i}`;\n if (!fieldLabelsInitialized) fieldLabels.push(label);\n item[label] = sortedRow[i].text;\n }\n fieldLabelsInitialized = true;\n items.push(item);\n }\n\n if (items.length < config.minListItems) return null;\n\n // Determine field data types\n const fields: ListItemField[] = fieldLabels.map((label) => {\n const values = items.map((item) => item[label]).filter(Boolean);\n const types = values.map((v) => classifyDataType(v).type);\n return { label, dataType: mode(types) ?? 'text' };\n });\n\n return {\n label: 'List',\n fields,\n items,\n };\n}\n\n/**\n * Extract all structured data (tables and lists) from page elements.\n */\nexport function extractStructuredData(\n elements: AIDiscoveredElement[],\n config: TableExtractionConfig = DEFAULT_TABLE_EXTRACTION_CONFIG\n): StructuredDataExtraction {\n const tables: TableSchema[] = [];\n const lists: ListSchema[] = [];\n\n // Try to detect table from all elements\n const table = detectTable(elements, config);\n if (table) {\n tables.push(table);\n }\n\n // Try to detect list from elements that have repeating patterns\n // Filter to elements with specific roles that commonly form lists\n const listCandidates = elements.filter((el) => {\n const role = el.role || el.type;\n return ['listitem', 'row', 'option', 'link', 'button'].includes(role);\n });\n\n if (listCandidates.length >= config.minListItems) {\n const list = detectList(listCandidates, config);\n if (list) {\n lists.push(list);\n }\n }\n\n return { tables, lists };\n}\n\n/** Find the most common value in an array. */\nfunction mode<T>(arr: T[]): T | undefined {\n if (arr.length === 0) return undefined;\n const counts = new Map<T, number>();\n let best: T = arr[0];\n let bestCount = 0;\n for (const v of arr) {\n const c = (counts.get(v) ?? 0) + 1;\n counts.set(v, c);\n if (c > bestCount) {\n bestCount = c;\n best = v;\n }\n }\n return best;\n}\n","/**\n * Format Analysis\n *\n * Analyzes the display format of data values and detects\n * format mismatches between source and target pages.\n */\n\nimport type { AIDiscoveredElement, DataType, FormatDescriptor, FormatMismatch } from './types';\nimport { classifyDataType } from './data-extraction';\n\nexport interface FormatAnalysisConfig {\n /** Treat minor format differences (e.g., comma vs period for thousands) as warnings rather than errors */\n lenientFormatting: boolean;\n}\n\nexport const DEFAULT_FORMAT_ANALYSIS_CONFIG: FormatAnalysisConfig = {\n lenientFormatting: true,\n};\n\n/**\n * Detect the format pattern of a value.\n */\nexport function detectFormatPattern(value: string, dataType: DataType): string {\n const trimmed = value.trim();\n\n switch (dataType) {\n case 'currency': {\n // Detect currency symbol position and thousand/decimal separators\n const hasLeadingSymbol = /^[£$€¥₹]/.test(trimmed);\n const hasTrailingSymbol = /[£$€¥₹]$/.test(trimmed);\n const usesCommaThousands = /\\d{1,3}(,\\d{3})+/.test(trimmed);\n const usesPeriodThousands = /\\d{1,3}(\\.\\d{3})+,/.test(trimmed);\n\n let pattern = hasLeadingSymbol ? '$' : '';\n if (usesCommaThousands) pattern += '#,###';\n else if (usesPeriodThousands) pattern += '#.###';\n else pattern += '#';\n\n if (/\\.\\d{2}$/.test(trimmed)) pattern += '.##';\n else if (/,\\d{2}$/.test(trimmed)) pattern += ',##';\n\n if (hasTrailingSymbol) pattern += '$';\n return pattern;\n }\n\n case 'date': {\n if (/^\\d{4}-\\d{2}-\\d{2}/.test(trimmed)) return 'YYYY-MM-DD';\n if (/^\\d{2}\\/\\d{2}\\/\\d{4}$/.test(trimmed)) return 'MM/DD/YYYY';\n if (/^\\d{2}\\.\\d{2}\\.\\d{4}$/.test(trimmed)) return 'DD.MM.YYYY';\n if (/^\\d{1,2}\\/\\d{1,2}\\/\\d{2}$/.test(trimmed)) return 'M/D/YY';\n if (/^\\w{3,9}\\s+\\d{1,2},?\\s+\\d{4}$/.test(trimmed)) return 'Month DD, YYYY';\n return 'date';\n }\n\n case 'percentage':\n return /\\s%$/.test(trimmed) ? '#.## %' : '#.##%';\n\n case 'number': {\n const hasCommas = /,/.test(trimmed);\n const decimalPlaces = trimmed.includes('.') ? trimmed.split('.')[1]?.length || 0 : 0;\n return (\n (hasCommas ? '#,###' : '#') + (decimalPlaces > 0 ? '.' + '#'.repeat(decimalPlaces) : '')\n );\n }\n\n case 'phone': {\n // Detect phone format\n if (/^\\(\\d{3}\\)\\s?\\d{3}-\\d{4}$/.test(trimmed)) return '(###) ###-####';\n if (/^\\d{3}-\\d{3}-\\d{4}$/.test(trimmed)) return '###-###-####';\n if (/^\\+\\d/.test(trimmed)) return '+# ###...';\n return 'phone';\n }\n\n default:\n return dataType;\n }\n}\n\n/**\n * Analyze format of a single element's value.\n */\nexport function analyzeFormat(\n elementId: string,\n label: string,\n rawValue: string\n): FormatDescriptor {\n const { type: dataType } = classifyDataType(rawValue);\n const pattern = detectFormatPattern(rawValue, dataType);\n\n return {\n elementId,\n label,\n dataType,\n pattern,\n example: rawValue.trim(),\n };\n}\n\n/**\n * Analyze formats for all data-bearing elements on a page.\n */\nexport function analyzePageFormats(elements: AIDiscoveredElement[]): FormatDescriptor[] {\n const descriptors: FormatDescriptor[] = [];\n\n for (const el of elements) {\n const rawValue = el.state?.value ?? el.state?.textContent ?? '';\n if (!rawValue) continue;\n\n const label = el.accessibleName || el.labelText || el.label || el.description || el.id;\n descriptors.push(analyzeFormat(el.id, label, rawValue));\n }\n\n return descriptors;\n}\n\n/**\n * Compare formats between source and target descriptors with matching labels.\n */\nexport function compareFormats(\n sourceFormats: FormatDescriptor[],\n targetFormats: FormatDescriptor[],\n config: FormatAnalysisConfig = DEFAULT_FORMAT_ANALYSIS_CONFIG\n): FormatMismatch[] {\n const mismatches: FormatMismatch[] = [];\n\n // Index target by label\n const targetByLabel = new Map<string, FormatDescriptor>();\n for (const t of targetFormats) {\n targetByLabel.set(t.label.toLowerCase(), t);\n }\n\n for (const source of sourceFormats) {\n const target = targetByLabel.get(source.label.toLowerCase());\n if (!target) continue; // No matching field in target\n\n // Same data type?\n if (source.dataType !== target.dataType) {\n mismatches.push({\n label: source.label,\n sourceFormat: source,\n targetFormat: target,\n severity: 'error',\n description: `Data type mismatch: source is ${source.dataType}, target is ${target.dataType}`,\n });\n continue;\n }\n\n // Same pattern?\n if (source.pattern !== target.pattern) {\n const severity = config.lenientFormatting ? 'warning' : 'error';\n mismatches.push({\n label: source.label,\n sourceFormat: source,\n targetFormat: target,\n severity,\n description: `Format differs: source uses \"${source.pattern}\", target uses \"${target.pattern}\"`,\n });\n }\n }\n\n return mismatches;\n}\n","/**\n * Cross-App Diff\n *\n * Matches elements between source and target pages and computes\n * a structured diff of data values, formats, and unmatched elements.\n */\n\nimport type {\n AIDiscoveredElement,\n MatchedElementPair,\n DataValueComparison,\n CrossAppDiff,\n} from './types';\nimport { jaroWinklerSimilarity, normalizeString } from './fuzzy-matcher';\nimport { extractPageData, normalizeValue, classifyDataType } from './data-extraction';\nimport { analyzePageFormats, compareFormats } from './format-analysis';\n\nexport interface CrossAppDiffConfig {\n /** Minimum confidence to consider a match */\n matchThreshold: number;\n /** Weight for accessible name matching */\n accessibleNameWeight: number;\n /** Weight for text matching */\n textWeight: number;\n /** Weight for role + position matching */\n rolePositionWeight: number;\n}\n\nexport const DEFAULT_CROSS_APP_DIFF_CONFIG: CrossAppDiffConfig = {\n matchThreshold: 0.5,\n accessibleNameWeight: 1.0,\n textWeight: 0.95,\n rolePositionWeight: 0.7,\n};\n\n/**\n * Get the displayable text from an element.\n */\nfunction getElementText(el: AIDiscoveredElement): string {\n return (\n el.accessibleName || el.labelText || el.label || el.state?.textContent || el.description || ''\n );\n}\n\n/**\n * Get the role of an element.\n */\nfunction getRole(el: AIDiscoveredElement): string {\n return (el.role || el.type || '').toLowerCase();\n}\n\n/**\n * Get the center position of an element.\n */\nfunction getCenter(el: AIDiscoveredElement): { x: number; y: number } | null {\n const rect = el.state?.rect;\n if (!rect) return null;\n return {\n x: rect.x + rect.width / 2,\n y: rect.y + rect.height / 2,\n };\n}\n\n/**\n * Compute a match score between two elements using multiple strategies.\n * Returns { score, strategy } where strategy describes the best match.\n */\nfunction computeMatchScore(\n source: AIDiscoveredElement,\n target: AIDiscoveredElement,\n config: CrossAppDiffConfig\n): { score: number; strategy: string } {\n let bestScore = 0;\n let bestStrategy = 'none';\n\n // Strategy 1: Exact accessible name match\n const srcName = (source.accessibleName || '').trim();\n const tgtName = (target.accessibleName || '').trim();\n if (srcName && tgtName && srcName.toLowerCase() === tgtName.toLowerCase()) {\n return { score: config.accessibleNameWeight, strategy: 'accessible-name-exact' };\n }\n\n // Strategy 2: Exact text match\n const srcText = getElementText(source);\n const tgtText = getElementText(target);\n if (srcText && tgtText && srcText.toLowerCase() === tgtText.toLowerCase()) {\n const score = config.textWeight;\n if (score > bestScore) {\n bestScore = score;\n bestStrategy = 'text-exact';\n }\n }\n\n // Strategy 3: Fuzzy text match via Jaro-Winkler\n if (srcText && tgtText) {\n const srcNorm = normalizeString(srcText);\n const tgtNorm = normalizeString(tgtText);\n const similarity = jaroWinklerSimilarity(srcNorm, tgtNorm);\n const score = similarity * 0.85;\n if (score > bestScore) {\n bestScore = score;\n bestStrategy = 'text-fuzzy';\n }\n }\n\n // Strategy 4: Same role + similar position\n const srcRole = getRole(source);\n const tgtRole = getRole(target);\n if (srcRole && srcRole === tgtRole) {\n const srcCenter = getCenter(source);\n const tgtCenter = getCenter(target);\n if (srcCenter && tgtCenter) {\n // Normalized position similarity (assume 1920x1080 viewport)\n const dx = Math.abs(srcCenter.x - tgtCenter.x) / 1920;\n const dy = Math.abs(srcCenter.y - tgtCenter.y) / 1080;\n const posSimilarity = 1 - Math.min(1, Math.sqrt(dx * dx + dy * dy));\n const score = config.rolePositionWeight * posSimilarity;\n if (score > bestScore) {\n bestScore = score;\n bestStrategy = 'role-position';\n }\n }\n }\n\n // Strategy 5: Data overlap (same normalized value)\n const srcVal = source.state?.value ?? source.state?.textContent ?? '';\n const tgtVal = target.state?.value ?? target.state?.textContent ?? '';\n if (srcVal && tgtVal) {\n const srcType = classifyDataType(srcVal).type;\n const tgtType = classifyDataType(tgtVal).type;\n const srcNorm = normalizeValue(srcVal, srcType);\n const tgtNorm = normalizeValue(tgtVal, tgtType);\n if (srcNorm === tgtNorm && srcNorm !== '') {\n const score = 0.6;\n if (score > bestScore) {\n bestScore = score;\n bestStrategy = 'data-overlap';\n }\n }\n }\n\n return { score: bestScore, strategy: bestStrategy };\n}\n\n/**\n * Match elements between source and target using greedy assignment.\n * Elements are matched by descending confidence.\n */\nexport function matchElements(\n sourceElements: AIDiscoveredElement[],\n targetElements: AIDiscoveredElement[],\n config: CrossAppDiffConfig = DEFAULT_CROSS_APP_DIFF_CONFIG\n): MatchedElementPair[] {\n // Compute all pairwise scores\n const candidates: Array<{\n sourceIdx: number;\n targetIdx: number;\n score: number;\n strategy: string;\n }> = [];\n\n for (let si = 0; si < sourceElements.length; si++) {\n for (let ti = 0; ti < targetElements.length; ti++) {\n const { score, strategy } = computeMatchScore(sourceElements[si], targetElements[ti], config);\n if (score >= config.matchThreshold) {\n candidates.push({ sourceIdx: si, targetIdx: ti, score, strategy });\n }\n }\n }\n\n // Greedy assignment: sort descending by score, assign first-come\n candidates.sort((a, b) => b.score - a.score);\n\n const usedSource = new Set<number>();\n const usedTarget = new Set<number>();\n const pairs: MatchedElementPair[] = [];\n\n for (const c of candidates) {\n if (usedSource.has(c.sourceIdx) || usedTarget.has(c.targetIdx)) continue;\n usedSource.add(c.sourceIdx);\n usedTarget.add(c.targetIdx);\n\n const src = sourceElements[c.sourceIdx];\n const tgt = targetElements[c.targetIdx];\n\n pairs.push({\n sourceId: src.id,\n targetId: tgt.id,\n sourceLabel: getElementText(src) || src.id,\n targetLabel: getElementText(tgt) || tgt.id,\n confidence: Math.round(c.score * 100) / 100,\n matchStrategy: c.strategy,\n });\n }\n\n return pairs;\n}\n\n/**\n * Compute a full cross-app diff between source and target element sets.\n */\nexport function computeCrossAppDiff(\n sourceElements: AIDiscoveredElement[],\n targetElements: AIDiscoveredElement[],\n config: CrossAppDiffConfig = DEFAULT_CROSS_APP_DIFF_CONFIG\n): CrossAppDiff {\n // Match elements\n const matchedPairs = matchElements(sourceElements, targetElements, config);\n const matchedSourceIds = new Set(matchedPairs.map((p) => p.sourceId));\n const matchedTargetIds = new Set(matchedPairs.map((p) => p.targetId));\n\n const unmatchedSourceIds = sourceElements\n .filter((e) => !matchedSourceIds.has(e.id))\n .map((e) => e.id);\n const unmatchedTargetIds = targetElements\n .filter((e) => !matchedTargetIds.has(e.id))\n .map((e) => e.id);\n\n // Data comparisons for matched pairs\n const sourceData = extractPageData(sourceElements);\n const targetData = extractPageData(targetElements);\n\n const dataComparisons: DataValueComparison[] = [];\n for (const pair of matchedPairs) {\n // Find data values by element ID\n const srcEntry = Object.values(sourceData.values).find((v) => v.elementId === pair.sourceId);\n const tgtEntry = Object.values(targetData.values).find((v) => v.elementId === pair.targetId);\n\n if (srcEntry && tgtEntry) {\n dataComparisons.push({\n label: pair.sourceLabel,\n sourceValue: srcEntry.rawValue,\n targetValue: tgtEntry.rawValue,\n valuesMatch: srcEntry.normalizedValue === tgtEntry.normalizedValue,\n formatsMatch: srcEntry.dataType === tgtEntry.dataType,\n });\n }\n }\n\n // Format mismatches\n const sourceFormats = analyzePageFormats(sourceElements);\n const targetFormats = analyzePageFormats(targetElements);\n const formatMismatches = compareFormats(sourceFormats, targetFormats);\n\n return {\n matchedPairs,\n unmatchedSourceIds,\n unmatchedTargetIds,\n dataComparisons,\n formatMismatches,\n };\n}\n","/**\n * Action Parity\n *\n * Compares the interactive capabilities (available actions) of matched\n * element pairs to detect missing functionality between source and target.\n */\n\nimport type { AIDiscoveredElement, MatchedElementPair, InteractionParity } from './types';\n\nexport interface ActionParityConfig {\n /** Actions to ignore in comparison (e.g., framework-internal actions) */\n ignoreActions: string[];\n}\n\nexport const DEFAULT_ACTION_PARITY_CONFIG: ActionParityConfig = {\n ignoreActions: [],\n};\n\n/**\n * Get the list of available actions for an element.\n */\nfunction getActions(el: AIDiscoveredElement, ignoreActions: string[]): string[] {\n const actions = el.actions || el.suggestedActions || [];\n const ignoreSet = new Set(ignoreActions.map((a) => a.toLowerCase()));\n return actions\n .map((a: string | { action?: string; name?: string }) =>\n typeof a === 'string' ? a : a.action || a.name || ''\n )\n .filter((a: string) => a && !ignoreSet.has(a.toLowerCase()));\n}\n\n/**\n * Analyze action parity for all matched element pairs.\n */\nexport function analyzeActionParity(\n matchedPairs: MatchedElementPair[],\n sourceElements: AIDiscoveredElement[],\n targetElements: AIDiscoveredElement[],\n config: ActionParityConfig = DEFAULT_ACTION_PARITY_CONFIG\n): InteractionParity[] {\n const sourceById = new Map(sourceElements.map((e) => [e.id, e]));\n const targetById = new Map(targetElements.map((e) => [e.id, e]));\n\n const results: InteractionParity[] = [];\n\n for (const pair of matchedPairs) {\n const src = sourceById.get(pair.sourceId);\n const tgt = targetById.get(pair.targetId);\n if (!src || !tgt) continue;\n\n const sourceActions = getActions(src, config.ignoreActions);\n const targetActions = getActions(tgt, config.ignoreActions);\n\n const sourceSet = new Set(sourceActions.map((a) => a.toLowerCase()));\n const targetSet = new Set(targetActions.map((a) => a.toLowerCase()));\n\n const missingInTarget = sourceActions.filter((a) => !targetSet.has(a.toLowerCase()));\n const missingInSource = targetActions.filter((a) => !sourceSet.has(a.toLowerCase()));\n\n results.push({\n pair,\n sourceActions,\n targetActions,\n missingInTarget,\n missingInSource,\n });\n }\n\n return results;\n}\n","/**\n * Navigation Map\n *\n * Identifies navigation elements in both source and target pages\n * and maps them to each other for parity analysis.\n */\n\nimport type { AIDiscoveredElement, NavigationPair, NavigationMap } from './types';\nimport { jaroWinklerSimilarity, normalizeString } from './fuzzy-matcher';\n\nexport interface NavigationMapConfig {\n /** Minimum similarity for label matching */\n labelMatchThreshold: number;\n}\n\nexport const DEFAULT_NAVIGATION_MAP_CONFIG: NavigationMapConfig = {\n labelMatchThreshold: 0.8,\n};\n\n/**\n * Determine whether an element is a navigation link/item.\n */\nexport function isNavigationElement(el: AIDiscoveredElement): boolean {\n const role = (el.role || '').toLowerCase();\n const type = (el.type || '').toLowerCase();\n const semanticType = (el.semanticType || '').toLowerCase();\n\n // Explicit navigation roles\n if (['link', 'menuitem', 'tab'].includes(role)) return true;\n\n // Element types\n if (['link', 'menuitem'].includes(type)) return true;\n\n // Semantic type hints\n if (\n semanticType.includes('nav') ||\n semanticType.includes('menu') ||\n semanticType.includes('tab')\n ) {\n return true;\n }\n\n // Check if element is inside a navigation context\n const context = (el.parentContext || '').toLowerCase();\n if (context.includes('nav') || context.includes('menu') || context.includes('sidebar')) {\n if (role === 'button' || type === 'button' || role === 'link' || type === 'link') {\n return true;\n }\n }\n\n return false;\n}\n\n/**\n * Extract the navigation label from an element.\n */\nfunction getNavLabel(el: AIDiscoveredElement): string {\n return el.accessibleName || el.labelText || el.label || el.description || el.id;\n}\n\n/**\n * Extract the href/destination from an element.\n */\nfunction getHref(el: AIDiscoveredElement): string | undefined {\n // href is not on ElementState; check for it via unknown cast\n const state = el.state as unknown as Record<string, unknown>;\n return (state?.href as string) || undefined;\n}\n\n/**\n * Check if two href values point to equivalent destinations.\n */\nfunction hrefsMatch(a?: string, b?: string): boolean {\n if (!a || !b) return false;\n // Normalize: strip trailing slashes, protocol, and port differences\n const normalize = (h: string) =>\n h\n .replace(/^https?:\\/\\//, '')\n .replace(/localhost:\\d+/, '')\n .replace(/\\/+$/, '')\n .toLowerCase();\n return normalize(a) === normalize(b);\n}\n\n/**\n * Build a navigation map comparing source and target pages.\n */\nexport function buildNavigationMap(\n sourceElements: AIDiscoveredElement[],\n targetElements: AIDiscoveredElement[],\n config: NavigationMapConfig = DEFAULT_NAVIGATION_MAP_CONFIG\n): NavigationMap {\n const sourceNav = sourceElements.filter(isNavigationElement);\n const targetNav = targetElements.filter(isNavigationElement);\n\n const pairs: NavigationPair[] = [];\n const matchedTargetIds = new Set<string>();\n\n for (const src of sourceNav) {\n const srcLabel = getNavLabel(src);\n const srcNorm = normalizeString(srcLabel);\n let bestTarget: AIDiscoveredElement | null = null;\n let bestScore = 0;\n\n for (const tgt of targetNav) {\n if (matchedTargetIds.has(tgt.id)) continue;\n\n const tgtLabel = getNavLabel(tgt);\n const tgtNorm = normalizeString(tgtLabel);\n\n // Exact match\n if (srcNorm === tgtNorm) {\n bestTarget = tgt;\n bestScore = 1.0;\n break;\n }\n\n // Fuzzy match\n const similarity = jaroWinklerSimilarity(srcNorm, tgtNorm);\n if (similarity > bestScore && similarity >= config.labelMatchThreshold) {\n bestScore = similarity;\n bestTarget = tgt;\n }\n }\n\n if (bestTarget) {\n matchedTargetIds.add(bestTarget.id);\n const srcHref = getHref(src);\n const tgtHref = getHref(bestTarget);\n pairs.push({\n sourceId: src.id,\n targetId: bestTarget.id,\n label: srcLabel,\n sourceHref: srcHref,\n targetHref: tgtHref,\n destinationMatch: hrefsMatch(srcHref, tgtHref),\n });\n }\n }\n\n const sourceOnly = sourceNav\n .filter((s) => !pairs.some((p) => p.sourceId === s.id))\n .map((s) => s.id);\n const targetOnly = targetNav.filter((t) => !matchedTargetIds.has(t.id)).map((t) => t.id);\n\n return { pairs, sourceOnly, targetOnly };\n}\n","/**\n * Component Comparison\n *\n * Compares registered components between source and target apps,\n * matching by name/type and diffing state keys and actions.\n */\n\nimport type { ComponentInfo, ComponentMatch, ComponentComparison } from './types';\nimport { jaroWinklerSimilarity, normalizeString } from './fuzzy-matcher';\n\nexport interface ComponentComparisonConfig {\n /** Minimum similarity for name matching */\n nameMatchThreshold: number;\n}\n\nexport const DEFAULT_COMPONENT_COMPARISON_CONFIG: ComponentComparisonConfig = {\n nameMatchThreshold: 0.75,\n};\n\n/**\n * Compute match score between two components based on name and type.\n */\nfunction computeComponentMatchScore(source: ComponentInfo, target: ComponentInfo): number {\n // Exact name match\n if (source.name.toLowerCase() === target.name.toLowerCase()) return 1.0;\n\n // Same type + similar name\n let score = 0;\n\n if (source.type === target.type) {\n score += 0.3;\n }\n\n const nameSimilarity = jaroWinklerSimilarity(\n normalizeString(source.name),\n normalizeString(target.name)\n );\n score += nameSimilarity * 0.7;\n\n return score;\n}\n\n/**\n * Compare components between source and target apps.\n *\n * Note: ComponentInfo is not part of SemanticSnapshot. The caller must\n * fetch component lists separately from /control/components endpoint.\n */\nexport function compareComponents(\n sourceComponents: ComponentInfo[],\n targetComponents: ComponentInfo[],\n config: ComponentComparisonConfig = DEFAULT_COMPONENT_COMPARISON_CONFIG\n): ComponentComparison {\n // Compute all pairwise match scores\n const candidates: Array<{\n sourceIdx: number;\n targetIdx: number;\n score: number;\n }> = [];\n\n for (let si = 0; si < sourceComponents.length; si++) {\n for (let ti = 0; ti < targetComponents.length; ti++) {\n const score = computeComponentMatchScore(sourceComponents[si], targetComponents[ti]);\n if (score >= config.nameMatchThreshold) {\n candidates.push({ sourceIdx: si, targetIdx: ti, score });\n }\n }\n }\n\n // Greedy assignment\n candidates.sort((a, b) => b.score - a.score);\n const usedSource = new Set<number>();\n const usedTarget = new Set<number>();\n const matches: ComponentMatch[] = [];\n\n for (const c of candidates) {\n if (usedSource.has(c.sourceIdx) || usedTarget.has(c.targetIdx)) continue;\n usedSource.add(c.sourceIdx);\n usedTarget.add(c.targetIdx);\n\n const src = sourceComponents[c.sourceIdx];\n const tgt = targetComponents[c.targetIdx];\n\n // Compute state key diff\n const srcKeys = new Set(src.stateKeys);\n const tgtKeys = new Set(tgt.stateKeys);\n const missingKeys = src.stateKeys.filter((k) => !tgtKeys.has(k));\n const extraKeys = tgt.stateKeys.filter((k) => !srcKeys.has(k));\n\n // Compute action diff\n const srcActions = new Set(src.actions.map((a) => a.toLowerCase()));\n const tgtActions = new Set(tgt.actions.map((a) => a.toLowerCase()));\n const missingActions = src.actions.filter((a) => !tgtActions.has(a.toLowerCase()));\n const extraActions = tgt.actions.filter((a) => !srcActions.has(a.toLowerCase()));\n\n matches.push({\n source: src,\n target: tgt,\n confidence: Math.round(c.score * 100) / 100,\n stateKeyDiff: { missing: missingKeys, extra: extraKeys },\n actionDiff: { missing: missingActions, extra: extraActions },\n });\n }\n\n const sourceOnly = sourceComponents.filter((_, i) => !usedSource.has(i));\n const targetOnly = targetComponents.filter((_, i) => !usedTarget.has(i));\n\n return { matches, sourceOnly, targetOnly };\n}\n","/**\n * Layout Comparison\n *\n * Compares the spatial layout between two pages: grid structure,\n * hierarchy depth, and information density.\n */\n\nimport type {\n AIDiscoveredElement,\n GridStructure,\n GridDiff,\n HierarchyDiff,\n DensityComparison,\n LayoutComparison,\n PageRegionMap,\n} from './types';\n\nexport interface LayoutComparisonConfig {\n /** Tolerance for column/row alignment detection (px) */\n gridTolerance: number;\n}\n\nexport const DEFAULT_LAYOUT_COMPARISON_CONFIG: LayoutComparisonConfig = {\n gridTolerance: 20,\n};\n\ninterface Bounds {\n x: number;\n y: number;\n width: number;\n height: number;\n}\n\nfunction getRect(el: AIDiscoveredElement): Bounds | null {\n const rect = el.state?.rect;\n if (!rect || !rect.width) return null;\n return { x: rect.x, y: rect.y, width: rect.width, height: rect.height };\n}\n\n/**\n * Cluster numeric values with a given tolerance.\n */\nfunction clusterValues(values: number[], tolerance: number): number[] {\n if (values.length === 0) return [];\n const sorted = [...values].sort((a, b) => a - b);\n const clusters: number[] = [sorted[0]];\n for (let i = 1; i < sorted.length; i++) {\n if (sorted[i] - clusters[clusters.length - 1] > tolerance) {\n clusters.push(sorted[i]);\n }\n }\n return clusters;\n}\n\n/**\n * Detect the implicit grid structure from element positions.\n */\nexport function detectGridStructure(\n elements: AIDiscoveredElement[],\n config: LayoutComparisonConfig = DEFAULT_LAYOUT_COMPARISON_CONFIG\n): GridStructure {\n const rects = elements.map(getRect).filter((r): r is Bounds => r !== null);\n\n const xPositions = rects.map((r) => r.x);\n const yPositions = rects.map((r) => r.y);\n\n const columns = clusterValues(xPositions, config.gridTolerance);\n const rows = clusterValues(yPositions, config.gridTolerance);\n\n return {\n columns,\n rows,\n columnCount: columns.length,\n rowCount: rows.length,\n };\n}\n\n/**\n * Compute the maximum nesting depth from parent context chains.\n */\nfunction computeMaxDepth(elements: AIDiscoveredElement[]): number {\n let maxDepth = 0;\n for (const el of elements) {\n // Use parentContext chain as a proxy for depth\n const context = el.parentContext || '';\n const depth = context ? context.split('>').length : 1;\n maxDepth = Math.max(maxDepth, depth);\n }\n return maxDepth;\n}\n\n/**\n * Compute a prominence score for an element (0-1) based on size and position.\n * Larger elements nearer the top are more prominent.\n */\nexport function computeProminence(\n element: AIDiscoveredElement,\n pageWidth: number,\n pageHeight: number\n): number {\n const rect = getRect(element);\n if (!rect || pageWidth === 0 || pageHeight === 0) return 0;\n\n const sizeScore = (rect.width * rect.height) / (pageWidth * pageHeight);\n const positionScore = 1 - rect.y / pageHeight;\n\n return Math.min(1, sizeScore * 0.6 + positionScore * 0.4);\n}\n\n/**\n * Compare layouts between source and target element sets.\n */\nexport function compareLayouts(\n sourceElements: AIDiscoveredElement[],\n targetElements: AIDiscoveredElement[],\n sourceRegions?: PageRegionMap,\n targetRegions?: PageRegionMap,\n config: LayoutComparisonConfig = DEFAULT_LAYOUT_COMPARISON_CONFIG\n): LayoutComparison {\n const sourceGrid = detectGridStructure(sourceElements, config);\n const targetGrid = detectGridStructure(targetElements, config);\n\n const gridDiff: GridDiff = {\n sourceGrid,\n targetGrid,\n columnDiff: sourceGrid.columnCount - targetGrid.columnCount,\n rowDiff: sourceGrid.rowCount - targetGrid.rowCount,\n };\n\n const sourceDepth = computeMaxDepth(sourceElements);\n const targetDepth = computeMaxDepth(targetElements);\n const hierarchyDiff: HierarchyDiff = {\n sourceDepth,\n targetDepth,\n depthDiff: sourceDepth - targetDepth,\n };\n\n // Density: elements per region (or elements per page if no regions)\n const sourceRegionCount = sourceRegions?.regions.length || 1;\n const targetRegionCount = targetRegions?.regions.length || 1;\n const sourceDensity = sourceElements.length / sourceRegionCount;\n const targetDensity = targetElements.length / targetRegionCount;\n\n const density: DensityComparison = {\n sourceDensity: Math.round(sourceDensity * 100) / 100,\n targetDensity: Math.round(targetDensity * 100) / 100,\n ratio: targetDensity > 0 ? Math.round((sourceDensity / targetDensity) * 100) / 100 : 0,\n };\n\n // Overall similarity: combine grid, hierarchy, and density similarity\n const gridSimilarity =\n sourceGrid.columnCount === 0 && targetGrid.columnCount === 0\n ? 1\n : 1 -\n Math.abs(gridDiff.columnDiff) / Math.max(sourceGrid.columnCount, targetGrid.columnCount, 1);\n\n const hierarchySimilarity =\n sourceDepth === 0 && targetDepth === 0\n ? 1\n : 1 - Math.abs(hierarchyDiff.depthDiff) / Math.max(sourceDepth, targetDepth, 1);\n\n const densitySimilarity = density.ratio > 0 ? Math.min(density.ratio, 1 / density.ratio) : 0;\n\n const similarity =\n Math.round((gridSimilarity * 0.4 + hierarchySimilarity * 0.3 + densitySimilarity * 0.3) * 100) /\n 100;\n\n return {\n gridDiff,\n hierarchyDiff,\n density,\n similarity,\n };\n}\n","/**\n * Content Comparison\n *\n * Compares content elements (headings, metrics, labels, statuses, table data)\n * between source and target semantic snapshots. Produces a structured\n * ContentComparison result alongside the existing interactive element comparison.\n */\n\nimport type {\n AIDiscoveredElement,\n ContentComparison,\n HeadingMatch,\n HeadingChange,\n MetricMatch,\n CrossAppMetricChange,\n StatusMatch,\n CrossAppStatusChange,\n TableComparison,\n HeadingLevelComparison,\n} from './types';\nimport { jaroWinklerSimilarity, normalizeString } from './fuzzy-matcher';\nimport { extractStructuredData } from './table-extraction';\n\nexport interface ContentComparisonConfig {\n /** Minimum fuzzy similarity to consider two labels as matching */\n labelMatchThreshold: number;\n /** Minimum fuzzy similarity to consider two headings as matching */\n headingMatchThreshold: number;\n /** Maximum cell differences to report per table */\n maxCellDifferences: number;\n}\n\nexport const DEFAULT_CONTENT_COMPARISON_CONFIG: ContentComparisonConfig = {\n labelMatchThreshold: 0.8,\n headingMatchThreshold: 0.75,\n maxCellDifferences: 50,\n};\n\n// ---------------------------------------------------------------------------\n// Helpers\n// ---------------------------------------------------------------------------\n\n/**\n * Get the text content of an element for comparison.\n */\nfunction getElementText(el: AIDiscoveredElement): string {\n return (\n el.accessibleName ||\n el.labelText ||\n el.label ||\n el.state?.textContent ||\n el.description ||\n ''\n ).trim();\n}\n\n/**\n * Get the content role from an element, checking both contentMetadata and\n * type-based heuristics.\n */\nfunction getContentRole(el: AIDiscoveredElement): string | null {\n if (el.contentMetadata?.contentRole) {\n return el.contentMetadata.contentRole;\n }\n // Fall back to element type for common content types\n const t = (el.type || '').toLowerCase();\n if (t === 'heading' || (t.startsWith('h') && /^h[1-6]$/.test(t))) return 'heading';\n if (t === 'metric-value' || t === 'metric') return 'metric';\n if (t === 'status-message' || t === 'status') return 'status';\n if (t === 'label') return 'label';\n if (t === 'badge') return 'badge';\n if (t === 'table-cell') return 'table-cell';\n if (t === 'table-header') return 'table-header';\n if (t === 'caption') return 'caption';\n return null;\n}\n\n/**\n * Get heading level from element metadata or type.\n */\nfunction getHeadingLevel(el: AIDiscoveredElement): number | undefined {\n if (el.contentMetadata?.headingLevel) {\n return el.contentMetadata.headingLevel;\n }\n // Check tagName or type like 'h1', 'h2', etc.\n const tag = (el.tagName || el.type || '').toLowerCase();\n const match = /^h([1-6])$/.exec(tag);\n if (match) return parseInt(match[1], 10);\n return undefined;\n}\n\n/**\n * Check if an element is a content element (not interactive).\n */\nfunction isContentElement(el: AIDiscoveredElement): boolean {\n if (el.category === 'content') return true;\n if (el.contentMetadata) return true;\n const role = getContentRole(el);\n return role !== null;\n}\n\n/**\n * Normalize text for fuzzy comparison: lowercase, collapse whitespace, trim.\n */\nfunction normalizeText(text: string): string {\n return normalizeString(text, { caseSensitive: false, ignoreWhitespace: true });\n}\n\n/**\n * Check if two texts match with fuzzy threshold.\n */\nfunction _textsMatch(a: string, b: string, threshold: number): boolean {\n const na = normalizeText(a);\n const nb = normalizeText(b);\n if (!na || !nb) return false;\n if (na === nb) return true;\n return jaroWinklerSimilarity(na, nb) >= threshold;\n}\n\n/**\n * Extract the numeric or data portion from a metric/status element.\n * For elements like \"Total: 42\", returns { label: \"Total\", value: \"42\" }.\n * If no separator found, the full text is the value and the element label is used.\n */\nfunction parseMetricText(el: AIDiscoveredElement): { label: string; value: string } {\n const text = getElementText(el);\n // Try common separator patterns: \"Label: Value\", \"Label - Value\"\n const colonMatch = text.match(/^(.+?):\\s*(.+)$/);\n if (colonMatch) {\n return { label: colonMatch[1].trim(), value: colonMatch[2].trim() };\n }\n const dashMatch = text.match(/^(.+?)\\s*[-]\\s*(.+)$/);\n if (dashMatch) {\n return { label: dashMatch[1].trim(), value: dashMatch[2].trim() };\n }\n // Use the element's own label/accessibleName as the label, text as value\n const elLabel = el.accessibleName || el.labelText || el.label || el.id;\n return { label: elLabel, value: text };\n}\n\n// ---------------------------------------------------------------------------\n// Filter elements by content role\n// ---------------------------------------------------------------------------\n\nfunction filterHeadings(elements: AIDiscoveredElement[]): AIDiscoveredElement[] {\n return elements.filter((el) => getContentRole(el) === 'heading');\n}\n\nfunction filterMetrics(elements: AIDiscoveredElement[]): AIDiscoveredElement[] {\n return elements.filter((el) => getContentRole(el) === 'metric');\n}\n\nfunction filterStatuses(elements: AIDiscoveredElement[]): AIDiscoveredElement[] {\n return elements.filter((el) => {\n const role = getContentRole(el);\n return role === 'status' || role === 'badge';\n });\n}\n\nfunction filterLabels(elements: AIDiscoveredElement[]): AIDiscoveredElement[] {\n return elements.filter((el) => {\n const role = getContentRole(el);\n return role === 'label' || role === 'caption';\n });\n}\n\n// ---------------------------------------------------------------------------\n// Greedy bipartite matching with fuzzy text\n// ---------------------------------------------------------------------------\n\ninterface MatchCandidate {\n sourceIdx: number;\n targetIdx: number;\n score: number;\n}\n\n/**\n * Match two lists of texts using greedy bipartite assignment.\n * Returns arrays of matched indices and unmatched indices.\n */\nfunction matchTexts(\n sourceTexts: string[],\n targetTexts: string[],\n threshold: number\n): {\n matched: Array<{ sourceIdx: number; targetIdx: number; score: number }>;\n unmatchedSource: number[];\n unmatchedTarget: number[];\n} {\n const candidates: MatchCandidate[] = [];\n\n for (let si = 0; si < sourceTexts.length; si++) {\n const sNorm = normalizeText(sourceTexts[si]);\n if (!sNorm) continue;\n for (let ti = 0; ti < targetTexts.length; ti++) {\n const tNorm = normalizeText(targetTexts[ti]);\n if (!tNorm) continue;\n const score = sNorm === tNorm ? 1.0 : jaroWinklerSimilarity(sNorm, tNorm);\n if (score >= threshold) {\n candidates.push({ sourceIdx: si, targetIdx: ti, score });\n }\n }\n }\n\n // Sort descending by score\n candidates.sort((a, b) => b.score - a.score);\n\n const usedSource = new Set<number>();\n const usedTarget = new Set<number>();\n const matched: Array<{ sourceIdx: number; targetIdx: number; score: number }> = [];\n\n for (const c of candidates) {\n if (usedSource.has(c.sourceIdx) || usedTarget.has(c.targetIdx)) continue;\n usedSource.add(c.sourceIdx);\n usedTarget.add(c.targetIdx);\n matched.push(c);\n }\n\n const unmatchedSource = sourceTexts.map((_, i) => i).filter((i) => !usedSource.has(i));\n const unmatchedTarget = targetTexts.map((_, i) => i).filter((i) => !usedTarget.has(i));\n\n return { matched, unmatchedSource, unmatchedTarget };\n}\n\n// ---------------------------------------------------------------------------\n// Heading comparison\n// ---------------------------------------------------------------------------\n\nfunction compareHeadings(\n sourceElements: AIDiscoveredElement[],\n targetElements: AIDiscoveredElement[],\n config: ContentComparisonConfig\n): ContentComparison['headings'] {\n const srcHeadings = filterHeadings(sourceElements);\n const tgtHeadings = filterHeadings(targetElements);\n\n const srcTexts = srcHeadings.map(getElementText);\n const tgtTexts = tgtHeadings.map(getElementText);\n\n const { matched, unmatchedSource, unmatchedTarget } = matchTexts(\n srcTexts,\n tgtTexts,\n config.headingMatchThreshold\n );\n\n const headingMatched: HeadingMatch[] = [];\n const headingChanged: HeadingChange[] = [];\n\n for (const m of matched) {\n const srcText = srcTexts[m.sourceIdx];\n const tgtText = tgtTexts[m.targetIdx];\n const srcLevel = getHeadingLevel(srcHeadings[m.sourceIdx]);\n const tgtLevel = getHeadingLevel(tgtHeadings[m.targetIdx]);\n\n if (normalizeText(srcText) === normalizeText(tgtText)) {\n headingMatched.push({\n source: srcText,\n target: tgtText,\n level: srcLevel,\n });\n } else {\n headingChanged.push({\n source: srcText,\n target: tgtText,\n level: srcLevel ?? tgtLevel,\n });\n }\n }\n\n return {\n matched: headingMatched,\n sourceOnly: unmatchedSource.map((i) => srcTexts[i]),\n targetOnly: unmatchedTarget.map((i) => tgtTexts[i]),\n changed: headingChanged,\n };\n}\n\n// ---------------------------------------------------------------------------\n// Metric comparison\n// ---------------------------------------------------------------------------\n\nfunction compareMetrics(\n sourceElements: AIDiscoveredElement[],\n targetElements: AIDiscoveredElement[],\n config: ContentComparisonConfig\n): ContentComparison['metrics'] {\n const srcMetrics = filterMetrics(sourceElements);\n const tgtMetrics = filterMetrics(targetElements);\n\n const srcParsed = srcMetrics.map(parseMetricText);\n const tgtParsed = tgtMetrics.map(parseMetricText);\n\n const srcLabels = srcParsed.map((p) => p.label);\n const tgtLabels = tgtParsed.map((p) => p.label);\n\n const { matched, unmatchedSource, unmatchedTarget } = matchTexts(\n srcLabels,\n tgtLabels,\n config.labelMatchThreshold\n );\n\n const metricMatched: MetricMatch[] = [];\n const metricChanged: CrossAppMetricChange[] = [];\n\n for (const m of matched) {\n const src = srcParsed[m.sourceIdx];\n const tgt = tgtParsed[m.targetIdx];\n\n if (normalizeText(src.value) === normalizeText(tgt.value)) {\n metricMatched.push({\n label: src.label,\n sourceValue: src.value,\n targetValue: tgt.value,\n });\n } else {\n metricChanged.push({\n label: src.label,\n sourceValue: src.value,\n targetValue: tgt.value,\n });\n }\n }\n\n return {\n matched: metricMatched,\n changed: metricChanged,\n sourceOnly: unmatchedSource.map((i) => srcParsed[i].label),\n targetOnly: unmatchedTarget.map((i) => tgtParsed[i].label),\n };\n}\n\n// ---------------------------------------------------------------------------\n// Status comparison\n// ---------------------------------------------------------------------------\n\nfunction compareStatuses(\n sourceElements: AIDiscoveredElement[],\n targetElements: AIDiscoveredElement[],\n config: ContentComparisonConfig\n): ContentComparison['statuses'] {\n const srcStatuses = filterStatuses(sourceElements);\n const tgtStatuses = filterStatuses(targetElements);\n\n const srcParsed = srcStatuses.map(parseMetricText);\n const tgtParsed = tgtStatuses.map(parseMetricText);\n\n const srcLabels = srcParsed.map((p) => p.label);\n const tgtLabels = tgtParsed.map((p) => p.label);\n\n const { matched } = matchTexts(srcLabels, tgtLabels, config.labelMatchThreshold);\n\n const statusMatched: StatusMatch[] = [];\n const statusChanged: CrossAppStatusChange[] = [];\n\n for (const m of matched) {\n const src = srcParsed[m.sourceIdx];\n const tgt = tgtParsed[m.targetIdx];\n\n if (normalizeText(src.value) === normalizeText(tgt.value)) {\n statusMatched.push({\n label: src.label,\n sourceStatus: src.value,\n targetStatus: tgt.value,\n });\n } else {\n statusChanged.push({\n label: src.label,\n sourceStatus: src.value,\n targetStatus: tgt.value,\n });\n }\n }\n\n return {\n matched: statusMatched,\n changed: statusChanged,\n };\n}\n\n// ---------------------------------------------------------------------------\n// Label / text comparison\n// ---------------------------------------------------------------------------\n\nfunction compareLabels(\n sourceElements: AIDiscoveredElement[],\n targetElements: AIDiscoveredElement[],\n config: ContentComparisonConfig\n): ContentComparison['labels'] {\n const srcLabels = filterLabels(sourceElements);\n const tgtLabels = filterLabels(targetElements);\n\n const srcTexts = srcLabels.map(getElementText);\n const tgtTexts = tgtLabels.map(getElementText);\n\n const { matched, unmatchedSource, unmatchedTarget } = matchTexts(\n srcTexts,\n tgtTexts,\n config.labelMatchThreshold\n );\n\n return {\n matched: matched.map((m) => srcTexts[m.sourceIdx]),\n sourceOnly: unmatchedSource.map((i) => srcTexts[i]),\n targetOnly: unmatchedTarget.map((i) => tgtTexts[i]),\n };\n}\n\n// ---------------------------------------------------------------------------\n// Table comparison\n// ---------------------------------------------------------------------------\n\nfunction compareTables(\n sourceElements: AIDiscoveredElement[],\n targetElements: AIDiscoveredElement[],\n config: ContentComparisonConfig\n): TableComparison[] {\n const srcData = extractStructuredData(sourceElements);\n const tgtData = extractStructuredData(targetElements);\n\n const srcTables = srcData.tables;\n const tgtTables = tgtData.tables;\n\n if (srcTables.length === 0 || tgtTables.length === 0) {\n return [];\n }\n\n // Match tables by label similarity\n const srcTableLabels = srcTables.map((t) => t.label || '');\n const tgtTableLabels = tgtTables.map((t) => t.label || '');\n\n const { matched } = matchTexts(srcTableLabels, tgtTableLabels, config.labelMatchThreshold);\n\n // If label matching finds nothing, try matching by column similarity\n const tablePairs: Array<{ srcIdx: number; tgtIdx: number }> = [];\n if (matched.length > 0) {\n for (const m of matched) {\n tablePairs.push({ srcIdx: m.sourceIdx, tgtIdx: m.targetIdx });\n }\n } else if (srcTables.length === 1 && tgtTables.length === 1) {\n // Single table in both -- assume they correspond\n tablePairs.push({ srcIdx: 0, tgtIdx: 0 });\n }\n\n const comparisons: TableComparison[] = [];\n\n for (const pair of tablePairs) {\n const srcTable = srcTables[pair.srcIdx];\n const tgtTable = tgtTables[pair.tgtIdx];\n\n const srcHeaders = srcTable.columns.map((c) => c.header);\n const tgtHeaders = tgtTable.columns.map((c) => c.header);\n\n const srcHeaderSet = new Set(srcHeaders.map(normalizeText));\n const tgtHeaderSet = new Set(tgtHeaders.map(normalizeText));\n\n const sourceOnlyColumns = srcHeaders.filter((h) => !tgtHeaderSet.has(normalizeText(h)));\n const targetOnlyColumns = tgtHeaders.filter((h) => !srcHeaderSet.has(normalizeText(h)));\n const columnsMatch = sourceOnlyColumns.length === 0 && targetOnlyColumns.length === 0;\n\n // Compare cell values for matching columns\n const cellDifferences: TableComparison['cellDifferences'] = [];\n const commonHeaders = srcHeaders.filter((h) => tgtHeaderSet.has(normalizeText(h)));\n\n const minRows = Math.min(srcTable.rows.length, tgtTable.rows.length);\n for (let row = 0; row < minRows; row++) {\n if (cellDifferences.length >= config.maxCellDifferences) break;\n\n for (const header of commonHeaders) {\n const srcColIdx = srcHeaders.indexOf(header);\n const tgtColIdx = tgtHeaders.findIndex((h) => normalizeText(h) === normalizeText(header));\n\n if (srcColIdx < 0 || tgtColIdx < 0) continue;\n\n const srcValue = srcTable.rows[row]?.[srcColIdx] ?? '';\n const tgtValue = tgtTable.rows[row]?.[tgtColIdx] ?? '';\n\n if (normalizeText(srcValue) !== normalizeText(tgtValue)) {\n cellDifferences.push({\n row,\n column: header,\n sourceValue: srcValue,\n targetValue: tgtValue,\n });\n }\n }\n }\n\n comparisons.push({\n sourceLabel: srcTable.label,\n targetLabel: tgtTable.label,\n columnsMatch,\n sourceOnlyColumns,\n targetOnlyColumns,\n sourceRowCount: srcTable.rows.length,\n targetRowCount: tgtTable.rows.length,\n cellDifferences,\n });\n }\n\n return comparisons;\n}\n\n// ---------------------------------------------------------------------------\n// Heading hierarchy comparison\n// ---------------------------------------------------------------------------\n\nfunction compareHeadingHierarchy(\n sourceElements: AIDiscoveredElement[],\n targetElements: AIDiscoveredElement[]\n): HeadingLevelComparison[] {\n const srcHeadings = filterHeadings(sourceElements);\n const tgtHeadings = filterHeadings(targetElements);\n\n const srcByLevel = new Map<number, number>();\n const tgtByLevel = new Map<number, number>();\n\n for (const el of srcHeadings) {\n const level = getHeadingLevel(el) ?? 0;\n srcByLevel.set(level, (srcByLevel.get(level) ?? 0) + 1);\n }\n for (const el of tgtHeadings) {\n const level = getHeadingLevel(el) ?? 0;\n tgtByLevel.set(level, (tgtByLevel.get(level) ?? 0) + 1);\n }\n\n const allLevels = new Set([...srcByLevel.keys(), ...tgtByLevel.keys()]);\n const result: HeadingLevelComparison[] = [];\n\n for (const level of [...allLevels].sort()) {\n result.push({\n level,\n sourceCount: srcByLevel.get(level) ?? 0,\n targetCount: tgtByLevel.get(level) ?? 0,\n });\n }\n\n return result;\n}\n\n// ---------------------------------------------------------------------------\n// Main comparison function\n// ---------------------------------------------------------------------------\n\n/**\n * Compare content elements between source and target.\n *\n * Analyzes headings, metrics, statuses, labels, and table data,\n * producing a structured ContentComparison result.\n */\nexport function compareContent(\n sourceElements: AIDiscoveredElement[],\n targetElements: AIDiscoveredElement[],\n config: ContentComparisonConfig = DEFAULT_CONTENT_COMPARISON_CONFIG\n): ContentComparison {\n // Filter to content elements only (but include all for table extraction\n // since tables may contain interactive elements mixed with content)\n const srcContent = sourceElements.filter(isContentElement);\n const tgtContent = targetElements.filter(isContentElement);\n\n const headings = compareHeadings(srcContent, tgtContent, config);\n const metrics = compareMetrics(srcContent, tgtContent, config);\n const statuses = compareStatuses(srcContent, tgtContent, config);\n const labels = compareLabels(srcContent, tgtContent, config);\n const tables = compareTables(sourceElements, targetElements, config);\n const headingHierarchy = compareHeadingHierarchy(srcContent, tgtContent);\n\n // Calculate content parity score\n const contentParity = calculateContentParity(headings, metrics, statuses, labels, tables);\n\n return {\n headings,\n metrics,\n statuses,\n labels,\n tables,\n headingHierarchy,\n contentParity,\n };\n}\n\n/**\n * Calculate a content parity score (0-1) from all content comparison results.\n */\nfunction calculateContentParity(\n headings: ContentComparison['headings'],\n metrics: ContentComparison['metrics'],\n statuses: ContentComparison['statuses'],\n labels: ContentComparison['labels'],\n tables: TableComparison[]\n): number {\n const scores: number[] = [];\n\n // Heading parity\n const totalHeadings =\n headings.matched.length +\n headings.changed.length +\n headings.sourceOnly.length +\n headings.targetOnly.length;\n if (totalHeadings > 0) {\n scores.push(headings.matched.length / totalHeadings);\n }\n\n // Metric parity\n const totalMetrics =\n metrics.matched.length +\n metrics.changed.length +\n metrics.sourceOnly.length +\n metrics.targetOnly.length;\n if (totalMetrics > 0) {\n // Matched metrics (same value) get full score, changed get half\n const metricScore = (metrics.matched.length + metrics.changed.length * 0.5) / totalMetrics;\n scores.push(metricScore);\n }\n\n // Status parity\n const totalStatuses = statuses.matched.length + statuses.changed.length;\n if (totalStatuses > 0) {\n scores.push(statuses.matched.length / totalStatuses);\n }\n\n // Label parity\n const totalLabels = labels.matched.length + labels.sourceOnly.length + labels.targetOnly.length;\n if (totalLabels > 0) {\n scores.push(labels.matched.length / totalLabels);\n }\n\n // Table parity\n if (tables.length > 0) {\n let tableScore = 0;\n for (const table of tables) {\n let tScore = table.columnsMatch ? 0.5 : 0;\n if (table.sourceRowCount > 0) {\n const rowRatio = Math.min(\n table.targetRowCount / table.sourceRowCount,\n table.sourceRowCount / table.targetRowCount\n );\n tScore += rowRatio * 0.3;\n } else {\n tScore += 0.3;\n }\n // Penalize cell differences\n const totalCells =\n Math.max(table.sourceRowCount, 1) *\n Math.max(\n table.sourceOnlyColumns.length +\n table.targetOnlyColumns.length +\n (table.columnsMatch ? 1 : 0),\n 1\n );\n const diffRatio =\n totalCells > 0 ? 1 - Math.min(table.cellDifferences.length / totalCells, 1) : 1;\n tScore += diffRatio * 0.2;\n tableScore += tScore;\n }\n scores.push(tableScore / tables.length);\n }\n\n if (scores.length === 0) return 1; // No content elements to compare\n return Math.round((scores.reduce((a, b) => a + b, 0) / scores.length) * 100) / 100;\n}\n","/**\n * Comparison Report\n *\n * Orchestrates all cross-app analysis modules to produce a unified\n * comparison report with scores, issues, and a summary.\n */\n\nimport type {\n SemanticSnapshot,\n CrossAppComparisonReport,\n ComparisonIssue,\n ComponentInfo,\n} from './types';\nimport { extractPageData } from './data-extraction';\nimport { segmentPageRegions } from './region-segmentation';\nimport { computeCrossAppDiff } from './cross-app-diff';\nimport { analyzeActionParity } from './action-parity';\nimport { buildNavigationMap } from './navigation-map';\nimport { compareComponents } from './component-comparison';\nimport { compareLayouts } from './layout-comparison';\nimport { compareContent } from './content-comparison';\n\nexport interface ComparisonReportConfig {\n /** Include component comparison (requires separate ComponentInfo arrays) */\n includeComponents: boolean;\n}\n\nexport const DEFAULT_COMPARISON_REPORT_CONFIG: ComparisonReportConfig = {\n includeComponents: false,\n};\n\n/**\n * Generate a comprehensive cross-app comparison report.\n *\n * @param source - Source page semantic snapshot\n * @param target - Target page semantic snapshot\n * @param options - Optional configuration and component data\n * @returns Full comparison report with scores, issues, and summary\n */\nexport function generateComparisonReport(\n source: SemanticSnapshot,\n target: SemanticSnapshot,\n options?: {\n config?: ComparisonReportConfig;\n sourceComponents?: ComponentInfo[];\n targetComponents?: ComponentInfo[];\n }\n): CrossAppComparisonReport {\n const startTime = Date.now();\n const config = { ...DEFAULT_COMPARISON_REPORT_CONFIG, ...options?.config };\n\n const srcElements = source.elements;\n const tgtElements = target.elements;\n\n // 1. Cross-app diff (element matching + data comparison)\n const diff = computeCrossAppDiff(srcElements, tgtElements);\n\n // 2. Navigation map\n const navigation = buildNavigationMap(srcElements, tgtElements);\n\n // 3. Region segmentation\n const sourceRegions = segmentPageRegions(srcElements);\n const targetRegions = segmentPageRegions(tgtElements);\n\n // 4. Layout comparison\n const layout = compareLayouts(srcElements, tgtElements, sourceRegions, targetRegions);\n\n // 5. Action parity\n const actionParityResults = analyzeActionParity(diff.matchedPairs, srcElements, tgtElements);\n\n // 6. Component comparison (optional)\n const componentComparison =\n config.includeComponents && options?.sourceComponents && options?.targetComponents\n ? compareComponents(options.sourceComponents, options.targetComponents)\n : null;\n\n // 7. Content comparison (headings, metrics, statuses, labels, tables)\n const contentComparison = compareContent(srcElements, tgtElements);\n\n // --- Compute Scores ---\n\n // Data completeness: how many source data fields are matched in target\n const sourceData = extractPageData(srcElements);\n const _targetData = extractPageData(tgtElements);\n const sourceFieldCount = Object.keys(sourceData.values).length;\n const matchedDataCount = diff.dataComparisons.length;\n const dataCompleteness =\n sourceFieldCount > 0 ? Math.round((matchedDataCount / sourceFieldCount) * 100) / 100 : 1;\n\n // Format alignment: fraction of matched fields with same format\n const formatMatchCount = diff.dataComparisons.filter((c) => c.formatsMatch).length;\n const formatAlignment =\n matchedDataCount > 0 ? Math.round((formatMatchCount / matchedDataCount) * 100) / 100 : 1;\n\n // Presentation alignment: layout similarity\n const presentationAlignment = layout.similarity;\n\n // Navigation parity\n const totalNavItems = navigation.pairs.length + navigation.sourceOnly.length;\n const navigationParity =\n totalNavItems > 0 ? Math.round((navigation.pairs.length / totalNavItems) * 100) / 100 : 1;\n\n // Action parity\n const totalActionChecks = actionParityResults.length;\n const fullParityCount = actionParityResults.filter((r) => r.missingInTarget.length === 0).length;\n const actionParity =\n totalActionChecks > 0 ? Math.round((fullParityCount / totalActionChecks) * 100) / 100 : 1;\n\n // Content parity\n const contentParity = contentComparison.contentParity;\n\n // Overall score (weighted average, includes content parity)\n const overallScore =\n Math.round(\n (dataCompleteness * 0.2 +\n formatAlignment * 0.1 +\n presentationAlignment * 0.15 +\n navigationParity * 0.15 +\n actionParity * 0.15 +\n contentParity * 0.25) *\n 100\n ) / 100;\n\n // --- Collect Issues ---\n\n const issues: ComparisonIssue[] = [];\n\n // Missing data fields\n for (const srcId of diff.unmatchedSourceIds) {\n const srcVal = Object.values(sourceData.values).find((v) => v.elementId === srcId);\n if (srcVal) {\n issues.push({\n severity: 'warning',\n category: 'missing-data',\n description: `Data field \"${srcVal.label}\" (${srcVal.dataType}) exists in source but has no match in target`,\n sourceElementId: srcId,\n });\n }\n }\n\n // Value mismatches\n for (const comp of diff.dataComparisons) {\n if (!comp.valuesMatch) {\n issues.push({\n severity: 'error',\n category: 'value-mismatch',\n description: `Value mismatch for \"${comp.label}\": source=\"${comp.sourceValue}\", target=\"${comp.targetValue}\"`,\n });\n }\n }\n\n // Format mismatches\n for (const fm of diff.formatMismatches) {\n issues.push({\n severity: fm.severity,\n category: 'format-mismatch',\n description: fm.description,\n });\n }\n\n // Missing actions\n for (const ap of actionParityResults) {\n for (const action of ap.missingInTarget) {\n issues.push({\n severity: 'warning',\n category: 'missing-action',\n description: `Action \"${action}\" available on source element \"${ap.pair.sourceLabel}\" is missing in target`,\n sourceElementId: ap.pair.sourceId,\n targetElementId: ap.pair.targetId,\n });\n }\n }\n\n // Navigation gaps\n for (const srcId of navigation.sourceOnly) {\n issues.push({\n severity: 'warning',\n category: 'navigation-gap',\n description: `Navigation item \"${srcId}\" in source has no match in target`,\n sourceElementId: srcId,\n });\n }\n\n // Layout differences (only if significant)\n if (layout.similarity < 0.5) {\n issues.push({\n severity: 'warning',\n category: 'layout-difference',\n description: `Layout similarity is low (${layout.similarity}). Grid: ${layout.gridDiff.sourceGrid.columnCount} cols vs ${layout.gridDiff.targetGrid.columnCount} cols`,\n });\n }\n\n // Component mismatches\n if (componentComparison) {\n for (const src of componentComparison.sourceOnly) {\n issues.push({\n severity: 'info',\n category: 'component-mismatch',\n description: `Component \"${src.name}\" (${src.type}) exists in source but not target`,\n });\n }\n for (const match of componentComparison.matches) {\n if (match.stateKeyDiff.missing.length > 0) {\n issues.push({\n severity: 'warning',\n category: 'component-mismatch',\n description: `Component \"${match.source.name}\": state keys missing in target: ${match.stateKeyDiff.missing.join(', ')}`,\n });\n }\n }\n }\n\n // Content differences\n for (const heading of contentComparison.headings.sourceOnly) {\n issues.push({\n severity: 'warning',\n category: 'content-difference',\n description: `Heading \"${heading}\" exists in source but not in target`,\n });\n }\n for (const heading of contentComparison.headings.targetOnly) {\n issues.push({\n severity: 'info',\n category: 'content-difference',\n description: `Heading \"${heading}\" exists in target but not in source`,\n });\n }\n for (const change of contentComparison.headings.changed) {\n issues.push({\n severity: 'warning',\n category: 'content-difference',\n description: `Heading changed: \"${change.source}\" -> \"${change.target}\"`,\n });\n }\n for (const change of contentComparison.metrics.changed) {\n issues.push({\n severity: 'warning',\n category: 'content-difference',\n description: `Metric \"${change.label}\" value differs: \"${change.sourceValue}\" vs \"${change.targetValue}\"`,\n });\n }\n for (const label of contentComparison.metrics.sourceOnly) {\n issues.push({\n severity: 'warning',\n category: 'content-difference',\n description: `Metric \"${label}\" exists in source but not in target`,\n });\n }\n for (const change of contentComparison.statuses.changed) {\n issues.push({\n severity: 'warning',\n category: 'content-difference',\n description: `Status \"${change.label}\" differs: \"${change.sourceStatus}\" vs \"${change.targetStatus}\"`,\n });\n }\n for (const table of contentComparison.tables) {\n if (!table.columnsMatch) {\n issues.push({\n severity: 'warning',\n category: 'content-difference',\n description: `Table \"${table.sourceLabel}\" column mismatch: source-only=[${table.sourceOnlyColumns.join(', ')}], target-only=[${table.targetOnlyColumns.join(', ')}]`,\n });\n }\n if (table.sourceRowCount !== table.targetRowCount) {\n issues.push({\n severity: 'info',\n category: 'content-difference',\n description: `Table \"${table.sourceLabel}\" row count differs: ${table.sourceRowCount} vs ${table.targetRowCount}`,\n });\n }\n if (table.cellDifferences.length > 0) {\n issues.push({\n severity: 'warning',\n category: 'content-difference',\n description: `Table \"${table.sourceLabel}\" has ${table.cellDifferences.length} cell value difference(s)`,\n });\n }\n }\n\n // Sort issues: error > warning > info\n const severityOrder = { error: 0, warning: 1, info: 2 };\n issues.sort((a, b) => severityOrder[a.severity] - severityOrder[b.severity]);\n\n // --- Build Summary ---\n\n const errorCount = issues.filter((i) => i.severity === 'error').length;\n const warningCount = issues.filter((i) => i.severity === 'warning').length;\n const infoCount = issues.filter((i) => i.severity === 'info').length;\n\n const summaryLines = [\n `Cross-app comparison: ${source.page.url} vs ${target.page.url}`,\n `Overall score: ${(overallScore * 100).toFixed(0)}%`,\n `Matched elements: ${diff.matchedPairs.length}`,\n `Unmatched: ${diff.unmatchedSourceIds.length} source, ${diff.unmatchedTargetIds.length} target`,\n `Navigation: ${navigation.pairs.length} matched, ${navigation.sourceOnly.length} source-only, ${navigation.targetOnly.length} target-only`,\n ];\n\n if (componentComparison) {\n summaryLines.push(\n `Components: ${componentComparison.matches.length} matched, ${componentComparison.sourceOnly.length} source-only, ${componentComparison.targetOnly.length} target-only`\n );\n }\n\n // Content summary\n const hMatched = contentComparison.headings.matched.length;\n const hChanged = contentComparison.headings.changed.length;\n const hSrcOnly = contentComparison.headings.sourceOnly.length;\n const hTgtOnly = contentComparison.headings.targetOnly.length;\n const mMatched = contentComparison.metrics.matched.length;\n const mChanged = contentComparison.metrics.changed.length;\n const sMatched = contentComparison.statuses.matched.length;\n const sChanged = contentComparison.statuses.changed.length;\n const totalContent =\n hMatched + hChanged + hSrcOnly + hTgtOnly + mMatched + mChanged + sMatched + sChanged;\n\n if (totalContent > 0) {\n summaryLines.push(\n `Content: headings=${hMatched} matched/${hChanged} changed/${hSrcOnly + hTgtOnly} unmatched, ` +\n `metrics=${mMatched} matched/${mChanged} changed, ` +\n `statuses=${sMatched} matched/${sChanged} changed, ` +\n `parity=${(contentParity * 100).toFixed(0)}%`\n );\n }\n\n summaryLines.push(`Issues: ${errorCount} errors, ${warningCount} warnings, ${infoCount} info`);\n\n const summary = summaryLines.join('\\n');\n\n const report: CrossAppComparisonReport = {\n sourceUrl: source.page.url,\n targetUrl: target.page.url,\n timestamp: Date.now(),\n durationMs: Date.now() - startTime,\n scores: {\n dataCompleteness,\n formatAlignment,\n presentationAlignment,\n navigationParity,\n actionParity,\n overallScore,\n },\n diff,\n navigation,\n layout,\n contentComparison,\n issues,\n summary,\n };\n\n if (componentComparison) {\n report.components = componentComparison;\n }\n\n return report;\n}\n","/**\n * UI Bridge Server Handlers\n *\n * Factory function to create handler implementations for all UI Bridge endpoints.\n */\n\nimport type { UIBridgeServerHandlers, APIResponse, RenderLogQuery } from './types';\nimport type { ControlSnapshot, PageNavigateRequest, PageNavigationResponse } from '../control';\nimport type { RenderLogEntry } from '../render-log';\nimport type { ActionFailureDetails, ActionErrorCode } from '../core';\nimport type {\n SearchCriteria,\n SearchResponse,\n NLActionRequest,\n NLActionResponse,\n AssertionRequest,\n AssertionResult,\n BatchAssertionRequest,\n BatchAssertionResult,\n SemanticSnapshot,\n SemanticDiff,\n SemanticSearchCriteria,\n SemanticSearchResponse,\n SemanticSearchResult,\n AIDiscoveredElement,\n Intent,\n IntentSearchResponse,\n IntentExecutionResult,\n RecoveryAttemptRequest,\n RecoveryAttemptResult,\n PageDataMap,\n PageRegionMap,\n StructuredDataExtraction,\n CrossAppComparisonReport,\n ComponentInfo,\n} from '../ai';\nimport type {\n UIState,\n UIStateGroup,\n UITransition,\n PathResult,\n TransitionResult,\n NavigationResult,\n StateSnapshot,\n} from '../core';\nimport {\n SearchEngine,\n NLActionExecutor,\n AssertionExecutor,\n SemanticSnapshotManager,\n SemanticDiffManager,\n generatePageSummary,\n extractPageData,\n segmentPageRegions,\n extractStructuredData,\n generateComparisonReport,\n} from '../ai';\nimport type { ElementAnnotation, AnnotationConfig, AnnotationCoverage } from '../annotations';\nimport { AnnotationStore, getGlobalAnnotationStore } from '../annotations';\nimport type { CapturedError } from '../debug/browser-capture-types';\n\n/**\n * Registry interface - minimal contract for handler usage\n */\nexport interface RegistryLike {\n getAllElements(): unknown[];\n getElement(id: string): unknown | undefined;\n getAllComponents(): unknown[];\n getComponent(id: string): unknown | undefined;\n getComponentState?(id: string): {\n state: Record<string, unknown>;\n computed: Record<string, unknown>;\n timestamp: number;\n } | null;\n createSnapshot(): ControlSnapshot;\n getRenderLog?(): RenderLogEntry[];\n clearRenderLog?(): void;\n captureSnapshot?(): unknown;\n findElements?(request?: unknown): unknown[];\n getAllWorkflows?(): unknown[];\n getWorkflow?(id: string): unknown;\n getActionHistory?(): unknown[];\n getMetrics?(): unknown;\n highlightElement?(id: string): void;\n getElementTree?(): unknown;\n\n // State management\n getStates?(): UIState[];\n getState?(id: string): UIState | undefined;\n getActiveStates?(): UIState[];\n activateState?(id: string): void;\n deactivateState?(id: string): void;\n getStateGroups?(): UIStateGroup[];\n activateStateGroup?(id: string): void;\n deactivateStateGroup?(id: string): void;\n getTransitions?(): UITransition[];\n canExecuteTransition?(id: string): { canExecute: boolean; reason?: string };\n executeTransition?(id: string): Promise<TransitionResult>;\n findPath?(targetStates: string[]): PathResult;\n navigateTo?(targetStates: string[]): Promise<NavigationResult>;\n getStateSnapshot?(): StateSnapshot;\n}\n\n/**\n * Action executor interface - minimal contract for handler usage\n */\nexport interface ActionExecutorLike {\n executeAction(\n elementId: string,\n request: { action: string; params?: Record<string, unknown>; waitOptions?: unknown }\n ): Promise<unknown>;\n executeComponentAction(\n componentId: string,\n request: { action: string; params?: Record<string, unknown> }\n ): Promise<unknown>;\n}\n\n/**\n * Console capture interface — minimal contract for handler usage\n */\nexport interface ConsoleCapturelike {\n getConsoleSince(ts: number): CapturedError[];\n getConsoleRecent(n?: number): CapturedError[];\n clear(): void;\n}\n\n/**\n * Configuration for creating handlers\n */\nexport interface CreateHandlersConfig {\n /** Optional render log path */\n renderLogPath?: string;\n /** Verbose logging */\n verbose?: boolean;\n /** Optional annotation store (defaults to global singleton) */\n annotationStore?: AnnotationStore;\n /** Optional console capture instance for error monitoring */\n consoleCapture?: ConsoleCapturelike;\n}\n\n/**\n * Create a success response\n */\nfunction success<T>(data: T): APIResponse<T> {\n return {\n success: true,\n data,\n timestamp: Date.now(),\n };\n}\n\n/**\n * Create an error response\n */\nfunction error<T = unknown>(message: string, code?: string): APIResponse<T> {\n return {\n success: false,\n error: message,\n code,\n timestamp: Date.now(),\n };\n}\n\n/**\n * Generate recovery suggestions based on error code\n */\nfunction getRecoverySuggestions(errorCode: ActionErrorCode): Array<{\n suggestion: string;\n command?: string;\n confidence: number;\n retryable: boolean;\n}> {\n switch (errorCode) {\n case 'ELEMENT_NOT_FOUND':\n return [\n {\n suggestion: 'Wait for the page to fully load',\n command: 'wait for page to load',\n confidence: 0.7,\n retryable: true,\n },\n {\n suggestion: 'Use a different description for the element',\n confidence: 0.8,\n retryable: false,\n },\n {\n suggestion: 'Scroll the page to reveal the element',\n command: 'scroll down',\n confidence: 0.6,\n retryable: true,\n },\n ];\n case 'ELEMENT_NOT_VISIBLE':\n return [\n {\n suggestion: 'Scroll to make the element visible',\n command: 'scroll to element',\n confidence: 0.9,\n retryable: true,\n },\n {\n suggestion: 'Wait for any loading overlays to disappear',\n confidence: 0.7,\n retryable: true,\n },\n {\n suggestion: 'Close any blocking modals or popups',\n command: 'click close button',\n confidence: 0.8,\n retryable: true,\n },\n ];\n case 'ELEMENT_NOT_ENABLED':\n return [\n { suggestion: 'Fill in required fields first', confidence: 0.8, retryable: false },\n {\n suggestion: 'Complete prerequisite steps in the form',\n confidence: 0.7,\n retryable: false,\n },\n {\n suggestion: 'Wait for the element to become enabled',\n command: 'wait for element to be enabled',\n confidence: 0.6,\n retryable: true,\n },\n ];\n case 'ELEMENT_NOT_INTERACTABLE':\n return [\n {\n suggestion: 'Close any modal or popup blocking the element',\n command: 'click close button',\n confidence: 0.9,\n retryable: true,\n },\n { suggestion: 'Wait for animations to complete', confidence: 0.7, retryable: true },\n {\n suggestion: 'Scroll the element into the viewport',\n command: 'scroll to element',\n confidence: 0.8,\n retryable: true,\n },\n ];\n case 'ACTION_TIMEOUT':\n return [\n { suggestion: 'Increase the timeout duration', confidence: 0.8, retryable: true },\n { suggestion: 'Check if the condition can ever be met', confidence: 0.7, retryable: false },\n {\n suggestion: 'Verify the page is responding',\n command: 'check page status',\n confidence: 0.6,\n retryable: true,\n },\n ];\n case 'LOW_CONFIDENCE':\n return [\n {\n suggestion: 'Use the exact text shown on the element',\n confidence: 0.9,\n retryable: false,\n },\n {\n suggestion: 'Try a different description that more closely matches the element',\n confidence: 0.8,\n retryable: false,\n },\n {\n suggestion: 'Lower the confidence threshold if the match is correct',\n confidence: 0.7,\n retryable: true,\n },\n ];\n case 'AMBIGUOUS_MATCH':\n return [\n {\n suggestion: 'Be more specific about which element you mean',\n confidence: 0.9,\n retryable: false,\n },\n {\n suggestion: 'Include the section or form name in the description',\n confidence: 0.8,\n retryable: false,\n },\n { suggestion: 'Use the element ID directly', confidence: 0.7, retryable: false },\n ];\n default:\n return [\n {\n suggestion: 'Try a different approach or check the page state',\n confidence: 0.5,\n retryable: false,\n },\n ];\n }\n}\n\n/**\n * Create structured failure details\n */\nfunction createFailureDetails(\n errorCode: ActionErrorCode,\n message: string,\n options: {\n elementId?: string;\n selectorsTried?: string[];\n durationMs?: number;\n timeoutMs?: number;\n } = {}\n): ActionFailureDetails {\n const retryableErrors: ActionErrorCode[] = [\n 'ELEMENT_NOT_VISIBLE',\n 'ACTION_TIMEOUT',\n 'LOW_CONFIDENCE',\n 'NETWORK_ERROR',\n 'STATE_NOT_REACHED',\n ];\n\n return {\n errorCode,\n message,\n elementId: options.elementId,\n selectorsTried: options.selectorsTried,\n suggestedActions: getRecoverySuggestions(errorCode),\n retryRecommended: retryableErrors.includes(errorCode),\n durationMs: options.durationMs,\n timeoutMs: options.timeoutMs,\n };\n}\n\n/**\n * Create server handlers for UI Bridge\n *\n * @param registry - The UI Bridge registry instance\n * @param actionExecutor - The action executor instance\n * @param config - Optional configuration\n * @returns Handler implementations for all endpoints\n *\n * @example\n * ```ts\n * import { createHandlers } from '@qontinui/ui-bridge/server';\n * import { getGlobalRegistry, createActionExecutor } from '@qontinui/ui-bridge';\n *\n * const registry = getGlobalRegistry();\n * const executor = createActionExecutor(registry);\n * const handlers = createHandlers(registry, executor);\n *\n * // Use with Express\n * const router = createExpressRouter(handlers);\n *\n * // Use with standalone server\n * const server = new StandaloneServer(handlers);\n * ```\n */\nexport function createHandlers(\n registry: RegistryLike,\n actionExecutor: ActionExecutorLike,\n config: CreateHandlersConfig = {}\n): UIBridgeServerHandlers {\n // Create AI module instances\n const searchEngine = new SearchEngine();\n const nlExecutor = new NLActionExecutor();\n const assertionExecutor = new AssertionExecutor();\n const snapshotManager = new SemanticSnapshotManager();\n const diffManager = new SemanticDiffManager();\n\n // Intent registry (in-memory store for registered intents)\n const intentRegistry = new Map<string, Intent>();\n\n // Console capture\n const consoleCapture = config.consoleCapture ?? null;\n\n // Annotation store\n const annotationStore = config.annotationStore ?? getGlobalAnnotationStore();\n\n // Helper to get fresh elements and update AI modules\n function refreshElements(): void {\n const elements = registry.getAllElements();\n searchEngine.updateElements(elements as any[]);\n nlExecutor.updateElements(elements as any[]);\n nlExecutor.setActionExecutor(actionExecutor as any);\n assertionExecutor.updateElements(elements as any[]);\n }\n\n return {\n // =========================================================================\n // Render Log Handlers\n // =========================================================================\n\n getRenderLog: async (query?: RenderLogQuery): Promise<APIResponse<RenderLogEntry[]>> => {\n try {\n const entries = registry.getRenderLog?.() ?? [];\n\n let filtered = entries;\n\n if (query?.type) {\n filtered = filtered.filter((e) => e.type === query.type);\n }\n if (query?.since) {\n filtered = filtered.filter((e) => e.timestamp >= query.since!);\n }\n if (query?.until) {\n filtered = filtered.filter((e) => e.timestamp <= query.until!);\n }\n if (query?.limit) {\n filtered = filtered.slice(0, query.limit);\n }\n\n return success(filtered);\n } catch (err) {\n return error((err as Error).message, 'RENDER_LOG_ERROR');\n }\n },\n\n clearRenderLog: async (): Promise<APIResponse<void>> => {\n try {\n registry.clearRenderLog?.();\n return success(undefined);\n } catch (err) {\n return error((err as Error).message, 'RENDER_LOG_ERROR');\n }\n },\n\n captureSnapshot: async (): Promise<APIResponse<unknown>> => {\n try {\n const snapshot = registry.captureSnapshot?.();\n return success(snapshot);\n } catch (err) {\n return error((err as Error).message, 'SNAPSHOT_ERROR');\n }\n },\n\n getRenderLogPath: async (): Promise<APIResponse<{ path: string }>> => {\n return success({ path: config.renderLogPath || '' });\n },\n\n // =========================================================================\n // Element Handlers\n // =========================================================================\n\n getElements: async (): Promise<APIResponse<ControlSnapshot['elements']>> => {\n try {\n const elements = registry.getAllElements();\n return success(elements as ControlSnapshot['elements']);\n } catch (err) {\n return error((err as Error).message, 'ELEMENTS_ERROR');\n }\n },\n\n getElement: async (id: string): Promise<APIResponse<ControlSnapshot['elements'][0]>> => {\n try {\n const element = registry.getElement(id);\n if (!element) {\n const failureDetails = createFailureDetails(\n 'ELEMENT_NOT_FOUND',\n `Element not found: ${id}`,\n {\n elementId: id,\n selectorsTried: [id],\n }\n );\n return {\n success: false,\n error: `Element not found: ${id}`,\n code: 'ELEMENT_NOT_FOUND',\n data: { failureDetails } as any,\n timestamp: Date.now(),\n };\n }\n return success(element as ControlSnapshot['elements'][0]);\n } catch (err) {\n return error((err as Error).message, 'ELEMENT_ERROR');\n }\n },\n\n getElementState: async (id: string): Promise<APIResponse<unknown>> => {\n try {\n const element = registry.getElement(id) as { state?: unknown } | undefined;\n if (!element) {\n return error(`Element not found: ${id}`, 'NOT_FOUND');\n }\n return success(element.state);\n } catch (err) {\n return error((err as Error).message, 'ELEMENT_STATE_ERROR');\n }\n },\n\n executeElementAction: async (\n id: string,\n request: { action: string; params?: Record<string, unknown>; waitOptions?: unknown }\n ) => {\n const startTime = Date.now();\n try {\n // Check if element exists first\n const element = registry.getElement(id);\n if (!element) {\n const failureDetails = createFailureDetails(\n 'ELEMENT_NOT_FOUND',\n `Element not found: ${id}`,\n {\n elementId: id,\n selectorsTried: [id],\n durationMs: Date.now() - startTime,\n }\n );\n return {\n success: false,\n error: `Element not found: ${id}`,\n code: 'ELEMENT_NOT_FOUND',\n data: {\n success: false,\n error: `Element not found: ${id}`,\n failureDetails,\n durationMs: Date.now() - startTime,\n timestamp: Date.now(),\n },\n timestamp: Date.now(),\n } as APIResponse<any>;\n }\n\n const result = await actionExecutor.executeAction(id, {\n action: request.action,\n params: request.params,\n waitOptions: request.waitOptions,\n });\n\n // If the action executor returned a failure, enhance with structured details\n if (result && typeof result === 'object' && 'success' in result && !result.success) {\n const actionResult = result as {\n success: boolean;\n error?: string;\n elementState?: unknown;\n };\n // Determine error code based on error message\n let errorCode: ActionErrorCode = 'UNKNOWN_ERROR';\n const errorMsg = actionResult.error?.toLowerCase() || '';\n\n if (errorMsg.includes('not found')) {\n errorCode = 'ELEMENT_NOT_FOUND';\n } else if (errorMsg.includes('not visible') || errorMsg.includes('hidden')) {\n errorCode = 'ELEMENT_NOT_VISIBLE';\n } else if (errorMsg.includes('disabled') || errorMsg.includes('not enabled')) {\n errorCode = 'ELEMENT_NOT_ENABLED';\n } else if (errorMsg.includes('timeout')) {\n errorCode = 'ACTION_TIMEOUT';\n } else if (errorMsg.includes('blocked') || errorMsg.includes('interactable')) {\n errorCode = 'ELEMENT_NOT_INTERACTABLE';\n }\n\n const failureDetails = createFailureDetails(\n errorCode,\n actionResult.error || 'Action failed',\n {\n elementId: id,\n durationMs: Date.now() - startTime,\n }\n );\n\n return success({\n ...actionResult,\n failureDetails,\n }) as APIResponse<any>;\n }\n\n return success(result) as APIResponse<any>;\n } catch (err) {\n const errorMessage = (err as Error).message;\n let errorCode: ActionErrorCode = 'UNKNOWN_ERROR';\n\n if (errorMessage.includes('not found')) {\n errorCode = 'ELEMENT_NOT_FOUND';\n } else if (errorMessage.includes('timeout')) {\n errorCode = 'ACTION_TIMEOUT';\n } else if (errorMessage.includes('network') || errorMessage.includes('fetch')) {\n errorCode = 'NETWORK_ERROR';\n }\n\n const failureDetails = createFailureDetails(errorCode, errorMessage, {\n elementId: id,\n durationMs: Date.now() - startTime,\n });\n\n return {\n success: false,\n error: errorMessage,\n code: errorCode,\n data: {\n success: false,\n error: errorMessage,\n failureDetails,\n durationMs: Date.now() - startTime,\n timestamp: Date.now(),\n },\n timestamp: Date.now(),\n } as APIResponse<any>;\n }\n },\n\n // =========================================================================\n // Component Handlers\n // =========================================================================\n\n getComponents: async (): Promise<APIResponse<ControlSnapshot['components']>> => {\n try {\n const components = registry.getAllComponents();\n return success(components as ControlSnapshot['components']);\n } catch (err) {\n return error((err as Error).message, 'COMPONENTS_ERROR');\n }\n },\n\n getComponent: async (id: string): Promise<APIResponse<ControlSnapshot['components'][0]>> => {\n try {\n const component = registry.getComponent(id);\n if (!component) {\n return error(`Component not found: ${id}`, 'NOT_FOUND');\n }\n return success(component as ControlSnapshot['components'][0]);\n } catch (err) {\n return error((err as Error).message, 'COMPONENT_ERROR');\n }\n },\n\n getComponentState: async (\n id: string\n ): Promise<\n APIResponse<{\n state: Record<string, unknown>;\n computed: Record<string, unknown>;\n timestamp: number;\n }>\n > => {\n try {\n // First check if the component exists\n const component = registry.getComponent(id);\n if (!component) {\n return error(`Component not found: ${id}`, 'NOT_FOUND');\n }\n\n // Use registry's getComponentState if available\n if (registry.getComponentState) {\n const stateResponse = registry.getComponentState(id);\n if (!stateResponse) {\n return error(`Component not found or not mounted: ${id}`, 'NOT_FOUND');\n }\n return success(stateResponse);\n }\n\n // Fallback: component exists but doesn't expose state\n const comp = component as {\n getState?: () => Record<string, unknown>;\n getComputed?: () => Record<string, unknown>;\n };\n return success({\n state: comp.getState?.() ?? {},\n computed: comp.getComputed?.() ?? {},\n timestamp: Date.now(),\n });\n } catch (err) {\n return error((err as Error).message, 'COMPONENT_STATE_ERROR');\n }\n },\n\n executeComponentAction: async (\n id: string,\n request: { action: string; params?: Record<string, unknown> }\n ) => {\n try {\n const result = await actionExecutor.executeComponentAction(id, {\n action: request.action,\n params: request.params,\n });\n return success(result) as APIResponse<any>;\n } catch (err) {\n return error((err as Error).message, 'COMPONENT_ACTION_ERROR');\n }\n },\n\n // =========================================================================\n // Find/Discovery Handlers\n // =========================================================================\n\n find: async (request?: unknown) => {\n try {\n const findRequest = request as\n | { types?: string[]; selector?: string; limit?: number }\n | undefined;\n const elements = registry.findElements?.(findRequest) ?? registry.getAllElements();\n return success({\n elements,\n timestamp: Date.now(),\n total: (elements as unknown[]).length,\n durationMs: 0,\n }) as APIResponse<any>;\n } catch (err) {\n return error((err as Error).message, 'FIND_ERROR');\n }\n },\n\n discover: async (request?: unknown) => {\n // Deprecated, delegates to find\n try {\n const findRequest = request as\n | { types?: string[]; selector?: string; limit?: number }\n | undefined;\n const elements = registry.findElements?.(findRequest) ?? registry.getAllElements();\n return success({\n elements,\n timestamp: Date.now(),\n total: (elements as unknown[]).length,\n durationMs: 0,\n }) as APIResponse<any>;\n } catch (err) {\n return error((err as Error).message, 'DISCOVER_ERROR');\n }\n },\n\n getControlSnapshot: async (): Promise<APIResponse<ControlSnapshot>> => {\n try {\n const snapshot = registry.createSnapshot();\n return success(snapshot);\n } catch (err) {\n return error((err as Error).message, 'SNAPSHOT_ERROR');\n }\n },\n\n // =========================================================================\n // Workflow Handlers\n // =========================================================================\n\n getWorkflows: async (): Promise<APIResponse<ControlSnapshot['workflows']>> => {\n try {\n const workflows = registry.getAllWorkflows?.() ?? [];\n return success(workflows as ControlSnapshot['workflows']);\n } catch (err) {\n return error((err as Error).message, 'WORKFLOWS_ERROR');\n }\n },\n\n runWorkflow: async (id: string, _request?: unknown) => {\n try {\n const workflow = registry.getWorkflow?.(id);\n if (!workflow) {\n return error(`Workflow not found: ${id}`, 'NOT_FOUND');\n }\n // TODO: Implement actual workflow execution\n const runId = `run-${Date.now()}`;\n return success({\n runId,\n workflowId: id,\n status: 'pending',\n startedAt: Date.now(),\n steps: [],\n totalSteps: 0,\n }) as APIResponse<any>;\n } catch (err) {\n return error((err as Error).message, 'WORKFLOW_ERROR');\n }\n },\n\n getWorkflowStatus: async (runId: string) => {\n try {\n // TODO: Implement workflow status tracking\n return success({\n runId,\n workflowId: '',\n status: 'completed',\n completedAt: Date.now(),\n startedAt: Date.now(),\n steps: [],\n totalSteps: 0,\n }) as APIResponse<any>;\n } catch (err) {\n return error((err as Error).message, 'WORKFLOW_STATUS_ERROR');\n }\n },\n\n // =========================================================================\n // Debug Handlers\n // =========================================================================\n\n getActionHistory: async (limit?: number): Promise<APIResponse<unknown[]>> => {\n try {\n const history = registry.getActionHistory?.() ?? [];\n const limited = limit ? history.slice(-limit) : history;\n return success(limited);\n } catch (err) {\n return error((err as Error).message, 'ACTION_HISTORY_ERROR');\n }\n },\n\n getMetrics: async (): Promise<APIResponse<unknown>> => {\n try {\n const metrics = registry.getMetrics?.() ?? {\n elementCount: registry.getAllElements().length,\n componentCount: registry.getAllComponents().length,\n };\n return success(metrics);\n } catch (err) {\n return error((err as Error).message, 'METRICS_ERROR');\n }\n },\n\n highlightElement: async (id: string): Promise<APIResponse<void>> => {\n try {\n registry.highlightElement?.(id);\n return success(undefined);\n } catch (err) {\n return error((err as Error).message, 'HIGHLIGHT_ERROR');\n }\n },\n\n getElementTree: async (): Promise<APIResponse<unknown>> => {\n try {\n const tree = registry.getElementTree?.() ?? { root: null, elements: [] };\n return success(tree);\n } catch (err) {\n return error((err as Error).message, 'ELEMENT_TREE_ERROR');\n }\n },\n\n getConsoleErrors: async (params?: {\n since?: number;\n limit?: number;\n }): Promise<APIResponse<{ errors: CapturedError[]; count: number }>> => {\n try {\n if (!consoleCapture) {\n return success({ errors: [], count: 0 });\n }\n const errors = params?.since\n ? consoleCapture.getConsoleSince(params.since)\n : consoleCapture.getConsoleRecent(params?.limit ?? 50);\n return success({ errors, count: errors.length });\n } catch (err) {\n return error((err as Error).message, 'CONSOLE_ERRORS_ERROR');\n }\n },\n\n clearConsoleErrors: async (): Promise<APIResponse<{ cleared: boolean }>> => {\n try {\n if (!consoleCapture) {\n return success({ cleared: false });\n }\n consoleCapture.clear();\n return success({ cleared: true });\n } catch (err) {\n return error((err as Error).message, 'CONSOLE_CLEAR_ERROR');\n }\n },\n\n // =========================================================================\n // AI-Native Handlers\n // =========================================================================\n\n aiSearch: async (criteria: SearchCriteria): Promise<APIResponse<SearchResponse>> => {\n try {\n // Refresh elements before search\n refreshElements();\n const response = searchEngine.search(criteria);\n return success(response);\n } catch (err) {\n return error((err as Error).message, 'AI_SEARCH_ERROR');\n }\n },\n\n aiExecute: async (request: NLActionRequest): Promise<APIResponse<NLActionResponse>> => {\n try {\n // Refresh elements before execution\n refreshElements();\n const response = await nlExecutor.execute(request);\n return success(response);\n } catch (err) {\n return error((err as Error).message, 'AI_EXECUTE_ERROR');\n }\n },\n\n aiAssert: async (request: AssertionRequest): Promise<APIResponse<AssertionResult>> => {\n try {\n // Refresh elements before assertion\n refreshElements();\n const result = await assertionExecutor.assert(request);\n return success(result);\n } catch (err) {\n return error((err as Error).message, 'AI_ASSERT_ERROR');\n }\n },\n\n aiAssertBatch: async (\n request: BatchAssertionRequest\n ): Promise<APIResponse<BatchAssertionResult>> => {\n try {\n // Refresh elements before batch assertion\n refreshElements();\n const result = await assertionExecutor.assertBatch(request);\n return success(result);\n } catch (err) {\n return error((err as Error).message, 'AI_ASSERT_BATCH_ERROR');\n }\n },\n\n getSemanticSnapshot: async (): Promise<APIResponse<SemanticSnapshot>> => {\n try {\n const controlSnapshot = registry.createSnapshot();\n const snapshot = snapshotManager.createSnapshot(controlSnapshot);\n return success(snapshot);\n } catch (err) {\n return error((err as Error).message, 'SEMANTIC_SNAPSHOT_ERROR');\n }\n },\n\n getSemanticDiff: async (_since?: number): Promise<APIResponse<SemanticDiff | null>> => {\n try {\n // Create current snapshot\n const controlSnapshot = registry.createSnapshot();\n const currentSnapshot = snapshotManager.createSnapshot(controlSnapshot);\n\n // Update the diff manager and get the diff from previous state\n const diff = diffManager.update(currentSnapshot);\n return success(diff);\n } catch (err) {\n return error((err as Error).message, 'SEMANTIC_DIFF_ERROR');\n }\n },\n\n getPageSummary: async (): Promise<APIResponse<string>> => {\n try {\n const snapshot = registry.createSnapshot();\n // Convert snapshot elements to AI elements format for summary\n const elements = snapshot.elements.map((el) => ({\n ...el,\n description: el.label || el.id,\n aliases: [],\n suggestedActions: [],\n tagName: el.type,\n accessibleName: el.label,\n registered: true,\n })) as any[];\n const summary = generatePageSummary(elements);\n return success(summary);\n } catch (err) {\n return error((err as Error).message, 'PAGE_SUMMARY_ERROR');\n }\n },\n\n // =========================================================================\n // Semantic Search Handler (Embedding-based)\n // =========================================================================\n\n // =========================================================================\n // Page Navigation Handlers\n // =========================================================================\n\n pageRefresh: async (): Promise<APIResponse<PageNavigationResponse>> => {\n try {\n window.location.reload();\n return success({ success: true, url: window.location.href, timestamp: Date.now() });\n } catch (err) {\n return error((err as Error).message, 'PAGE_REFRESH_ERROR');\n }\n },\n\n pageNavigate: async (\n request: PageNavigateRequest\n ): Promise<APIResponse<PageNavigationResponse>> => {\n try {\n if (!request.url) {\n return error('URL is required', 'INVALID_REQUEST');\n }\n window.location.href = request.url;\n return success({ success: true, url: request.url, timestamp: Date.now() });\n } catch (err) {\n return error((err as Error).message, 'PAGE_NAVIGATE_ERROR');\n }\n },\n\n pageGoBack: async (): Promise<APIResponse<PageNavigationResponse>> => {\n try {\n window.history.back();\n return success({ success: true, url: window.location.href, timestamp: Date.now() });\n } catch (err) {\n return error((err as Error).message, 'PAGE_GO_BACK_ERROR');\n }\n },\n\n pageGoForward: async (): Promise<APIResponse<PageNavigationResponse>> => {\n try {\n window.history.forward();\n return success({ success: true, url: window.location.href, timestamp: Date.now() });\n } catch (err) {\n return error((err as Error).message, 'PAGE_GO_FORWARD_ERROR');\n }\n },\n\n // =========================================================================\n // Annotation Handlers\n //\n // REST API endpoints for managing element annotations:\n // GET /annotations - List all annotations\n // GET /annotations/export - Export all annotations as AnnotationConfig\n // GET /annotations/coverage - Get annotation coverage statistics\n // GET /annotations/:id - Get annotation for a specific element\n // PUT /annotations/:id - Create or update an annotation\n // DELETE /annotations/:id - Delete an annotation\n // POST /annotations/import - Import annotations from AnnotationConfig\n // =========================================================================\n\n getAnnotations: async (): Promise<APIResponse<Record<string, ElementAnnotation>>> => {\n try {\n return success(annotationStore.getAll());\n } catch (err) {\n return error((err as Error).message, 'ANNOTATIONS_ERROR');\n }\n },\n\n getAnnotation: async (id: string): Promise<APIResponse<ElementAnnotation>> => {\n try {\n const annotation = annotationStore.get(id);\n if (!annotation) {\n return error(`Annotation not found: ${id}`, 'NOT_FOUND');\n }\n return success(annotation);\n } catch (err) {\n return error((err as Error).message, 'ANNOTATION_ERROR');\n }\n },\n\n setAnnotation: async (\n id: string,\n annotation: ElementAnnotation\n ): Promise<APIResponse<ElementAnnotation>> => {\n try {\n annotationStore.set(id, annotation);\n return success(annotationStore.get(id)!);\n } catch (err) {\n return error((err as Error).message, 'ANNOTATION_SET_ERROR');\n }\n },\n\n deleteAnnotation: async (id: string): Promise<APIResponse<void>> => {\n try {\n const existed = annotationStore.delete(id);\n if (!existed) {\n return error(`Annotation not found: ${id}`, 'NOT_FOUND');\n }\n return success(undefined);\n } catch (err) {\n return error((err as Error).message, 'ANNOTATION_DELETE_ERROR');\n }\n },\n\n importAnnotations: async (\n config: AnnotationConfig\n ): Promise<APIResponse<{ count: number }>> => {\n try {\n const count = annotationStore.importConfig(config);\n return success({ count });\n } catch (err) {\n return error((err as Error).message, 'ANNOTATION_IMPORT_ERROR');\n }\n },\n\n exportAnnotations: async (): Promise<APIResponse<AnnotationConfig>> => {\n try {\n return success(annotationStore.exportConfig());\n } catch (err) {\n return error((err as Error).message, 'ANNOTATION_EXPORT_ERROR');\n }\n },\n\n getAnnotationCoverage: async (): Promise<APIResponse<AnnotationCoverage>> => {\n try {\n const allElements = registry.getAllElements() as Array<{ id: string }>;\n const allIds = allElements.map((el) => el.id);\n return success(annotationStore.getCoverage(allIds));\n } catch (err) {\n return error((err as Error).message, 'ANNOTATION_COVERAGE_ERROR');\n }\n },\n\n aiSemanticSearch: async (\n criteria: SemanticSearchCriteria\n ): Promise<APIResponse<SemanticSearchResponse>> => {\n const startTime = performance.now();\n try {\n // Refresh elements for search\n refreshElements();\n\n // Get all elements\n const allElements = registry.getAllElements() as any[];\n\n // Convert to AI discovered elements for semantic search\n const aiElements: Array<{ element: AIDiscoveredElement; text: string }> = allElements.map(\n (el) => {\n // Build searchable text from element properties\n const textParts: string[] = [];\n\n // Prioritize description and accessible name for semantic matching\n const state = 'getState' in el ? (el as any).getState() : el.state;\n const textContent = state?.textContent || '';\n const label = el.label || '';\n const accessibleName = el.accessibleName || '';\n const placeholder = el.placeholder || '';\n const title = el.title || '';\n\n if (label) textParts.push(label);\n if (accessibleName && accessibleName !== label) textParts.push(accessibleName);\n if (textContent && textContent !== label && textContent !== accessibleName) {\n textParts.push(textContent);\n }\n if (placeholder) textParts.push(`placeholder: ${placeholder}`);\n if (title) textParts.push(title);\n\n const combinedText = textParts.join(' ').trim() || el.id;\n\n return {\n element: {\n id: el.id,\n type: el.type,\n label: el.label,\n tagName: el.tagName || el.type,\n role: el.role,\n accessibleName: el.accessibleName,\n actions: el.actions || [],\n state: state || {},\n registered: true,\n description: label || el.id,\n aliases: [],\n suggestedActions: [],\n } as AIDiscoveredElement,\n text: combinedText,\n };\n }\n );\n\n // Apply type/role filters if specified\n let filteredElements = aiElements;\n if (criteria.type) {\n filteredElements = filteredElements.filter(\n ({ element }) => element.type.toLowerCase() === criteria.type!.toLowerCase()\n );\n }\n if (criteria.role) {\n filteredElements = filteredElements.filter(\n ({ element }) => element.role?.toLowerCase() === criteria.role!.toLowerCase()\n );\n }\n\n // NOTE: Semantic search with embeddings requires server-side embedding support.\n // This handler provides the API structure. Actual embedding computation\n // should be delegated to the qontinui library or a separate embedding service.\n //\n // For now, we fall back to fuzzy text matching as a placeholder.\n // In production, this would call the qontinui embeddings module.\n\n const query = criteria.query.toLowerCase();\n const threshold = criteria.threshold ?? 0.5;\n const limit = criteria.limit ?? 10;\n\n // Simple text similarity as fallback (to be replaced with embedding similarity)\n const scoredResults: SemanticSearchResult[] = filteredElements.map(({ element, text }) => {\n // Calculate basic text similarity\n const textLower = text.toLowerCase();\n let similarity = 0;\n\n // Exact match\n if (textLower.includes(query)) {\n similarity = 0.9;\n } else {\n // Word overlap similarity\n const queryWords = new Set(query.split(/\\s+/).filter((w: string) => w.length > 2));\n const textWords = new Set(textLower.split(/\\s+/).filter((w: string) => w.length > 2));\n\n if (queryWords.size > 0 && textWords.size > 0) {\n let matchCount = 0;\n for (const word of queryWords) {\n for (const textWord of textWords) {\n if (textWord.includes(word) || word.includes(textWord)) {\n matchCount++;\n break;\n }\n }\n }\n similarity = (matchCount / queryWords.size) * 0.7;\n }\n }\n\n return {\n element,\n similarity,\n rank: 0, // Will be set after sorting\n embeddedText: text,\n };\n });\n\n // Filter by threshold and sort by similarity\n const filteredResults = scoredResults\n .filter((r) => r.similarity >= threshold)\n .sort((a, b) => b.similarity - a.similarity)\n .slice(0, limit);\n\n // Set ranks\n filteredResults.forEach((result, index) => {\n result.rank = index + 1;\n });\n\n const response: SemanticSearchResponse = {\n results: filteredResults,\n bestMatch: filteredResults.length > 0 ? filteredResults[0] : null,\n scannedCount: filteredElements.length,\n durationMs: performance.now() - startTime,\n query: criteria.query,\n providerInfo: {\n provider: 'text-fallback',\n model: 'simple-similarity',\n dimension: 0,\n },\n timestamp: Date.now(),\n };\n\n return success(response);\n } catch (err) {\n return error((err as Error).message, 'AI_SEMANTIC_SEARCH_ERROR');\n }\n },\n\n // =========================================================================\n // State Management Handlers\n // =========================================================================\n\n getStates: async (): Promise<APIResponse<UIState[]>> => {\n try {\n const states = registry.getStates?.() ?? [];\n return success(states);\n } catch (err) {\n return error((err as Error).message, 'STATES_ERROR');\n }\n },\n\n getState: async (id: string): Promise<APIResponse<UIState>> => {\n try {\n const state = registry.getState?.(id);\n if (!state) {\n return error(`State not found: ${id}`, 'NOT_FOUND');\n }\n return success(state);\n } catch (err) {\n return error((err as Error).message, 'STATE_ERROR');\n }\n },\n\n getActiveStates: async (): Promise<APIResponse<UIState[]>> => {\n try {\n const states = registry.getActiveStates?.() ?? [];\n return success(states);\n } catch (err) {\n return error((err as Error).message, 'ACTIVE_STATES_ERROR');\n }\n },\n\n activateState: async (id: string): Promise<APIResponse<void>> => {\n try {\n if (!registry.activateState) {\n return error('State management not available', 'NOT_IMPLEMENTED');\n }\n registry.activateState(id);\n return success(undefined);\n } catch (err) {\n return error((err as Error).message, 'ACTIVATE_STATE_ERROR');\n }\n },\n\n deactivateState: async (id: string): Promise<APIResponse<void>> => {\n try {\n if (!registry.deactivateState) {\n return error('State management not available', 'NOT_IMPLEMENTED');\n }\n registry.deactivateState(id);\n return success(undefined);\n } catch (err) {\n return error((err as Error).message, 'DEACTIVATE_STATE_ERROR');\n }\n },\n\n getStateGroups: async (): Promise<APIResponse<UIStateGroup[]>> => {\n try {\n const groups = registry.getStateGroups?.() ?? [];\n return success(groups);\n } catch (err) {\n return error((err as Error).message, 'STATE_GROUPS_ERROR');\n }\n },\n\n activateStateGroup: async (id: string): Promise<APIResponse<void>> => {\n try {\n if (!registry.activateStateGroup) {\n return error('State group management not available', 'NOT_IMPLEMENTED');\n }\n registry.activateStateGroup(id);\n return success(undefined);\n } catch (err) {\n return error((err as Error).message, 'ACTIVATE_STATE_GROUP_ERROR');\n }\n },\n\n deactivateStateGroup: async (id: string): Promise<APIResponse<void>> => {\n try {\n if (!registry.deactivateStateGroup) {\n return error('State group management not available', 'NOT_IMPLEMENTED');\n }\n registry.deactivateStateGroup(id);\n return success(undefined);\n } catch (err) {\n return error((err as Error).message, 'DEACTIVATE_STATE_GROUP_ERROR');\n }\n },\n\n getTransitions: async (): Promise<APIResponse<UITransition[]>> => {\n try {\n const transitions = registry.getTransitions?.() ?? [];\n return success(transitions);\n } catch (err) {\n return error((err as Error).message, 'TRANSITIONS_ERROR');\n }\n },\n\n canExecuteTransition: async (\n id: string\n ): Promise<APIResponse<{ canExecute: boolean; reason?: string }>> => {\n try {\n if (!registry.canExecuteTransition) {\n return error('Transition management not available', 'NOT_IMPLEMENTED');\n }\n const result = registry.canExecuteTransition(id);\n return success(result);\n } catch (err) {\n return error((err as Error).message, 'CAN_EXECUTE_TRANSITION_ERROR');\n }\n },\n\n executeTransition: async (id: string): Promise<APIResponse<TransitionResult>> => {\n try {\n if (!registry.executeTransition) {\n return error('Transition execution not available', 'NOT_IMPLEMENTED');\n }\n const result = await registry.executeTransition(id);\n return success(result);\n } catch (err) {\n return error((err as Error).message, 'EXECUTE_TRANSITION_ERROR');\n }\n },\n\n findPath: async (request: { targetStates: string[] }): Promise<APIResponse<PathResult>> => {\n try {\n if (!registry.findPath) {\n return error('Pathfinding not available', 'NOT_IMPLEMENTED');\n }\n const result = registry.findPath(request.targetStates);\n return success(result);\n } catch (err) {\n return error((err as Error).message, 'FIND_PATH_ERROR');\n }\n },\n\n navigateTo: async (request: {\n targetStates: string[];\n }): Promise<APIResponse<NavigationResult>> => {\n try {\n if (!registry.navigateTo) {\n return error('Navigation not available', 'NOT_IMPLEMENTED');\n }\n const result = await registry.navigateTo(request.targetStates);\n return success(result);\n } catch (err) {\n return error((err as Error).message, 'NAVIGATE_TO_ERROR');\n }\n },\n\n getStateSnapshot: async (): Promise<APIResponse<StateSnapshot>> => {\n try {\n if (!registry.getStateSnapshot) {\n // Fallback: build from available data\n const snapshot: StateSnapshot = {\n timestamp: Date.now(),\n activeStates: (registry.getActiveStates?.() ?? []).map((s) => s.id),\n states: registry.getStates?.() ?? [],\n groups: registry.getStateGroups?.() ?? [],\n transitions: registry.getTransitions?.() ?? [],\n };\n return success(snapshot);\n }\n return success(registry.getStateSnapshot());\n } catch (err) {\n return error((err as Error).message, 'STATE_SNAPSHOT_ERROR');\n }\n },\n\n // =========================================================================\n // Intent Handlers\n // =========================================================================\n\n executeIntent: async (request: {\n intentId: string;\n params?: Record<string, unknown>;\n }): Promise<APIResponse<IntentExecutionResult>> => {\n const startTime = Date.now();\n try {\n refreshElements();\n const intent = intentRegistry.get(request.intentId);\n if (!intent) {\n return error(`Intent not found: ${request.intentId}`, 'NOT_FOUND');\n }\n // Execute via NL executor using intent description as instruction\n const nlResponse = await nlExecutor.execute({\n instruction: intent.description,\n context: `Executing intent: ${intent.name}`,\n });\n return success({\n success: nlResponse.success,\n intentId: request.intentId,\n result: nlResponse,\n error: nlResponse.error,\n durationMs: Date.now() - startTime,\n });\n } catch (err) {\n return error((err as Error).message, 'EXECUTE_INTENT_ERROR');\n }\n },\n\n findIntent: async (request: { query: string }): Promise<APIResponse<IntentSearchResponse>> => {\n try {\n const query = request.query.toLowerCase();\n const results: Array<{ intent: Intent; confidence: number }> = [];\n\n for (const intent of intentRegistry.values()) {\n let confidence = 0;\n const nameLower = intent.name.toLowerCase();\n const descLower = intent.description.toLowerCase();\n\n if (nameLower === query) {\n confidence = 1.0;\n } else if (nameLower.includes(query) || query.includes(nameLower)) {\n confidence = 0.8;\n } else if (descLower.includes(query)) {\n confidence = 0.6;\n } else if (intent.tags?.some((t) => t.toLowerCase().includes(query))) {\n confidence = 0.5;\n }\n\n if (confidence > 0) {\n results.push({ intent, confidence });\n }\n }\n\n results.sort((a, b) => b.confidence - a.confidence);\n return success({ intents: results });\n } catch (err) {\n return error((err as Error).message, 'FIND_INTENT_ERROR');\n }\n },\n\n listIntents: async (): Promise<APIResponse<Intent[]>> => {\n try {\n return success(Array.from(intentRegistry.values()));\n } catch (err) {\n return error((err as Error).message, 'LIST_INTENTS_ERROR');\n }\n },\n\n registerIntent: async (intent: Intent): Promise<APIResponse<Intent>> => {\n try {\n intentRegistry.set(intent.id, intent);\n return success(intent);\n } catch (err) {\n return error((err as Error).message, 'REGISTER_INTENT_ERROR');\n }\n },\n\n executeIntentFromQuery: async (request: {\n query: string;\n params?: Record<string, unknown>;\n }): Promise<APIResponse<IntentExecutionResult>> => {\n const startTime = Date.now();\n try {\n refreshElements();\n // Find best matching intent\n const query = request.query.toLowerCase();\n let bestIntent: Intent | null = null;\n let bestConfidence = 0;\n\n for (const intent of intentRegistry.values()) {\n let confidence = 0;\n const nameLower = intent.name.toLowerCase();\n const descLower = intent.description.toLowerCase();\n\n if (nameLower === query) {\n confidence = 1.0;\n } else if (nameLower.includes(query) || query.includes(nameLower)) {\n confidence = 0.8;\n } else if (descLower.includes(query)) {\n confidence = 0.6;\n }\n\n if (confidence > bestConfidence) {\n bestConfidence = confidence;\n bestIntent = intent;\n }\n }\n\n if (!bestIntent) {\n return success({\n success: false,\n intentId: '',\n error: `No intent found matching query: ${request.query}`,\n durationMs: Date.now() - startTime,\n });\n }\n\n const nlResponse = await nlExecutor.execute({\n instruction: bestIntent.description,\n context: `Executing intent from query: ${request.query}`,\n });\n\n return success({\n success: nlResponse.success,\n intentId: bestIntent.id,\n result: nlResponse,\n error: nlResponse.error,\n durationMs: Date.now() - startTime,\n });\n } catch (err) {\n return error((err as Error).message, 'EXECUTE_INTENT_FROM_QUERY_ERROR');\n }\n },\n\n // =========================================================================\n // Recovery Handler\n // =========================================================================\n\n attemptRecovery: async (\n request: RecoveryAttemptRequest\n ): Promise<APIResponse<RecoveryAttemptResult>> => {\n const startTime = Date.now();\n try {\n refreshElements();\n const strategiesAttempted: string[] = [];\n let lastResult: NLActionResponse | undefined;\n\n // Try recovery strategies based on the failure info\n const suggestions = request.failure.suggestedActions ?? [];\n\n for (let i = 0; i < Math.min(suggestions.length, request.maxRetries); i++) {\n const suggestion = suggestions[i];\n strategiesAttempted.push(suggestion.suggestion || `strategy-${i}`);\n\n // If the suggestion has a command, try executing it\n const instruction = suggestion.command || request.instruction;\n try {\n const result = await nlExecutor.execute({\n instruction,\n context: `Recovery attempt ${i + 1}: ${suggestion.suggestion}`,\n });\n lastResult = result;\n\n if (result.success) {\n return success({\n recovered: true,\n strategiesAttempted,\n finalResult: result,\n durationMs: Date.now() - startTime,\n });\n }\n } catch {\n // Continue to next strategy\n }\n }\n\n // If no suggestions or all failed, try the instruction directly\n if (strategiesAttempted.length === 0 || !lastResult?.success) {\n strategiesAttempted.push('direct-instruction');\n try {\n const result = await nlExecutor.execute({\n instruction: request.instruction,\n context: 'Recovery: direct instruction attempt',\n });\n lastResult = result;\n\n if (result.success) {\n return success({\n recovered: true,\n strategiesAttempted,\n finalResult: result,\n durationMs: Date.now() - startTime,\n });\n }\n } catch {\n // Fall through to failure\n }\n }\n\n return success({\n recovered: false,\n strategiesAttempted,\n finalResult: lastResult,\n error: 'All recovery strategies exhausted',\n durationMs: Date.now() - startTime,\n });\n } catch (err) {\n return error((err as Error).message, 'RECOVERY_ERROR');\n }\n },\n\n // =========================================================================\n // Cross-App Analysis Handlers\n // =========================================================================\n\n analyzePageData: async (): Promise<APIResponse<PageDataMap>> => {\n try {\n const controlSnapshot = registry.createSnapshot();\n const snapshot = snapshotManager.createSnapshot(controlSnapshot);\n const result = extractPageData(snapshot.elements);\n return success(result);\n } catch (err) {\n return error((err as Error).message, 'ANALYZE_DATA_ERROR');\n }\n },\n\n analyzePageRegions: async (): Promise<APIResponse<PageRegionMap>> => {\n try {\n const controlSnapshot = registry.createSnapshot();\n const snapshot = snapshotManager.createSnapshot(controlSnapshot);\n const result = segmentPageRegions(snapshot.elements);\n return success(result);\n } catch (err) {\n return error((err as Error).message, 'ANALYZE_REGIONS_ERROR');\n }\n },\n\n analyzeStructuredData: async (): Promise<APIResponse<StructuredDataExtraction>> => {\n try {\n const controlSnapshot = registry.createSnapshot();\n const snapshot = snapshotManager.createSnapshot(controlSnapshot);\n const result = extractStructuredData(snapshot.elements);\n return success(result);\n } catch (err) {\n return error((err as Error).message, 'ANALYZE_STRUCTURED_DATA_ERROR');\n }\n },\n\n crossAppCompare: async (request: {\n sourceSnapshot: SemanticSnapshot;\n targetSnapshot: SemanticSnapshot;\n sourceComponents?: ComponentInfo[];\n targetComponents?: ComponentInfo[];\n }): Promise<APIResponse<CrossAppComparisonReport>> => {\n try {\n const hasComponents = request.sourceComponents && request.targetComponents;\n const report = generateComparisonReport(\n request.sourceSnapshot,\n request.targetSnapshot,\n hasComponents\n ? {\n config: { includeComponents: true },\n sourceComponents: request.sourceComponents,\n targetComponents: request.targetComponents,\n }\n : undefined\n );\n return success(report);\n } catch (err) {\n return error((err as Error).message, 'CROSS_APP_COMPARE_ERROR');\n }\n },\n\n // =========================================================================\n // Performance Diagnostics Handlers\n // =========================================================================\n\n getPerformanceEntries: async (): Promise<APIResponse<unknown>> => {\n // Performance entries are browser-only; the SDK handler returns empty data.\n // The actual implementation lives in the browser transport (useUIBridgeTransport).\n return {\n success: true,\n data: { navigation: null, resources: [], paint: [] },\n timestamp: Date.now(),\n };\n },\n\n clearPerformanceEntries: async (): Promise<APIResponse<{ cleared: boolean }>> => {\n return { success: true, data: { cleared: true }, timestamp: Date.now() };\n },\n\n getBrowserEvents: async (_params?: {\n type?: string;\n since?: number;\n limit?: number;\n }): Promise<APIResponse<{ events: unknown[]; count: number }>> => {\n return { success: true, data: { events: [], count: 0 }, timestamp: Date.now() };\n },\n };\n}\n\n/**\n * Create partial handlers for AI-specific functionality only\n *\n * Use this when you want to add AI endpoints to an existing handler setup.\n */\nexport function createAIHandlers(\n registry: RegistryLike,\n actionExecutor: ActionExecutorLike\n): Pick<\n UIBridgeServerHandlers,\n | 'aiSearch'\n | 'aiExecute'\n | 'aiAssert'\n | 'aiAssertBatch'\n | 'getSemanticSnapshot'\n | 'getSemanticDiff'\n | 'getPageSummary'\n> {\n const searchEngine = new SearchEngine();\n const nlExecutor = new NLActionExecutor();\n const assertionExecutor = new AssertionExecutor();\n const snapshotManager = new SemanticSnapshotManager();\n const diffManager = new SemanticDiffManager();\n\n function refreshElements(): void {\n const elements = registry.getAllElements();\n searchEngine.updateElements(elements as any[]);\n nlExecutor.updateElements(elements as any[]);\n nlExecutor.setActionExecutor(actionExecutor as any);\n assertionExecutor.updateElements(elements as any[]);\n }\n\n return {\n aiSearch: async (criteria: SearchCriteria): Promise<APIResponse<SearchResponse>> => {\n try {\n refreshElements();\n const response = searchEngine.search(criteria);\n return { success: true, data: response, timestamp: Date.now() };\n } catch (err) {\n return {\n success: false,\n error: (err as Error).message,\n code: 'AI_SEARCH_ERROR',\n timestamp: Date.now(),\n };\n }\n },\n\n aiExecute: async (request: NLActionRequest): Promise<APIResponse<NLActionResponse>> => {\n try {\n refreshElements();\n const response = await nlExecutor.execute(request);\n return { success: true, data: response, timestamp: Date.now() };\n } catch (err) {\n return {\n success: false,\n error: (err as Error).message,\n code: 'AI_EXECUTE_ERROR',\n timestamp: Date.now(),\n };\n }\n },\n\n aiAssert: async (request: AssertionRequest): Promise<APIResponse<AssertionResult>> => {\n try {\n refreshElements();\n const result = await assertionExecutor.assert(request);\n return { success: true, data: result, timestamp: Date.now() };\n } catch (err) {\n return {\n success: false,\n error: (err as Error).message,\n code: 'AI_ASSERT_ERROR',\n timestamp: Date.now(),\n };\n }\n },\n\n aiAssertBatch: async (\n request: BatchAssertionRequest\n ): Promise<APIResponse<BatchAssertionResult>> => {\n try {\n refreshElements();\n const result = await assertionExecutor.assertBatch(request);\n return { success: true, data: result, timestamp: Date.now() };\n } catch (err) {\n return {\n success: false,\n error: (err as Error).message,\n code: 'AI_ASSERT_BATCH_ERROR',\n timestamp: Date.now(),\n };\n }\n },\n\n getSemanticSnapshot: async (): Promise<APIResponse<SemanticSnapshot>> => {\n try {\n const controlSnapshot = registry.createSnapshot();\n const snapshot = snapshotManager.createSnapshot(controlSnapshot);\n return { success: true, data: snapshot, timestamp: Date.now() };\n } catch (err) {\n return {\n success: false,\n error: (err as Error).message,\n code: 'SEMANTIC_SNAPSHOT_ERROR',\n timestamp: Date.now(),\n };\n }\n },\n\n getSemanticDiff: async (_since?: number): Promise<APIResponse<SemanticDiff | null>> => {\n try {\n const controlSnapshot = registry.createSnapshot();\n const currentSnapshot = snapshotManager.createSnapshot(controlSnapshot);\n const diff = diffManager.update(currentSnapshot);\n return { success: true, data: diff, timestamp: Date.now() };\n } catch (err) {\n return {\n success: false,\n error: (err as Error).message,\n code: 'SEMANTIC_DIFF_ERROR',\n timestamp: Date.now(),\n };\n }\n },\n\n getPageSummary: async (): Promise<APIResponse<string>> => {\n try {\n const snapshot = registry.createSnapshot();\n // Convert snapshot elements to AI elements format for summary\n const elements = snapshot.elements.map((el) => ({\n ...el,\n description: el.label || el.id,\n aliases: [],\n suggestedActions: [],\n tagName: el.type,\n accessibleName: el.label,\n registered: true,\n })) as any[];\n const summary = generatePageSummary(elements);\n return { success: true, data: summary, timestamp: Date.now() };\n } catch (err) {\n return {\n success: false,\n error: (err as Error).message,\n code: 'PAGE_SUMMARY_ERROR',\n timestamp: Date.now(),\n };\n }\n },\n };\n}\n"]}
|