@secondlayer/cli 1.2.4 → 1.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js.map CHANGED
@@ -1,18 +1,18 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../src/utils/format.ts", "../src/core/plugin-manager.ts", "../src/utils/contract-id.ts", "../src/types/plugin.ts", "../src/plugins/clarinet/index.ts", "../src/generators/contract.ts", "../src/utils/type-mapping.ts", "../src/utils/clarity-conversion.ts", "../src/utils/abi-compat.ts", "../src/plugins/actions/generators.ts", "../src/utils/generator-helpers.ts", "../src/plugins/actions/index.ts", "../src/plugins/react/provider/index.ts", "../src/plugins/react/generators/generic.ts", "../src/generators/templates/use-contract.ts", "../src/plugins/react/generators/contract.ts", "../src/plugins/react/generators/utils.ts", "../src/plugins/react/index.ts", "../src/plugins/testing/generators.ts", "../src/plugins/testing/index.ts", "../src/plugins/index.ts"],
3
+ "sources": ["../src/utils/format.ts", "../src/core/plugin-manager.ts", "../src/utils/contract-id.ts", "../src/types/plugin.ts", "../src/plugins/clarinet/index.ts", "../src/generators/contract.ts", "../src/utils/type-mapping.ts", "../src/utils/clarity-conversion.ts", "../src/utils/generator-helpers.ts", "../src/utils/abi-compat.ts", "../src/plugins/actions/generators.ts", "../src/plugins/actions/index.ts", "../src/plugins/react/provider/index.ts", "../src/plugins/react/generators/generic.ts", "../src/generators/templates/use-contract.ts", "../src/plugins/react/generators/contract.ts", "../src/plugins/react/generators/utils.ts", "../src/plugins/react/index.ts", "../src/plugins/testing/generators.ts", "../src/plugins/testing/index.ts", "../src/plugins/index.ts"],
4
4
  "sourcesContent": [
5
5
  "/**\n * Shared code formatting utilities using Biome\n */\n\nimport { Biome, Distribution } from \"@biomejs/js-api\";\n\nlet biome: Biome | null = null;\n\n/**\n * Lazily initialize Biome singleton\n */\nasync function getBiome(): Promise<Biome> {\n\tif (!biome) {\n\t\tbiome = await Biome.create({\n\t\t\tdistribution: Distribution.NODE,\n\t\t});\n\n\t\tbiome.applyConfiguration({\n\t\t\tformatter: {\n\t\t\t\tenabled: true,\n\t\t\t\tindentStyle: \"tab\",\n\t\t\t\tlineWidth: 80,\n\t\t\t},\n\t\t\tjavascript: {\n\t\t\t\tformatter: {\n\t\t\t\t\tsemicolons: \"always\",\n\t\t\t\t\tquoteStyle: \"single\",\n\t\t\t\t},\n\t\t\t},\n\t\t\torganizeImports: {\n\t\t\t\tenabled: true,\n\t\t\t},\n\t\t\tlinter: {\n\t\t\t\tenabled: true,\n\t\t\t},\n\t\t\tassists: {\n\t\t\t\tenabled: true,\n\t\t\t},\n\t\t});\n\n\t\tbiome.registerProjectFolder();\n\t}\n\n\treturn biome;\n}\n\n/**\n * Format TypeScript code using Biome\n */\nexport async function formatCode(code: string): Promise<string> {\n\tconst b = await getBiome();\n\n\t// Use lintContent with SafeFixes to organize imports\n\tconst linted = b.lintContent(code, {\n\t\tfilePath: \"generated.ts\",\n\t\tfixFileMode: \"SafeFixes\",\n\t});\n\n\t// Then format\n\tconst formatted = b.formatContent(linted.content, {\n\t\tfilePath: \"generated.ts\",\n\t});\n\n\treturn formatted.content;\n}\n",
6
6
  "/**\n * Plugin Manager for @secondlayer/cli\n * Handles plugin registration, lifecycle execution, and output management\n */\n\nimport { promises as fs } from \"fs\";\nimport path from \"path\";\nimport { isValidAddress as _validateStacksAddress } from \"@secondlayer/stacks\";\nconst validateStacksAddress = _validateStacksAddress as (address: string) => boolean;\nimport { parseContractId } from \"../utils/contract-id\";\nimport type {\n SecondLayerPlugin,\n UserConfig,\n ResolvedConfig,\n GenerateContext,\n Logger,\n PluginUtils,\n GeneratedOutput,\n ProcessedContract,\n ContractConfig,\n HookResult,\n PluginExecutionContext,\n} from \"../types/plugin\";\nimport { isClarinetContract, isDirectFileContract } from \"../types/plugin\";\n\n/**\n * Core plugin manager that orchestrates plugin execution\n */\nexport class PluginManager {\n private plugins: SecondLayerPlugin[] = [];\n private logger: Logger;\n private utils: PluginUtils;\n private executionContext: PluginExecutionContext;\n\n constructor() {\n this.logger = this.createLogger();\n this.utils = this.createUtils();\n this.executionContext = {\n phase: \"config\",\n startTime: Date.now(),\n results: new Map(),\n };\n }\n\n /**\n * Register a plugin\n */\n register(plugin: SecondLayerPlugin): void {\n // Validate plugin\n if (!plugin.name || !plugin.version) {\n throw new Error(\"Plugin must have a name and version\");\n }\n\n // Check for duplicate plugin names\n const existing = this.plugins.find((p) => p.name === plugin.name);\n if (existing) {\n throw new Error(\n `Plugin \"${plugin.name}\" is already registered (version ${existing.version})`\n );\n }\n\n this.plugins.push(plugin);\n this.logger.debug(`Registered plugin: ${plugin.name}@${plugin.version}`);\n }\n\n /**\n * Get all registered plugins\n */\n getPlugins(): SecondLayerPlugin[] {\n return [...this.plugins];\n }\n\n /**\n * Transform user config through all plugins\n */\n async transformConfig(config: UserConfig): Promise<ResolvedConfig> {\n this.executionContext.phase = \"config\";\n let transformedConfig = { ...config };\n\n for (const plugin of this.plugins) {\n if (plugin.transformConfig) {\n this.executionContext.currentPlugin = plugin;\n try {\n const result = await plugin.transformConfig(transformedConfig);\n transformedConfig = result;\n this.recordHookResult(plugin.name, \"transformConfig\", {\n success: true,\n });\n } catch (error) {\n const err = error as Error;\n this.recordHookResult(plugin.name, \"transformConfig\", {\n success: false,\n error: err,\n });\n throw new Error(\n `Plugin \"${plugin.name}\" failed during config transformation: ${err.message}`\n );\n }\n }\n }\n\n // Add plugins array to resolved config\n const resolvedConfig: ResolvedConfig = {\n ...transformedConfig,\n plugins: this.plugins,\n };\n\n return resolvedConfig;\n }\n\n /**\n * Transform contracts through all plugins\n */\n async transformContracts(\n contracts: ContractConfig[],\n _config: ResolvedConfig\n ): Promise<ProcessedContract[]> {\n const processedContracts: ProcessedContract[] = [];\n\n for (let contract of contracts) {\n // Handle special case for Clarinet plugin contracts\n if (isClarinetContract(contract) && contract.abi) {\n // Convert Clarinet contracts directly to ProcessedContract format\n const address =\n typeof contract.address === \"string\" ? contract.address : \"\";\n const parsed = parseContractId(address);\n const processed: ProcessedContract = {\n name: contract.name || parsed.contractName,\n address: parsed.address,\n contractName: parsed.contractName,\n abi: contract.abi,\n source: \"local\" as const,\n metadata: { source: \"clarinet\" },\n };\n processedContracts.push(processed);\n continue;\n }\n\n // Handle direct file mode contracts (already have ABIs parsed)\n if (isDirectFileContract(contract) && contract.abi) {\n const address =\n typeof contract.address === \"string\" ? contract.address : \"\";\n const parsed = parseContractId(address);\n const processed: ProcessedContract = {\n name: contract.name || parsed.contractName,\n address: parsed.address,\n contractName: parsed.contractName,\n abi: contract.abi,\n source: \"local\" as const,\n metadata: { source: \"direct\" },\n };\n processedContracts.push(processed);\n continue;\n }\n\n // Transform through each plugin\n for (const plugin of this.plugins) {\n if (plugin.transformContract) {\n this.executionContext.currentPlugin = plugin;\n try {\n contract = await plugin.transformContract(contract);\n this.recordHookResult(plugin.name, \"transformContract\", {\n success: true,\n });\n } catch (error) {\n const err = error as Error;\n this.recordHookResult(plugin.name, \"transformContract\", {\n success: false,\n error: err,\n });\n this.logger.warn(\n `Plugin \"${plugin.name}\" failed to transform contract: ${err.message}`\n );\n }\n }\n }\n\n // Convert to ProcessedContract\n if (contract.abi) {\n const addressStr = typeof contract.address === \"string\" ? contract.address : \"\";\n const parsed = parseContractId(addressStr);\n const processed: ProcessedContract = {\n name: contract.name || parsed.contractName || \"unknown\",\n address: parsed.address || \"unknown\",\n contractName: parsed.contractName || contract.name || \"unknown\",\n abi: contract.abi,\n source: \"api\" as const, // Use \"api\" as default for plugin-processed contracts\n metadata: contract.metadata,\n };\n processedContracts.push(processed);\n }\n }\n\n return processedContracts;\n }\n\n /**\n * Execute lifecycle hooks\n */\n async executeHook(\n hookName: keyof SecondLayerPlugin,\n context: any\n ): Promise<void> {\n for (const plugin of this.plugins) {\n const hook = plugin[hookName];\n if (typeof hook === \"function\") {\n this.executionContext.currentPlugin = plugin;\n try {\n await (hook as any).call(plugin, context);\n this.recordHookResult(plugin.name, hookName as string, {\n success: true,\n });\n } catch (error) {\n const err = error as Error;\n this.recordHookResult(plugin.name, hookName as string, {\n success: false,\n error: err,\n });\n this.logger.error(\n `Plugin \"${plugin.name}\" failed during ${hookName as string}: ${err.message}`\n );\n // Don't throw - allow other plugins to continue\n }\n }\n }\n }\n\n /**\n * Execute generation phase with full context\n */\n async executeGeneration(\n contracts: ProcessedContract[],\n config: ResolvedConfig\n ): Promise<Map<string, GeneratedOutput>> {\n this.executionContext.phase = \"generate\";\n const outputs = new Map<string, GeneratedOutput>();\n\n // Create generation context\n const context: GenerateContext = {\n config,\n logger: this.logger,\n utils: this.utils,\n contracts,\n outputs,\n augment: (outputKey: string, contractName: string, content: any) => {\n this.augmentOutput(outputs, outputKey, contractName, content);\n },\n addOutput: (key: string, output: GeneratedOutput) => {\n outputs.set(key, output);\n },\n };\n\n // Execute beforeGenerate hooks\n await this.executeHook(\"beforeGenerate\", context);\n\n // Execute generate hooks\n await this.executeHook(\"generate\", context);\n\n // Execute afterGenerate hooks\n await this.executeHook(\"afterGenerate\", context);\n\n return outputs;\n }\n\n /**\n * Transform outputs through plugins\n */\n async transformOutputs(\n outputs: Map<string, GeneratedOutput>\n ): Promise<Map<string, GeneratedOutput>> {\n this.executionContext.phase = \"output\";\n const transformedOutputs = new Map<string, GeneratedOutput>();\n\n for (const [key, output] of outputs) {\n let transformedContent = output.content;\n\n for (const plugin of this.plugins) {\n if (plugin.transformOutput) {\n this.executionContext.currentPlugin = plugin;\n try {\n transformedContent = await plugin.transformOutput(\n transformedContent,\n output.type || \"other\"\n );\n this.recordHookResult(plugin.name, \"transformOutput\", {\n success: true,\n });\n } catch (error) {\n const err = error as Error;\n this.recordHookResult(plugin.name, \"transformOutput\", {\n success: false,\n error: err,\n });\n this.logger.warn(\n `Plugin \"${plugin.name}\" failed to transform output: ${err.message}`\n );\n }\n }\n }\n\n transformedOutputs.set(key, {\n ...output,\n content: transformedContent,\n });\n }\n\n return transformedOutputs;\n }\n\n /**\n * Write outputs to disk\n */\n async writeOutputs(outputs: Map<string, GeneratedOutput>): Promise<void> {\n for (const [, output] of outputs) {\n try {\n const resolvedPath = path.resolve(process.cwd(), output.path);\n await this.utils.ensureDir(path.dirname(resolvedPath));\n await this.utils.writeFile(resolvedPath, output.content);\n // Don't log here - let the main command handle success messaging\n } catch (error) {\n const err = error as Error;\n this.logger.error(`Failed to write ${output.path}: ${err.message}`);\n throw err;\n }\n }\n }\n\n /**\n * Get execution results for debugging\n */\n getExecutionResults(): Map<string, HookResult[]> {\n return new Map(this.executionContext.results);\n }\n\n /**\n * Augment existing output with additional content\n */\n private augmentOutput(\n outputs: Map<string, GeneratedOutput>,\n outputKey: string,\n contractName: string,\n content: any\n ): void {\n const existing = outputs.get(outputKey);\n if (!existing) {\n this.logger.warn(`Cannot augment non-existent output: ${outputKey}`);\n return;\n }\n\n // Simple augmentation - append content\n // In a real implementation, this would be more sophisticated\n const augmentedContent = `${existing.content}\\n\\n// Augmented by plugin for ${contractName}\\n${JSON.stringify(content, null, 2)}`;\n\n outputs.set(outputKey, {\n ...existing,\n content: augmentedContent,\n });\n }\n\n /**\n * Record hook execution result\n */\n private recordHookResult(\n pluginName: string,\n hookName: string,\n result: Omit<HookResult, \"plugin\">\n ): void {\n const key = `${pluginName}:${hookName}`;\n const existing = this.executionContext.results.get(key) || [];\n existing.push({ ...result, plugin: pluginName });\n this.executionContext.results.set(key, existing);\n }\n\n /**\n * Create logger instance\n */\n private createLogger(): Logger {\n return {\n info: (message: string) => console.log(`ℹ️ ${message}`),\n warn: (message: string) => console.warn(`⚠️ ${message}`),\n error: (message: string) => console.error(`❌ ${message}`),\n debug: (message: string) => {\n if (process.env.DEBUG) {\n console.log(`🐛 ${message}`);\n }\n },\n success: (message: string) => console.log(`✅ ${message}`),\n };\n }\n\n /**\n * Create utils instance\n */\n private createUtils(): PluginUtils {\n return {\n toCamelCase: (str: string) => {\n return str.replace(/-([a-z])/g, (_, letter) => letter.toUpperCase());\n },\n\n toKebabCase: (str: string) => {\n return str.replace(/[A-Z]/g, (letter) => `-${letter.toLowerCase()}`);\n },\n\n validateAddress: (address: string) => {\n return validateStacksAddress(parseContractId(address).address);\n },\n\n parseContractId: (contractId: string) => {\n return parseContractId(contractId);\n },\n\n formatCode: async (code: string) => {\n const { formatCode } = await import(\"../utils/format\");\n return formatCode(code);\n },\n\n resolvePath: (relativePath: string) => {\n return path.resolve(process.cwd(), relativePath);\n },\n\n fileExists: async (filePath: string) => {\n try {\n await fs.access(filePath);\n return true;\n } catch {\n return false;\n }\n },\n\n readFile: async (filePath: string) => {\n return fs.readFile(filePath, \"utf-8\");\n },\n\n writeFile: async (filePath: string, content: string) => {\n await fs.writeFile(filePath, content, \"utf-8\");\n },\n\n ensureDir: async (dirPath: string) => {\n await fs.mkdir(dirPath, { recursive: true });\n },\n };\n }\n}\n",
7
7
  "/**\n * Parse a fully-qualified contract ID (\"address.contractName\") into its parts.\n * Throws if the input doesn't contain a dot separator.\n */\nexport function parseContractId(contractId: string): {\n address: string;\n contractName: string;\n} {\n const dotIndex = contractId.indexOf(\".\");\n if (dotIndex === -1) {\n throw new Error(\n `Invalid contract ID: \"${contractId}\" (expected \"address.contractName\")`\n );\n }\n return {\n address: contractId.slice(0, dotIndex),\n contractName: contractId.slice(dotIndex + 1),\n };\n}\n",
8
8
  "/**\n * Plugin system types for @secondlayer/cli\n */\n\nimport type { SecondLayerConfig, ResolvedContract, NetworkName } from \"./config\";\n\n/**\n * Core plugin interface that all plugins must implement\n */\nexport interface SecondLayerPlugin {\n /** Plugin name (should be unique) */\n name: string;\n\n /** Plugin version */\n version: string;\n\n // Lifecycle hooks\n /** Called after config is resolved but before generation starts */\n configResolved?: (config: ResolvedConfig) => void | Promise<void>;\n\n /** Called before generation starts */\n beforeGenerate?: (context: GenerateContext) => void | Promise<void>;\n\n /** Called during generation phase - plugins can add their own outputs */\n generate?: (context: GenerateContext) => void | Promise<void>;\n\n /** Called after all generation is complete */\n afterGenerate?: (context: GenerateContext) => void | Promise<void>;\n\n // Transform hooks\n /** Transform user config before resolution */\n transformConfig?: (config: UserConfig) => UserConfig | Promise<UserConfig>;\n\n /** Transform individual contracts during processing */\n transformContract?: (\n contract: ContractConfig\n ) => ContractConfig | Promise<ContractConfig>;\n\n /** Transform generated output before writing to disk */\n transformOutput?: (\n output: string,\n type: OutputType\n ) => string | Promise<string>;\n}\n\n/**\n * User configuration (before plugin transformations)\n */\nexport type UserConfig = SecondLayerConfig;\n\n/**\n * Resolved configuration (after plugin transformations)\n */\nexport interface ResolvedConfig extends SecondLayerConfig {\n /** Resolved plugins array */\n plugins: SecondLayerPlugin[];\n}\n\n/**\n * Contract configuration that can be transformed by plugins\n */\nexport interface ContractConfig {\n name?: string;\n address?: string | Partial<Record<NetworkName, string>>;\n source?: string;\n abi?: any;\n metadata?: Record<string, any>;\n}\n\n/**\n * Contract config from Clarinet plugin\n */\nexport interface ClarinetContractConfig extends ContractConfig {\n _clarinetSource: true;\n}\n\n/**\n * Contract config from direct file input\n */\nexport interface DirectFileContractConfig extends ContractConfig {\n _directFile: true;\n}\n\n/**\n * Union of all contract config types\n */\nexport type PluginContractConfig =\n | ContractConfig\n | ClarinetContractConfig\n | DirectFileContractConfig;\n\n/**\n * Type guard for Clarinet contracts\n */\nexport function isClarinetContract(\n c: ContractConfig\n): c is ClarinetContractConfig {\n return \"_clarinetSource\" in c && c._clarinetSource === true;\n}\n\n/**\n * Type guard for direct file contracts\n */\nexport function isDirectFileContract(\n c: ContractConfig\n): c is DirectFileContractConfig {\n return \"_directFile\" in c && c._directFile === true;\n}\n\n/**\n * Processed contract with resolved ABI and metadata\n */\nexport interface ProcessedContract extends ResolvedContract {\n /** Additional metadata added by plugins */\n metadata?: Record<string, any>;\n}\n\n/**\n * Generated output from plugins\n */\nexport interface GeneratedOutput {\n /** File path where output should be written */\n path: string;\n\n /** Generated content */\n content: string;\n\n /** Output type for transformation hooks */\n type?: OutputType;\n\n /** Whether this output should overwrite existing files */\n overwrite?: boolean;\n}\n\n/**\n * Types of outputs that can be generated\n */\nexport type OutputType =\n | \"contracts\"\n | \"hooks\"\n | \"actions\"\n | \"types\"\n | \"utils\"\n | \"config\"\n | \"other\";\n\n/**\n * Base context available to all plugin hooks\n */\nexport interface PluginContext {\n /** Resolved configuration */\n config: ResolvedConfig;\n\n /** Logger for plugin output */\n logger: Logger;\n\n /** Utility functions for plugins */\n utils: PluginUtils;\n}\n\n/**\n * Context available during generation phase\n */\nexport interface GenerateContext extends PluginContext {\n /** Processed contracts ready for generation */\n contracts: ProcessedContract[];\n\n /** Map of output keys to generated content */\n outputs: Map<string, GeneratedOutput>;\n\n /** Function to augment existing outputs */\n augment: (outputKey: string, contractName: string, content: any) => void;\n\n /** Function to add new outputs */\n addOutput: (key: string, output: GeneratedOutput) => void;\n}\n\n/**\n * Logger interface for plugin output\n */\nexport interface Logger {\n info: (message: string) => void;\n warn: (message: string) => void;\n error: (message: string) => void;\n debug: (message: string) => void;\n success: (message: string) => void;\n}\n\n/**\n * Utility functions available to plugins\n */\nexport interface PluginUtils {\n /** Convert kebab-case to camelCase */\n toCamelCase: (str: string) => string;\n\n /** Convert camelCase to kebab-case */\n toKebabCase: (str: string) => string;\n\n /** Validate Stacks address format */\n validateAddress: (address: string) => boolean;\n\n /** Parse contract identifier (address.contract-name) */\n parseContractId: (contractId: string) => {\n address: string;\n contractName: string;\n };\n\n /** Format TypeScript code using prettier */\n formatCode: (code: string) => Promise<string>;\n\n /** Resolve file path relative to project root */\n resolvePath: (relativePath: string) => string;\n\n /** Check if file exists */\n fileExists: (path: string) => Promise<boolean>;\n\n /** Read file content */\n readFile: (path: string) => Promise<string>;\n\n /** Write file content */\n writeFile: (path: string, content: string) => Promise<void>;\n\n /** Create directory recursively */\n ensureDir: (path: string) => Promise<void>;\n}\n\n/**\n * Plugin factory function type for creating plugins with options\n */\nexport type PluginFactory<TOptions = any> = (\n options?: TOptions\n) => SecondLayerPlugin;\n\n/**\n * Plugin options base interface\n */\nexport interface PluginOptions {\n /** Include only specific contracts/functions */\n include?: string[];\n\n /** Exclude specific contracts/functions */\n exclude?: string[];\n\n /** Enable debug output */\n debug?: boolean;\n}\n\n/**\n * Hook execution result\n */\nexport interface HookResult<T = any> {\n /** Whether the hook was successful */\n success: boolean;\n\n /** Result data from the hook */\n data?: T;\n\n /** Error if hook failed */\n error?: Error;\n\n /** Plugin that executed the hook */\n plugin: string;\n}\n\n/**\n * Plugin execution context for internal use\n */\nexport interface PluginExecutionContext {\n /** Current plugin being executed */\n currentPlugin?: SecondLayerPlugin;\n\n /** Execution phase */\n phase: \"config\" | \"generate\" | \"output\";\n\n /** Start time for performance tracking */\n startTime: number;\n\n /** Plugin execution results */\n results: Map<string, HookResult[]>;\n}\n",
9
9
  "/**\n * Clarinet Plugin for @secondlayer/cli\n * Generates type-safe contract interfaces from local Clarity contracts using Clarinet SDK\n */\n\nimport { initSimnet } from \"@hirosystems/clarinet-sdk\";\nimport { toCamelCase } from \"@secondlayer/stacks/clarity\";\nimport { parseContractId } from \"../../utils/contract-id\";\nimport { generateContractInterface } from \"../../generators/contract\";\nimport { normalizeAbi } from \"../../utils/abi-compat\";\nimport type {\n PluginFactory,\n UserConfig,\n GenerateContext,\n} from \"../../types/plugin\";\n\nexport interface ClarinetPluginOptions {\n /** Path to Clarinet.toml file */\n path?: string;\n\n /** Include only specific contracts */\n include?: string[];\n\n /** Exclude specific contracts */\n exclude?: string[];\n\n /** Enable debug output */\n debug?: boolean;\n}\n\n/**\n * Sanitize contract name to be a valid JavaScript identifier using camelCase\n */\nfunction sanitizeContractName(name: string): string {\n return toCamelCase(name);\n}\n\n/**\n * Check if a contract is a user-defined contract (not a system contract)\n */\nasync function isUserDefinedContract(\n contractId: string,\n manifestPath: string\n): Promise<boolean> {\n const { address, contractName } = parseContractId(contractId);\n\n try {\n // Read Clarinet.toml to get user-defined contracts\n const { promises: fs } = await import(\"fs\");\n const tomlContent = await fs.readFile(manifestPath, \"utf-8\");\n\n // Simple TOML parsing to find [contracts.CONTRACT_NAME] sections\n const contractSectionRegex = /^\\[contracts\\.([^\\]]+)\\]/gm;\n const userContracts = new Set<string>();\n\n let match;\n while ((match = contractSectionRegex.exec(tomlContent)) !== null) {\n userContracts.add(match[1]);\n }\n\n // If the contract is explicitly defined in Clarinet.toml, it's user-defined\n if (userContracts.has(contractName)) {\n return true;\n }\n } catch (error) {\n // If we can't read the TOML file, fall back to pattern matching\n }\n\n // Fallback: System contracts typically have specific addresses or are in the boot contracts\n // Common system contract patterns:\n const systemContractPatterns = [\n /^pox-\\d+$/, // pox-2, pox-3, etc.\n /^bns$/, // Blockchain Name System\n /^costs-\\d+$/, // costs-2, costs-3, etc.\n /^lockup$/, // lockup contract\n ];\n\n // Check if it matches any system contract pattern\n if (systemContractPatterns.some((pattern) => pattern.test(contractName))) {\n return false;\n }\n\n // System contracts often use specific addresses\n const systemAddresses = [\n \"SP000000000000000000002Q6VF78\", // Boot contracts address\n \"ST000000000000000000002AMW42H\", // Boot contracts address (testnet)\n ];\n\n if (systemAddresses.includes(address)) {\n return false;\n }\n\n return true;\n}\n\n/**\n * Clarinet plugin factory\n */\nexport const clarinet: PluginFactory<ClarinetPluginOptions> = (\n options = {}\n) => {\n const manifestPath = options.path || \"./Clarinet.toml\";\n let simnet: any;\n\n return {\n name: \"@secondlayer/cli/plugin-clarinet\",\n version: \"1.0.0\",\n\n async transformConfig(config: UserConfig): Promise<UserConfig> {\n try {\n // Initialize simnet to extract contract ABIs\n simnet = await initSimnet(manifestPath);\n\n // Get contract interfaces from Clarinet\n const contractInterfaces = simnet.getContractsInterfaces();\n const contracts = [];\n\n for (const [contractId, abi] of contractInterfaces) {\n const { contractName } = parseContractId(contractId);\n\n // Skip system contracts\n if (!(await isUserDefinedContract(contractId, manifestPath))) {\n if (options.debug) {\n console.log(`🚫 Skipping system contract: ${contractId}`);\n }\n continue;\n }\n\n // Apply user filters\n if (options.include && !options.include.includes(contractName)) {\n continue;\n }\n if (options.exclude && options.exclude.includes(contractName)) {\n continue;\n }\n\n // Sanitize the contract name for JavaScript export\n const sanitizedName = sanitizeContractName(contractName);\n\n // Don't set source field to avoid conflict with file resolution\n // Instead, we'll track this in metadata during processing\n contracts.push({\n name: sanitizedName,\n address: contractId,\n abi: normalizeAbi(abi),\n // Remove source field - this was causing the path resolution issue\n _clarinetSource: true, // Internal flag for our plugin\n });\n }\n\n if (options.debug) {\n console.log(\n `🔍 Clarinet plugin found ${contracts.length} user-defined contracts`\n );\n }\n\n return {\n ...config,\n contracts: [...(config.contracts || []), ...contracts],\n };\n } catch (error) {\n const err = error as Error;\n if (options.debug) {\n console.warn(\n `⚠️ Clarinet plugin failed to load contracts: ${err.message}`\n );\n }\n // If Clarinet.toml doesn't exist or fails, just return config unchanged\n return config;\n }\n },\n\n async generate(context: GenerateContext): Promise<void> {\n // Filter contracts that came from Clarinet\n const clarinetContracts = context.contracts.filter(\n (contract) => contract.metadata?.source === \"clarinet\"\n );\n\n if (clarinetContracts.length === 0) {\n return;\n }\n\n if (options.debug) {\n context.logger.debug(\n `Generating interfaces for ${clarinetContracts.length} Clarinet contracts`\n );\n }\n\n // Generate the main contracts file using existing generator\n const contractsCode = await generateContractInterface(clarinetContracts);\n\n context.addOutput(\"contracts\", {\n path: context.config.out,\n content: contractsCode,\n type: \"contracts\",\n });\n\n // Don't log success here - let the main command handle it\n },\n };\n};\n\n/**\n * Utility function to check if a Clarinet project exists\n */\nexport async function hasClarinetProject(\n path = \"./Clarinet.toml\"\n): Promise<boolean> {\n try {\n const { promises: fs } = await import(\"fs\");\n await fs.access(path);\n return true;\n } catch {\n return false;\n }\n}\n",
10
- "import type { ResolvedContract } from \"../types/config\";\nimport { formatCode } from \"../utils/format\";\nimport {\n toCamelCase,\n type AbiFunction,\n type AbiMap,\n type AbiVariable,\n} from \"@secondlayer/stacks/clarity\";\nimport { getTypeForArg } from \"../utils/type-mapping\";\nimport { generateClarityConversion } from \"../utils/clarity-conversion\";\n\n/**\n * Code generator for contract interfaces\n */\n\n/**\n * Generate shared network utilities for the generated code\n */\nfunction generateNetworkUtils(): string {\n return `/**\n * API URLs for different networks\n */\nconst API_URLS: Record<'mainnet' | 'testnet' | 'devnet', string> = {\n mainnet: 'https://api.hiro.so',\n testnet: 'https://api.testnet.hiro.so',\n devnet: 'http://localhost:3999'\n};\n\n/**\n * Infer network from Stacks address prefix\n * SP/SM = mainnet, ST/SN = testnet\n */\nfunction inferNetworkFromAddress(address: string): 'mainnet' | 'testnet' | undefined {\n if (address.startsWith('SP') || address.startsWith('SM')) return 'mainnet';\n if (address.startsWith('ST') || address.startsWith('SN')) return 'testnet';\n return undefined;\n}\n\n/**\n * Get API URL, inferring network from contract address if not specified\n */\nfunction getApiUrl(\n contractAddress: string,\n explicitNetwork?: 'mainnet' | 'testnet' | 'devnet'\n): string {\n const network = explicitNetwork ?? inferNetworkFromAddress(contractAddress) ?? 'mainnet';\n return API_URLS[network];\n}`;\n}\n\n/**\n * Generate validation utilities that are inlined in generated code\n * This avoids requiring external dependencies beyond @secondlayer/stacks\n */\nfunction generateValidationUtils(): string {\n return `/**\n * Contract name validation regex\n * Must start with letter, contain only letters, numbers, and hyphens, max 128 chars\n */\nconst CONTRACT_NAME_REGEX = /^[a-zA-Z][a-zA-Z0-9\\\\-]{0,127}$/;`;\n}\n\nexport async function generateContractInterface(\n contracts: ResolvedContract[]\n): Promise<string> {\n const imports = `import { Cl, validateStacksAddress } from '@secondlayer/stacks'`;\n\n const header = `/**\n * Generated by @secondlayer/cli\n * DO NOT EDIT MANUALLY\n *\n * @requires @secondlayer/stacks - Install with: npm install @secondlayer/stacks\n */`;\n\n const validationUtils = generateValidationUtils();\n const networkUtils = generateNetworkUtils();\n\n const contractsCode = contracts\n .map((contract) => generateContract(contract))\n .join(\"\\n\\n\");\n\n const code = `${imports}\\n\\n${header}\\n\\n${validationUtils}\\n\\n${networkUtils}\\n\\n${contractsCode}`;\n\n return formatCode(code);\n}\n\nfunction generateContract(contract: ResolvedContract): string {\n const { name, address, contractName, abi } = contract;\n\n const abiCode = generateAbiConstant(name, abi);\n\n const methods = abi.functions\n .filter((func: AbiFunction) => func.access !== \"private\")\n .map((func: AbiFunction) => generateMethod(func, address, contractName))\n .join(\",\\n\\n \");\n\n // Generate maps object if contract has maps\n const mapsObject = generateMapsObject(abi.maps || [], address, contractName);\n\n // Generate vars object if contract has variables (only data vars, not constants)\n const varsObject = generateVarsObject(abi.variables || [], address, contractName);\n\n // Generate constants object if contract has constants\n const constantsObject = generateConstantsObject(abi.variables || [], address, contractName);\n\n // Combine all members\n const allMembers = [methods, mapsObject, varsObject, constantsObject].filter(Boolean);\n\n const contractCode = `export const ${name} = {\n address: '${address}',\n contractAddress: '${address}',\n contractName: '${contractName}',\n\n ${allMembers.join(\",\\n\\n \")}\n} as const`;\n\n return `${abiCode}\\n\\n${contractCode}`;\n}\n\nfunction generateAbiConstant(name: string, abi: any): string {\n const abiJson = JSON.stringify(abi, null, 2)\n .replace(/\"([a-zA-Z_$][a-zA-Z0-9_$]*)\":/g, \"$1:\") // Only remove quotes from valid JS identifiers\n .replace(/\"/g, \"'\"); // Use single quotes\n\n return `export const ${name}Abi = ${abiJson} as const`;\n}\n\nfunction generateMethod(\n func: AbiFunction,\n address: string,\n contractName: string\n): string {\n const methodName = toCamelCase(func.name);\n\n if (func.args.length === 0) {\n return `${methodName}() {\n return {\n contractAddress: '${address}',\n contractName: '${contractName}',\n functionName: '${func.name}',\n functionArgs: []\n }\n }`;\n }\n\n if (func.args.length === 1) {\n const originalArgName = func.args[0].name;\n const argName = toCamelCase(originalArgName);\n const argType = getTypeForArg(func.args[0]);\n const clarityConversion = generateClarityConversion(argName, func.args[0]);\n\n return `${methodName}(...args: [{ ${argName}: ${argType} }] | [${argType}]) {\n const ${argName} = args.length === 1 && typeof args[0] === 'object' && args[0] !== null && '${argName}' in args[0]\n ? args[0].${argName}\n : args[0] as ${argType}\n \n return {\n contractAddress: '${address}',\n contractName: '${contractName}',\n functionName: '${func.name}',\n functionArgs: [${clarityConversion}]\n }\n }`;\n }\n\n const argsList = func.args.map((arg) => toCamelCase(arg.name)).join(\", \");\n const argsTypes = func.args\n .map((arg) => {\n const camelName = toCamelCase(arg.name);\n return `${camelName}: ${getTypeForArg(arg)}`;\n })\n .join(\"; \");\n const argsArray = func.args\n .map((arg) => {\n const argName = toCamelCase(arg.name);\n return generateClarityConversion(argName, arg);\n })\n .join(\", \");\n const objectAccess = func.args\n .map((arg) => {\n const camelName = toCamelCase(arg.name);\n return `args[0].${camelName}`;\n })\n .join(\", \");\n const positionTypes = func.args.map((arg) => getTypeForArg(arg)).join(\", \");\n\n return `${methodName}(...args: [{ ${argsTypes} }] | [${positionTypes}]) {\n const [${argsList}] = args.length === 1 && typeof args[0] === 'object' && args[0] !== null\n ? [${objectAccess}]\n : args as [${positionTypes}]\n \n return {\n contractAddress: '${address}',\n contractName: '${contractName}',\n functionName: '${func.name}',\n functionArgs: [${argsArray}]\n }\n }`;\n}\n\n\n\n/**\n * Generate maps object with type-safe accessors for contract data maps\n */\nfunction generateMapsObject(\n maps: readonly AbiMap[],\n address: string,\n contractName: string\n): string {\n if (!maps || maps.length === 0) {\n return \"\";\n }\n\n const mapMethods = maps.map((map) => {\n const methodName = toCamelCase(map.name);\n const keyType = getTypeForArg({ type: map.key });\n const valueType = getTypeForArg({ type: map.value });\n const keyConversion = generateMapKeyConversion(map.key);\n\n return `${methodName}: {\n async get(key: ${keyType}, options?: { network?: 'mainnet' | 'testnet' | 'devnet' }): Promise<${valueType} | null> {\n try {\n const { cvToJSON, serializeCV } = await import('@secondlayer/stacks/clarity');\n const baseUrl = getApiUrl('${address}', options?.network);\n const mapKey = ${keyConversion};\n const keyHex = serializeCV(mapKey).toString('hex');\n\n const response = await fetch(\n \\`\\${baseUrl}/v2/map_entry/${address}/${contractName}/${map.name}\\`,\n {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(keyHex)\n }\n );\n\n if (!response.ok) {\n throw new Error(\\`HTTP \\${response.status}: \\${response.statusText}\\`);\n }\n\n const result = await response.json();\n if (!result.data || result.data === '0x09') {\n return null; // none value\n }\n\n const { deserializeCV } = await import('@secondlayer/stacks/clarity');\n const cv = deserializeCV(result.data);\n const parsed = cvToJSON(cv);\n // Unwrap the (some ...) wrapper\n return parsed.value?.value ?? parsed.value ?? null;\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\\`Map access failed for '${map.name}': \\${error.message}\\`);\n }\n throw error;\n }\n },\n keyType: ${JSON.stringify(map.key)} as const,\n valueType: ${JSON.stringify(map.value)} as const\n }`;\n });\n\n return `maps: {\n ${mapMethods.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate vars object with type-safe accessors for contract data variables\n */\nfunction generateVarsObject(\n variables: readonly AbiVariable[],\n address: string,\n contractName: string\n): string {\n if (!variables || variables.length === 0) {\n return \"\";\n }\n\n // Filter to only include mutable data variables (not constants)\n const dataVars = variables.filter((v) => v.access === \"variable\");\n\n if (dataVars.length === 0) {\n return \"\";\n }\n\n const varMethods = dataVars.map((variable) => {\n const methodName = toCamelCase(variable.name);\n const valueType = getTypeForArg({ type: variable.type });\n\n return `${methodName}: {\n async get(options?: { network?: 'mainnet' | 'testnet' | 'devnet' }): Promise<${valueType}> {\n try {\n const { cvToJSON, deserializeCV } = await import('@secondlayer/stacks/clarity');\n const baseUrl = getApiUrl('${address}', options?.network);\n\n const response = await fetch(\n \\`\\${baseUrl}/v2/data_var/${address}/${contractName}/${variable.name}?proof=0\\`\n );\n\n if (!response.ok) {\n throw new Error(\\`HTTP \\${response.status}: \\${response.statusText}\\`);\n }\n\n const result = await response.json();\n const cv = deserializeCV(result.data);\n const parsed = cvToJSON(cv);\n return parsed.value ?? parsed;\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\\`Variable access failed for '${variable.name}': \\${error.message}\\`);\n }\n throw error;\n }\n },\n type: ${JSON.stringify(variable.type)} as const\n }`;\n });\n\n return `vars: {\n ${varMethods.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate constants object with type-safe accessors for contract constants\n */\nfunction generateConstantsObject(\n variables: readonly AbiVariable[],\n address: string,\n contractName: string\n): string {\n if (!variables || variables.length === 0) {\n return \"\";\n }\n\n // Filter to only include constants\n const constants = variables.filter((v) => v.access === \"constant\");\n\n if (constants.length === 0) {\n return \"\";\n }\n\n const constMethods = constants.map((constant) => {\n const methodName = toCamelCase(constant.name);\n const valueType = getTypeForArg({ type: constant.type });\n\n return `${methodName}: {\n async get(options?: { network?: 'mainnet' | 'testnet' | 'devnet' }): Promise<${valueType}> {\n try {\n const { cvToJSON, deserializeCV } = await import('@secondlayer/stacks/clarity');\n const baseUrl = getApiUrl('${address}', options?.network);\n\n const response = await fetch(\n \\`\\${baseUrl}/v2/constant_val/${address}/${contractName}/${constant.name}?proof=0\\`\n );\n\n if (!response.ok) {\n throw new Error(\\`HTTP \\${response.status}: \\${response.statusText}\\`);\n }\n\n const result = await response.json();\n const cv = deserializeCV(result.data);\n const parsed = cvToJSON(cv);\n return parsed.value ?? parsed;\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\\`Constant access failed for '${constant.name}': \\${error.message}\\`);\n }\n throw error;\n }\n },\n type: ${JSON.stringify(constant.type)} as const\n }`;\n });\n\n return `constants: {\n ${constMethods.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate Clarity conversion for map key\n */\nfunction generateMapKeyConversion(keyType: any): string {\n // Map keys are typically tuples or simple types\n if (keyType.tuple) {\n const fields = keyType.tuple\n .map((field: any) => {\n const camelFieldName = toCamelCase(field.name);\n const fieldConversion = generateClarityConversion(\n `key.${camelFieldName}`,\n { type: field.type }\n );\n return `\"${field.name}\": ${fieldConversion}`;\n })\n .join(\", \");\n return `Cl.tuple({ ${fields} })`;\n }\n\n // Single-value keys\n return generateClarityConversion(\"key\", { type: keyType });\n}\n",
10
+ "import type { ResolvedContract } from \"../types/config\";\nimport { formatCode } from \"../utils/format\";\nimport {\n toCamelCase,\n type AbiFunction,\n type AbiMap,\n type AbiVariable,\n} from \"@secondlayer/stacks/clarity\";\nimport { getTypeForArg } from \"../utils/type-mapping\";\nimport { generateClarityConversion } from \"../utils/clarity-conversion\";\nimport { generateMapKeyConversion } from \"../utils/generator-helpers\";\n\n/**\n * Code generator for contract interfaces\n */\n\n/**\n * Generate shared network utilities for the generated code\n */\nfunction generateNetworkUtils(): string {\n return `/**\n * API URLs for different networks\n */\nconst API_URLS: Record<'mainnet' | 'testnet' | 'devnet', string> = {\n mainnet: 'https://api.hiro.so',\n testnet: 'https://api.testnet.hiro.so',\n devnet: 'http://localhost:3999'\n};\n\n/**\n * Infer network from Stacks address prefix\n * SP/SM = mainnet, ST/SN = testnet\n */\nfunction inferNetworkFromAddress(address: string): 'mainnet' | 'testnet' | undefined {\n if (address.startsWith('SP') || address.startsWith('SM')) return 'mainnet';\n if (address.startsWith('ST') || address.startsWith('SN')) return 'testnet';\n return undefined;\n}\n\n/**\n * Get API URL, inferring network from contract address if not specified\n */\nfunction getApiUrl(\n contractAddress: string,\n explicitNetwork?: 'mainnet' | 'testnet' | 'devnet'\n): string {\n const network = explicitNetwork ?? inferNetworkFromAddress(contractAddress) ?? 'mainnet';\n return API_URLS[network];\n}`;\n}\n\n/**\n * Generate validation utilities that are inlined in generated code\n * This avoids requiring external dependencies beyond @secondlayer/stacks\n */\nfunction generateValidationUtils(): string {\n return `/**\n * Contract name validation regex\n * Must start with letter, contain only letters, numbers, and hyphens, max 128 chars\n */\nconst CONTRACT_NAME_REGEX = /^[a-zA-Z][a-zA-Z0-9\\\\-]{0,127}$/;`;\n}\n\nexport async function generateContractInterface(\n contracts: ResolvedContract[]\n): Promise<string> {\n const imports = `import { Cl, validateStacksAddress } from '@secondlayer/stacks'`;\n\n const header = `/**\n * Generated by @secondlayer/cli\n * DO NOT EDIT MANUALLY\n *\n * @requires @secondlayer/stacks - Install with: npm install @secondlayer/stacks\n */`;\n\n const validationUtils = generateValidationUtils();\n const networkUtils = generateNetworkUtils();\n\n const contractsCode = contracts\n .map((contract) => generateContract(contract))\n .join(\"\\n\\n\");\n\n const code = `${imports}\\n\\n${header}\\n\\n${validationUtils}\\n\\n${networkUtils}\\n\\n${contractsCode}`;\n\n return formatCode(code);\n}\n\nfunction generateContract(contract: ResolvedContract): string {\n const { name, address, contractName, abi } = contract;\n\n const abiCode = generateAbiConstant(name, abi);\n\n const methods = abi.functions\n .filter((func: AbiFunction) => func.access !== \"private\")\n .map((func: AbiFunction) => generateMethod(func, address, contractName))\n .join(\",\\n\\n \");\n\n // Generate maps object if contract has maps\n const mapsObject = generateMapsObject(abi.maps || [], address, contractName);\n\n // Generate vars object if contract has variables (only data vars, not constants)\n const varsObject = generateVarsObject(abi.variables || [], address, contractName);\n\n // Generate constants object if contract has constants\n const constantsObject = generateConstantsObject(abi.variables || [], address, contractName);\n\n // Combine all members\n const allMembers = [methods, mapsObject, varsObject, constantsObject].filter(Boolean);\n\n const contractCode = `export const ${name} = {\n address: '${address}',\n contractAddress: '${address}',\n contractName: '${contractName}',\n\n ${allMembers.join(\",\\n\\n \")}\n} as const`;\n\n return `${abiCode}\\n\\n${contractCode}`;\n}\n\nfunction generateAbiConstant(name: string, abi: any): string {\n const abiJson = JSON.stringify(abi, null, 2)\n .replace(/\"([a-zA-Z_$][a-zA-Z0-9_$]*)\":/g, \"$1:\") // Only remove quotes from valid JS identifiers\n .replace(/\"/g, \"'\"); // Use single quotes\n\n return `export const ${name}Abi = ${abiJson} as const`;\n}\n\nfunction generateMethod(\n func: AbiFunction,\n address: string,\n contractName: string\n): string {\n const methodName = toCamelCase(func.name);\n\n if (func.args.length === 0) {\n return `${methodName}() {\n return {\n contractAddress: '${address}',\n contractName: '${contractName}',\n functionName: '${func.name}',\n functionArgs: []\n }\n }`;\n }\n\n if (func.args.length === 1) {\n const originalArgName = func.args[0].name;\n const argName = toCamelCase(originalArgName);\n const argType = getTypeForArg(func.args[0]);\n const clarityConversion = generateClarityConversion(argName, func.args[0]);\n\n return `${methodName}(...args: [{ ${argName}: ${argType} }] | [${argType}]) {\n const ${argName} = args.length === 1 && typeof args[0] === 'object' && args[0] !== null && '${argName}' in args[0]\n ? args[0].${argName}\n : args[0] as ${argType}\n \n return {\n contractAddress: '${address}',\n contractName: '${contractName}',\n functionName: '${func.name}',\n functionArgs: [${clarityConversion}]\n }\n }`;\n }\n\n const argsList = func.args.map((arg) => toCamelCase(arg.name)).join(\", \");\n const argsTypes = func.args\n .map((arg) => {\n const camelName = toCamelCase(arg.name);\n return `${camelName}: ${getTypeForArg(arg)}`;\n })\n .join(\"; \");\n const argsArray = func.args\n .map((arg) => {\n const argName = toCamelCase(arg.name);\n return generateClarityConversion(argName, arg);\n })\n .join(\", \");\n const objectAccess = func.args\n .map((arg) => {\n const camelName = toCamelCase(arg.name);\n return `args[0].${camelName}`;\n })\n .join(\", \");\n const positionTypes = func.args.map((arg) => getTypeForArg(arg)).join(\", \");\n\n return `${methodName}(...args: [{ ${argsTypes} }] | [${positionTypes}]) {\n const [${argsList}] = args.length === 1 && typeof args[0] === 'object' && args[0] !== null\n ? [${objectAccess}]\n : args as [${positionTypes}]\n \n return {\n contractAddress: '${address}',\n contractName: '${contractName}',\n functionName: '${func.name}',\n functionArgs: [${argsArray}]\n }\n }`;\n}\n\n\n\n/**\n * Generate maps object with type-safe accessors for contract data maps\n */\nfunction generateMapsObject(\n maps: readonly AbiMap[],\n address: string,\n contractName: string\n): string {\n if (!maps || maps.length === 0) {\n return \"\";\n }\n\n const mapMethods = maps.map((map) => {\n const methodName = toCamelCase(map.name);\n const keyType = getTypeForArg({ type: map.key });\n const valueType = getTypeForArg({ type: map.value });\n const keyConversion = generateMapKeyConversion(map.key);\n\n return `${methodName}: {\n async get(key: ${keyType}, options?: { network?: 'mainnet' | 'testnet' | 'devnet' }): Promise<${valueType} | null> {\n try {\n const { cvToJSON, serializeCV } = await import('@secondlayer/stacks/clarity');\n const baseUrl = getApiUrl('${address}', options?.network);\n const mapKey = ${keyConversion};\n const keyHex = serializeCV(mapKey).toString('hex');\n\n const response = await fetch(\n \\`\\${baseUrl}/v2/map_entry/${address}/${contractName}/${map.name}\\`,\n {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(keyHex)\n }\n );\n\n if (!response.ok) {\n throw new Error(\\`HTTP \\${response.status}: \\${response.statusText}\\`);\n }\n\n const result = await response.json();\n if (!result.data || result.data === '0x09') {\n return null; // none value\n }\n\n const { deserializeCV } = await import('@secondlayer/stacks/clarity');\n const cv = deserializeCV(result.data);\n const parsed = cvToJSON(cv);\n // Unwrap the (some ...) wrapper\n return parsed.value?.value ?? parsed.value ?? null;\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\\`Map access failed for '${map.name}': \\${error.message}\\`);\n }\n throw error;\n }\n },\n keyType: ${JSON.stringify(map.key)} as const,\n valueType: ${JSON.stringify(map.value)} as const\n }`;\n });\n\n return `maps: {\n ${mapMethods.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate vars object with type-safe accessors for contract data variables\n */\nfunction generateVarsObject(\n variables: readonly AbiVariable[],\n address: string,\n contractName: string\n): string {\n if (!variables || variables.length === 0) {\n return \"\";\n }\n\n // Filter to only include mutable data variables (not constants)\n const dataVars = variables.filter((v) => v.access === \"variable\");\n\n if (dataVars.length === 0) {\n return \"\";\n }\n\n const varMethods = dataVars.map((variable) => {\n const methodName = toCamelCase(variable.name);\n const valueType = getTypeForArg({ type: variable.type });\n\n return `${methodName}: {\n async get(options?: { network?: 'mainnet' | 'testnet' | 'devnet' }): Promise<${valueType}> {\n try {\n const { cvToJSON, deserializeCV } = await import('@secondlayer/stacks/clarity');\n const baseUrl = getApiUrl('${address}', options?.network);\n\n const response = await fetch(\n \\`\\${baseUrl}/v2/data_var/${address}/${contractName}/${variable.name}?proof=0\\`\n );\n\n if (!response.ok) {\n throw new Error(\\`HTTP \\${response.status}: \\${response.statusText}\\`);\n }\n\n const result = await response.json();\n const cv = deserializeCV(result.data);\n const parsed = cvToJSON(cv);\n return parsed.value ?? parsed;\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\\`Variable access failed for '${variable.name}': \\${error.message}\\`);\n }\n throw error;\n }\n },\n type: ${JSON.stringify(variable.type)} as const\n }`;\n });\n\n return `vars: {\n ${varMethods.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate constants object with type-safe accessors for contract constants\n */\nfunction generateConstantsObject(\n variables: readonly AbiVariable[],\n address: string,\n contractName: string\n): string {\n if (!variables || variables.length === 0) {\n return \"\";\n }\n\n // Filter to only include constants\n const constants = variables.filter((v) => v.access === \"constant\");\n\n if (constants.length === 0) {\n return \"\";\n }\n\n const constMethods = constants.map((constant) => {\n const methodName = toCamelCase(constant.name);\n const valueType = getTypeForArg({ type: constant.type });\n\n return `${methodName}: {\n async get(options?: { network?: 'mainnet' | 'testnet' | 'devnet' }): Promise<${valueType}> {\n try {\n const { cvToJSON, deserializeCV } = await import('@secondlayer/stacks/clarity');\n const baseUrl = getApiUrl('${address}', options?.network);\n\n const response = await fetch(\n \\`\\${baseUrl}/v2/constant_val/${address}/${contractName}/${constant.name}?proof=0\\`\n );\n\n if (!response.ok) {\n throw new Error(\\`HTTP \\${response.status}: \\${response.statusText}\\`);\n }\n\n const result = await response.json();\n const cv = deserializeCV(result.data);\n const parsed = cvToJSON(cv);\n return parsed.value ?? parsed;\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\\`Constant access failed for '${constant.name}': \\${error.message}\\`);\n }\n throw error;\n }\n },\n type: ${JSON.stringify(constant.type)} as const\n }`;\n });\n\n return `constants: {\n ${constMethods.join(\",\\n\\n \")}\n }`;\n}\n\n",
11
11
  "/**\n * Shared type mapping utility for Clarity types to TypeScript types\n *\n * This module provides a single, consistent implementation for mapping\n * Clarity types to their TypeScript equivalents, used across all generators.\n */\n\nimport {\n toCamelCase,\n isAbiList,\n isAbiTuple,\n isAbiOptional,\n isAbiResponse,\n isAbiBuffer,\n isAbiStringAscii,\n isAbiStringUtf8,\n type AbiType,\n} from \"@secondlayer/stacks/clarity\";\n\n/**\n * Map a Clarity type to its TypeScript type string representation\n *\n * @param type - The Clarity type definition from an ABI\n * @returns The TypeScript type string (e.g., \"bigint\", \"string\", \"{ field: bigint }\")\n */\nexport function clarityTypeToTS(type: AbiType): string {\n // Handle string primitive types\n if (typeof type === \"string\") {\n switch (type) {\n case \"uint128\":\n case \"int128\":\n return \"bigint\";\n case \"bool\":\n return \"boolean\";\n case \"principal\":\n case \"trait_reference\":\n return \"string\";\n default: {\n // Handle shorthand string formats (e.g., \"string-ascii\", \"string-utf8\", \"buff\")\n // Cast to string since TypeScript narrows to never in exhaustive switches\n const typeStr = type as string;\n // Handle \"none\" type (commonly used in response types)\n if (typeStr === \"none\") {\n return \"null\";\n }\n if (typeStr.includes(\"string\") || typeStr.includes(\"ascii\") || typeStr.includes(\"utf8\")) {\n return \"string\";\n }\n if (typeStr.includes(\"buff\")) {\n return \"Uint8Array | string | { type: 'ascii' | 'utf8' | 'hex'; value: string }\";\n }\n if (typeStr.includes(\"uint\") || typeStr.includes(\"int\")) {\n return \"bigint\";\n }\n return \"any\";\n }\n }\n }\n\n // Handle buffer types - support flexible input\n if (isAbiBuffer(type)) {\n return \"Uint8Array | string | { type: 'ascii' | 'utf8' | 'hex'; value: string }\";\n }\n\n // Handle string types\n if (isAbiStringAscii(type) || isAbiStringUtf8(type)) {\n return \"string\";\n }\n\n // Handle optional types\n if (isAbiOptional(type)) {\n const innerType = clarityTypeToTS(type.optional);\n // Wrap union types in parentheses for correct precedence\n if (innerType.includes(\" | \") && !innerType.startsWith(\"(\")) {\n return `(${innerType}) | null`;\n }\n return `${innerType} | null`;\n }\n\n // Handle list types\n if (isAbiList(type)) {\n const innerType = clarityTypeToTS(type.list.type);\n // Wrap union types in parentheses for correct precedence\n if (innerType.includes(\" | \") && !innerType.startsWith(\"(\")) {\n return `(${innerType})[]`;\n }\n return `${innerType}[]`;\n }\n\n // Handle tuple types\n if (isAbiTuple(type)) {\n const fields = type.tuple\n .map((field) => `${toCamelCase(field.name)}: ${clarityTypeToTS(field.type)}`)\n .join(\"; \");\n return `{ ${fields} }`;\n }\n\n // Handle response types\n if (isAbiResponse(type)) {\n const okType = clarityTypeToTS(type.response.ok);\n const errType = clarityTypeToTS(type.response.error);\n return `{ ok: ${okType} } | { err: ${errType} }`;\n }\n\n // Fallback for unknown types\n return \"any\";\n}\n\n/**\n * Map a Clarity argument definition to its TypeScript type\n * This is a convenience wrapper that extracts the type from an argument object\n *\n * @param arg - An argument object with a `type` property\n * @returns The TypeScript type string\n */\nexport function getTypeForArg(arg: { type: AbiType }): string {\n return clarityTypeToTS(arg.type);\n}\n\n/**\n * Generate a TypeScript type signature for function arguments\n *\n * @param args - Array of argument definitions with name and type\n * @returns TypeScript type string like \"{ arg1: bigint; arg2: string }\"\n */\nexport function generateArgsTypeSignature(\n args: readonly { name: string; type: AbiType }[]\n): string {\n if (args.length === 0) return \"void\";\n\n const argsList = args\n .map((arg) => `${toCamelCase(arg.name)}: ${clarityTypeToTS(arg.type)}`)\n .join(\"; \");\n return `{ ${argsList} }`;\n}\n",
12
12
  "/**\n * Shared code-generation utility for converting TypeScript values to ClarityValue expressions.\n * Used by contract, actions, and testing generators.\n */\n\nimport {\n toCamelCase,\n isAbiStringAscii,\n isAbiStringUtf8,\n isAbiBuffer,\n isAbiOptional,\n isAbiList,\n isAbiTuple,\n isAbiResponse,\n type AbiType,\n} from \"@secondlayer/stacks/clarity\";\n\n/**\n * Generate a code string that converts a TypeScript value to a ClarityValue\n * based on the Clarity ABI argument type.\n */\nexport function generateClarityConversion(\n argName: string,\n argType: { type: AbiType }\n): string {\n const type = argType.type;\n\n if (typeof type === \"string\") {\n switch (type) {\n case \"uint128\":\n return `Cl.uint(${argName})`;\n case \"int128\":\n return `Cl.int(${argName})`;\n case \"bool\":\n return `Cl.bool(${argName})`;\n case \"principal\":\n case \"trait_reference\":\n return `(() => {\n const [address, contractName] = ${argName}.split(\".\") as [string, string | undefined];\n if (!validateStacksAddress(address)) {\n throw new Error(\"Invalid Stacks address format\");\n }\n if (contractName !== undefined) {\n if (!CONTRACT_NAME_REGEX.test(contractName)) {\n throw new Error(\"Invalid contract name format: must start with letter and contain only letters, numbers, and hyphens\");\n }\n return Cl.contractPrincipal(address, contractName);\n }\n return Cl.standardPrincipal(${argName});\n })()`;\n default:\n return `${argName}`;\n }\n }\n\n if (isAbiStringAscii(type)) {\n return `Cl.stringAscii(${argName})`;\n }\n\n if (isAbiStringUtf8(type)) {\n return `Cl.stringUtf8(${argName})`;\n }\n\n if (isAbiBuffer(type)) {\n return `(() => {\n const value = ${argName};\n if (value instanceof Uint8Array) {\n return Cl.buffer(value);\n }\n if (typeof value === 'object' && value !== null && value.type && value.value) {\n switch (value.type) {\n case 'ascii':\n return Cl.bufferFromAscii(value.value);\n case 'utf8':\n return Cl.bufferFromUtf8(value.value);\n case 'hex':\n return Cl.bufferFromHex(value.value);\n default:\n throw new Error(\\`Unsupported buffer type: \\${value.type}\\`);\n }\n }\n if (typeof value === 'string') {\n if (value.startsWith('0x') || /^[0-9a-fA-F]+$/.test(value)) {\n return Cl.bufferFromHex(value);\n }\n const hasNonAscii = value.split('').some(char => char.charCodeAt(0) > 127);\n if (hasNonAscii) {\n return Cl.bufferFromUtf8(value);\n }\n return Cl.bufferFromAscii(value);\n }\n throw new Error(\\`Invalid buffer value: \\${value}\\`);\n })()`;\n }\n\n if (isAbiOptional(type)) {\n const innerConversion = generateClarityConversion(argName, {\n type: type.optional,\n });\n return `${argName} !== null ? Cl.some(${innerConversion.replace(argName, `${argName}`)}) : Cl.none()`;\n }\n\n if (isAbiList(type)) {\n const innerConversion = generateClarityConversion(\"item\", {\n type: type.list.type,\n });\n const maxLength = type.list.length || 100;\n return `(() => {\n const listValue = ${argName};\n if (listValue.length > ${maxLength}) {\n throw new Error(\\`List length \\${listValue.length} exceeds max ${maxLength}\\`);\n }\n return Cl.list(listValue.map(item => ${innerConversion}));\n })()`;\n }\n\n if (isAbiTuple(type)) {\n const requiredFields = type.tuple.map((f) => f.name);\n const fieldNames = JSON.stringify(requiredFields);\n const fields = type.tuple\n .map((field) => {\n const camelFieldName = toCamelCase(field.name);\n const fieldConversion = generateClarityConversion(\n `tupleValue.${camelFieldName}`,\n { type: field.type }\n );\n return `\"${field.name}\": ${fieldConversion}`;\n })\n .join(\", \");\n return `(() => {\n const tupleValue = ${argName};\n const requiredFields = ${fieldNames};\n for (const fieldName of requiredFields) {\n const camelName = fieldName.replace(/-([a-z])/g, (_: string, l: string) => l.toUpperCase());\n if (!(fieldName in tupleValue) && !(camelName in tupleValue)) {\n throw new Error(\\`Missing tuple field: \\${fieldName}\\`);\n }\n }\n return Cl.tuple({ ${fields} });\n })()`;\n }\n\n if (isAbiResponse(type)) {\n const okConversion = generateClarityConversion(`responseValue.ok`, {\n type: type.response.ok,\n });\n const errConversion = generateClarityConversion(`responseValue.err`, {\n type: type.response.error,\n });\n return `(() => {\n const responseValue = ${argName};\n const hasOk = 'ok' in responseValue;\n const hasErr = 'err' in responseValue;\n if (hasOk && !hasErr) {\n return Cl.ok(${okConversion});\n }\n if (hasErr && !hasOk) {\n return Cl.error(${errConversion});\n }\n throw new Error(\"Response must have exactly 'ok' or 'err' property\");\n })()`;\n }\n\n return `${argName}`;\n}\n",
13
+ "/**\n * Shared utilities for plugin code generators (actions, testing).\n */\n\nimport { toCamelCase, isAbiTuple, type FunctionArg, type AbiType } from \"@secondlayer/stacks/clarity\";\nimport { getTypeForArg } from \"./type-mapping\";\nimport { generateClarityConversion } from \"./clarity-conversion\";\n\n/**\n * Generate a TypeScript args signature for a helper function.\n * e.g. `args: { amount: bigint; recipient: string }, `\n */\nexport function generateArgsSignature(args: ReadonlyArray<FunctionArg>): string {\n if (args.length === 0) return \"\";\n\n const argsTypes = args\n .map((arg) => {\n const camelName = toCamelCase(arg.name);\n return `${camelName}: ${getTypeForArg(arg)}`;\n })\n .join(\"; \");\n\n return `args: { ${argsTypes} }, `;\n}\n\n/**\n * Generate Clarity argument expressions for function calls.\n * e.g. `Cl.uint(args.amount), Cl.standardPrincipal(args.recipient)`\n */\nexport function generateClarityArgs(args: ReadonlyArray<FunctionArg>): string {\n if (args.length === 0) return \"\";\n\n return args\n .map((arg) => {\n const argName = `args.${toCamelCase(arg.name)}`;\n return generateClarityConversion(argName, arg);\n })\n .join(\", \");\n}\n\n/**\n * Generate Clarity conversion for a map key (tuple or simple type).\n */\nexport function generateMapKeyConversion(keyType: AbiType): string {\n if (isAbiTuple(keyType)) {\n const fields = keyType.tuple\n .map((field) => {\n const camelFieldName = toCamelCase(field.name);\n const fieldConversion = generateClarityConversion(\n `key.${camelFieldName}`,\n { type: field.type }\n );\n return `\"${field.name}\": ${fieldConversion}`;\n })\n .join(\", \");\n return `Cl.tuple({ ${fields} })`;\n }\n return generateClarityConversion(\"key\", { type: keyType });\n}\n",
13
14
  "/**\n * ABI compatibility layer for normalizing different ABI formats\n *\n * Handles differences between:\n * - Upstream ClarityAbi types (uses `buffer`, `read_only`)\n * - Internal format (uses `buff`, `read-only`)\n */\n\nimport type {\n AbiContract,\n AbiFunction,\n AbiMap,\n AbiVariable,\n AbiType,\n} from \"@secondlayer/stacks/clarity\";\n\n/**\n * Normalize function access type from various formats to internal format\n */\nexport function normalizeAccess(\n access: string\n): \"public\" | \"read-only\" | \"private\" {\n if (access === \"read_only\") return \"read-only\";\n return access as \"public\" | \"read-only\" | \"private\";\n}\n\n/**\n * Normalize a Clarity type from API format to internal format\n * Handles buffer vs buff, and recursively normalizes nested types\n */\nexport function normalizeType(type: unknown): AbiType {\n if (typeof type === \"string\") {\n // Handle string primitive types\n switch (type) {\n case \"uint128\":\n case \"int128\":\n case \"bool\":\n case \"principal\":\n case \"trait_reference\":\n return type;\n default:\n // Unknown string type, return as-is\n return type as AbiType;\n }\n }\n\n if (typeof type !== \"object\" || type === null) {\n throw new Error(`Invalid ABI type: expected object, got ${typeof type}`);\n }\n\n const typeObj = type as Record<string, unknown>;\n\n // Handle buffer vs buff (API uses buffer, we use buff)\n if (\"buffer\" in typeObj) {\n const buffer = typeObj.buffer as { length?: number };\n return {\n buff: {\n length: buffer?.length ?? 32,\n },\n };\n }\n\n // Already in internal format\n if (\"buff\" in typeObj) {\n const buff = typeObj.buff as { length?: number };\n return {\n buff: {\n length: buff?.length ?? 32,\n },\n };\n }\n\n // String types\n if (\"string-ascii\" in typeObj) {\n const strAscii = typeObj[\"string-ascii\"] as { length?: number };\n return {\n \"string-ascii\": {\n length: strAscii?.length ?? 256,\n },\n };\n }\n\n if (\"string-utf8\" in typeObj) {\n const strUtf8 = typeObj[\"string-utf8\"] as { length?: number };\n return {\n \"string-utf8\": {\n length: strUtf8?.length ?? 256,\n },\n };\n }\n\n // Response type - recursively normalize ok and error types\n if (\"response\" in typeObj) {\n const response = typeObj.response as { ok?: unknown; error?: unknown };\n return {\n response: {\n ok: normalizeType(response?.ok ?? \"bool\"),\n error: normalizeType(response?.error ?? \"uint128\"),\n },\n };\n }\n\n // Optional type - recursively normalize inner type\n if (\"optional\" in typeObj) {\n return {\n optional: normalizeType(typeObj.optional),\n };\n }\n\n // List type - recursively normalize element type\n if (\"list\" in typeObj) {\n const list = typeObj.list as { type?: unknown; length?: number };\n return {\n list: {\n type: normalizeType(list?.type ?? \"uint128\"),\n length: list?.length ?? 100,\n },\n };\n }\n\n // Tuple type - recursively normalize field types\n if (\"tuple\" in typeObj) {\n const tuple = typeObj.tuple as Array<{ name: string; type: unknown }>;\n return {\n tuple: tuple.map((field) => ({\n name: field.name,\n type: normalizeType(field.type),\n })),\n };\n }\n\n // Unknown type - fail explicitly\n throw new Error(`Unknown ABI type structure: ${JSON.stringify(type)}`);\n}\n\n/**\n * Normalize a function definition from API format to internal format\n */\nexport function normalizeFunction(func: Record<string, unknown>): AbiFunction {\n const access = normalizeAccess(func.access as string);\n const args = (func.args as Array<{ name: string; type: unknown }>) ?? [];\n const outputs = func.outputs as { type?: unknown } | unknown;\n\n return {\n name: func.name as string,\n access,\n args: args.map((arg) => ({\n name: arg.name,\n type: normalizeType(arg.type),\n })),\n outputs: normalizeType(\n typeof outputs === \"object\" && outputs !== null && \"type\" in outputs\n ? (outputs as { type: unknown }).type\n : outputs\n ),\n };\n}\n\n/**\n * Normalize a map definition from API format to internal format\n */\nexport function normalizeMap(map: Record<string, unknown>): AbiMap {\n return {\n name: map.name as string,\n key: normalizeType(map.key),\n value: normalizeType(map.value),\n };\n}\n\n/**\n * Normalize a variable definition from API format to internal format\n */\nexport function normalizeVariable(\n variable: Record<string, unknown>\n): AbiVariable {\n return {\n name: variable.name as string,\n type: normalizeType(variable.type),\n access: variable.access as \"constant\" | \"variable\",\n };\n}\n\n/**\n * Normalize an entire ABI from various sources to consistent internal format\n *\n * This handles ABIs from:\n * - Hiro API responses\n * - Clarinet SDK\n * - Upstream @secondlayer/stacks types\n */\nexport function normalizeAbi(abi: unknown): AbiContract {\n if (typeof abi !== \"object\" || abi === null) {\n return { functions: [] };\n }\n\n const abiObj = abi as Record<string, unknown>;\n\n const functions: AbiFunction[] = [];\n const maps: AbiMap[] = [];\n const variables: AbiVariable[] = [];\n\n // Normalize functions\n if (Array.isArray(abiObj.functions)) {\n for (const func of abiObj.functions) {\n if (typeof func === \"object\" && func !== null) {\n functions.push(normalizeFunction(func as Record<string, unknown>));\n }\n }\n }\n\n // Normalize maps\n if (Array.isArray(abiObj.maps)) {\n for (const map of abiObj.maps) {\n if (typeof map === \"object\" && map !== null) {\n maps.push(normalizeMap(map as Record<string, unknown>));\n }\n }\n }\n\n // Normalize variables\n if (Array.isArray(abiObj.variables)) {\n for (const variable of abiObj.variables) {\n if (typeof variable === \"object\" && variable !== null) {\n variables.push(normalizeVariable(variable as Record<string, unknown>));\n }\n }\n }\n\n return {\n functions,\n maps: maps.length > 0 ? maps : undefined,\n variables: variables.length > 0 ? variables : undefined,\n };\n}\n",
14
15
  "/**\n * Action generators for read and write helper functions\n */\n\nimport type { ProcessedContract } from \"../../types/plugin\";\nimport { toCamelCase, type AbiFunction } from \"@secondlayer/stacks/clarity\";\nimport type { ActionsPluginOptions } from \"./index\";\nimport { generateArgsSignature, generateClarityArgs } from \"../../utils/generator-helpers\";\n\n\n/**\n * Generate read helper functions for a contract (fixed version)\n */\nfunction generateReadHelpers(\n contract: ProcessedContract,\n options: ActionsPluginOptions\n): string {\n const { abi } = contract;\n const functions = abi.functions || [];\n\n const readOnlyFunctions = functions.filter(\n (f: AbiFunction) =>\n f.access === \"read-only\"\n );\n\n if (readOnlyFunctions.length === 0) {\n return \"\";\n }\n\n // Apply function filters\n const filteredFunctions = readOnlyFunctions.filter(\n (func: AbiFunction) => {\n if (\n options.includeFunctions &&\n !options.includeFunctions.includes(func.name)\n ) {\n return false;\n }\n if (\n options.excludeFunctions &&\n options.excludeFunctions.includes(func.name)\n ) {\n return false;\n }\n return true;\n }\n );\n\n if (filteredFunctions.length === 0) {\n return \"\";\n }\n\n const helpers = filteredFunctions.map((func: AbiFunction) => {\n const methodName = toCamelCase(func.name);\n const argsSignature = generateArgsSignature(func.args);\n const clarityArgs = generateClarityArgs(func.args);\n\n return `async ${methodName}(${argsSignature}options?: {\n network?: 'mainnet' | 'testnet' | 'devnet';\n senderAddress?: string;\n }) {\n return await fetchCallReadOnlyFunction({\n contractAddress: '${contract.address}',\n contractName: '${contract.contractName}',\n functionName: '${func.name}',\n functionArgs: [${clarityArgs}],\n network: options?.network ?? inferNetworkFromAddress('${contract.address}') ?? 'mainnet',\n senderAddress: options?.senderAddress || 'SP000000000000000000002Q6VF78'\n });\n }`;\n });\n\n return `read: {\n ${helpers.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate write helper functions for a contract (fixed version)\n */\nfunction generateWriteHelpers(\n contract: ProcessedContract,\n options: ActionsPluginOptions\n): string {\n const { abi } = contract;\n const functions = abi.functions || [];\n const envVarName = options.senderKeyEnv ?? \"STX_SENDER_KEY\";\n\n const publicFunctions = functions.filter(\n (f: AbiFunction) => f.access === \"public\"\n );\n\n if (publicFunctions.length === 0) {\n return \"\";\n }\n\n // Apply function filters\n const filteredFunctions = publicFunctions.filter((func: AbiFunction) => {\n if (\n options.includeFunctions &&\n !options.includeFunctions.includes(func.name)\n ) {\n return false;\n }\n if (\n options.excludeFunctions &&\n options.excludeFunctions.includes(func.name)\n ) {\n return false;\n }\n return true;\n });\n\n if (filteredFunctions.length === 0) {\n return \"\";\n }\n\n const helpers = filteredFunctions.map((func: AbiFunction) => {\n const methodName = toCamelCase(func.name);\n const argsSignature = generateArgsSignature(func.args);\n const clarityArgs = generateClarityArgs(func.args);\n\n return `async ${methodName}(${argsSignature}senderKey?: string, options?: {\n network?: 'mainnet' | 'testnet' | 'devnet';\n fee?: string | number | undefined;\n nonce?: bigint;\n anchorMode?: 1 | 2 | 3; // AnchorMode: OnChainOnly = 1, OffChainOnly = 2, Any = 3\n postConditions?: PostCondition[];\n validateWithAbi?: boolean;\n }) {\n const resolvedSenderKey = senderKey ?? process.env.${envVarName};\n if (!resolvedSenderKey) {\n throw new Error('senderKey required: pass as argument or set ${envVarName} env var');\n }\n const { network = 'mainnet', ...txOptions } = options ?? {};\n\n return await makeContractCall({\n contractAddress: '${contract.address}',\n contractName: '${contract.contractName}',\n functionName: '${func.name}',\n functionArgs: [${clarityArgs}],\n senderKey: resolvedSenderKey,\n network,\n validateWithAbi: true,\n ...txOptions\n });\n }`;\n });\n\n return `write: {\n ${helpers.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate action helpers (read and write functions) for a contract\n */\nexport async function generateActionHelpers(\n contract: ProcessedContract,\n options: ActionsPluginOptions\n): Promise<string> {\n const readHelpers = generateReadHelpers(contract, options);\n const writeHelpers = generateWriteHelpers(contract, options);\n\n if (!readHelpers && !writeHelpers) {\n return \"\";\n }\n\n const helpers = [readHelpers, writeHelpers].filter(Boolean);\n return helpers.join(\",\\n\\n\");\n}\n",
15
- "/**\n * Shared utilities for plugin code generators (actions, testing).\n */\n\nimport { toCamelCase, type FunctionArg } from \"@secondlayer/stacks/clarity\";\nimport { getTypeForArg } from \"./type-mapping\";\nimport { generateClarityConversion } from \"./clarity-conversion\";\n\n/**\n * Generate a TypeScript args signature for a helper function.\n * e.g. `args: { amount: bigint; recipient: string }, `\n */\nexport function generateArgsSignature(args: ReadonlyArray<FunctionArg>): string {\n if (args.length === 0) return \"\";\n\n const argsTypes = args\n .map((arg) => {\n const camelName = toCamelCase(arg.name);\n return `${camelName}: ${getTypeForArg(arg)}`;\n })\n .join(\"; \");\n\n return `args: { ${argsTypes} }, `;\n}\n\n/**\n * Generate Clarity argument expressions for function calls.\n * e.g. `Cl.uint(args.amount), Cl.standardPrincipal(args.recipient)`\n */\nexport function generateClarityArgs(args: ReadonlyArray<FunctionArg>): string {\n if (args.length === 0) return \"\";\n\n return args\n .map((arg) => {\n const argName = `args.${toCamelCase(arg.name)}`;\n return generateClarityConversion(argName, arg);\n })\n .join(\", \");\n}\n",
16
16
  "/**\n * Actions Plugin for @secondlayer/cli\n * Generates read and write helper functions for direct blockchain interaction\n */\n\nimport { generateActionHelpers } from \"./generators\";\nimport type {\n PluginFactory,\n // UserConfig,\n GenerateContext,\n} from \"../../types/plugin\";\n\nexport interface ActionsPluginOptions {\n /** Include only specific contracts */\n include?: string[];\n\n /** Exclude specific contracts */\n exclude?: string[];\n\n /** Include only specific functions */\n includeFunctions?: string[];\n\n /** Exclude specific functions */\n excludeFunctions?: string[];\n\n /** Enable debug output */\n debug?: boolean;\n\n /** Environment variable name for default sender key (default: \"STX_SENDER_KEY\") */\n senderKeyEnv?: string;\n}\n\n/**\n * Actions plugin factory\n */\nexport const actions: PluginFactory<ActionsPluginOptions> = (options = {}) => {\n return {\n name: \"@secondlayer/cli/plugin-actions\",\n version: \"1.0.0\",\n\n async generate(context: GenerateContext): Promise<void> {\n const { contracts } = context;\n\n // Filter contracts based on options\n const filteredContracts = contracts.filter((contract) => {\n if (options.include && !options.include.includes(contract.name)) {\n return false;\n }\n if (options.exclude && options.exclude.includes(contract.name)) {\n return false;\n }\n return true;\n });\n\n if (filteredContracts.length === 0) {\n if (options.debug) {\n context.logger.debug(\"Actions plugin: No contracts to process\");\n }\n return;\n }\n\n if (options.debug) {\n context.logger.debug(\n `Actions plugin: Generating read/write helpers for ${filteredContracts.length} contracts`\n );\n }\n\n // Collect all helpers for all contracts\n const contractHelpers = new Map<string, string>();\n\n for (const contract of filteredContracts) {\n const actionsCode = await generateActionHelpers(contract, options);\n if (actionsCode) {\n contractHelpers.set(contract.name, actionsCode);\n }\n }\n\n // Inject all helpers into the output\n if (contractHelpers.size > 0) {\n const existingOutput = context.outputs.get(\"contracts\");\n if (existingOutput) {\n let modifiedContent = addRequiredImports(existingOutput.content);\n\n // Inject helpers for each contract\n for (const [contractName, helpersCode] of contractHelpers) {\n modifiedContent = injectHelpersIntoContract(\n modifiedContent,\n contractName,\n helpersCode\n );\n }\n\n context.outputs.set(\"contracts\", {\n ...existingOutput,\n content: modifiedContent,\n });\n }\n }\n },\n };\n};\n\n/**\n * Add required imports for fetchCallReadOnlyFunction, makeContractCall, and PostCondition\n */\nfunction addRequiredImports(content: string): string {\n // Find the existing @secondlayer/stacks import line\n const stacksImportRegex =\n /import\\s+\\{([^}]+)\\}\\s+from\\s+['\"]@secondlayer\\/stacks['\"];/;\n const match = content.match(stacksImportRegex);\n\n if (match) {\n let updatedContent = content;\n\n // Add fetchCallReadOnlyFunction and makeContractCall from @secondlayer/stacks/clarity\n if (!updatedContent.includes(\"fetchCallReadOnlyFunction\")) {\n updatedContent = updatedContent.replace(\n stacksImportRegex,\n `${match[0]}\\nimport { fetchCallReadOnlyFunction, makeContractCall } from '@secondlayer/stacks/clarity';`\n );\n }\n\n // Add type import for PostCondition if not present\n if (!updatedContent.includes(\"type PostCondition\")) {\n updatedContent = updatedContent.replace(\n stacksImportRegex,\n `${match[0]}\\nimport type { PostCondition } from '@secondlayer/stacks';`\n );\n }\n\n return updatedContent;\n }\n\n return content;\n}\n\n/**\n * Inject read/write helpers into a specific contract object in the output\n */\nfunction injectHelpersIntoContract(\n content: string,\n contractName: string,\n helpersCode: string\n): string {\n // Use a more precise regex to find the entire contract object\n const contractPattern = new RegExp(\n `(export const ${contractName} = \\\\{[\\\\s\\\\S]*?)\\\\n\\\\} as const;`,\n \"g\"\n );\n\n return content.replace(contractPattern, (_, contractBody) => {\n // Remove any trailing comma and whitespace from the contract body\n const cleanBody = contractBody.replace(/,\\s*$/, \"\");\n\n // Add proper indentation to lines that start top-level properties\n const indentedHelpersCode = helpersCode\n .split(\"\\n\")\n .map((line) => {\n // Only add indentation to lines that start with a property name (like \"write:\")\n if (line.match(/^[a-zA-Z_$][a-zA-Z0-9_$]*\\s*:/)) {\n return ` ${line}`;\n }\n return line;\n })\n .join(\"\\n\");\n\n // Add the helpers with proper formatting\n return `${cleanBody},\n\n${indentedHelpersCode}\n} as const;`;\n });\n}\n",
17
17
  "/**\n * Provider generator for React plugin\n */\n\nimport { formatCode } from \"../../../utils/format\";\n\n/**\n * Generate the provider file content for user projects\n */\nexport async function generateProvider(): Promise<string> {\n const code = `/**\n * Generated SecondLayer React Provider\n * DO NOT EDIT MANUALLY\n */\n\nimport React, { createContext, useContext } from 'react'\n\n/**\n * SecondLayer configuration interface\n */\nexport interface SecondLayerReactConfig {\n /**\n * Network to use for API calls\n */\n network: 'mainnet' | 'testnet' | 'devnet'\n\n /**\n * API key for Stacks API (optional)\n */\n apiKey?: string\n\n /**\n * Base URL for Stacks API (optional override)\n */\n apiUrl?: string\n\n /**\n * Default sender address for read-only calls\n */\n senderAddress?: string\n}\n\n/**\n * Provider component props\n */\nexport interface SecondLayerProviderProps {\n children: React.ReactNode\n config: SecondLayerReactConfig\n}\n\n/**\n * React context for SecondLayer configuration\n */\nconst SecondLayerContext = createContext<SecondLayerReactConfig | undefined>(undefined)\nSecondLayerContext.displayName = 'SecondLayerContext'\n\n/**\n * Create a SecondLayer React configuration with defaults\n */\nexport function createSecondLayerConfig(config: SecondLayerReactConfig): SecondLayerReactConfig {\n return {\n network: config.network,\n apiKey: config.apiKey,\n apiUrl: config.apiUrl,\n senderAddress: config.senderAddress || 'SP000000000000000000002Q6VF78'\n }\n}\n\n/**\n * Provider component that makes SecondLayer configuration available to hooks\n */\nexport function SecondLayerProvider({ children, config }: SecondLayerProviderProps) {\n const resolvedConfig = createSecondLayerConfig(config)\n\n return (\n <SecondLayerContext.Provider value={resolvedConfig}>\n {children}\n </SecondLayerContext.Provider>\n )\n}\n\n/**\n * Hook to access the SecondLayer configuration\n */\nexport function useSecondLayerConfig(): SecondLayerReactConfig {\n const context = useContext(SecondLayerContext)\n\n if (context === undefined) {\n throw new Error(\n 'useSecondLayerConfig must be used within a SecondLayerProvider. ' +\n 'Make sure to wrap your app with <SecondLayerProvider config={{...}}>'\n )\n }\n\n return context\n}`;\n\n return formatCode(code);\n}\n",
18
18
  "/**\n * Generic Stacks hooks generator for React plugin\n */\n\nimport { formatCode } from \"../../../utils/format\";\nimport { USE_CONTRACT_TEMPLATE } from \"../../../generators/templates/use-contract\";\n\nconst GENERIC_HOOKS = [\n \"useAccount\",\n \"useConnect\",\n \"useDisconnect\",\n \"useNetwork\",\n \"useContract\",\n \"useOpenSTXTransfer\",\n \"useSignMessage\",\n \"useDeployContract\",\n \"useReadContract\",\n \"useTransaction\",\n \"useBlock\",\n \"useAccountTransactions\",\n \"useWaitForTransaction\",\n] as const;\n\nexport async function generateGenericHooks(\n excludeList: string[] = []\n): Promise<string> {\n // Filter out excluded hooks\n const hooksToGenerate = GENERIC_HOOKS.filter(\n (hookName) => !excludeList.includes(hookName)\n );\n\n const imports = `import { useQuery, useMutation, useQueryClient } from '@tanstack/react-query'\nimport { useState, useCallback } from 'react'\nimport { useSecondLayerConfig } from './provider'\nimport { connect, disconnect, isConnected, request } from '@secondlayer/stacks/connect'\nimport { Cl, validateStacksAddress } from '@secondlayer/stacks'\nimport type { PostCondition } from '@secondlayer/stacks'\nimport type { ExtractFunctionArgs, ExtractFunctionNames, AbiContract } from '@secondlayer/stacks/clarity'\n\nconst API_URLS: Record<string, string> = {\n mainnet: 'https://api.hiro.so',\n testnet: 'https://api.testnet.hiro.so',\n devnet: 'http://localhost:3999'\n}\n\nasync function fetchTransaction({ txId, network, apiUrl }: { txId: string; network?: string; apiUrl?: string }): Promise<any> {\n const baseUrl = apiUrl || API_URLS[network || 'mainnet']\n const response = await fetch(\\`\\${baseUrl}/extended/v1/tx/\\${txId}\\`)\n if (!response.ok) throw new Error(\\`Failed to fetch transaction: \\${response.statusText}\\`)\n return response.json()\n}\n\nasync function fetchBlock({ height, network, apiUrl }: { height: number; network?: string; apiUrl?: string }): Promise<any> {\n const baseUrl = apiUrl || API_URLS[network || 'mainnet']\n const response = await fetch(\\`\\${baseUrl}/extended/v1/block/by_height/\\${height}\\`)\n if (!response.ok) throw new Error(\\`Failed to fetch block: \\${response.statusText}\\`)\n return response.json()\n}\n\nasync function fetchAccountTransactions({ address, network, apiUrl }: { address: string; network?: string; apiUrl?: string }): Promise<any> {\n const baseUrl = apiUrl || API_URLS[network || 'mainnet']\n const response = await fetch(\\`\\${baseUrl}/extended/v1/address/\\${address}/transactions\\`)\n if (!response.ok) throw new Error(\\`Failed to fetch transactions: \\${response.statusText}\\`)\n return response.json()\n}`;\n\n const header = `/**\n * Generated generic Stacks React hooks\n * DO NOT EDIT MANUALLY\n */`;\n\n const hooksCode = hooksToGenerate\n .map((hookName) => generateGenericHook(hookName))\n .filter(Boolean)\n .join(\"\\n\\n\");\n\n const code = `${imports}\\n\\n${header}\\n\\n${hooksCode}`;\n\n return formatCode(code);\n}\n\nfunction generateGenericHook(hookName: string): string {\n switch (hookName) {\n case \"useAccount\":\n return `export function useAccount() {\n const config = useSecondLayerConfig()\n \n return useQuery({\n queryKey: ['stacks-account', config.network],\n queryFn: async () => {\n try {\n // Check if already connected\n const connected = isConnected()\n \n if (!connected) {\n return {\n address: undefined,\n addresses: undefined,\n isConnected: false,\n isConnecting: false,\n isDisconnected: true,\n status: 'disconnected' as const\n }\n }\n\n // Get addresses via SIP-030\n const result = await request('stx_getAddresses')\n \n if (!result || !result.addresses || result.addresses.length === 0) {\n return {\n address: undefined,\n addresses: undefined,\n isConnected: false,\n isConnecting: false,\n isDisconnected: true,\n status: 'disconnected' as const\n }\n }\n\n // Extract STX addresses from the response\n const stxAddresses = result.addresses\n .filter((addr: any) => addr.address.startsWith('SP') || addr.address.startsWith('ST'))\n .map((addr: any) => addr.address)\n\n return {\n address: stxAddresses[0] || undefined,\n addresses: stxAddresses,\n isConnected: true,\n isConnecting: false,\n isDisconnected: false,\n status: 'connected' as const\n }\n } catch (error) {\n // Handle case where wallet is not available or user rejected\n return {\n address: undefined,\n addresses: undefined,\n isConnected: false,\n isConnecting: false,\n isDisconnected: true,\n status: 'disconnected' as const\n }\n }\n },\n refetchOnWindowFocus: false,\n retry: false,\n staleTime: 1000 * 60 * 5, // 5 minutes\n refetchInterval: 1000 * 30, // Refetch every 30 seconds to detect wallet changes\n })\n}`;\n\n case \"useConnect\":\n return `export function useConnect() {\n const queryClient = useQueryClient()\n \n const mutation = useMutation({\n mutationFn: async (options: { forceWalletSelect?: boolean } = {}) => {\n // SIP-030 connect\n return await connect(options)\n },\n onSuccess: () => {\n // Invalidate account queries to refetch connection state\n queryClient.invalidateQueries({ queryKey: ['stacks-account'] })\n },\n onError: (error) => {\n console.error('Connection failed:', error)\n }\n })\n\n return {\n // Custom connect function that works without arguments\n connect: (options?: { forceWalletSelect?: boolean }) => {\n return mutation.mutate(options || {})\n },\n connectAsync: async (options?: { forceWalletSelect?: boolean }) => {\n return mutation.mutateAsync(options || {})\n },\n // Expose all the mutation state\n isPending: mutation.isPending,\n isError: mutation.isError,\n isSuccess: mutation.isSuccess,\n error: mutation.error,\n data: mutation.data,\n reset: mutation.reset,\n // Keep the original mutate/mutateAsync for advanced users\n mutate: mutation.mutate,\n mutateAsync: mutation.mutateAsync\n }\n}`;\n\n case \"useDisconnect\":\n return `export function useDisconnect() {\n const queryClient = useQueryClient()\n \n const mutation = useMutation({\n mutationFn: async () => {\n // SIP-030 disconnect\n return await disconnect()\n },\n onSuccess: () => {\n // Clear all cached data on disconnect\n queryClient.clear()\n },\n onError: (error) => {\n console.error('Disconnect failed:', error)\n }\n })\n\n return {\n // Custom disconnect function\n disconnect: () => {\n return mutation.mutate()\n },\n disconnectAsync: async () => {\n return mutation.mutateAsync()\n },\n // Expose all the mutation state\n isPending: mutation.isPending,\n isError: mutation.isError,\n isSuccess: mutation.isSuccess,\n error: mutation.error,\n data: mutation.data,\n reset: mutation.reset,\n // Keep the original mutate/mutateAsync for advanced users\n mutate: mutation.mutate,\n mutateAsync: mutation.mutateAsync\n }\n}`;\n\n case \"useNetwork\":\n return `export function useNetwork() {\n const config = useSecondLayerConfig()\n \n return useQuery({\n queryKey: ['stacks-network', config.network],\n queryFn: async () => {\n // Currently read-only from config\n // Future: Use request('stx_getNetworks') when wallet support improves\n const network = config.network\n \n return {\n network,\n isMainnet: network === 'mainnet',\n isTestnet: network === 'testnet', \n isDevnet: network === 'devnet',\n // Future: Add switchNetwork when wallets support stx_networkChange\n // switchNetwork: async (newNetwork: string) => {\n // return await request('wallet_changeNetwork', { network: newNetwork })\n // }\n }\n },\n staleTime: Infinity, // Network config rarely changes\n refetchOnWindowFocus: false,\n retry: false\n })\n}`;\n\n case \"useContract\":\n return USE_CONTRACT_TEMPLATE;\n\n case \"useReadContract\":\n return `export function useReadContract<TArgs = any, TResult = any>(params: {\n contractAddress: string;\n contractName: string;\n functionName: string;\n args?: TArgs;\n network?: 'mainnet' | 'testnet' | 'devnet';\n enabled?: boolean;\n}) {\n const config = useSecondLayerConfig()\n \n return useQuery<TResult>({\n queryKey: ['read-contract', params.contractAddress, params.contractName, params.functionName, params.args, params.network || config.network],\n queryFn: async () => {\n const { fetchCallReadOnlyFunction } = await import('@secondlayer/stacks/clarity')\n \n // For now, we'll need to handle the args conversion here\n // In the future, we could integrate with the contract interface for automatic conversion\n let functionArgs: any[] = []\n \n if (params.args) {\n // This is a simplified conversion - in practice, we'd need the ABI to do proper conversion\n // For now, we'll assume the args are already in the correct format or simple types\n if (Array.isArray(params.args)) {\n functionArgs = params.args\n } else if (typeof params.args === 'object') {\n // Convert object args to array (this is a basic implementation)\n functionArgs = Object.values(params.args)\n } else {\n functionArgs = [params.args]\n }\n }\n \n return await fetchCallReadOnlyFunction({\n contractAddress: params.contractAddress,\n contractName: params.contractName,\n functionName: params.functionName,\n functionArgs,\n network: params.network || config.network || 'mainnet',\n senderAddress: config.senderAddress || 'SP000000000000000000002Q6VF78'\n }) as TResult\n },\n enabled: params.enabled ?? true\n })\n}`;\n\n case \"useTransaction\":\n return `export function useTransaction(txId?: string) {\n const config = useSecondLayerConfig()\n \n return useQuery({\n queryKey: ['transaction', txId, config.network],\n queryFn: () => fetchTransaction({\n txId: txId!,\n network: config.network,\n apiUrl: config.apiUrl\n }),\n enabled: !!txId\n })\n}`;\n\n case \"useBlock\":\n return `export function useBlock(height?: number) {\n const config = useSecondLayerConfig()\n \n return useQuery({\n queryKey: ['block', height, config.network],\n queryFn: () => fetchBlock({\n height: height!,\n network: config.network,\n apiUrl: config.apiUrl\n }),\n enabled: typeof height === 'number'\n })\n}`;\n\n case \"useAccountTransactions\":\n return `export function useAccountTransactions(address?: string) {\n const config = useSecondLayerConfig()\n \n return useQuery({\n queryKey: ['account-transactions', address, config.network],\n queryFn: () => fetchAccountTransactions({\n address: address!,\n network: config.network,\n apiUrl: config.apiUrl\n }),\n enabled: !!address\n })\n}`;\n\n case \"useWaitForTransaction\":\n return `export function useWaitForTransaction(txId?: string) {\n const config = useSecondLayerConfig()\n \n return useQuery({\n queryKey: ['wait-for-transaction', txId, config.network],\n queryFn: () => fetchTransaction({\n txId: txId!,\n network: config.network,\n apiUrl: config.apiUrl\n }),\n enabled: !!txId,\n refetchInterval: (data) => {\n // Stop polling when transaction is complete\n if (data?.tx_status === 'success' || \n data?.tx_status === 'abort_by_response' || \n data?.tx_status === 'abort_by_post_condition') {\n return false\n }\n return 2000 // Poll every 2 seconds\n },\n staleTime: 0 // Always refetch\n })\n}`;\n\n case \"useOpenSTXTransfer\":\n return `export function useOpenSTXTransfer() {\n const config = useSecondLayerConfig()\n const queryClient = useQueryClient()\n\n const mutation = useMutation({\n mutationFn: async (params: {\n recipient: string;\n amount: string | number;\n memo?: string;\n network?: string;\n }) => {\n const { recipient, amount, memo } = params\n const network = params.network || config.network || 'mainnet'\n\n return await request('stx_transferStx', {\n recipient,\n amount: amount.toString(),\n memo,\n network,\n })\n },\n onSuccess: () => {\n queryClient.invalidateQueries({ queryKey: ['stacks-account'] })\n },\n onError: (error) => {\n console.error('STX transfer failed:', error)\n }\n })\n\n const openSTXTransfer = useCallback(async (params: {\n recipient: string;\n amount: string | number;\n memo?: string;\n network?: string;\n }) => {\n return mutation.mutateAsync(params)\n }, [mutation])\n\n return {\n openSTXTransfer,\n isPending: mutation.isPending,\n isError: mutation.isError,\n isSuccess: mutation.isSuccess,\n error: mutation.error,\n data: mutation.data,\n reset: mutation.reset\n }\n}`;\n\n case \"useSignMessage\":\n return `export function useSignMessage() {\n const config = useSecondLayerConfig()\n\n const mutation = useMutation({\n mutationFn: async (params: {\n message: string;\n network?: string;\n }) => {\n const { message } = params\n const network = params.network || config.network || 'mainnet'\n\n return await request('stx_signMessage', {\n message,\n network,\n })\n },\n onError: (error) => {\n console.error('Message signing failed:', error)\n }\n })\n\n const signMessage = useCallback(async (params: {\n message: string;\n network?: string;\n }) => {\n return mutation.mutateAsync(params)\n }, [mutation])\n\n return {\n signMessage,\n isPending: mutation.isPending,\n isError: mutation.isError,\n isSuccess: mutation.isSuccess,\n error: mutation.error,\n data: mutation.data,\n reset: mutation.reset\n }\n}`;\n\n case \"useDeployContract\":\n return `export function useDeployContract() {\n const config = useSecondLayerConfig()\n const queryClient = useQueryClient()\n\n const mutation = useMutation({\n mutationFn: async (params: {\n contractName: string;\n codeBody: string;\n network?: string;\n }) => {\n const { contractName, codeBody } = params\n const network = params.network || config.network || 'mainnet'\n\n return await request('stx_deployContract', {\n name: contractName,\n clarityCode: codeBody,\n network,\n })\n },\n onSuccess: () => {\n queryClient.invalidateQueries({ queryKey: ['stacks-account'] })\n },\n onError: (error) => {\n console.error('Contract deployment failed:', error)\n }\n })\n\n const deployContract = useCallback(async (params: {\n contractName: string;\n codeBody: string;\n network?: string;\n }) => {\n return mutation.mutateAsync(params)\n }, [mutation])\n\n return {\n deployContract,\n isPending: mutation.isPending,\n isError: mutation.isError,\n isSuccess: mutation.isSuccess,\n error: mutation.error,\n data: mutation.data,\n reset: mutation.reset\n }\n}`;\n\n default:\n return \"\";\n }\n}\n",
@@ -20,11 +20,11 @@
20
20
  "/**\n * Contract-specific hooks generator for React plugin\n */\n\nimport type { ProcessedContract } from \"../../../types/plugin\";\nimport { formatCode } from \"../../../utils/format\";\nimport type { AbiFunction } from \"@secondlayer/stacks/clarity\";\nimport {\n toCamelCase,\n capitalize,\n generateHookArgsSignature,\n generateArgsType,\n generateArgNames,\n generateEnabledCondition,\n generateObjectArgs,\n clarityTypeToTS,\n} from \"./utils\";\nimport type { AbiMap, AbiVariable } from \"@secondlayer/stacks/clarity\";\n\nexport async function generateContractHooks(\n contracts: ProcessedContract[],\n excludeList: string[] = []\n): Promise<string> {\n const imports = `import { useQuery, useMutation, useQueryClient } from '@tanstack/react-query'\nimport { useCallback } from 'react'\nimport { useSecondLayerConfig } from './provider'\nimport { request } from '@secondlayer/stacks/connect'\nimport type { PostCondition } from '@secondlayer/stacks'\nimport { ${contracts.map((c) => c.name).join(\", \")} } from './contracts'`;\n\n const header = `/**\n * Generated contract-specific React hooks\n * DO NOT EDIT MANUALLY\n */`;\n\n const hooksCode = contracts\n .map((contract) => generateContractHookMethods(contract, excludeList))\n .filter(Boolean)\n .join(\"\\n\\n\");\n\n const code = `${imports}\\n\\n${header}\\n\\n${hooksCode}`;\n\n return formatCode(code);\n}\n\nfunction generateContractHookMethods(\n contract: ProcessedContract,\n excludeList: string[]\n): string {\n const { abi, name, address, contractName } = contract;\n const functions = abi.functions || [];\n const maps = abi.maps || [];\n const variables = abi.variables || [];\n\n const readOnlyFunctions = functions.filter(\n (f: AbiFunction) =>\n f.access === \"read-only\"\n );\n const publicFunctions = functions.filter(\n (f: AbiFunction) => f.access === \"public\"\n );\n\n const readHooks = readOnlyFunctions\n .map((func: AbiFunction) => {\n const hookName = `use${capitalize(name)}${capitalize(toCamelCase(func.name))}`;\n // Check if this specific hook is excluded\n if (excludeList.includes(hookName)) {\n return null;\n }\n return generateReadHook(func, name);\n })\n .filter(Boolean);\n\n const writeHooks = publicFunctions\n .map((func: AbiFunction) => {\n const hookName = `use${capitalize(name)}${capitalize(toCamelCase(func.name))}`;\n // Check if this specific hook is excluded\n if (excludeList.includes(hookName)) {\n return null;\n }\n return generateWriteHook(func, name);\n })\n .filter(Boolean);\n\n // Generate hooks for maps\n const mapHooks = maps\n .map((map: AbiMap) => {\n const hookName = `use${capitalize(name)}${capitalize(toCamelCase(map.name))}`;\n if (excludeList.includes(hookName)) {\n return null;\n }\n return generateMapHook(map, name, address, contractName);\n })\n .filter(Boolean);\n\n // Generate hooks for data variables\n const dataVars = variables.filter((v) => v.access === \"variable\");\n const varHooks = dataVars\n .map((variable: AbiVariable) => {\n const hookName = `use${capitalize(name)}${capitalize(toCamelCase(variable.name))}`;\n if (excludeList.includes(hookName)) {\n return null;\n }\n return generateVarHook(variable, name, address, contractName);\n })\n .filter(Boolean);\n\n // Generate hooks for constants\n const constants = variables.filter((v) => v.access === \"constant\");\n const constantHooks = constants\n .map((constant: AbiVariable) => {\n const hookName = `use${capitalize(name)}${capitalize(toCamelCase(constant.name))}`;\n if (excludeList.includes(hookName)) {\n return null;\n }\n return generateConstantHook(constant, name, address, contractName);\n })\n .filter(Boolean);\n\n const allHooks = [...readHooks, ...writeHooks, ...mapHooks, ...varHooks, ...constantHooks];\n\n // If all hooks for this contract are excluded, return empty string\n if (allHooks.length === 0) {\n return \"\";\n }\n\n return allHooks.join(\"\\n\\n\");\n}\n\nfunction generateReadHook(func: AbiFunction, contractName: string): string {\n const hookName = `use${capitalize(contractName)}${capitalize(toCamelCase(func.name))}`;\n const argsSignature = generateHookArgsSignature(func.args);\n const enabledParam =\n func.args.length > 0\n ? \", options?: { enabled?: boolean }\"\n : \"options?: { enabled?: boolean }\";\n\n // Generate proper return type from function outputs\n const returnType = clarityTypeToTS(func.outputs);\n\n return `export function ${hookName}(${argsSignature}${enabledParam}) {\n const config = useSecondLayerConfig()\n\n return useQuery<${returnType}>({\n queryKey: ['${func.name}', ${contractName}.address, ${generateArgNames(func.args)}],\n queryFn: () => ${contractName}.read.${toCamelCase(func.name)}(${generateArgNames(func.args) ? `{ ${generateObjectArgs(func.args)} }, ` : \"\"}{\n network: config.network,\n senderAddress: config.senderAddress || 'SP000000000000000000002Q6VF78'\n }),\n ${func.args.length > 0 ? `enabled: ${generateEnabledCondition(func.args)} && (options?.enabled ?? true),` : \"\"}\n ...options\n })\n}`;\n}\n\nfunction generateWriteHook(\n func: AbiFunction,\n contractName: string\n): string {\n const hookName = `use${capitalize(contractName)}${capitalize(toCamelCase(func.name))}`;\n const argsType = generateArgsType(func.args);\n\n return `export function ${hookName}() {\n const config = useSecondLayerConfig()\n const queryClient = useQueryClient()\n \n const mutation = useMutation({\n mutationFn: async (params: {\n args: ${argsType};\n options?: {\n postConditions?: PostCondition[];\n attachment?: string;\n onFinish?: (data: any) => void;\n onCancel?: () => void;\n };\n }) => {\n const { args, options = {} } = params\n const contractCallData = ${contractName}.${toCamelCase(func.name)}(args)\n const { contractAddress, contractName: name, functionName, functionArgs } = contractCallData\n const network = config.network || 'mainnet'\n const contract = \\`\\${contractAddress}.\\${name}\\`\n\n const result = await request('stx_callContract', {\n contract,\n functionName,\n functionArgs,\n network,\n ...options\n })\n\n options.onFinish?.(result)\n return result\n },\n onSuccess: () => {\n // Invalidate relevant queries on success\n queryClient.invalidateQueries({ queryKey: ['stacks-account'] })\n },\n onError: (error) => {\n console.error('Contract call failed:', error)\n }\n })\n\n const ${toCamelCase(func.name)} = useCallback(async (\n args: ${argsType},\n options?: {\n postConditions?: PostCondition[];\n attachment?: string;\n onFinish?: (data: any) => void;\n onCancel?: () => void;\n }\n ) => {\n return mutation.mutateAsync({ args, options })\n }, [mutation])\n\n return {\n ${toCamelCase(func.name)},\n // Expose mutation state\n isPending: mutation.isPending,\n isError: mutation.isError,\n isSuccess: mutation.isSuccess,\n error: mutation.error,\n data: mutation.data,\n reset: mutation.reset\n }\n}`;\n}\n\n/**\n * Generate a hook for reading a map entry\n */\nfunction generateMapHook(\n map: AbiMap,\n contractVarName: string,\n _address: string,\n _contractName: string\n): string {\n const hookName = `use${capitalize(contractVarName)}${capitalize(toCamelCase(map.name))}`;\n const keyType = clarityTypeToTS(map.key);\n const valueType = clarityTypeToTS(map.value);\n\n return `export function ${hookName}(key: ${keyType}, options?: { enabled?: boolean }) {\n const config = useSecondLayerConfig()\n\n return useQuery<${valueType} | null>({\n queryKey: ['${contractVarName}', '${map.name}', 'map', key, config.network],\n queryFn: async () => {\n return ${contractVarName}.maps.${toCamelCase(map.name)}.get(key, { network: config.network })\n },\n enabled: options?.enabled ?? true\n })\n}`;\n}\n\n/**\n * Generate a hook for reading a data variable\n */\nfunction generateVarHook(\n variable: AbiVariable,\n contractVarName: string,\n _address: string,\n _contractName: string\n): string {\n const hookName = `use${capitalize(contractVarName)}${capitalize(toCamelCase(variable.name))}`;\n const valueType = clarityTypeToTS(variable.type);\n\n return `export function ${hookName}(options?: { enabled?: boolean }) {\n const config = useSecondLayerConfig()\n\n return useQuery<${valueType}>({\n queryKey: ['${contractVarName}', '${variable.name}', 'var', config.network],\n queryFn: async () => {\n return ${contractVarName}.vars.${toCamelCase(variable.name)}.get({ network: config.network })\n },\n enabled: options?.enabled ?? true\n })\n}`;\n}\n\n/**\n * Generate a hook for reading a constant\n */\nfunction generateConstantHook(\n constant: AbiVariable,\n contractVarName: string,\n _address: string,\n _contractName: string\n): string {\n const hookName = `use${capitalize(contractVarName)}${capitalize(toCamelCase(constant.name))}`;\n const valueType = clarityTypeToTS(constant.type);\n\n return `export function ${hookName}(options?: { enabled?: boolean }) {\n const config = useSecondLayerConfig()\n\n return useQuery<${valueType}>({\n queryKey: ['${contractVarName}', '${constant.name}', 'constant', config.network],\n queryFn: async () => {\n return ${contractVarName}.constants.${toCamelCase(constant.name)}.get({ network: config.network })\n },\n enabled: options?.enabled ?? true,\n staleTime: Infinity // Constants never change\n })\n}`;\n}\n",
21
21
  "/**\n * Utility functions for React hook generation\n */\n\nimport { toCamelCase, type FunctionArg } from \"@secondlayer/stacks/clarity\";\nimport { clarityTypeToTS } from \"../../../utils/type-mapping\";\n\n// Re-export for use in other files\nexport { toCamelCase, clarityTypeToTS };\n\nexport function capitalize(str: string): string {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\n\nexport function generateHookArgsSignature(args: ReadonlyArray<FunctionArg>): string {\n if (args.length === 0) return \"\";\n\n const argsList = args\n .map((arg) => `${toCamelCase(arg.name)}: ${clarityTypeToTS(arg.type)}`)\n .join(\", \");\n return `${argsList}`;\n}\n\nexport function generateArgsType(args: ReadonlyArray<FunctionArg>): string {\n if (args.length === 0) return \"void\";\n\n const argsList = args\n .map((arg) => `${toCamelCase(arg.name)}: ${clarityTypeToTS(arg.type)}`)\n .join(\"; \");\n return `{ ${argsList} }`;\n}\n\nexport function generateArgNames(args: ReadonlyArray<FunctionArg>): string {\n if (args.length === 0) return \"\";\n return args.map((arg) => toCamelCase(arg.name)).join(\", \");\n}\n\nexport function generateEnabledCondition(args: ReadonlyArray<FunctionArg>): string {\n return args\n .map((arg) => {\n const camelName = toCamelCase(arg.name);\n const type = clarityTypeToTS(arg.type);\n if (type === \"string\") return `!!${camelName}`;\n if (type === \"bigint\") return `${camelName} !== undefined`;\n return `${camelName} !== undefined`;\n })\n .join(\" && \");\n}\n\nexport function generateObjectArgs(args: ReadonlyArray<FunctionArg>): string {\n if (args.length === 0) return \"\";\n return args.map((arg) => `${arg.name}: ${toCamelCase(arg.name)}`).join(\", \");\n}\n",
22
22
  "/**\n * React Plugin for @secondlayer/cli\n * Generates React hooks for contract interfaces and generic Stacks functionality\n */\n\nimport type { PluginFactory, GenerateContext } from \"../../types/plugin\";\nimport type { ReactPluginOptions } from \"./types\";\nimport { generateProvider } from \"./provider/index\";\nimport { generateGenericHooks } from \"./generators/generic\";\nimport { generateContractHooks } from \"./generators/contract\";\n\n/**\n * React plugin factory\n */\nexport const react: PluginFactory<ReactPluginOptions> = (options = {}) => {\n const excludeList = options.exclude || [];\n\n return {\n name: \"@secondlayer/cli/plugin-react\",\n version: \"1.0.0\",\n\n async generate(context: GenerateContext): Promise<void> {\n if (options.debug) {\n context.logger.debug(\n `React plugin generating hooks (excluding: ${excludeList.join(\", \") || \"none\"})`\n );\n }\n\n // Generate provider (always generated)\n const provider = await generateProvider();\n context.addOutput(\"provider\", {\n path: \"./src/generated/provider.tsx\",\n content: provider,\n type: \"config\",\n });\n\n // Generate generic hooks (all by default, minus excludes)\n const genericHooks = await generateGenericHooks(excludeList);\n context.addOutput(\"generic-hooks\", {\n path: \"./src/generated/hooks.ts\",\n content: genericHooks,\n type: \"hooks\",\n });\n\n // Generate contract hooks (all contracts, minus excludes)\n if (context.contracts.length > 0) {\n const contractHooks = await generateContractHooks(\n context.contracts,\n excludeList\n );\n\n // Only add output if there are hooks to generate\n if (contractHooks.trim()) {\n context.addOutput(\"contract-hooks\", {\n path: \"./src/generated/contract-hooks.ts\",\n content: contractHooks,\n type: \"hooks\",\n });\n }\n }\n\n if (options.debug) {\n context.logger.success(\n `React plugin generated ${context.contracts.length} contract hook sets`\n );\n }\n },\n };\n};\n\n// Re-export types for convenience\nexport type { ReactPluginOptions } from \"./types\";\n",
23
- "/**\n * Code generators for the testing plugin\n * Generates type-safe helpers for Clarinet SDK unit tests\n */\n\nimport type { ProcessedContract } from \"../../types/plugin\";\nimport {\n toCamelCase,\n isAbiTuple,\n type AbiFunction,\n type AbiMap,\n type AbiType,\n type AbiVariable,\n} from \"@secondlayer/stacks/clarity\";\nimport type { TestingPluginOptions } from \"./index\";\nimport { getTypeForArg } from \"../../utils/type-mapping\";\nimport { generateClarityConversion } from \"../../utils/clarity-conversion\";\nimport { generateArgsSignature, generateClarityArgs } from \"../../utils/generator-helpers\";\n\n/**\n * Convert string to PascalCase\n */\nfunction toPascalCase(str: string): string {\n const camel = toCamelCase(str);\n return camel.charAt(0).toUpperCase() + camel.slice(1);\n}\n\n\n/**\n * Generate a public function helper\n */\nfunction generatePublicFunction(\n func: AbiFunction,\n contractId: string\n): string {\n const methodName = toCamelCase(func.name);\n const argsSignature = generateArgsSignature(func.args);\n const clarityArgs = generateClarityArgs(func.args);\n\n return `${methodName}: (${argsSignature}caller: string) => {\n const callerAddr = accounts.get(caller) ?? caller;\n return simnet.callPublicFn(\n '${contractId}',\n '${func.name}',\n [${clarityArgs}],\n callerAddr\n );\n }`;\n}\n\n/**\n * Generate a read-only function helper\n */\nfunction generateReadOnlyFunction(\n func: AbiFunction,\n contractId: string\n): string {\n const methodName = toCamelCase(func.name);\n const argsSignature = generateArgsSignature(func.args);\n const clarityArgs = generateClarityArgs(func.args);\n\n // Read-only functions don't need a caller, use deployer as default\n const hasArgs = func.args.length > 0;\n const argsParam = hasArgs ? argsSignature : \"\";\n\n return `${methodName}: (${argsParam}) => {\n return simnet.callReadOnlyFn(\n '${contractId}',\n '${func.name}',\n [${clarityArgs}],\n accounts.get('deployer')!\n );\n }`;\n}\n\n/**\n * Generate a private function helper (for testing only)\n */\nfunction generatePrivateFunction(\n func: AbiFunction,\n contractId: string\n): string {\n const methodName = toCamelCase(func.name);\n const argsSignature = generateArgsSignature(func.args);\n const clarityArgs = generateClarityArgs(func.args);\n\n return `${methodName}: (${argsSignature}caller: string) => {\n const callerAddr = accounts.get(caller) ?? caller;\n return simnet.callPrivateFn(\n '${contractId}',\n '${func.name}',\n [${clarityArgs}],\n callerAddr\n );\n }`;\n}\n\n/**\n * Generate a data variable accessor helper\n */\nfunction generateDataVarHelper(\n variable: AbiVariable,\n contractId: string\n): string {\n const methodName = toCamelCase(variable.name);\n\n return `${methodName}: () => {\n return simnet.getDataVar('${contractId}', '${variable.name}');\n }`;\n}\n\n/**\n * Generate TypeScript type for map key based on its structure\n */\nfunction getMapKeyType(keyType: AbiType): string {\n // Map keys are typically tuples\n if (isAbiTuple(keyType)) {\n const fields = keyType.tuple\n .map(\n (field) =>\n `${toCamelCase(field.name)}: ${getTypeForArg({ type: field.type })}`\n )\n .join(\"; \");\n return `{ ${fields} }`;\n }\n\n // Single-value keys (less common but possible)\n return getTypeForArg({ type: keyType });\n}\n\n/**\n * Generate Clarity conversion for map key\n */\nfunction generateMapKeyConversion(keyType: AbiType): string {\n // Map keys are typically tuples\n if (isAbiTuple(keyType)) {\n const fields = keyType.tuple\n .map((field) => {\n const camelFieldName = toCamelCase(field.name);\n const fieldConversion = generateClarityConversion(\n `key.${camelFieldName}`,\n { type: field.type }\n );\n return `\"${field.name}\": ${fieldConversion}`;\n })\n .join(\", \");\n return `Cl.tuple({ ${fields} })`;\n }\n\n // Single-value keys\n return generateClarityConversion(\"key\", { type: keyType });\n}\n\n/**\n * Generate a map entry accessor helper\n */\nfunction generateMapEntryHelper(map: AbiMap, contractId: string): string {\n const methodName = toCamelCase(map.name);\n const keyType = getMapKeyType(map.key);\n const keyConversion = generateMapKeyConversion(map.key);\n\n return `${methodName}: (key: ${keyType}) => {\n return simnet.getMapEntry(\n '${contractId}',\n '${map.name}',\n ${keyConversion}\n );\n }`;\n}\n\n/**\n * Generate the vars object containing all data variable accessors\n */\nfunction generateVarsObject(\n variables: readonly AbiVariable[],\n contractId: string\n): string {\n // Filter to only include mutable variables (not constants)\n const dataVars = variables.filter((v) => v.access === \"variable\");\n\n if (dataVars.length === 0) {\n return \"\";\n }\n\n const varHelpers = dataVars.map((v) => generateDataVarHelper(v, contractId));\n\n return `vars: {\n ${varHelpers.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate the maps object containing all map entry accessors\n */\nfunction generateMapsObject(maps: readonly AbiMap[], contractId: string): string {\n if (maps.length === 0) {\n return \"\";\n }\n\n const mapHelpers = maps.map((m) => generateMapEntryHelper(m, contractId));\n\n return `maps: {\n ${mapHelpers.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate a contract helper factory function\n */\nfunction generateContractHelper(\n contract: ProcessedContract,\n options: TestingPluginOptions\n): string {\n const { abi, name, address } = contract;\n const functions = abi.functions || [];\n const variables = abi.variables || [];\n const maps = abi.maps || [];\n const pascalName = toPascalCase(name);\n\n // Filter functions by access type\n const publicFns = functions.filter(\n (f: AbiFunction) => f.access === \"public\"\n );\n const readOnlyFns = functions.filter(\n (f: AbiFunction) =>\n f.access === \"read-only\"\n );\n const privateFns = options.includePrivate\n ? functions.filter((f: AbiFunction) => f.access === \"private\")\n : [];\n\n // Generate function helpers\n const publicHelpers = publicFns.map((f: AbiFunction) =>\n generatePublicFunction(f, address)\n );\n const readOnlyHelpers = readOnlyFns.map((f: AbiFunction) =>\n generateReadOnlyFunction(f, address)\n );\n const privateHelpers = privateFns.map((f: AbiFunction) =>\n generatePrivateFunction(f, address)\n );\n\n // Generate data variable and map accessors\n const varsObject = generateVarsObject(variables, address);\n const mapsObject = generateMapsObject(maps, address);\n\n const allHelpers = [...publicHelpers, ...readOnlyHelpers, ...privateHelpers];\n\n // Include vars and maps objects if they have content\n if (varsObject) {\n allHelpers.push(varsObject);\n }\n if (mapsObject) {\n allHelpers.push(mapsObject);\n }\n\n if (allHelpers.length === 0) {\n return \"\";\n }\n\n return `export function get${pascalName}(simnet: Simnet) {\n const accounts = simnet.getAccounts();\n\n return {\n ${allHelpers.join(\",\\n\\n \")}\n };\n}`;\n}\n\n/**\n * Generate the getContracts convenience wrapper\n */\nfunction generateGetContracts(contracts: ProcessedContract[]): string {\n const contractEntries = contracts\n .map((contract) => {\n const camelName = toCamelCase(contract.name);\n const pascalName = toPascalCase(contract.name);\n return `${camelName}: get${pascalName}(simnet)`;\n })\n .join(\",\\n \");\n\n return `export function getContracts(simnet: Simnet) {\n const accounts = simnet.getAccounts();\n\n return {\n accounts,\n ${contractEntries}\n };\n}`;\n}\n\n/**\n * Generate type exports for consumer convenience\n */\nfunction generateTypeExports(contracts: ProcessedContract[]): string {\n const typeExports = contracts\n .map((contract) => {\n const pascalName = toPascalCase(contract.name);\n return `export type ${pascalName}Helpers = ReturnType<typeof get${pascalName}>;`;\n })\n .join(\"\\n\");\n\n return `${typeExports}\nexport type Contracts = ReturnType<typeof getContracts>;`;\n}\n\n/**\n * Main entry point - generates the full testing helpers file\n */\nexport async function generateTestingHelpers(\n contracts: ProcessedContract[],\n options: TestingPluginOptions\n): Promise<string> {\n const contractHelpers = contracts\n .map((contract) => generateContractHelper(contract, options))\n .filter(Boolean);\n\n if (contractHelpers.length === 0) {\n return `// No contracts with functions to generate helpers for\nexport {};`;\n }\n\n const getContractsCode = generateGetContracts(contracts);\n const typeExports = generateTypeExports(contracts);\n\n return `/**\n * Generated by @secondlayer/cli testing plugin\n * Type-safe helpers for Clarinet SDK unit tests\n */\n\nimport { type Simnet, Cl } from '@hirosystems/clarinet-sdk';\n\n// ============================================\n// Per-contract factory functions\n// ============================================\n\n${contractHelpers.join(\"\\n\\n\")}\n\n// ============================================\n// Convenience: all contracts at once\n// ============================================\n\n${getContractsCode}\n\n// ============================================\n// Type exports\n// ============================================\n\n${typeExports}\n`;\n}\n",
23
+ "/**\n * Code generators for the testing plugin\n * Generates type-safe helpers for Clarinet SDK unit tests\n */\n\nimport type { ProcessedContract } from \"../../types/plugin\";\nimport {\n toCamelCase,\n isAbiTuple,\n type AbiFunction,\n type AbiMap,\n type AbiType,\n type AbiVariable,\n} from \"@secondlayer/stacks/clarity\";\nimport type { TestingPluginOptions } from \"./index\";\nimport { getTypeForArg } from \"../../utils/type-mapping\";\nimport { generateArgsSignature, generateClarityArgs, generateMapKeyConversion } from \"../../utils/generator-helpers\";\n\n/**\n * Convert string to PascalCase\n */\nfunction toPascalCase(str: string): string {\n const camel = toCamelCase(str);\n return camel.charAt(0).toUpperCase() + camel.slice(1);\n}\n\n\n/**\n * Generate a public function helper\n */\nfunction generatePublicFunction(\n func: AbiFunction,\n contractId: string\n): string {\n const methodName = toCamelCase(func.name);\n const argsSignature = generateArgsSignature(func.args);\n const clarityArgs = generateClarityArgs(func.args);\n\n return `${methodName}: (${argsSignature}caller: string) => {\n const callerAddr = accounts.get(caller) ?? caller;\n return simnet.callPublicFn(\n '${contractId}',\n '${func.name}',\n [${clarityArgs}],\n callerAddr\n );\n }`;\n}\n\n/**\n * Generate a read-only function helper\n */\nfunction generateReadOnlyFunction(\n func: AbiFunction,\n contractId: string\n): string {\n const methodName = toCamelCase(func.name);\n const argsSignature = generateArgsSignature(func.args);\n const clarityArgs = generateClarityArgs(func.args);\n\n // Read-only functions don't need a caller, use deployer as default\n const hasArgs = func.args.length > 0;\n const argsParam = hasArgs ? argsSignature : \"\";\n\n return `${methodName}: (${argsParam}) => {\n return simnet.callReadOnlyFn(\n '${contractId}',\n '${func.name}',\n [${clarityArgs}],\n accounts.get('deployer')!\n );\n }`;\n}\n\n/**\n * Generate a private function helper (for testing only)\n */\nfunction generatePrivateFunction(\n func: AbiFunction,\n contractId: string\n): string {\n const methodName = toCamelCase(func.name);\n const argsSignature = generateArgsSignature(func.args);\n const clarityArgs = generateClarityArgs(func.args);\n\n return `${methodName}: (${argsSignature}caller: string) => {\n const callerAddr = accounts.get(caller) ?? caller;\n return simnet.callPrivateFn(\n '${contractId}',\n '${func.name}',\n [${clarityArgs}],\n callerAddr\n );\n }`;\n}\n\n/**\n * Generate a data variable accessor helper\n */\nfunction generateDataVarHelper(\n variable: AbiVariable,\n contractId: string\n): string {\n const methodName = toCamelCase(variable.name);\n\n return `${methodName}: () => {\n return simnet.getDataVar('${contractId}', '${variable.name}');\n }`;\n}\n\n/**\n * Generate TypeScript type for map key based on its structure\n */\nfunction getMapKeyType(keyType: AbiType): string {\n // Map keys are typically tuples\n if (isAbiTuple(keyType)) {\n const fields = keyType.tuple\n .map(\n (field) =>\n `${toCamelCase(field.name)}: ${getTypeForArg({ type: field.type })}`\n )\n .join(\"; \");\n return `{ ${fields} }`;\n }\n\n // Single-value keys (less common but possible)\n return getTypeForArg({ type: keyType });\n}\n\n\n/**\n * Generate a map entry accessor helper\n */\nfunction generateMapEntryHelper(map: AbiMap, contractId: string): string {\n const methodName = toCamelCase(map.name);\n const keyType = getMapKeyType(map.key);\n const keyConversion = generateMapKeyConversion(map.key);\n\n return `${methodName}: (key: ${keyType}) => {\n return simnet.getMapEntry(\n '${contractId}',\n '${map.name}',\n ${keyConversion}\n );\n }`;\n}\n\n/**\n * Generate the vars object containing all data variable accessors\n */\nfunction generateVarsObject(\n variables: readonly AbiVariable[],\n contractId: string\n): string {\n // Filter to only include mutable variables (not constants)\n const dataVars = variables.filter((v) => v.access === \"variable\");\n\n if (dataVars.length === 0) {\n return \"\";\n }\n\n const varHelpers = dataVars.map((v) => generateDataVarHelper(v, contractId));\n\n return `vars: {\n ${varHelpers.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate the maps object containing all map entry accessors\n */\nfunction generateMapsObject(maps: readonly AbiMap[], contractId: string): string {\n if (maps.length === 0) {\n return \"\";\n }\n\n const mapHelpers = maps.map((m) => generateMapEntryHelper(m, contractId));\n\n return `maps: {\n ${mapHelpers.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate a contract helper factory function\n */\nfunction generateContractHelper(\n contract: ProcessedContract,\n options: TestingPluginOptions\n): string {\n const { abi, name, address } = contract;\n const functions = abi.functions || [];\n const variables = abi.variables || [];\n const maps = abi.maps || [];\n const pascalName = toPascalCase(name);\n\n // Filter functions by access type\n const publicFns = functions.filter(\n (f: AbiFunction) => f.access === \"public\"\n );\n const readOnlyFns = functions.filter(\n (f: AbiFunction) =>\n f.access === \"read-only\"\n );\n const privateFns = options.includePrivate\n ? functions.filter((f: AbiFunction) => f.access === \"private\")\n : [];\n\n // Generate function helpers\n const publicHelpers = publicFns.map((f: AbiFunction) =>\n generatePublicFunction(f, address)\n );\n const readOnlyHelpers = readOnlyFns.map((f: AbiFunction) =>\n generateReadOnlyFunction(f, address)\n );\n const privateHelpers = privateFns.map((f: AbiFunction) =>\n generatePrivateFunction(f, address)\n );\n\n // Generate data variable and map accessors\n const varsObject = generateVarsObject(variables, address);\n const mapsObject = generateMapsObject(maps, address);\n\n const allHelpers = [...publicHelpers, ...readOnlyHelpers, ...privateHelpers];\n\n // Include vars and maps objects if they have content\n if (varsObject) {\n allHelpers.push(varsObject);\n }\n if (mapsObject) {\n allHelpers.push(mapsObject);\n }\n\n if (allHelpers.length === 0) {\n return \"\";\n }\n\n return `export function get${pascalName}(simnet: Simnet) {\n const accounts = simnet.getAccounts();\n\n return {\n ${allHelpers.join(\",\\n\\n \")}\n };\n}`;\n}\n\n/**\n * Generate the getContracts convenience wrapper\n */\nfunction generateGetContracts(contracts: ProcessedContract[]): string {\n const contractEntries = contracts\n .map((contract) => {\n const camelName = toCamelCase(contract.name);\n const pascalName = toPascalCase(contract.name);\n return `${camelName}: get${pascalName}(simnet)`;\n })\n .join(\",\\n \");\n\n return `export function getContracts(simnet: Simnet) {\n const accounts = simnet.getAccounts();\n\n return {\n accounts,\n ${contractEntries}\n };\n}`;\n}\n\n/**\n * Generate type exports for consumer convenience\n */\nfunction generateTypeExports(contracts: ProcessedContract[]): string {\n const typeExports = contracts\n .map((contract) => {\n const pascalName = toPascalCase(contract.name);\n return `export type ${pascalName}Helpers = ReturnType<typeof get${pascalName}>;`;\n })\n .join(\"\\n\");\n\n return `${typeExports}\nexport type Contracts = ReturnType<typeof getContracts>;`;\n}\n\n/**\n * Main entry point - generates the full testing helpers file\n */\nexport async function generateTestingHelpers(\n contracts: ProcessedContract[],\n options: TestingPluginOptions\n): Promise<string> {\n const contractHelpers = contracts\n .map((contract) => generateContractHelper(contract, options))\n .filter(Boolean);\n\n if (contractHelpers.length === 0) {\n return `// No contracts with functions to generate helpers for\nexport {};`;\n }\n\n const getContractsCode = generateGetContracts(contracts);\n const typeExports = generateTypeExports(contracts);\n\n return `/**\n * Generated by @secondlayer/cli testing plugin\n * Type-safe helpers for Clarinet SDK unit tests\n */\n\nimport { type Simnet, Cl } from '@hirosystems/clarinet-sdk';\n\n// ============================================\n// Per-contract factory functions\n// ============================================\n\n${contractHelpers.join(\"\\n\\n\")}\n\n// ============================================\n// Convenience: all contracts at once\n// ============================================\n\n${getContractsCode}\n\n// ============================================\n// Type exports\n// ============================================\n\n${typeExports}\n`;\n}\n",
24
24
  "/**\n * Testing plugin for @secondlayer/cli\n * Generates type-safe helpers for Clarinet SDK unit tests\n */\n\nimport type { PluginFactory, GenerateContext } from \"../../types/plugin\";\nimport { generateTestingHelpers } from \"./generators\";\n\nexport interface TestingPluginOptions {\n /** Include only specific contracts */\n include?: string[];\n\n /** Exclude specific contracts */\n exclude?: string[];\n\n /** Output path for generated testing helpers (default: ./src/generated/testing.ts) */\n out?: string;\n\n /** Include private function helpers (default: false) */\n includePrivate?: boolean;\n\n /** Enable debug output */\n debug?: boolean;\n}\n\nexport const testing: PluginFactory<TestingPluginOptions> = (options = {}) => {\n return {\n name: \"@secondlayer/cli/plugin-testing\",\n version: \"1.0.0\",\n\n async generate(context: GenerateContext): Promise<void> {\n const { contracts } = context;\n\n // Filter contracts based on options\n const filteredContracts = contracts.filter((contract) => {\n if (options.include && !options.include.includes(contract.name)) {\n return false;\n }\n if (options.exclude && options.exclude.includes(contract.name)) {\n return false;\n }\n return true;\n });\n\n if (filteredContracts.length === 0) {\n if (options.debug) {\n context.logger.debug(\"Testing plugin: No contracts to process\");\n }\n return;\n }\n\n if (options.debug) {\n context.logger.debug(\n `Testing plugin: Generating helpers for ${filteredContracts.length} contracts`\n );\n }\n\n // Generate testing helpers\n const testingCode = await generateTestingHelpers(\n filteredContracts,\n options\n );\n\n const outputPath = options.out || \"./src/generated/testing.ts\";\n\n context.addOutput(\"testing\", {\n path: outputPath,\n content: testingCode,\n type: \"utils\",\n });\n\n if (options.debug) {\n context.logger.debug(\n `Testing plugin: Generated helpers for ${filteredContracts.length} contracts`\n );\n }\n },\n };\n};\n",
25
25
  "/**\n * Plugin exports for @secondlayer/cli\n * This will be expanded as plugins are implemented\n */\n\nimport type { SecondLayerPlugin } from \"../types/plugin\";\n\n// Re-export plugin types for convenience\nexport type {\n SecondLayerPlugin,\n PluginFactory,\n PluginOptions,\n GenerateContext,\n PluginContext,\n Logger,\n PluginUtils,\n} from \"../types/plugin\";\n\n// Plugin utilities\nexport { PluginManager } from \"../core/plugin-manager\";\n\n// Base plugin options interface\nexport interface BasePluginOptions {\n /** Include only specific contracts/functions */\n include?: string[];\n\n /** Exclude specific contracts/functions */\n exclude?: string[];\n\n /** Enable debug output */\n debug?: boolean;\n}\n\n/**\n * Utility function to filter contracts/functions based on include/exclude options\n */\nexport function filterByOptions<T extends { name: string }>(\n items: T[],\n options: BasePluginOptions = {}\n): T[] {\n let filtered = items;\n\n if (options.include && options.include.length > 0) {\n filtered = filtered.filter((item) =>\n options.include!.some(\n (pattern) =>\n item.name.includes(pattern) || item.name.match(new RegExp(pattern))\n )\n );\n }\n\n if (options.exclude && options.exclude.length > 0) {\n filtered = filtered.filter(\n (item) =>\n !options.exclude!.some(\n (pattern) =>\n item.name.includes(pattern) || item.name.match(new RegExp(pattern))\n )\n );\n }\n\n return filtered;\n}\n\n/**\n * Utility function to create a simple plugin\n */\nexport function createPlugin(\n name: string,\n version: string,\n implementation: Partial<SecondLayerPlugin>\n): SecondLayerPlugin {\n return {\n name,\n version,\n ...implementation,\n };\n}\n\n// Plugin exports\nexport { clarinet, hasClarinetProject } from \"./clarinet/index\";\nexport type { ClarinetPluginOptions } from \"./clarinet/index\";\n\nexport { actions } from \"./actions/index\";\nexport type { ActionsPluginOptions } from \"./actions/index\";\n\nexport { react } from \"./react/index\";\nexport type { ReactPluginOptions } from \"./react/index\";\n\nexport { testing } from \"./testing/index\";\nexport type { TestingPluginOptions } from \"./testing/index\";\n\n"
26
26
  ],
27
- "mappings": "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;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAmEJ;AAAA,MACH,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAsCJ;AAAA,MACH,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAsCJ;AAAA,MACH,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SA2BJ;AAAA,MACH,OAAO;AAAA,SAEJ;AAAA,MACH,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SA6CJ;AAAA,MACH,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAcJ;AAAA,MACH,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAcJ;AAAA,MACH,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAcJ;AAAA,MACH,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAwBJ;AAAA,MACH,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAiDJ;AAAA,MACH,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAuCJ;AAAA,MACH,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MA+CP,OAAO;AAAA;AAAA;;;AE7fb;;;ACDA,wBAAS;AAMF,SAAS,UAAU,CAAC,KAAqB;AAAA,EAC9C,OAAO,IAAI,OAAO,CAAC,EAAE,YAAY,IAAI,IAAI,MAAM,CAAC;AAAA;AAG3C,SAAS,yBAAyB,CAAC,MAA0C;AAAA,EAClF,IAAI,KAAK,WAAW;AAAA,IAAG,OAAO;AAAA,EAE9B,MAAM,WAAW,KACd,IAAI,CAAC,QAAQ,GAAG,aAAY,IAAI,IAAI,MAAM,gBAAgB,IAAI,IAAI,GAAG,EACrE,KAAK,IAAI;AAAA,EACZ,OAAO,GAAG;AAAA;AAGL,SAAS,gBAAgB,CAAC,MAA0C;AAAA,EACzE,IAAI,KAAK,WAAW;AAAA,IAAG,OAAO;AAAA,EAE9B,MAAM,WAAW,KACd,IAAI,CAAC,QAAQ,GAAG,aAAY,IAAI,IAAI,MAAM,gBAAgB,IAAI,IAAI,GAAG,EACrE,KAAK,IAAI;AAAA,EACZ,OAAO,KAAK;AAAA;AAGP,SAAS,gBAAgB,CAAC,MAA0C;AAAA,EACzE,IAAI,KAAK,WAAW;AAAA,IAAG,OAAO;AAAA,EAC9B,OAAO,KAAK,IAAI,CAAC,QAAQ,aAAY,IAAI,IAAI,CAAC,EAAE,KAAK,IAAI;AAAA;AAGpD,SAAS,wBAAwB,CAAC,MAA0C;AAAA,EACjF,OAAO,KACJ,IAAI,CAAC,QAAQ;AAAA,IACZ,MAAM,YAAY,aAAY,IAAI,IAAI;AAAA,IACtC,MAAM,OAAO,gBAAgB,IAAI,IAAI;AAAA,IACrC,IAAI,SAAS;AAAA,MAAU,OAAO,KAAK;AAAA,IACnC,IAAI,SAAS;AAAA,MAAU,OAAO,GAAG;AAAA,IACjC,OAAO,GAAG;AAAA,GACX,EACA,KAAK,MAAM;AAAA;AAGT,SAAS,kBAAkB,CAAC,MAA0C;AAAA,EAC3E,IAAI,KAAK,WAAW;AAAA,IAAG,OAAO;AAAA,EAC9B,OAAO,KAAK,IAAI,CAAC,QAAQ,GAAG,IAAI,SAAS,aAAY,IAAI,IAAI,GAAG,EAAE,KAAK,IAAI;AAAA;;;ADhC7E,eAAsB,qBAAqB,CACzC,WACA,cAAwB,CAAC,GACR;AAAA,EACjB,MAAM,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA,WAKP,UAAU,IAAI,CAAC,MAAM,EAAE,IAAI,EAAE,KAAK,IAAI;AAAA,EAE/C,MAAM,SAAS;AAAA;AAAA;AAAA;AAAA,EAKf,MAAM,YAAY,UACf,IAAI,CAAC,aAAa,4BAA4B,UAAU,WAAW,CAAC,EACpE,OAAO,OAAO,EACd,KAAK;AAAA;AAAA,CAAM;AAAA,EAEd,MAAM,OAAO,GAAG;AAAA;AAAA,EAAc;AAAA;AAAA,EAAa;AAAA,EAE3C,OAAO,WAAW,IAAI;AAAA;AAGxB,SAAS,2BAA2B,CAClC,UACA,aACQ;AAAA,EACR,QAAQ,KAAK,MAAM,SAAS,iBAAiB;AAAA,EAC7C,MAAM,YAAY,IAAI,aAAa,CAAC;AAAA,EACpC,MAAM,OAAO,IAAI,QAAQ,CAAC;AAAA,EAC1B,MAAM,YAAY,IAAI,aAAa,CAAC;AAAA,EAEpC,MAAM,oBAAoB,UAAU,OAClC,CAAC,MACC,EAAE,WAAW,WACjB;AAAA,EACA,MAAM,kBAAkB,UAAU,OAChC,CAAC,MAAmB,EAAE,WAAW,QACnC;AAAA,EAEA,MAAM,YAAY,kBACf,IAAI,CAAC,SAAsB;AAAA,IAC1B,MAAM,WAAW,MAAM,WAAW,IAAI,IAAI,WAAW,aAAY,KAAK,IAAI,CAAC;AAAA,IAE3E,IAAI,YAAY,SAAS,QAAQ,GAAG;AAAA,MAClC,OAAO;AAAA,IACT;AAAA,IACA,OAAO,iBAAiB,MAAM,IAAI;AAAA,GACnC,EACA,OAAO,OAAO;AAAA,EAEjB,MAAM,aAAa,gBAChB,IAAI,CAAC,SAAsB;AAAA,IAC1B,MAAM,WAAW,MAAM,WAAW,IAAI,IAAI,WAAW,aAAY,KAAK,IAAI,CAAC;AAAA,IAE3E,IAAI,YAAY,SAAS,QAAQ,GAAG;AAAA,MAClC,OAAO;AAAA,IACT;AAAA,IACA,OAAO,kBAAkB,MAAM,IAAI;AAAA,GACpC,EACA,OAAO,OAAO;AAAA,EAGjB,MAAM,WAAW,KACd,IAAI,CAAC,QAAgB;AAAA,IACpB,MAAM,WAAW,MAAM,WAAW,IAAI,IAAI,WAAW,aAAY,IAAI,IAAI,CAAC;AAAA,IAC1E,IAAI,YAAY,SAAS,QAAQ,GAAG;AAAA,MAClC,OAAO;AAAA,IACT;AAAA,IACA,OAAO,gBAAgB,KAAK,MAAM,SAAS,YAAY;AAAA,GACxD,EACA,OAAO,OAAO;AAAA,EAGjB,MAAM,WAAW,UAAU,OAAO,CAAC,MAAM,EAAE,WAAW,UAAU;AAAA,EAChE,MAAM,WAAW,SACd,IAAI,CAAC,aAA0B;AAAA,IAC9B,MAAM,WAAW,MAAM,WAAW,IAAI,IAAI,WAAW,aAAY,SAAS,IAAI,CAAC;AAAA,IAC/E,IAAI,YAAY,SAAS,QAAQ,GAAG;AAAA,MAClC,OAAO;AAAA,IACT;AAAA,IACA,OAAO,gBAAgB,UAAU,MAAM,SAAS,YAAY;AAAA,GAC7D,EACA,OAAO,OAAO;AAAA,EAGjB,MAAM,YAAY,UAAU,OAAO,CAAC,MAAM,EAAE,WAAW,UAAU;AAAA,EACjE,MAAM,gBAAgB,UACnB,IAAI,CAAC,aAA0B;AAAA,IAC9B,MAAM,WAAW,MAAM,WAAW,IAAI,IAAI,WAAW,aAAY,SAAS,IAAI,CAAC;AAAA,IAC/E,IAAI,YAAY,SAAS,QAAQ,GAAG;AAAA,MAClC,OAAO;AAAA,IACT;AAAA,IACA,OAAO,qBAAqB,UAAU,MAAM,SAAS,YAAY;AAAA,GAClE,EACA,OAAO,OAAO;AAAA,EAEjB,MAAM,WAAW,CAAC,GAAG,WAAW,GAAG,YAAY,GAAG,UAAU,GAAG,UAAU,GAAG,aAAa;AAAA,EAGzF,IAAI,SAAS,WAAW,GAAG;AAAA,IACzB,OAAO;AAAA,EACT;AAAA,EAEA,OAAO,SAAS,KAAK;AAAA;AAAA,CAAM;AAAA;AAG7B,SAAS,gBAAgB,CAAC,MAAmB,cAA8B;AAAA,EACzE,MAAM,WAAW,MAAM,WAAW,YAAY,IAAI,WAAW,aAAY,KAAK,IAAI,CAAC;AAAA,EACnF,MAAM,gBAAgB,0BAA0B,KAAK,IAAI;AAAA,EACzD,MAAM,eACJ,KAAK,KAAK,SAAS,IACf,sCACA;AAAA,EAGN,MAAM,aAAa,gBAAgB,KAAK,OAAO;AAAA,EAE/C,OAAO,mBAAmB,YAAY,gBAAgB;AAAA;AAAA;AAAA,oBAGpC;AAAA,kBACF,KAAK,UAAU,yBAAyB,iBAAiB,KAAK,IAAI;AAAA,qBAC/D,qBAAqB,aAAY,KAAK,IAAI,KAAK,iBAAiB,KAAK,IAAI,IAAI,KAAK,mBAAmB,KAAK,IAAI,UAAU;AAAA;AAAA;AAAA;AAAA,MAIvI,KAAK,KAAK,SAAS,IAAI,YAAY,yBAAyB,KAAK,IAAI,qCAAqC;AAAA;AAAA;AAAA;AAAA;AAMhH,SAAS,iBAAiB,CACxB,MACA,cACQ;AAAA,EACR,MAAM,WAAW,MAAM,WAAW,YAAY,IAAI,WAAW,aAAY,KAAK,IAAI,CAAC;AAAA,EACnF,MAAM,WAAW,iBAAiB,KAAK,IAAI;AAAA,EAE3C,OAAO,mBAAmB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,cAMd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,iCASmB,gBAAgB,aAAY,KAAK,IAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,UAyB5D,aAAY,KAAK,IAAI;AAAA,YACnB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAYN,aAAY,KAAK,IAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAe3B,SAAS,eAAe,CACtB,KACA,iBACA,UACA,eACQ;AAAA,EACR,MAAM,WAAW,MAAM,WAAW,eAAe,IAAI,WAAW,aAAY,IAAI,IAAI,CAAC;AAAA,EACrF,MAAM,UAAU,gBAAgB,IAAI,GAAG;AAAA,EACvC,MAAM,YAAY,gBAAgB,IAAI,KAAK;AAAA,EAE3C,OAAO,mBAAmB,iBAAiB;AAAA;AAAA;AAAA,oBAGzB;AAAA,kBACF,sBAAsB,IAAI;AAAA;AAAA,eAE7B,wBAAwB,aAAY,IAAI,IAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAU3D,SAAS,eAAe,CACtB,UACA,iBACA,UACA,eACQ;AAAA,EACR,MAAM,WAAW,MAAM,WAAW,eAAe,IAAI,WAAW,aAAY,SAAS,IAAI,CAAC;AAAA,EAC1F,MAAM,YAAY,gBAAgB,SAAS,IAAI;AAAA,EAE/C,OAAO,mBAAmB;AAAA;AAAA;AAAA,oBAGR;AAAA,kBACF,sBAAsB,SAAS;AAAA;AAAA,eAElC,wBAAwB,aAAY,SAAS,IAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAUhE,SAAS,oBAAoB,CAC3B,UACA,iBACA,UACA,eACQ;AAAA,EACR,MAAM,WAAW,MAAM,WAAW,eAAe,IAAI,WAAW,aAAY,SAAS,IAAI,CAAC;AAAA,EAC1F,MAAM,YAAY,gBAAgB,SAAS,IAAI;AAAA,EAE/C,OAAO,mBAAmB;AAAA;AAAA;AAAA,oBAGR;AAAA,kBACF,sBAAsB,SAAS;AAAA;AAAA,eAElC,6BAA6B,aAAY,SAAS,IAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;AE1R9D,IAAM,QAA2C,CAAC,UAAU,CAAC,MAAM;AAAA,EACxE,MAAM,cAAc,QAAQ,WAAW,CAAC;AAAA,EAExC,OAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,SAEH,SAAQ,CAAC,SAAyC;AAAA,MACtD,IAAI,QAAQ,OAAO;AAAA,QACjB,QAAQ,OAAO,MACb,6CAA6C,YAAY,KAAK,IAAI,KAAK,SACzE;AAAA,MACF;AAAA,MAGA,MAAM,WAAW,MAAM,iBAAiB;AAAA,MACxC,QAAQ,UAAU,YAAY;AAAA,QAC5B,MAAM;AAAA,QACN,SAAS;AAAA,QACT,MAAM;AAAA,MACR,CAAC;AAAA,MAGD,MAAM,eAAe,MAAM,qBAAqB,WAAW;AAAA,MAC3D,QAAQ,UAAU,iBAAiB;AAAA,QACjC,MAAM;AAAA,QACN,SAAS;AAAA,QACT,MAAM;AAAA,MACR,CAAC;AAAA,MAGD,IAAI,QAAQ,UAAU,SAAS,GAAG;AAAA,QAChC,MAAM,gBAAgB,MAAM,sBAC1B,QAAQ,WACR,WACF;AAAA,QAGA,IAAI,cAAc,KAAK,GAAG;AAAA,UACxB,QAAQ,UAAU,kBAAkB;AAAA,YAClC,MAAM;AAAA,YACN,SAAS;AAAA,YACT,MAAM;AAAA,UACR,CAAC;AAAA,QACH;AAAA,MACF;AAAA,MAEA,IAAI,QAAQ,OAAO;AAAA,QACjB,QAAQ,OAAO,QACb,0BAA0B,QAAQ,UAAU,2BAC9C;AAAA,MACF;AAAA;AAAA,EAEJ;AAAA;;AC7DF;AAAA,iBACE;AAAA,gBACA;AAAA;AAcF,SAAS,YAAY,CAAC,KAAqB;AAAA,EACzC,MAAM,QAAQ,aAAY,GAAG;AAAA,EAC7B,OAAO,MAAM,OAAO,CAAC,EAAE,YAAY,IAAI,MAAM,MAAM,CAAC;AAAA;AAOtD,SAAS,sBAAsB,CAC7B,MACA,YACQ;AAAA,EACR,MAAM,aAAa,aAAY,KAAK,IAAI;AAAA,EACxC,MAAM,gBAAgB,sBAAsB,KAAK,IAAI;AAAA,EACrD,MAAM,cAAc,oBAAoB,KAAK,IAAI;AAAA,EAEjD,OAAO,GAAG,gBAAgB;AAAA;AAAA;AAAA,WAGjB;AAAA,WACA,KAAK;AAAA,WACL;AAAA;AAAA;AAAA;AAAA;AASX,SAAS,wBAAwB,CAC/B,MACA,YACQ;AAAA,EACR,MAAM,aAAa,aAAY,KAAK,IAAI;AAAA,EACxC,MAAM,gBAAgB,sBAAsB,KAAK,IAAI;AAAA,EACrD,MAAM,cAAc,oBAAoB,KAAK,IAAI;AAAA,EAGjD,MAAM,UAAU,KAAK,KAAK,SAAS;AAAA,EACnC,MAAM,YAAY,UAAU,gBAAgB;AAAA,EAE5C,OAAO,GAAG,gBAAgB;AAAA;AAAA,WAEjB;AAAA,WACA,KAAK;AAAA,WACL;AAAA;AAAA;AAAA;AAAA;AASX,SAAS,uBAAuB,CAC9B,MACA,YACQ;AAAA,EACR,MAAM,aAAa,aAAY,KAAK,IAAI;AAAA,EACxC,MAAM,gBAAgB,sBAAsB,KAAK,IAAI;AAAA,EACrD,MAAM,cAAc,oBAAoB,KAAK,IAAI;AAAA,EAEjD,OAAO,GAAG,gBAAgB;AAAA;AAAA;AAAA,WAGjB;AAAA,WACA,KAAK;AAAA,WACL;AAAA;AAAA;AAAA;AAAA;AASX,SAAS,qBAAqB,CAC5B,UACA,YACQ;AAAA,EACR,MAAM,aAAa,aAAY,SAAS,IAAI;AAAA,EAE5C,OAAO,GAAG;AAAA,kCACsB,iBAAiB,SAAS;AAAA;AAAA;AAO5D,SAAS,aAAa,CAAC,SAA0B;AAAA,EAE/C,IAAI,YAAW,OAAO,GAAG;AAAA,IACvB,MAAM,SAAS,QAAQ,MACpB,IACC,CAAC,UACC,GAAG,aAAY,MAAM,IAAI,MAAM,cAAc,EAAE,MAAM,MAAM,KAAK,CAAC,GACrE,EACC,KAAK,IAAI;AAAA,IACZ,OAAO,KAAK;AAAA,EACd;AAAA,EAGA,OAAO,cAAc,EAAE,MAAM,QAAQ,CAAC;AAAA;AAMxC,SAAS,yBAAwB,CAAC,SAA0B;AAAA,EAE1D,IAAI,YAAW,OAAO,GAAG;AAAA,IACvB,MAAM,SAAS,QAAQ,MACpB,IAAI,CAAC,UAAU;AAAA,MACd,MAAM,iBAAiB,aAAY,MAAM,IAAI;AAAA,MAC7C,MAAM,kBAAkB,0BACtB,OAAO,kBACP,EAAE,MAAM,MAAM,KAAK,CACrB;AAAA,MACA,OAAO,IAAI,MAAM,UAAU;AAAA,KAC5B,EACA,KAAK,IAAI;AAAA,IACZ,OAAO,cAAc;AAAA,EACvB;AAAA,EAGA,OAAO,0BAA0B,OAAO,EAAE,MAAM,QAAQ,CAAC;AAAA;AAM3D,SAAS,sBAAsB,CAAC,KAAa,YAA4B;AAAA,EACvE,MAAM,aAAa,aAAY,IAAI,IAAI;AAAA,EACvC,MAAM,UAAU,cAAc,IAAI,GAAG;AAAA,EACrC,MAAM,gBAAgB,0BAAyB,IAAI,GAAG;AAAA,EAEtD,OAAO,GAAG,qBAAqB;AAAA;AAAA,WAEtB;AAAA,WACA,IAAI;AAAA,UACL;AAAA;AAAA;AAAA;AAQV,SAAS,mBAAkB,CACzB,WACA,YACQ;AAAA,EAER,MAAM,WAAW,UAAU,OAAO,CAAC,MAAM,EAAE,WAAW,UAAU;AAAA,EAEhE,IAAI,SAAS,WAAW,GAAG;AAAA,IACzB,OAAO;AAAA,EACT;AAAA,EAEA,MAAM,aAAa,SAAS,IAAI,CAAC,MAAM,sBAAsB,GAAG,UAAU,CAAC;AAAA,EAE3E,OAAO;AAAA,QACD,WAAW,KAAK;AAAA;AAAA,OAAa;AAAA;AAAA;AAOrC,SAAS,mBAAkB,CAAC,MAAyB,YAA4B;AAAA,EAC/E,IAAI,KAAK,WAAW,GAAG;AAAA,IACrB,OAAO;AAAA,EACT;AAAA,EAEA,MAAM,aAAa,KAAK,IAAI,CAAC,MAAM,uBAAuB,GAAG,UAAU,CAAC;AAAA,EAExE,OAAO;AAAA,QACD,WAAW,KAAK;AAAA;AAAA,OAAa;AAAA;AAAA;AAOrC,SAAS,sBAAsB,CAC7B,UACA,SACQ;AAAA,EACR,QAAQ,KAAK,MAAM,YAAY;AAAA,EAC/B,MAAM,YAAY,IAAI,aAAa,CAAC;AAAA,EACpC,MAAM,YAAY,IAAI,aAAa,CAAC;AAAA,EACpC,MAAM,OAAO,IAAI,QAAQ,CAAC;AAAA,EAC1B,MAAM,aAAa,aAAa,IAAI;AAAA,EAGpC,MAAM,YAAY,UAAU,OAC1B,CAAC,MAAmB,EAAE,WAAW,QACnC;AAAA,EACA,MAAM,cAAc,UAAU,OAC5B,CAAC,MACC,EAAE,WAAW,WACjB;AAAA,EACA,MAAM,aAAa,QAAQ,iBACvB,UAAU,OAAO,CAAC,MAAmB,EAAE,WAAW,SAAS,IAC3D,CAAC;AAAA,EAGL,MAAM,gBAAgB,UAAU,IAAI,CAAC,MACnC,uBAAuB,GAAG,OAAO,CACnC;AAAA,EACA,MAAM,kBAAkB,YAAY,IAAI,CAAC,MACvC,yBAAyB,GAAG,OAAO,CACrC;AAAA,EACA,MAAM,iBAAiB,WAAW,IAAI,CAAC,MACrC,wBAAwB,GAAG,OAAO,CACpC;AAAA,EAGA,MAAM,aAAa,oBAAmB,WAAW,OAAO;AAAA,EACxD,MAAM,aAAa,oBAAmB,MAAM,OAAO;AAAA,EAEnD,MAAM,aAAa,CAAC,GAAG,eAAe,GAAG,iBAAiB,GAAG,cAAc;AAAA,EAG3E,IAAI,YAAY;AAAA,IACd,WAAW,KAAK,UAAU;AAAA,EAC5B;AAAA,EACA,IAAI,YAAY;AAAA,IACd,WAAW,KAAK,UAAU;AAAA,EAC5B;AAAA,EAEA,IAAI,WAAW,WAAW,GAAG;AAAA,IAC3B,OAAO;AAAA,EACT;AAAA,EAEA,OAAO,sBAAsB;AAAA;AAAA;AAAA;AAAA,MAIzB,WAAW,KAAK;AAAA;AAAA,KAAW;AAAA;AAAA;AAAA;AAQjC,SAAS,oBAAoB,CAAC,WAAwC;AAAA,EACpE,MAAM,kBAAkB,UACrB,IAAI,CAAC,aAAa;AAAA,IACjB,MAAM,YAAY,aAAY,SAAS,IAAI;AAAA,IAC3C,MAAM,aAAa,aAAa,SAAS,IAAI;AAAA,IAC7C,OAAO,GAAG,iBAAiB;AAAA,GAC5B,EACA,KAAK;AAAA,KAAS;AAAA,EAEjB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA,MAKH;AAAA;AAAA;AAAA;AAQN,SAAS,mBAAmB,CAAC,WAAwC;AAAA,EACnE,MAAM,cAAc,UACjB,IAAI,CAAC,aAAa;AAAA,IACjB,MAAM,aAAa,aAAa,SAAS,IAAI;AAAA,IAC7C,OAAO,eAAe,4CAA4C;AAAA,GACnE,EACA,KAAK;AAAA,CAAI;AAAA,EAEZ,OAAO,GAAG;AAAA;AAAA;AAOZ,eAAsB,sBAAsB,CAC1C,WACA,SACiB;AAAA,EACjB,MAAM,kBAAkB,UACrB,IAAI,CAAC,aAAa,uBAAuB,UAAU,OAAO,CAAC,EAC3D,OAAO,OAAO;AAAA,EAEjB,IAAI,gBAAgB,WAAW,GAAG;AAAA,IAChC,OAAO;AAAA;AAAA,EAET;AAAA,EAEA,MAAM,mBAAmB,qBAAqB,SAAS;AAAA,EACvD,MAAM,cAAc,oBAAoB,SAAS;AAAA,EAEjD,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAWP,gBAAgB,KAAK;AAAA;AAAA,CAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAM3B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA;AAAA;AAAA;;;ACnUK,IAAM,UAA+C,CAAC,UAAU,CAAC,MAAM;AAAA,EAC5E,OAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,SAEH,SAAQ,CAAC,SAAyC;AAAA,MACtD,QAAQ,cAAc;AAAA,MAGtB,MAAM,oBAAoB,UAAU,OAAO,CAAC,aAAa;AAAA,QACvD,IAAI,QAAQ,WAAW,CAAC,QAAQ,QAAQ,SAAS,SAAS,IAAI,GAAG;AAAA,UAC/D,OAAO;AAAA,QACT;AAAA,QACA,IAAI,QAAQ,WAAW,QAAQ,QAAQ,SAAS,SAAS,IAAI,GAAG;AAAA,UAC9D,OAAO;AAAA,QACT;AAAA,QACA,OAAO;AAAA,OACR;AAAA,MAED,IAAI,kBAAkB,WAAW,GAAG;AAAA,QAClC,IAAI,QAAQ,OAAO;AAAA,UACjB,QAAQ,OAAO,MAAM,yCAAyC;AAAA,QAChE;AAAA,QACA;AAAA,MACF;AAAA,MAEA,IAAI,QAAQ,OAAO;AAAA,QACjB,QAAQ,OAAO,MACb,0CAA0C,kBAAkB,kBAC9D;AAAA,MACF;AAAA,MAGA,MAAM,cAAc,MAAM,uBACxB,mBACA,OACF;AAAA,MAEA,MAAM,aAAa,QAAQ,OAAO;AAAA,MAElC,QAAQ,UAAU,WAAW;AAAA,QAC3B,MAAM;AAAA,QACN,SAAS;AAAA,QACT,MAAM;AAAA,MACR,CAAC;AAAA,MAED,IAAI,QAAQ,OAAO;AAAA,QACjB,QAAQ,OAAO,MACb,yCAAyC,kBAAkB,kBAC7D;AAAA,MACF;AAAA;AAAA,EAEJ;AAAA;;;ACzCK,SAAS,eAA2C,CACzD,OACA,UAA6B,CAAC,GACzB;AAAA,EACL,IAAI,WAAW;AAAA,EAEf,IAAI,QAAQ,WAAW,QAAQ,QAAQ,SAAS,GAAG;AAAA,IACjD,WAAW,SAAS,OAAO,CAAC,SAC1B,QAAQ,QAAS,KACf,CAAC,YACC,KAAK,KAAK,SAAS,OAAO,KAAK,KAAK,KAAK,MAAM,IAAI,OAAO,OAAO,CAAC,CACtE,CACF;AAAA,EACF;AAAA,EAEA,IAAI,QAAQ,WAAW,QAAQ,QAAQ,SAAS,GAAG;AAAA,IACjD,WAAW,SAAS,OAClB,CAAC,SACC,CAAC,QAAQ,QAAS,KAChB,CAAC,YACC,KAAK,KAAK,SAAS,OAAO,KAAK,KAAK,KAAK,MAAM,IAAI,OAAO,OAAO,CAAC,CACtE,CACJ;AAAA,EACF;AAAA,EAEA,OAAO;AAAA;AAMF,SAAS,YAAY,CAC1B,MACA,SACA,gBACmB;AAAA,EACnB,OAAO;AAAA,IACL;AAAA,IACA;AAAA,OACG;AAAA,EACL;AAAA;",
28
- "debugId": "217DF2A543BBE57564756E2164756E21",
27
+ "mappings": ";;;;;;;;;;;;;;;;;;;AAIA;AAOA,eAAe,QAAQ,GAAmB;AAAA,EACzC,IAAI,CAAC,OAAO;AAAA,IACX,QAAQ,MAAM,MAAM,OAAO;AAAA,MAC1B,cAAc,aAAa;AAAA,IAC5B,CAAC;AAAA,IAED,MAAM,mBAAmB;AAAA,MACxB,WAAW;AAAA,QACV,SAAS;AAAA,QACT,aAAa;AAAA,QACb,WAAW;AAAA,MACZ;AAAA,MACA,YAAY;AAAA,QACX,WAAW;AAAA,UACV,YAAY;AAAA,UACZ,YAAY;AAAA,QACb;AAAA,MACD;AAAA,MACA,iBAAiB;AAAA,QAChB,SAAS;AAAA,MACV;AAAA,MACA,QAAQ;AAAA,QACP,SAAS;AAAA,MACV;AAAA,MACA,SAAS;AAAA,QACR,SAAS;AAAA,MACV;AAAA,IACD,CAAC;AAAA,IAED,MAAM,sBAAsB;AAAA,EAC7B;AAAA,EAEA,OAAO;AAAA;AAMR,eAAsB,UAAU,CAAC,MAA+B;AAAA,EAC/D,MAAM,IAAI,MAAM,SAAS;AAAA,EAGzB,MAAM,SAAS,EAAE,YAAY,MAAM;AAAA,IAClC,UAAU;AAAA,IACV,aAAa;AAAA,EACd,CAAC;AAAA,EAGD,MAAM,YAAY,EAAE,cAAc,OAAO,SAAS;AAAA,IACjD,UAAU;AAAA,EACX,CAAC;AAAA,EAED,OAAO,UAAU;AAAA;AAAA,IAzDd,QAAsB;AAAA;;;ACD1B,qBAAS;AACT;AACA,2BAAS;;;ACHF,SAAS,eAAe,CAAC,YAG9B;AAAA,EACA,MAAM,WAAW,WAAW,QAAQ,GAAG;AAAA,EACvC,IAAI,aAAa,IAAI;AAAA,IACnB,MAAM,IAAI,MACR,yBAAyB,+CAC3B;AAAA,EACF;AAAA,EACA,OAAO;AAAA,IACL,SAAS,WAAW,MAAM,GAAG,QAAQ;AAAA,IACrC,cAAc,WAAW,MAAM,WAAW,CAAC;AAAA,EAC7C;AAAA;;;AC6EK,SAAS,kBAAkB,CAChC,GAC6B;AAAA,EAC7B,OAAO,qBAAqB,KAAK,EAAE,oBAAoB;AAAA;AAMlD,SAAS,oBAAoB,CAClC,GAC+B;AAAA,EAC/B,OAAO,iBAAiB,KAAK,EAAE,gBAAgB;AAAA;;;AFlGjD,IAAM,wBAAwB;AAAA;AAoBvB,MAAM,cAAc;AAAA,EACjB,UAA+B,CAAC;AAAA,EAChC;AAAA,EACA;AAAA,EACA;AAAA,EAER,WAAW,GAAG;AAAA,IACZ,KAAK,SAAS,KAAK,aAAa;AAAA,IAChC,KAAK,QAAQ,KAAK,YAAY;AAAA,IAC9B,KAAK,mBAAmB;AAAA,MACtB,OAAO;AAAA,MACP,WAAW,KAAK,IAAI;AAAA,MACpB,SAAS,IAAI;AAAA,IACf;AAAA;AAAA,EAMF,QAAQ,CAAC,QAAiC;AAAA,IAExC,IAAI,CAAC,OAAO,QAAQ,CAAC,OAAO,SAAS;AAAA,MACnC,MAAM,IAAI,MAAM,qCAAqC;AAAA,IACvD;AAAA,IAGA,MAAM,WAAW,KAAK,QAAQ,KAAK,CAAC,MAAM,EAAE,SAAS,OAAO,IAAI;AAAA,IAChE,IAAI,UAAU;AAAA,MACZ,MAAM,IAAI,MACR,WAAW,OAAO,wCAAwC,SAAS,UACrE;AAAA,IACF;AAAA,IAEA,KAAK,QAAQ,KAAK,MAAM;AAAA,IACxB,KAAK,OAAO,MAAM,sBAAsB,OAAO,QAAQ,OAAO,SAAS;AAAA;AAAA,EAMzE,UAAU,GAAwB;AAAA,IAChC,OAAO,CAAC,GAAG,KAAK,OAAO;AAAA;AAAA,OAMnB,gBAAe,CAAC,QAA6C;AAAA,IACjE,KAAK,iBAAiB,QAAQ;AAAA,IAC9B,IAAI,oBAAoB,KAAK,OAAO;AAAA,IAEpC,WAAW,UAAU,KAAK,SAAS;AAAA,MACjC,IAAI,OAAO,iBAAiB;AAAA,QAC1B,KAAK,iBAAiB,gBAAgB;AAAA,QACtC,IAAI;AAAA,UACF,MAAM,SAAS,MAAM,OAAO,gBAAgB,iBAAiB;AAAA,UAC7D,oBAAoB;AAAA,UACpB,KAAK,iBAAiB,OAAO,MAAM,mBAAmB;AAAA,YACpD,SAAS;AAAA,UACX,CAAC;AAAA,UACD,OAAO,OAAO;AAAA,UACd,MAAM,MAAM;AAAA,UACZ,KAAK,iBAAiB,OAAO,MAAM,mBAAmB;AAAA,YACpD,SAAS;AAAA,YACT,OAAO;AAAA,UACT,CAAC;AAAA,UACD,MAAM,IAAI,MACR,WAAW,OAAO,8CAA8C,IAAI,SACtE;AAAA;AAAA,MAEJ;AAAA,IACF;AAAA,IAGA,MAAM,iBAAiC;AAAA,SAClC;AAAA,MACH,SAAS,KAAK;AAAA,IAChB;AAAA,IAEA,OAAO;AAAA;AAAA,OAMH,mBAAkB,CACtB,WACA,SAC8B;AAAA,IAC9B,MAAM,qBAA0C,CAAC;AAAA,IAEjD,SAAS,YAAY,WAAW;AAAA,MAE9B,IAAI,mBAAmB,QAAQ,KAAK,SAAS,KAAK;AAAA,QAEhD,MAAM,UACJ,OAAO,SAAS,YAAY,WAAW,SAAS,UAAU;AAAA,QAC5D,MAAM,SAAS,gBAAgB,OAAO;AAAA,QACtC,MAAM,YAA+B;AAAA,UACnC,MAAM,SAAS,QAAQ,OAAO;AAAA,UAC9B,SAAS,OAAO;AAAA,UAChB,cAAc,OAAO;AAAA,UACrB,KAAK,SAAS;AAAA,UACd,QAAQ;AAAA,UACR,UAAU,EAAE,QAAQ,WAAW;AAAA,QACjC;AAAA,QACA,mBAAmB,KAAK,SAAS;AAAA,QACjC;AAAA,MACF;AAAA,MAGA,IAAI,qBAAqB,QAAQ,KAAK,SAAS,KAAK;AAAA,QAClD,MAAM,UACJ,OAAO,SAAS,YAAY,WAAW,SAAS,UAAU;AAAA,QAC5D,MAAM,SAAS,gBAAgB,OAAO;AAAA,QACtC,MAAM,YAA+B;AAAA,UACnC,MAAM,SAAS,QAAQ,OAAO;AAAA,UAC9B,SAAS,OAAO;AAAA,UAChB,cAAc,OAAO;AAAA,UACrB,KAAK,SAAS;AAAA,UACd,QAAQ;AAAA,UACR,UAAU,EAAE,QAAQ,SAAS;AAAA,QAC/B;AAAA,QACA,mBAAmB,KAAK,SAAS;AAAA,QACjC;AAAA,MACF;AAAA,MAGA,WAAW,UAAU,KAAK,SAAS;AAAA,QACjC,IAAI,OAAO,mBAAmB;AAAA,UAC5B,KAAK,iBAAiB,gBAAgB;AAAA,UACtC,IAAI;AAAA,YACF,WAAW,MAAM,OAAO,kBAAkB,QAAQ;AAAA,YAClD,KAAK,iBAAiB,OAAO,MAAM,qBAAqB;AAAA,cACtD,SAAS;AAAA,YACX,CAAC;AAAA,YACD,OAAO,OAAO;AAAA,YACd,MAAM,MAAM;AAAA,YACZ,KAAK,iBAAiB,OAAO,MAAM,qBAAqB;AAAA,cACtD,SAAS;AAAA,cACT,OAAO;AAAA,YACT,CAAC;AAAA,YACD,KAAK,OAAO,KACV,WAAW,OAAO,uCAAuC,IAAI,SAC/D;AAAA;AAAA,QAEJ;AAAA,MACF;AAAA,MAGA,IAAI,SAAS,KAAK;AAAA,QAChB,MAAM,aAAa,OAAO,SAAS,YAAY,WAAW,SAAS,UAAU;AAAA,QAC7E,MAAM,SAAS,gBAAgB,UAAU;AAAA,QACzC,MAAM,YAA+B;AAAA,UACnC,MAAM,SAAS,QAAQ,OAAO,gBAAgB;AAAA,UAC9C,SAAS,OAAO,WAAW;AAAA,UAC3B,cAAc,OAAO,gBAAgB,SAAS,QAAQ;AAAA,UACtD,KAAK,SAAS;AAAA,UACd,QAAQ;AAAA,UACR,UAAU,SAAS;AAAA,QACrB;AAAA,QACA,mBAAmB,KAAK,SAAS;AAAA,MACnC;AAAA,IACF;AAAA,IAEA,OAAO;AAAA;AAAA,OAMH,YAAW,CACf,UACA,SACe;AAAA,IACf,WAAW,UAAU,KAAK,SAAS;AAAA,MACjC,MAAM,OAAO,OAAO;AAAA,MACpB,IAAI,OAAO,SAAS,YAAY;AAAA,QAC9B,KAAK,iBAAiB,gBAAgB;AAAA,QACtC,IAAI;AAAA,UACF,MAAO,KAAa,KAAK,QAAQ,OAAO;AAAA,UACxC,KAAK,iBAAiB,OAAO,MAAM,UAAoB;AAAA,YACrD,SAAS;AAAA,UACX,CAAC;AAAA,UACD,OAAO,OAAO;AAAA,UACd,MAAM,MAAM;AAAA,UACZ,KAAK,iBAAiB,OAAO,MAAM,UAAoB;AAAA,YACrD,SAAS;AAAA,YACT,OAAO;AAAA,UACT,CAAC;AAAA,UACD,KAAK,OAAO,MACV,WAAW,OAAO,uBAAuB,aAAuB,IAAI,SACtE;AAAA;AAAA,MAGJ;AAAA,IACF;AAAA;AAAA,OAMI,kBAAiB,CACrB,WACA,QACuC;AAAA,IACvC,KAAK,iBAAiB,QAAQ;AAAA,IAC9B,MAAM,UAAU,IAAI;AAAA,IAGpB,MAAM,UAA2B;AAAA,MAC/B;AAAA,MACA,QAAQ,KAAK;AAAA,MACb,OAAO,KAAK;AAAA,MACZ;AAAA,MACA;AAAA,MACA,SAAS,CAAC,WAAmB,cAAsB,YAAiB;AAAA,QAClE,KAAK,cAAc,SAAS,WAAW,cAAc,OAAO;AAAA;AAAA,MAE9D,WAAW,CAAC,KAAa,WAA4B;AAAA,QACnD,QAAQ,IAAI,KAAK,MAAM;AAAA;AAAA,IAE3B;AAAA,IAGA,MAAM,KAAK,YAAY,kBAAkB,OAAO;AAAA,IAGhD,MAAM,KAAK,YAAY,YAAY,OAAO;AAAA,IAG1C,MAAM,KAAK,YAAY,iBAAiB,OAAO;AAAA,IAE/C,OAAO;AAAA;AAAA,OAMH,iBAAgB,CACpB,SACuC;AAAA,IACvC,KAAK,iBAAiB,QAAQ;AAAA,IAC9B,MAAM,qBAAqB,IAAI;AAAA,IAE/B,YAAY,KAAK,WAAW,SAAS;AAAA,MACnC,IAAI,qBAAqB,OAAO;AAAA,MAEhC,WAAW,UAAU,KAAK,SAAS;AAAA,QACjC,IAAI,OAAO,iBAAiB;AAAA,UAC1B,KAAK,iBAAiB,gBAAgB;AAAA,UACtC,IAAI;AAAA,YACF,qBAAqB,MAAM,OAAO,gBAChC,oBACA,OAAO,QAAQ,OACjB;AAAA,YACA,KAAK,iBAAiB,OAAO,MAAM,mBAAmB;AAAA,cACpD,SAAS;AAAA,YACX,CAAC;AAAA,YACD,OAAO,OAAO;AAAA,YACd,MAAM,MAAM;AAAA,YACZ,KAAK,iBAAiB,OAAO,MAAM,mBAAmB;AAAA,cACpD,SAAS;AAAA,cACT,OAAO;AAAA,YACT,CAAC;AAAA,YACD,KAAK,OAAO,KACV,WAAW,OAAO,qCAAqC,IAAI,SAC7D;AAAA;AAAA,QAEJ;AAAA,MACF;AAAA,MAEA,mBAAmB,IAAI,KAAK;AAAA,WACvB;AAAA,QACH,SAAS;AAAA,MACX,CAAC;AAAA,IACH;AAAA,IAEA,OAAO;AAAA;AAAA,OAMH,aAAY,CAAC,SAAsD;AAAA,IACvE,cAAc,WAAW,SAAS;AAAA,MAChC,IAAI;AAAA,QACF,MAAM,eAAe,KAAK,QAAQ,QAAQ,IAAI,GAAG,OAAO,IAAI;AAAA,QAC5D,MAAM,KAAK,MAAM,UAAU,KAAK,QAAQ,YAAY,CAAC;AAAA,QACrD,MAAM,KAAK,MAAM,UAAU,cAAc,OAAO,OAAO;AAAA,QAEvD,OAAO,OAAO;AAAA,QACd,MAAM,MAAM;AAAA,QACZ,KAAK,OAAO,MAAM,mBAAmB,OAAO,SAAS,IAAI,SAAS;AAAA,QAClE,MAAM;AAAA;AAAA,IAEV;AAAA;AAAA,EAMF,mBAAmB,GAA8B;AAAA,IAC/C,OAAO,IAAI,IAAI,KAAK,iBAAiB,OAAO;AAAA;AAAA,EAMtC,aAAa,CACnB,SACA,WACA,cACA,SACM;AAAA,IACN,MAAM,WAAW,QAAQ,IAAI,SAAS;AAAA,IACtC,IAAI,CAAC,UAAU;AAAA,MACb,KAAK,OAAO,KAAK,uCAAuC,WAAW;AAAA,MACnE;AAAA,IACF;AAAA,IAIA,MAAM,mBAAmB,GAAG,SAAS;AAAA;AAAA,6BAAyC;AAAA,EAAiB,KAAK,UAAU,SAAS,MAAM,CAAC;AAAA,IAE9H,QAAQ,IAAI,WAAW;AAAA,SAClB;AAAA,MACH,SAAS;AAAA,IACX,CAAC;AAAA;AAAA,EAMK,gBAAgB,CACtB,YACA,UACA,QACM;AAAA,IACN,MAAM,MAAM,GAAG,cAAc;AAAA,IAC7B,MAAM,WAAW,KAAK,iBAAiB,QAAQ,IAAI,GAAG,KAAK,CAAC;AAAA,IAC5D,SAAS,KAAK,KAAK,QAAQ,QAAQ,WAAW,CAAC;AAAA,IAC/C,KAAK,iBAAiB,QAAQ,IAAI,KAAK,QAAQ;AAAA;AAAA,EAMzC,YAAY,GAAW;AAAA,IAC7B,OAAO;AAAA,MACL,MAAM,CAAC,YAAoB,QAAQ,IAAI,OAAM,SAAS;AAAA,MACtD,MAAM,CAAC,YAAoB,QAAQ,KAAK,OAAM,SAAS;AAAA,MACvD,OAAO,CAAC,YAAoB,QAAQ,MAAM,KAAI,SAAS;AAAA,MACvD,OAAO,CAAC,YAAoB;AAAA,QAC1B,IAAI,QAAQ,IAAI,OAAO;AAAA,UACrB,QAAQ,IAAI,gBAAK,SAAS;AAAA,QAC5B;AAAA;AAAA,MAEF,SAAS,CAAC,YAAoB,QAAQ,IAAI,KAAI,SAAS;AAAA,IACzD;AAAA;AAAA,EAMM,WAAW,GAAgB;AAAA,IACjC,OAAO;AAAA,MACL,aAAa,CAAC,QAAgB;AAAA,QAC5B,OAAO,IAAI,QAAQ,aAAa,CAAC,GAAG,WAAW,OAAO,YAAY,CAAC;AAAA;AAAA,MAGrE,aAAa,CAAC,QAAgB;AAAA,QAC5B,OAAO,IAAI,QAAQ,UAAU,CAAC,WAAW,IAAI,OAAO,YAAY,GAAG;AAAA;AAAA,MAGrE,iBAAiB,CAAC,YAAoB;AAAA,QACpC,OAAO,sBAAsB,gBAAgB,OAAO,EAAE,OAAO;AAAA;AAAA,MAG/D,iBAAiB,CAAC,eAAuB;AAAA,QACvC,OAAO,gBAAgB,UAAU;AAAA;AAAA,MAGnC,YAAY,OAAO,SAAiB;AAAA,QAClC,QAAQ,4BAAe;AAAA,QACvB,OAAO,YAAW,IAAI;AAAA;AAAA,MAGxB,aAAa,CAAC,iBAAyB;AAAA,QACrC,OAAO,KAAK,QAAQ,QAAQ,IAAI,GAAG,YAAY;AAAA;AAAA,MAGjD,YAAY,OAAO,aAAqB;AAAA,QACtC,IAAI;AAAA,UACF,MAAM,GAAG,OAAO,QAAQ;AAAA,UACxB,OAAO;AAAA,UACP,MAAM;AAAA,UACN,OAAO;AAAA;AAAA;AAAA,MAIX,UAAU,OAAO,aAAqB;AAAA,QACpC,OAAO,GAAG,SAAS,UAAU,OAAO;AAAA;AAAA,MAGtC,WAAW,OAAO,UAAkB,YAAoB;AAAA,QACtD,MAAM,GAAG,UAAU,UAAU,SAAS,OAAO;AAAA;AAAA,MAG/C,WAAW,OAAO,YAAoB;AAAA,QACpC,MAAM,GAAG,MAAM,SAAS,EAAE,WAAW,KAAK,CAAC;AAAA;AAAA,IAE/C;AAAA;AAEJ;;AGrbA;AACA,wBAAS;;;ACLT;AACA;AAAA,iBACE;AAAA;;;ACIF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAkBO,SAAS,eAAe,CAAC,MAAuB;AAAA,EAErD,IAAI,OAAO,SAAS,UAAU;AAAA,IAC5B,QAAQ;AAAA,WACD;AAAA,WACA;AAAA,QACH,OAAO;AAAA,WACJ;AAAA,QACH,OAAO;AAAA,WACJ;AAAA,WACA;AAAA,QACH,OAAO;AAAA,eACA;AAAA,QAGP,MAAM,UAAU;AAAA,QAEhB,IAAI,YAAY,QAAQ;AAAA,UACtB,OAAO;AAAA,QACT;AAAA,QACA,IAAI,QAAQ,SAAS,QAAQ,KAAK,QAAQ,SAAS,OAAO,KAAK,QAAQ,SAAS,MAAM,GAAG;AAAA,UACvF,OAAO;AAAA,QACT;AAAA,QACA,IAAI,QAAQ,SAAS,MAAM,GAAG;AAAA,UAC5B,OAAO;AAAA,QACT;AAAA,QACA,IAAI,QAAQ,SAAS,MAAM,KAAK,QAAQ,SAAS,KAAK,GAAG;AAAA,UACvD,OAAO;AAAA,QACT;AAAA,QACA,OAAO;AAAA,MACT;AAAA;AAAA,EAEJ;AAAA,EAGA,IAAI,YAAY,IAAI,GAAG;AAAA,IACrB,OAAO;AAAA,EACT;AAAA,EAGA,IAAI,iBAAiB,IAAI,KAAK,gBAAgB,IAAI,GAAG;AAAA,IACnD,OAAO;AAAA,EACT;AAAA,EAGA,IAAI,cAAc,IAAI,GAAG;AAAA,IACvB,MAAM,YAAY,gBAAgB,KAAK,QAAQ;AAAA,IAE/C,IAAI,UAAU,SAAS,KAAK,KAAK,CAAC,UAAU,WAAW,GAAG,GAAG;AAAA,MAC3D,OAAO,IAAI;AAAA,IACb;AAAA,IACA,OAAO,GAAG;AAAA,EACZ;AAAA,EAGA,IAAI,UAAU,IAAI,GAAG;AAAA,IACnB,MAAM,YAAY,gBAAgB,KAAK,KAAK,IAAI;AAAA,IAEhD,IAAI,UAAU,SAAS,KAAK,KAAK,CAAC,UAAU,WAAW,GAAG,GAAG;AAAA,MAC3D,OAAO,IAAI;AAAA,IACb;AAAA,IACA,OAAO,GAAG;AAAA,EACZ;AAAA,EAGA,IAAI,WAAW,IAAI,GAAG;AAAA,IACpB,MAAM,SAAS,KAAK,MACjB,IAAI,CAAC,UAAU,GAAG,YAAY,MAAM,IAAI,MAAM,gBAAgB,MAAM,IAAI,GAAG,EAC3E,KAAK,IAAI;AAAA,IACZ,OAAO,KAAK;AAAA,EACd;AAAA,EAGA,IAAI,cAAc,IAAI,GAAG;AAAA,IACvB,MAAM,SAAS,gBAAgB,KAAK,SAAS,EAAE;AAAA,IAC/C,MAAM,UAAU,gBAAgB,KAAK,SAAS,KAAK;AAAA,IACnD,OAAO,SAAS,qBAAqB;AAAA,EACvC;AAAA,EAGA,OAAO;AAAA;AAUF,SAAS,aAAa,CAAC,KAAgC;AAAA,EAC5D,OAAO,gBAAgB,IAAI,IAAI;AAAA;;;AC/GjC;AAAA,iBACE;AAAA,sBACA;AAAA,qBACA;AAAA,iBACA;AAAA,mBACA;AAAA,eACA;AAAA,gBACA;AAAA,mBACA;AAAA;AAQK,SAAS,yBAAyB,CACvC,SACA,SACQ;AAAA,EACR,MAAM,OAAO,QAAQ;AAAA,EAErB,IAAI,OAAO,SAAS,UAAU;AAAA,IAC5B,QAAQ;AAAA,WACD;AAAA,QACH,OAAO,WAAW;AAAA,WACf;AAAA,QACH,OAAO,UAAU;AAAA,WACd;AAAA,QACH,OAAO,WAAW;AAAA,WACf;AAAA,WACA;AAAA,QACH,OAAO;AAAA,4CAC6B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,wCAUJ;AAAA;AAAA;AAAA,QAGhC,OAAO,GAAG;AAAA;AAAA,EAEhB;AAAA,EAEA,IAAI,kBAAiB,IAAI,GAAG;AAAA,IAC1B,OAAO,kBAAkB;AAAA,EAC3B;AAAA,EAEA,IAAI,iBAAgB,IAAI,GAAG;AAAA,IACzB,OAAO,iBAAiB;AAAA,EAC1B;AAAA,EAEA,IAAI,aAAY,IAAI,GAAG;AAAA,IACrB,OAAO;AAAA,sBACW;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EA4BpB;AAAA,EAEA,IAAI,eAAc,IAAI,GAAG;AAAA,IACvB,MAAM,kBAAkB,0BAA0B,SAAS;AAAA,MACzD,MAAM,KAAK;AAAA,IACb,CAAC;AAAA,IACD,OAAO,GAAG,8BAA8B,gBAAgB,QAAQ,SAAS,GAAG,SAAS;AAAA,EACvF;AAAA,EAEA,IAAI,WAAU,IAAI,GAAG;AAAA,IACnB,MAAM,kBAAkB,0BAA0B,QAAQ;AAAA,MACxD,MAAM,KAAK,KAAK;AAAA,IAClB,CAAC;AAAA,IACD,MAAM,YAAY,KAAK,KAAK,UAAU;AAAA,IACtC,OAAO;AAAA,0BACe;AAAA,+BACK;AAAA,yEAC0C;AAAA;AAAA,6CAE5B;AAAA;AAAA,EAE3C;AAAA,EAEA,IAAI,YAAW,IAAI,GAAG;AAAA,IACpB,MAAM,iBAAiB,KAAK,MAAM,IAAI,CAAC,MAAM,EAAE,IAAI;AAAA,IACnD,MAAM,aAAa,KAAK,UAAU,cAAc;AAAA,IAChD,MAAM,SAAS,KAAK,MACjB,IAAI,CAAC,UAAU;AAAA,MACd,MAAM,iBAAiB,aAAY,MAAM,IAAI;AAAA,MAC7C,MAAM,kBAAkB,0BACtB,cAAc,kBACd,EAAE,MAAM,MAAM,KAAK,CACrB;AAAA,MACA,OAAO,IAAI,MAAM,UAAU;AAAA,KAC5B,EACA,KAAK,IAAI;AAAA,IACZ,OAAO;AAAA,2BACgB;AAAA,+BACI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,0BAOL;AAAA;AAAA,EAExB;AAAA,EAEA,IAAI,eAAc,IAAI,GAAG;AAAA,IACvB,MAAM,eAAe,0BAA0B,oBAAoB;AAAA,MACjE,MAAM,KAAK,SAAS;AAAA,IACtB,CAAC;AAAA,IACD,MAAM,gBAAgB,0BAA0B,qBAAqB;AAAA,MACnE,MAAM,KAAK,SAAS;AAAA,IACtB,CAAC;AAAA,IACD,OAAO;AAAA,8BACmB;AAAA;AAAA;AAAA;AAAA,uBAIP;AAAA;AAAA;AAAA,0BAGG;AAAA;AAAA;AAAA;AAAA,EAIxB;AAAA,EAEA,OAAO,GAAG;AAAA;;;AC/JZ,wBAAS,4BAAa;AAQf,SAAS,qBAAqB,CAAC,MAA0C;AAAA,EAC9E,IAAI,KAAK,WAAW;AAAA,IAAG,OAAO;AAAA,EAE9B,MAAM,YAAY,KACf,IAAI,CAAC,QAAQ;AAAA,IACZ,MAAM,YAAY,aAAY,IAAI,IAAI;AAAA,IACtC,OAAO,GAAG,cAAc,cAAc,GAAG;AAAA,GAC1C,EACA,KAAK,IAAI;AAAA,EAEZ,OAAO,WAAW;AAAA;AAOb,SAAS,mBAAmB,CAAC,MAA0C;AAAA,EAC5E,IAAI,KAAK,WAAW;AAAA,IAAG,OAAO;AAAA,EAE9B,OAAO,KACJ,IAAI,CAAC,QAAQ;AAAA,IACZ,MAAM,UAAU,QAAQ,aAAY,IAAI,IAAI;AAAA,IAC5C,OAAO,0BAA0B,SAAS,GAAG;AAAA,GAC9C,EACA,KAAK,IAAI;AAAA;AAMP,SAAS,wBAAwB,CAAC,SAA0B;AAAA,EACjE,IAAI,YAAW,OAAO,GAAG;AAAA,IACvB,MAAM,SAAS,QAAQ,MACpB,IAAI,CAAC,UAAU;AAAA,MACd,MAAM,iBAAiB,aAAY,MAAM,IAAI;AAAA,MAC7C,MAAM,kBAAkB,0BACtB,OAAO,kBACP,EAAE,MAAM,MAAM,KAAK,CACrB;AAAA,MACA,OAAO,IAAI,MAAM,UAAU;AAAA,KAC5B,EACA,KAAK,IAAI;AAAA,IACZ,OAAO,cAAc;AAAA,EACvB;AAAA,EACA,OAAO,0BAA0B,OAAO,EAAE,MAAM,QAAQ,CAAC;AAAA;;;AHtC3D,SAAS,oBAAoB,GAAW;AAAA,EACtC,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAmCT,SAAS,uBAAuB,GAAW;AAAA,EACzC,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAOT,eAAsB,yBAAyB,CAC7C,WACiB;AAAA,EACjB,MAAM,UAAU;AAAA,EAEhB,MAAM,SAAS;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOf,MAAM,kBAAkB,wBAAwB;AAAA,EAChD,MAAM,eAAe,qBAAqB;AAAA,EAE1C,MAAM,gBAAgB,UACnB,IAAI,CAAC,aAAa,iBAAiB,QAAQ,CAAC,EAC5C,KAAK;AAAA;AAAA,CAAM;AAAA,EAEd,MAAM,OAAO,GAAG;AAAA;AAAA,EAAc;AAAA;AAAA,EAAa;AAAA;AAAA,EAAsB;AAAA;AAAA,EAAmB;AAAA,EAEpF,OAAO,WAAW,IAAI;AAAA;AAGxB,SAAS,gBAAgB,CAAC,UAAoC;AAAA,EAC5D,QAAQ,MAAM,SAAS,cAAc,QAAQ;AAAA,EAE7C,MAAM,UAAU,oBAAoB,MAAM,GAAG;AAAA,EAE7C,MAAM,UAAU,IAAI,UACjB,OAAO,CAAC,SAAsB,KAAK,WAAW,SAAS,EACvD,IAAI,CAAC,SAAsB,eAAe,MAAM,SAAS,YAAY,CAAC,EACtE,KAAK;AAAA;AAAA,GAAS;AAAA,EAGjB,MAAM,aAAa,mBAAmB,IAAI,QAAQ,CAAC,GAAG,SAAS,YAAY;AAAA,EAG3E,MAAM,aAAa,mBAAmB,IAAI,aAAa,CAAC,GAAG,SAAS,YAAY;AAAA,EAGhF,MAAM,kBAAkB,wBAAwB,IAAI,aAAa,CAAC,GAAG,SAAS,YAAY;AAAA,EAG1F,MAAM,aAAa,CAAC,SAAS,YAAY,YAAY,eAAe,EAAE,OAAO,OAAO;AAAA,EAEpF,MAAM,eAAe,gBAAgB;AAAA,cACzB;AAAA,sBACQ;AAAA,mBACH;AAAA;AAAA,IAEf,WAAW,KAAK;AAAA;AAAA,GAAS;AAAA;AAAA,EAG3B,OAAO,GAAG;AAAA;AAAA,EAAc;AAAA;AAG1B,SAAS,mBAAmB,CAAC,MAAc,KAAkB;AAAA,EAC3D,MAAM,UAAU,KAAK,UAAU,KAAK,MAAM,CAAC,EACxC,QAAQ,kCAAkC,KAAK,EAC/C,QAAQ,MAAM,GAAG;AAAA,EAEpB,OAAO,gBAAgB,aAAa;AAAA;AAGtC,SAAS,cAAc,CACrB,MACA,SACA,cACQ;AAAA,EACR,MAAM,aAAa,aAAY,KAAK,IAAI;AAAA,EAExC,IAAI,KAAK,KAAK,WAAW,GAAG;AAAA,IAC1B,OAAO,GAAG;AAAA;AAAA,0BAEY;AAAA,uBACH;AAAA,uBACA,KAAK;AAAA;AAAA;AAAA;AAAA,EAI1B;AAAA,EAEA,IAAI,KAAK,KAAK,WAAW,GAAG;AAAA,IAC1B,MAAM,kBAAkB,KAAK,KAAK,GAAG;AAAA,IACrC,MAAM,UAAU,aAAY,eAAe;AAAA,IAC3C,MAAM,UAAU,cAAc,KAAK,KAAK,EAAE;AAAA,IAC1C,MAAM,oBAAoB,0BAA0B,SAAS,KAAK,KAAK,EAAE;AAAA,IAEzE,OAAO,GAAG,0BAA0B,YAAY,iBAAiB;AAAA,YACzD,sFAAsF;AAAA,kBAChF;AAAA,qBACG;AAAA;AAAA;AAAA,0BAGK;AAAA,uBACH;AAAA,uBACA,KAAK;AAAA,uBACL;AAAA;AAAA;AAAA,EAGrB;AAAA,EAEA,MAAM,WAAW,KAAK,KAAK,IAAI,CAAC,QAAQ,aAAY,IAAI,IAAI,CAAC,EAAE,KAAK,IAAI;AAAA,EACxE,MAAM,YAAY,KAAK,KACpB,IAAI,CAAC,QAAQ;AAAA,IACZ,MAAM,YAAY,aAAY,IAAI,IAAI;AAAA,IACtC,OAAO,GAAG,cAAc,cAAc,GAAG;AAAA,GAC1C,EACA,KAAK,IAAI;AAAA,EACZ,MAAM,YAAY,KAAK,KACpB,IAAI,CAAC,QAAQ;AAAA,IACZ,MAAM,UAAU,aAAY,IAAI,IAAI;AAAA,IACpC,OAAO,0BAA0B,SAAS,GAAG;AAAA,GAC9C,EACA,KAAK,IAAI;AAAA,EACZ,MAAM,eAAe,KAAK,KACvB,IAAI,CAAC,QAAQ;AAAA,IACZ,MAAM,YAAY,aAAY,IAAI,IAAI;AAAA,IACtC,OAAO,WAAW;AAAA,GACnB,EACA,KAAK,IAAI;AAAA,EACZ,MAAM,gBAAgB,KAAK,KAAK,IAAI,CAAC,QAAQ,cAAc,GAAG,CAAC,EAAE,KAAK,IAAI;AAAA,EAE1E,OAAO,GAAG,0BAA0B,mBAAmB;AAAA,aAC5C;AAAA,WACF;AAAA,mBACQ;AAAA;AAAA;AAAA,0BAGO;AAAA,uBACH;AAAA,uBACA,KAAK;AAAA,uBACL;AAAA;AAAA;AAAA;AAUvB,SAAS,kBAAkB,CACzB,MACA,SACA,cACQ;AAAA,EACR,IAAI,CAAC,QAAQ,KAAK,WAAW,GAAG;AAAA,IAC9B,OAAO;AAAA,EACT;AAAA,EAEA,MAAM,aAAa,KAAK,IAAI,CAAC,QAAQ;AAAA,IACnC,MAAM,aAAa,aAAY,IAAI,IAAI;AAAA,IACvC,MAAM,UAAU,cAAc,EAAE,MAAM,IAAI,IAAI,CAAC;AAAA,IAC/C,MAAM,YAAY,cAAc,EAAE,MAAM,IAAI,MAAM,CAAC;AAAA,IACnD,MAAM,gBAAgB,yBAAyB,IAAI,GAAG;AAAA,IAEtD,OAAO,GAAG;AAAA,uBACS,+EAA+E;AAAA;AAAA;AAAA,uCAG/D;AAAA,2BACZ;AAAA;AAAA;AAAA;AAAA,yCAIc,WAAW,gBAAgB,IAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,uDAwBjB,IAAI;AAAA;AAAA;AAAA;AAAA;AAAA,iBAK1C,KAAK,UAAU,IAAI,GAAG;AAAA,mBACpB,KAAK,UAAU,IAAI,KAAK;AAAA;AAAA,GAExC;AAAA,EAED,OAAO;AAAA,MACH,WAAW,KAAK;AAAA;AAAA,KAAW;AAAA;AAAA;AAOjC,SAAS,kBAAkB,CACzB,WACA,SACA,cACQ;AAAA,EACR,IAAI,CAAC,aAAa,UAAU,WAAW,GAAG;AAAA,IACxC,OAAO;AAAA,EACT;AAAA,EAGA,MAAM,WAAW,UAAU,OAAO,CAAC,MAAM,EAAE,WAAW,UAAU;AAAA,EAEhE,IAAI,SAAS,WAAW,GAAG;AAAA,IACzB,OAAO;AAAA,EACT;AAAA,EAEA,MAAM,aAAa,SAAS,IAAI,CAAC,aAAa;AAAA,IAC5C,MAAM,aAAa,aAAY,SAAS,IAAI;AAAA,IAC5C,MAAM,YAAY,cAAc,EAAE,MAAM,SAAS,KAAK,CAAC;AAAA,IAEvD,OAAO,GAAG;AAAA,qFACuE;AAAA;AAAA;AAAA,uCAG9C;AAAA;AAAA;AAAA,wCAGC,WAAW,gBAAgB,SAAS;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,4DAahB,SAAS;AAAA;AAAA;AAAA;AAAA;AAAA,cAKvD,KAAK,UAAU,SAAS,IAAI;AAAA;AAAA,GAEvC;AAAA,EAED,OAAO;AAAA,MACH,WAAW,KAAK;AAAA;AAAA,KAAW;AAAA;AAAA;AAOjC,SAAS,uBAAuB,CAC9B,WACA,SACA,cACQ;AAAA,EACR,IAAI,CAAC,aAAa,UAAU,WAAW,GAAG;AAAA,IACxC,OAAO;AAAA,EACT;AAAA,EAGA,MAAM,YAAY,UAAU,OAAO,CAAC,MAAM,EAAE,WAAW,UAAU;AAAA,EAEjE,IAAI,UAAU,WAAW,GAAG;AAAA,IAC1B,OAAO;AAAA,EACT;AAAA,EAEA,MAAM,eAAe,UAAU,IAAI,CAAC,aAAa;AAAA,IAC/C,MAAM,aAAa,aAAY,SAAS,IAAI;AAAA,IAC5C,MAAM,YAAY,cAAc,EAAE,MAAM,SAAS,KAAK,CAAC;AAAA,IAEvD,OAAO,GAAG;AAAA,qFACuE;AAAA;AAAA;AAAA,uCAG9C;AAAA;AAAA;AAAA,4CAGK,WAAW,gBAAgB,SAAS;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,4DAapB,SAAS;AAAA;AAAA;AAAA;AAAA;AAAA,cAKvD,KAAK,UAAU,SAAS,IAAI;AAAA;AAAA,GAEvC;AAAA,EAED,OAAO;AAAA,MACH,aAAa,KAAK;AAAA;AAAA,KAAW;AAAA;AAAA;;;AIxW5B,SAAS,eAAe,CAC7B,QACoC;AAAA,EACpC,IAAI,WAAW;AAAA,IAAa,OAAO;AAAA,EACnC,OAAO;AAAA;AAOF,SAAS,aAAa,CAAC,MAAwB;AAAA,EACpD,IAAI,OAAO,SAAS,UAAU;AAAA,IAE5B,QAAQ;AAAA,WACD;AAAA,WACA;AAAA,WACA;AAAA,WACA;AAAA,WACA;AAAA,QACH,OAAO;AAAA;AAAA,QAGP,OAAO;AAAA;AAAA,EAEb;AAAA,EAEA,IAAI,OAAO,SAAS,YAAY,SAAS,MAAM;AAAA,IAC7C,MAAM,IAAI,MAAM,0CAA0C,OAAO,MAAM;AAAA,EACzE;AAAA,EAEA,MAAM,UAAU;AAAA,EAGhB,IAAI,YAAY,SAAS;AAAA,IACvB,MAAM,SAAS,QAAQ;AAAA,IACvB,OAAO;AAAA,MACL,MAAM;AAAA,QACJ,QAAQ,QAAQ,UAAU;AAAA,MAC5B;AAAA,IACF;AAAA,EACF;AAAA,EAGA,IAAI,UAAU,SAAS;AAAA,IACrB,MAAM,OAAO,QAAQ;AAAA,IACrB,OAAO;AAAA,MACL,MAAM;AAAA,QACJ,QAAQ,MAAM,UAAU;AAAA,MAC1B;AAAA,IACF;AAAA,EACF;AAAA,EAGA,IAAI,kBAAkB,SAAS;AAAA,IAC7B,MAAM,WAAW,QAAQ;AAAA,IACzB,OAAO;AAAA,MACL,gBAAgB;AAAA,QACd,QAAQ,UAAU,UAAU;AAAA,MAC9B;AAAA,IACF;AAAA,EACF;AAAA,EAEA,IAAI,iBAAiB,SAAS;AAAA,IAC5B,MAAM,UAAU,QAAQ;AAAA,IACxB,OAAO;AAAA,MACL,eAAe;AAAA,QACb,QAAQ,SAAS,UAAU;AAAA,MAC7B;AAAA,IACF;AAAA,EACF;AAAA,EAGA,IAAI,cAAc,SAAS;AAAA,IACzB,MAAM,WAAW,QAAQ;AAAA,IACzB,OAAO;AAAA,MACL,UAAU;AAAA,QACR,IAAI,cAAc,UAAU,MAAM,MAAM;AAAA,QACxC,OAAO,cAAc,UAAU,SAAS,SAAS;AAAA,MACnD;AAAA,IACF;AAAA,EACF;AAAA,EAGA,IAAI,cAAc,SAAS;AAAA,IACzB,OAAO;AAAA,MACL,UAAU,cAAc,QAAQ,QAAQ;AAAA,IAC1C;AAAA,EACF;AAAA,EAGA,IAAI,UAAU,SAAS;AAAA,IACrB,MAAM,OAAO,QAAQ;AAAA,IACrB,OAAO;AAAA,MACL,MAAM;AAAA,QACJ,MAAM,cAAc,MAAM,QAAQ,SAAS;AAAA,QAC3C,QAAQ,MAAM,UAAU;AAAA,MAC1B;AAAA,IACF;AAAA,EACF;AAAA,EAGA,IAAI,WAAW,SAAS;AAAA,IACtB,MAAM,QAAQ,QAAQ;AAAA,IACtB,OAAO;AAAA,MACL,OAAO,MAAM,IAAI,CAAC,WAAW;AAAA,QAC3B,MAAM,MAAM;AAAA,QACZ,MAAM,cAAc,MAAM,IAAI;AAAA,MAChC,EAAE;AAAA,IACJ;AAAA,EACF;AAAA,EAGA,MAAM,IAAI,MAAM,+BAA+B,KAAK,UAAU,IAAI,GAAG;AAAA;AAMhE,SAAS,iBAAiB,CAAC,MAA4C;AAAA,EAC5E,MAAM,SAAS,gBAAgB,KAAK,MAAgB;AAAA,EACpD,MAAM,OAAQ,KAAK,QAAmD,CAAC;AAAA,EACvE,MAAM,UAAU,KAAK;AAAA,EAErB,OAAO;AAAA,IACL,MAAM,KAAK;AAAA,IACX;AAAA,IACA,MAAM,KAAK,IAAI,CAAC,SAAS;AAAA,MACvB,MAAM,IAAI;AAAA,MACV,MAAM,cAAc,IAAI,IAAI;AAAA,IAC9B,EAAE;AAAA,IACF,SAAS,cACP,OAAO,YAAY,YAAY,YAAY,QAAQ,UAAU,UACxD,QAA8B,OAC/B,OACN;AAAA,EACF;AAAA;AAMK,SAAS,YAAY,CAAC,KAAsC;AAAA,EACjE,OAAO;AAAA,IACL,MAAM,IAAI;AAAA,IACV,KAAK,cAAc,IAAI,GAAG;AAAA,IAC1B,OAAO,cAAc,IAAI,KAAK;AAAA,EAChC;AAAA;AAMK,SAAS,iBAAiB,CAC/B,UACa;AAAA,EACb,OAAO;AAAA,IACL,MAAM,SAAS;AAAA,IACf,MAAM,cAAc,SAAS,IAAI;AAAA,IACjC,QAAQ,SAAS;AAAA,EACnB;AAAA;AAWK,SAAS,YAAY,CAAC,KAA2B;AAAA,EACtD,IAAI,OAAO,QAAQ,YAAY,QAAQ,MAAM;AAAA,IAC3C,OAAO,EAAE,WAAW,CAAC,EAAE;AAAA,EACzB;AAAA,EAEA,MAAM,SAAS;AAAA,EAEf,MAAM,YAA2B,CAAC;AAAA,EAClC,MAAM,OAAiB,CAAC;AAAA,EACxB,MAAM,YAA2B,CAAC;AAAA,EAGlC,IAAI,MAAM,QAAQ,OAAO,SAAS,GAAG;AAAA,IACnC,WAAW,QAAQ,OAAO,WAAW;AAAA,MACnC,IAAI,OAAO,SAAS,YAAY,SAAS,MAAM;AAAA,QAC7C,UAAU,KAAK,kBAAkB,IAA+B,CAAC;AAAA,MACnE;AAAA,IACF;AAAA,EACF;AAAA,EAGA,IAAI,MAAM,QAAQ,OAAO,IAAI,GAAG;AAAA,IAC9B,WAAW,OAAO,OAAO,MAAM;AAAA,MAC7B,IAAI,OAAO,QAAQ,YAAY,QAAQ,MAAM;AAAA,QAC3C,KAAK,KAAK,aAAa,GAA8B,CAAC;AAAA,MACxD;AAAA,IACF;AAAA,EACF;AAAA,EAGA,IAAI,MAAM,QAAQ,OAAO,SAAS,GAAG;AAAA,IACnC,WAAW,YAAY,OAAO,WAAW;AAAA,MACvC,IAAI,OAAO,aAAa,YAAY,aAAa,MAAM;AAAA,QACrD,UAAU,KAAK,kBAAkB,QAAmC,CAAC;AAAA,MACvE;AAAA,IACF;AAAA,EACF;AAAA,EAEA,OAAO;AAAA,IACL;AAAA,IACA,MAAM,KAAK,SAAS,IAAI,OAAO;AAAA,IAC/B,WAAW,UAAU,SAAS,IAAI,YAAY;AAAA,EAChD;AAAA;;;ALvMF,SAAS,oBAAoB,CAAC,MAAsB;AAAA,EAClD,OAAO,aAAY,IAAI;AAAA;AAMzB,eAAe,qBAAqB,CAClC,YACA,cACkB;AAAA,EAClB,QAAQ,SAAS,iBAAiB,gBAAgB,UAAU;AAAA,EAE5D,IAAI;AAAA,IAEF,QAAQ,UAAU,QAAO,MAAa;AAAA,IACtC,MAAM,cAAc,MAAM,IAAG,SAAS,cAAc,OAAO;AAAA,IAG3D,MAAM,uBAAuB;AAAA,IAC7B,MAAM,gBAAgB,IAAI;AAAA,IAE1B,IAAI;AAAA,IACJ,QAAQ,QAAQ,qBAAqB,KAAK,WAAW,OAAO,MAAM;AAAA,MAChE,cAAc,IAAI,MAAM,EAAE;AAAA,IAC5B;AAAA,IAGA,IAAI,cAAc,IAAI,YAAY,GAAG;AAAA,MACnC,OAAO;AAAA,IACT;AAAA,IACA,OAAO,OAAO;AAAA,EAMhB,MAAM,yBAAyB;AAAA,IAC7B;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AAAA,EAGA,IAAI,uBAAuB,KAAK,CAAC,YAAY,QAAQ,KAAK,YAAY,CAAC,GAAG;AAAA,IACxE,OAAO;AAAA,EACT;AAAA,EAGA,MAAM,kBAAkB;AAAA,IACtB;AAAA,IACA;AAAA,EACF;AAAA,EAEA,IAAI,gBAAgB,SAAS,OAAO,GAAG;AAAA,IACrC,OAAO;AAAA,EACT;AAAA,EAEA,OAAO;AAAA;AAMF,IAAM,WAAiD,CAC5D,UAAU,CAAC,MACR;AAAA,EACH,MAAM,eAAe,QAAQ,QAAQ;AAAA,EACrC,IAAI;AAAA,EAEJ,OAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,SAEH,gBAAe,CAAC,QAAyC;AAAA,MAC7D,IAAI;AAAA,QAEF,SAAS,MAAM,WAAW,YAAY;AAAA,QAGtC,MAAM,qBAAqB,OAAO,uBAAuB;AAAA,QACzD,MAAM,YAAY,CAAC;AAAA,QAEnB,YAAY,YAAY,QAAQ,oBAAoB;AAAA,UAClD,QAAQ,iBAAiB,gBAAgB,UAAU;AAAA,UAGnD,IAAI,CAAE,MAAM,sBAAsB,YAAY,YAAY,GAAI;AAAA,YAC5D,IAAI,QAAQ,OAAO;AAAA,cACjB,QAAQ,IAAI,0CAA+B,YAAY;AAAA,YACzD;AAAA,YACA;AAAA,UACF;AAAA,UAGA,IAAI,QAAQ,WAAW,CAAC,QAAQ,QAAQ,SAAS,YAAY,GAAG;AAAA,YAC9D;AAAA,UACF;AAAA,UACA,IAAI,QAAQ,WAAW,QAAQ,QAAQ,SAAS,YAAY,GAAG;AAAA,YAC7D;AAAA,UACF;AAAA,UAGA,MAAM,gBAAgB,qBAAqB,YAAY;AAAA,UAIvD,UAAU,KAAK;AAAA,YACb,MAAM;AAAA,YACN,SAAS;AAAA,YACT,KAAK,aAAa,GAAG;AAAA,YAErB,iBAAiB;AAAA,UACnB,CAAC;AAAA,QACH;AAAA,QAEA,IAAI,QAAQ,OAAO;AAAA,UACjB,QAAQ,IACN,sCAA2B,UAAU,+BACvC;AAAA,QACF;AAAA,QAEA,OAAO;AAAA,aACF;AAAA,UACH,WAAW,CAAC,GAAI,OAAO,aAAa,CAAC,GAAI,GAAG,SAAS;AAAA,QACvD;AAAA,QACA,OAAO,OAAO;AAAA,QACd,MAAM,MAAM;AAAA,QACZ,IAAI,QAAQ,OAAO;AAAA,UACjB,QAAQ,KACN,iDAAgD,IAAI,SACtD;AAAA,QACF;AAAA,QAEA,OAAO;AAAA;AAAA;AAAA,SAIL,SAAQ,CAAC,SAAyC;AAAA,MAEtD,MAAM,oBAAoB,QAAQ,UAAU,OAC1C,CAAC,aAAa,SAAS,UAAU,WAAW,UAC9C;AAAA,MAEA,IAAI,kBAAkB,WAAW,GAAG;AAAA,QAClC;AAAA,MACF;AAAA,MAEA,IAAI,QAAQ,OAAO;AAAA,QACjB,QAAQ,OAAO,MACb,6BAA6B,kBAAkB,2BACjD;AAAA,MACF;AAAA,MAGA,MAAM,gBAAgB,MAAM,0BAA0B,iBAAiB;AAAA,MAEvE,QAAQ,UAAU,aAAa;AAAA,QAC7B,MAAM,QAAQ,OAAO;AAAA,QACrB,SAAS;AAAA,QACT,MAAM;AAAA,MACR,CAAC;AAAA;AAAA,EAIL;AAAA;AAMF,eAAsB,kBAAkB,CACtC,QAAO,mBACW;AAAA,EAClB,IAAI;AAAA,IACF,QAAQ,UAAU,QAAO,MAAa;AAAA,IACtC,MAAM,IAAG,OAAO,KAAI;AAAA,IACpB,OAAO;AAAA,IACP,MAAM;AAAA,IACN,OAAO;AAAA;AAAA;;AMhNX,wBAAS;AAQT,SAAS,mBAAmB,CAC1B,UACA,SACQ;AAAA,EACR,QAAQ,QAAQ;AAAA,EAChB,MAAM,YAAY,IAAI,aAAa,CAAC;AAAA,EAEpC,MAAM,oBAAoB,UAAU,OAClC,CAAC,MACC,EAAE,WAAW,WACjB;AAAA,EAEA,IAAI,kBAAkB,WAAW,GAAG;AAAA,IAClC,OAAO;AAAA,EACT;AAAA,EAGA,MAAM,oBAAoB,kBAAkB,OAC1C,CAAC,SAAsB;AAAA,IACrB,IACE,QAAQ,oBACR,CAAC,QAAQ,iBAAiB,SAAS,KAAK,IAAI,GAC5C;AAAA,MACA,OAAO;AAAA,IACT;AAAA,IACA,IACE,QAAQ,oBACR,QAAQ,iBAAiB,SAAS,KAAK,IAAI,GAC3C;AAAA,MACA,OAAO;AAAA,IACT;AAAA,IACA,OAAO;AAAA,GAEX;AAAA,EAEA,IAAI,kBAAkB,WAAW,GAAG;AAAA,IAClC,OAAO;AAAA,EACT;AAAA,EAEA,MAAM,UAAU,kBAAkB,IAAI,CAAC,SAAsB;AAAA,IAC3D,MAAM,aAAa,aAAY,KAAK,IAAI;AAAA,IACxC,MAAM,gBAAgB,sBAAsB,KAAK,IAAI;AAAA,IACrD,MAAM,cAAc,oBAAoB,KAAK,IAAI;AAAA,IAEjD,OAAO,SAAS,cAAc;AAAA;AAAA;AAAA;AAAA;AAAA,4BAKN,SAAS;AAAA,yBACZ,SAAS;AAAA,yBACT,KAAK;AAAA,yBACL;AAAA,gEACuC,SAAS;AAAA;AAAA;AAAA;AAAA,GAItE;AAAA,EAED,OAAO;AAAA,MACH,QAAQ,KAAK;AAAA;AAAA,KAAW;AAAA;AAAA;AAO9B,SAAS,oBAAoB,CAC3B,UACA,SACQ;AAAA,EACR,QAAQ,QAAQ;AAAA,EAChB,MAAM,YAAY,IAAI,aAAa,CAAC;AAAA,EACpC,MAAM,aAAa,QAAQ,gBAAgB;AAAA,EAE3C,MAAM,kBAAkB,UAAU,OAChC,CAAC,MAAmB,EAAE,WAAW,QACnC;AAAA,EAEA,IAAI,gBAAgB,WAAW,GAAG;AAAA,IAChC,OAAO;AAAA,EACT;AAAA,EAGA,MAAM,oBAAoB,gBAAgB,OAAO,CAAC,SAAsB;AAAA,IACtE,IACE,QAAQ,oBACR,CAAC,QAAQ,iBAAiB,SAAS,KAAK,IAAI,GAC5C;AAAA,MACA,OAAO;AAAA,IACT;AAAA,IACA,IACE,QAAQ,oBACR,QAAQ,iBAAiB,SAAS,KAAK,IAAI,GAC3C;AAAA,MACA,OAAO;AAAA,IACT;AAAA,IACA,OAAO;AAAA,GACR;AAAA,EAED,IAAI,kBAAkB,WAAW,GAAG;AAAA,IAClC,OAAO;AAAA,EACT;AAAA,EAEA,MAAM,UAAU,kBAAkB,IAAI,CAAC,SAAsB;AAAA,IAC3D,MAAM,aAAa,aAAY,KAAK,IAAI;AAAA,IACxC,MAAM,gBAAgB,sBAAsB,KAAK,IAAI;AAAA,IACrD,MAAM,cAAc,oBAAoB,KAAK,IAAI;AAAA,IAEjD,OAAO,SAAS,cAAc;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,2DAQyB;AAAA;AAAA,uEAEY;AAAA;AAAA;AAAA;AAAA;AAAA,4BAK3C,SAAS;AAAA,yBACZ,SAAS;AAAA,yBACT,KAAK;AAAA,yBACL;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAOtB;AAAA,EAED,OAAO;AAAA,MACH,QAAQ,KAAK;AAAA;AAAA,KAAW;AAAA;AAAA;AAO9B,eAAsB,qBAAqB,CACzC,UACA,SACiB;AAAA,EACjB,MAAM,cAAc,oBAAoB,UAAU,OAAO;AAAA,EACzD,MAAM,eAAe,qBAAqB,UAAU,OAAO;AAAA,EAE3D,IAAI,CAAC,eAAe,CAAC,cAAc;AAAA,IACjC,OAAO;AAAA,EACT;AAAA,EAEA,MAAM,UAAU,CAAC,aAAa,YAAY,EAAE,OAAO,OAAO;AAAA,EAC1D,OAAO,QAAQ,KAAK;AAAA;AAAA,CAAO;AAAA;;;ACtItB,IAAM,UAA+C,CAAC,UAAU,CAAC,MAAM;AAAA,EAC5E,OAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,SAEH,SAAQ,CAAC,SAAyC;AAAA,MACtD,QAAQ,cAAc;AAAA,MAGtB,MAAM,oBAAoB,UAAU,OAAO,CAAC,aAAa;AAAA,QACvD,IAAI,QAAQ,WAAW,CAAC,QAAQ,QAAQ,SAAS,SAAS,IAAI,GAAG;AAAA,UAC/D,OAAO;AAAA,QACT;AAAA,QACA,IAAI,QAAQ,WAAW,QAAQ,QAAQ,SAAS,SAAS,IAAI,GAAG;AAAA,UAC9D,OAAO;AAAA,QACT;AAAA,QACA,OAAO;AAAA,OACR;AAAA,MAED,IAAI,kBAAkB,WAAW,GAAG;AAAA,QAClC,IAAI,QAAQ,OAAO;AAAA,UACjB,QAAQ,OAAO,MAAM,yCAAyC;AAAA,QAChE;AAAA,QACA;AAAA,MACF;AAAA,MAEA,IAAI,QAAQ,OAAO;AAAA,QACjB,QAAQ,OAAO,MACb,qDAAqD,kBAAkB,kBACzE;AAAA,MACF;AAAA,MAGA,MAAM,kBAAkB,IAAI;AAAA,MAE5B,WAAW,YAAY,mBAAmB;AAAA,QACxC,MAAM,cAAc,MAAM,sBAAsB,UAAU,OAAO;AAAA,QACjE,IAAI,aAAa;AAAA,UACf,gBAAgB,IAAI,SAAS,MAAM,WAAW;AAAA,QAChD;AAAA,MACF;AAAA,MAGA,IAAI,gBAAgB,OAAO,GAAG;AAAA,QAC5B,MAAM,iBAAiB,QAAQ,QAAQ,IAAI,WAAW;AAAA,QACtD,IAAI,gBAAgB;AAAA,UAClB,IAAI,kBAAkB,mBAAmB,eAAe,OAAO;AAAA,UAG/D,YAAY,cAAc,gBAAgB,iBAAiB;AAAA,YACzD,kBAAkB,0BAChB,iBACA,cACA,WACF;AAAA,UACF;AAAA,UAEA,QAAQ,QAAQ,IAAI,aAAa;AAAA,eAC5B;AAAA,YACH,SAAS;AAAA,UACX,CAAC;AAAA,QACH;AAAA,MACF;AAAA;AAAA,EAEJ;AAAA;AAMF,SAAS,kBAAkB,CAAC,SAAyB;AAAA,EAEnD,MAAM,oBACJ;AAAA,EACF,MAAM,QAAQ,QAAQ,MAAM,iBAAiB;AAAA,EAE7C,IAAI,OAAO;AAAA,IACT,IAAI,iBAAiB;AAAA,IAGrB,IAAI,CAAC,eAAe,SAAS,2BAA2B,GAAG;AAAA,MACzD,iBAAiB,eAAe,QAC9B,mBACA,GAAG,MAAM;AAAA,2FACX;AAAA,IACF;AAAA,IAGA,IAAI,CAAC,eAAe,SAAS,oBAAoB,GAAG;AAAA,MAClD,iBAAiB,eAAe,QAC9B,mBACA,GAAG,MAAM;AAAA,0DACX;AAAA,IACF;AAAA,IAEA,OAAO;AAAA,EACT;AAAA,EAEA,OAAO;AAAA;AAMT,SAAS,yBAAyB,CAChC,SACA,cACA,aACQ;AAAA,EAER,MAAM,kBAAkB,IAAI,OAC1B,iBAAiB,iDACjB,GACF;AAAA,EAEA,OAAO,QAAQ,QAAQ,iBAAiB,CAAC,GAAG,iBAAiB;AAAA,IAE3D,MAAM,YAAY,aAAa,QAAQ,SAAS,EAAE;AAAA,IAGlD,MAAM,sBAAsB,YACzB,MAAM;AAAA,CAAI,EACV,IAAI,CAAC,SAAS;AAAA,MAEb,IAAI,KAAK,MAAM,+BAA+B,GAAG;AAAA,QAC/C,OAAO,KAAK;AAAA,MACd;AAAA,MACA,OAAO;AAAA,KACR,EACA,KAAK;AAAA,CAAI;AAAA,IAGZ,OAAO,GAAG;AAAA;AAAA,EAEZ;AAAA;AAAA,GAEC;AAAA;;ACvKH;AAKA,eAAsB,gBAAgB,GAAoB;AAAA,EACxD,MAAM,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAuFb,OAAO,WAAW,IAAI;AAAA;;;AC7FxB;;;ACCO,IAAM,wBAAwB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ADErC,IAAM,gBAAgB;AAAA,EACpB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;AAEA,eAAsB,oBAAoB,CACxC,cAAwB,CAAC,GACR;AAAA,EAEjB,MAAM,kBAAkB,cAAc,OACpC,CAAC,aAAa,CAAC,YAAY,SAAS,QAAQ,CAC9C;AAAA,EAEA,MAAM,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAmChB,MAAM,SAAS;AAAA;AAAA;AAAA;AAAA,EAKf,MAAM,YAAY,gBACf,IAAI,CAAC,aAAa,oBAAoB,QAAQ,CAAC,EAC/C,OAAO,OAAO,EACd,KAAK;AAAA;AAAA,CAAM;AAAA,EAEd,MAAM,OAAO,GAAG;AAAA;AAAA,EAAc;AAAA;AAAA,EAAa;AAAA,EAE3C,OAAO,WAAW,IAAI;AAAA;AAGxB,SAAS,mBAAmB,CAAC,UAA0B;AAAA,EACrD,QAAQ;AAAA,SACD;AAAA,MACH,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAmEJ;AAAA,MACH,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAsCJ;AAAA,MACH,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAsCJ;AAAA,MACH,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SA2BJ;AAAA,MACH,OAAO;AAAA,SAEJ;AAAA,MACH,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SA6CJ;AAAA,MACH,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAcJ;A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",
28
+ "debugId": "7A78469222B5E6D664756E2164756E21",
29
29
  "names": []
30
30
  }