reneco-advanced-input-module 0.0.1-beta.1 → 0.0.1-beta.2
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/loader/cdn.js +1 -0
- package/loader/index.cjs.js +1 -0
- package/loader/index.d.ts +24 -0
- package/loader/index.es2017.js +1 -0
- package/loader/index.js +2 -0
- package/package.json +6 -2
- package/www/build/index.esm.js +2 -0
- package/www/build/index.esm.js.map +1 -0
- package/www/build/loader.esm.js.map +1 -0
- package/www/build/ocr-file-uploader.voice-input-module.entry.esm.js.map +1 -0
- package/www/build/p-52e59129.entry.js +2 -0
- package/www/build/p-52e59129.entry.js.map +1 -0
- package/www/build/p-DQuL1Twl.js +2 -0
- package/www/build/p-DQuL1Twl.js.map +1 -0
- package/www/build/p-jmc2yzBp.js +3 -0
- package/www/build/p-jmc2yzBp.js.map +1 -0
- package/www/build/voice-input-module.esm.js +2 -0
- package/www/build/voice-input-module.esm.js.map +1 -0
- package/www/build/voice-input-module.js +33 -0
- package/www/host.config.json +15 -0
- package/www/index.html +922 -0
- package/.editorconfig +0 -15
- package/.prettierrc.json +0 -13
- package/api-key-inject.js +0 -46
- package/env-config.js +0 -4
- package/inject-env.js +0 -20
- package/src/components/ocr-file-uploader/ocr-file-uploader.css +0 -26
- package/src/components/ocr-file-uploader/ocr-file-uploader.tsx +0 -100
- package/src/components/ocr-file-uploader/readme.md +0 -31
- package/src/components/voice-input-module/readme.md +0 -114
- package/src/components/voice-input-module/voice-input-module.css +0 -286
- package/src/components/voice-input-module/voice-input-module.tsx +0 -778
- package/src/components.d.ts +0 -158
- package/src/index.html +0 -1015
- package/src/index.ts +0 -12
- package/src/services/audio-recorder.service.ts +0 -74
- package/src/services/llm.service.ts +0 -221
- package/src/services/speech-to-text.service.ts +0 -70
- package/src/types/form-schema.types.ts +0 -78
- package/src/types/service-providers.types.ts +0 -22
- package/src/utils/schema-converter.ts +0 -494
- package/stencil.config.ts +0 -24
- package/tsconfig.json +0 -30
package/loader/cdn.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
module.exports = require('../dist/cjs/loader.cjs.js');
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
module.exports = require('../dist/cjs/loader.cjs.js');
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
export * from '../dist/types/components';
|
|
2
|
+
export interface CustomElementsDefineOptions {
|
|
3
|
+
exclude?: string[];
|
|
4
|
+
resourcesUrl?: string;
|
|
5
|
+
syncQueue?: boolean;
|
|
6
|
+
jmp?: (c: Function) => any;
|
|
7
|
+
raf?: (c: FrameRequestCallback) => number;
|
|
8
|
+
ael?: (el: EventTarget, eventName: string, listener: EventListenerOrEventListenerObject, options: boolean | AddEventListenerOptions) => void;
|
|
9
|
+
rel?: (el: EventTarget, eventName: string, listener: EventListenerOrEventListenerObject, options: boolean | AddEventListenerOptions) => void;
|
|
10
|
+
}
|
|
11
|
+
export declare function defineCustomElements(win?: Window, opts?: CustomElementsDefineOptions): void;
|
|
12
|
+
/**
|
|
13
|
+
* @deprecated
|
|
14
|
+
*/
|
|
15
|
+
export declare function applyPolyfills(): Promise<void>;
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Used to specify a nonce value that corresponds with an application's CSP.
|
|
19
|
+
* When set, the nonce will be added to all dynamically created script and style tags at runtime.
|
|
20
|
+
* Alternatively, the nonce value can be set on a meta tag in the DOM head
|
|
21
|
+
* (<meta name="csp-nonce" content="{ nonce value here }" />) which
|
|
22
|
+
* will result in the same behavior.
|
|
23
|
+
*/
|
|
24
|
+
export declare function setNonce(nonce: string): void;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from '../dist/esm/loader.js';
|
package/loader/index.js
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
(function(){if("undefined"!==typeof window&&void 0!==window.Reflect&&void 0!==window.customElements){var a=HTMLElement;window.HTMLElement=function(){return Reflect.construct(a,[],this.constructor)};HTMLElement.prototype=a.prototype;HTMLElement.prototype.constructor=HTMLElement;Object.setPrototypeOf(HTMLElement,a)}})();
|
|
2
|
+
export * from '../dist/esm/loader.js';
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "reneco-advanced-input-module",
|
|
3
|
-
"version": "0.0.1-beta.
|
|
3
|
+
"version": "0.0.1-beta.2",
|
|
4
4
|
"description": "Component to input data into forms by voice",
|
|
5
5
|
"keywords": [],
|
|
6
6
|
"author": "Natural Solutions",
|
|
@@ -27,7 +27,11 @@
|
|
|
27
27
|
"jest": "^29.7.0",
|
|
28
28
|
"jest-cli": "^29.7.0"
|
|
29
29
|
},
|
|
30
|
-
|
|
30
|
+
"files": [
|
|
31
|
+
"dist/",
|
|
32
|
+
"loader/",
|
|
33
|
+
"www/"
|
|
34
|
+
],
|
|
31
35
|
"main": "dist/index.cjs.js",
|
|
32
36
|
"module": "dist/custom-elements/index.js",
|
|
33
37
|
"es2015": "dist/esm/index.mjs",
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.esm.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loader.esm.js","sources":["@lazy-external-entrypoint?app-data=conditional"],"sourcesContent":["export { setNonce } from '@stencil/core';\nimport { bootstrapLazy } from '@stencil/core';\nimport { globalScripts } from '@stencil/core/internal/app-globals';\nexport const defineCustomElements = async (win, options) => {\n if (typeof window === 'undefined') return undefined;\n await globalScripts();\n return bootstrapLazy([/*!__STENCIL_LAZY_DATA__*/], options);\n};\n"],"names":[],"mappings":";;;;AAGY,MAAC,oBAAoB,GAAG,OAAO,GAAG,EAAE,OAAO,KAAK;AAC5D,EAAE,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,OAAO,SAAS;AACrD,EAAE,MAAM,aAAa,EAAE;AACvB,EAAE,OAAO,aAAa,CAAC,4BAA4B,EAAE,OAAO,CAAC;AAC7D;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ocr-file-uploader.voice-input-module.entry.esm.js","sources":["src/components/ocr-file-uploader/ocr-file-uploader.css?tag=ocr-file-uploader&encapsulation=shadow","src/components/ocr-file-uploader/ocr-file-uploader.tsx","src/services/audio-recorder.service.ts","src/services/speech-to-text.service.ts","src/services/llm.service.ts","src/utils/schema-converter.ts","src/components/voice-input-module/voice-input-module.css?tag=voice-input-module&encapsulation=shadow","src/components/voice-input-module/voice-input-module.tsx"],"sourcesContent":["\r\n.upload-container {\r\n display: inline-block;\r\n cursor: pointer;\r\n width: 50px;\r\n height: 50px;\r\n}\r\n\r\n.upload-button {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n transition: transform 0.2s ease, box-shadow 0.2s ease;\r\n user-select: none;\r\n}\r\n\r\n.upload-button svg {\r\n width: 50px;\r\n height: 50px;\r\n stroke: #44ee44;\r\n}\r\n\r\n.upload-button:hover svg{\r\n transform: scale(1.05);\r\n stroke: #33dd33;\r\n}","import { Component, h, Prop } from '@stencil/core';\r\n\r\n@Component({\r\n tag: 'ocr-file-uploader',\r\n styleUrl: 'ocr-file-uploader.css',\r\n shadow: true\r\n})\r\nexport class OcrFileUploader {\r\n @Prop() batch: boolean = false;\r\n @Prop() callback: Function;\r\n\r\n private fileInput!: HTMLInputElement;\r\n\r\n private triggerUpload = () => {\r\n this.fileInput.click();\r\n };\r\n\r\n private handleFileChange = async (event: Event) => {\r\n const input = event.target as HTMLInputElement;\r\n if (!input.files || input.files.length === 0) return;\r\n\r\n const file = input.files[0];\r\n\r\n // Here you can handle the file upload to your API\r\n console.log('Selected file:', file);\r\n\r\n const formData = new FormData();\r\n formData.append('file', file);\r\n\r\n if (this.batch) {\r\n try {\r\n const response = await fetch('http://127.0.0.1:5001/api/convert-to-xml', {\r\n method: 'POST',\r\n body: formData\r\n });\r\n\r\n if (!response.ok) {\r\n console.error(\"There has been an error!:\", response);\r\n throw new Error(`HTTP error! status: ${response.status}`);\r\n }\r\n // get the file as a blob\r\n const blob = await response.blob();\r\n // create a download link\r\n const url = window.URL.createObjectURL(blob);\r\n const a = document.createElement('a');\r\n a.href = url;\r\n a.download = 'result-'+Date.now().toString()+'.xlsx'; // filename\r\n document.body.appendChild(a);\r\n a.click();\r\n a.remove();\r\n window.URL.revokeObjectURL(url);\r\n } catch (err) {\r\n console.error(err);\r\n alert('Error uploading file');\r\n }\r\n }\r\n else {\r\n try {\r\n const response = await fetch('http://127.0.0.1:5001/api/convert-to-json', {\r\n method: 'POST',\r\n body: formData\r\n });\r\n\r\n if (!response.ok) {\r\n console.error(\"There has been an error!:\", response);\r\n throw new Error(`HTTP error! status: ${response.status}`);\r\n }\r\n const data = await response.json();\r\n console.log('Upload successful:', data);\r\n \r\n if (this.callback && data[0] && data[0].content){\r\n this.callback(data[0].content);\r\n }\r\n } catch (err) {\r\n console.error(err);\r\n alert('Error uploading file');\r\n }\r\n }\r\n \r\n };\r\n\r\n render() {\r\n return (\r\n <div class=\"upload-container\" onClick={this.triggerUpload}>\r\n <input\r\n type=\"file\"\r\n ref={el => (this.fileInput = el!)}\r\n onChange={this.handleFileChange}\r\n style={{ display: 'none' }}\r\n />\r\n <div class=\"upload-button\">\r\n <svg viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M13.5 3H12H8C6.34315 3 5 4.34315 5 6V18C5 19.6569 6.34315 21 8 21H12M13.5 3L19 8.625M13.5 3V7.625C13.5 8.17728 13.9477 8.625 14.5 8.625H19M19 8.625V11.8125\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M17.5 21L17.5 15M17.5 15L20 17.5M17.5 15L15 17.5\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n </div>\r\n </div>\r\n );\r\n }\r\n}\r\n","export class AudioRecorderService {\r\n private mediaRecorder: MediaRecorder | null = null;\r\n private audioChunks: Blob[] = [];\r\n private stream: MediaStream | null = null;\r\n\r\n async startRecording(): Promise<void> {\r\n try {\r\n // Check if the API exists before calling\r\n if (!navigator.mediaDevices || !navigator.mediaDevices.getUserMedia) {\r\n console.error(\r\n 'Failed to start recording:', 'Microphone access is not supported in this browser or the page is not served over HTTPS/localhost.'\r\n );\r\n return; // Exit gracefully instead of throwing\r\n }\r\n \r\n this.stream = await navigator.mediaDevices.getUserMedia({\r\n audio: {\r\n echoCancellation: true,\r\n noiseSuppression: true,\r\n autoGainControl: true\r\n }\r\n });\r\n\r\n this.audioChunks = [];\r\n this.mediaRecorder = new MediaRecorder(this.stream, {\r\n mimeType: 'audio/webm;codecs=opus'\r\n });\r\n\r\n this.mediaRecorder.ondataavailable = (event) => {\r\n if (event.data && event.data.size > 0) {\r\n this.audioChunks.push(event.data);\r\n }\r\n };\r\n\r\n this.mediaRecorder.start(100); // Collect data every 100ms\r\n } catch (error: any) {\r\n console.error('Failed to start recording:', error);\r\n }\r\n }\r\n\r\n async stopRecording(): Promise<Blob> {\r\n return new Promise((resolve, reject) => {\r\n if (!this.mediaRecorder) {\r\n reject(new Error('No active recording found'));\r\n return;\r\n }\r\n\r\n this.mediaRecorder.onstop = () => {\r\n const audioBlob = new Blob(this.audioChunks, { type: 'audio/webm' });\r\n this.cleanup();\r\n resolve(audioBlob);\r\n };\r\n\r\n this.mediaRecorder.onerror = (event) => {\r\n reject(new Error(`Recording error: ${event}`));\r\n };\r\n\r\n this.mediaRecorder.stop();\r\n });\r\n }\r\n\r\n isRecording(): boolean {\r\n return this.mediaRecorder?.state === 'recording';\r\n }\r\n\r\n private cleanup(): void {\r\n if (this.stream) {\r\n this.stream.getTracks().forEach(track => track.stop());\r\n this.stream = null;\r\n }\r\n this.mediaRecorder = null;\r\n this.audioChunks = [];\r\n }\r\n}\r\n","import { SpeechToTextProvider, ServiceProviderConfig } from '../types/service-providers.types';\r\n\r\nexport class WhisperSpeechToTextService implements SpeechToTextProvider {\r\n private apiKey: string;\r\n private baseUrl: string;\r\n\r\n constructor(config: ServiceProviderConfig['speechToText']) {\r\n // Get API key from config or environment\r\n this.apiKey = config?.apiKey || this.getEnvironmentVariable('OPENAI_API_KEY') || '';\r\n this.baseUrl = config?.baseUrl || 'https://api.openai.com/v1';\r\n \r\n if (!this.apiKey) {\r\n throw new Error('OpenAI API key is required for Whisper service');\r\n }\r\n }\r\n\r\n private getEnvironmentVariable(name: string): string | undefined {\r\n // In browser environment, we might get env vars through other means\r\n if (typeof process !== 'undefined' && process.env) {\r\n return process.env[name];\r\n }\r\n // Check if it's available as a global variable or through other means\r\n return (window as any)[name] || undefined;\r\n }\r\n\r\n async transcribe(audioContent: File, lang: string = 'en'): Promise<string> {\r\n try {\r\n const formData = new FormData();\r\n \r\n formData.append('file', audioContent);\r\n formData.append('model', 'gpt-4o-transcribe');// >>> tronque le texte ?\r\n // formData.append('model', 'gpt-4o-mini-transcribe');// >>> tronque le texte ?\r\n // formData.append('model', 'whisper-1');\r\n formData.append('language', lang);\r\n formData.append('response_format', 'json');\r\n formData.append('max_output_tokens', '2000');\r\n\r\n const response = await fetch(`${this.baseUrl}/audio/transcriptions`, {\r\n method: 'POST',\r\n headers: {\r\n 'Authorization': `Bearer ${this.apiKey}`,\r\n },\r\n body: formData,\r\n });\r\n\r\n if (!response.ok) {\r\n const errorData = await response.json().catch(() => ({ error: 'Unknown error' }));\r\n throw new Error(`Transcription failed: ${errorData.error?.message || response.statusText}`);\r\n }\r\n\r\n const result = await response.json();\r\n return result.text || '';\r\n } catch (error) {\r\n throw new Error(`Speech-to-text transcription failed: ${error.message}`);\r\n }\r\n }\r\n}\r\n\r\nexport class SpeechToTextServiceFactory {\r\n static create(config: ServiceProviderConfig): SpeechToTextProvider {\r\n const provider = config.speechToText?.provider || 'whisper';\r\n \r\n switch (provider) {\r\n case 'whisper':\r\n return new WhisperSpeechToTextService(config.speechToText);\r\n default:\r\n throw new Error(`Unsupported speech-to-text provider: ${provider}`);\r\n }\r\n }\r\n}\r\n","import { LLMProvider, ServiceProviderConfig } from '../types/service-providers.types';\r\nimport { FormSchema } from '../types/form-schema.types';\r\n\r\nexport class OpenAILLMService implements LLMProvider {\r\n private apiKey: string;\r\n private model: string;\r\n private baseUrl: string;\r\n\r\n constructor(config: ServiceProviderConfig['llm']) {\r\n // Get API key from config or environment\r\n this.apiKey = config?.apiKey || this.getEnvironmentVariable('OPENAI_API_KEY') || '';\r\n // the newest OpenAI model is \"gpt-4.1-mini\". do not change this unless explicitly requested by the user\r\n // this.model = config?.model || 'gpt-4.1-mini';\r\n this.model = config?.model || 'gpt-4.1';\r\n this.baseUrl = config?.baseUrl || 'https://api.openai.com/v1';\r\n \r\n if (!this.apiKey) {\r\n throw new Error('OpenAI API key is required for LLM service');\r\n }\r\n }\r\n\r\n private getEnvironmentVariable(name: string): string | undefined {\r\n // In browser environment, we might get env vars through other means\r\n if (typeof process !== 'undefined' && process.env) {\r\n return process.env[name];\r\n }\r\n // Check if it's available as a global variable or through other means\r\n return (window as any)[name] || undefined;\r\n }\r\n\r\n private getOptimizeFieldsDescription(schema: any){\r\n return Object.values(schema).map((field: any) => \r\n `- ${field.name ?? field.title} ` +\r\n `(${field.type}` +\r\n `${field.required ? ', required' : ''}` +\r\n `${field.readonly ? ', readonly' : ''}` +\r\n `${field.min && field.min !== \"\" ? ', min='+field.min : ''}` +\r\n `${field.max && field.max !== \"\" ? ', max='+field.max : ''}` +\r\n `)` +\r\n `${field.options ? ` - options: ${field.options.join(', ')}` : ''}`\r\n ).join('\\n')\r\n }\r\n\r\n async fillFormFromTranscription(transcription: string, schema: any): Promise<any> {\r\n return this.fillForm(transcription, schema, true);\r\n }\r\n\r\n async fillFormFromJson(json: string, schema: any): Promise<any> {\r\n return this.fillForm(json, schema, false);\r\n }\r\n\r\n private async fillForm(data: string, schema: any, dataIsTranscription: boolean = true): Promise<any> {\r\n try {\r\n // Handle complex schema format with fields array\r\n if (schema?.fields || schema?.schema) {\r\n const finalSchema = schema?.fields || schema?.schema;\r\n const systemPrompt = `You are an expert form-filling assistant. You will receive a voice transcription and form field definitions. Your task is to extract values from the spoken content.\r\n Rules:\r\n 1. Only extract values that can be confidently determined from the transcription\r\n 2. Respect field types (string, number, datetime, boolean, select)\r\n 3. For datetime fields, use ISO format (YYYY-MM-DDTHH:MM)\r\n 4. For date fields, use the following format: DD/MM/YYY\r\n 5. For boolean fields, interpret yes/no, true/false, positive/negative responses\r\n 6. For select fields, use exact option values from the provided choices\r\n 7. Only include fields where relevant information is found\r\n 8. The current GMT datetime is ${(new Date() as any).toGMTString()}\r\n 9. Respect the constraints written between parenthesis for readonly status (readonly fields must not be filled with values), min and max values, whatever the transcription says\r\n\r\n Respond with JSON in this exact format: {\"fields\": [{\"name\": \"field_name\", \"value\": \"extracted_value\"}]}`;\r\n\r\n let userPrompt = `\r\n Voice transcription: \"${data}\"\r\n\r\n Form fields:\r\n ${this.getOptimizeFieldsDescription(finalSchema)}\r\n\r\n Please extract values from the Transcription for these fields.\r\n `;\r\n\r\n //TODO\r\n\r\n // const userPrompt = (\r\n // dataIsTranscription \r\n // ?\r\n // `Voice transcription: \"${data}\"`\r\n // : \r\n // `Json datas: \"${JSON.stringify(data)}\"`\r\n // )+`\r\n\r\n // Form fields:\r\n // ${this.getOptimizeFieldsDescription(finalSchema)}\r\n\r\n // Please extract values from the ` + \r\n // (\r\n // dataIsTranscription \r\n // ?\r\n // `Transcription`\r\n // : \r\n // `Json generated file`\r\n // )+` for these fields.`;\r\n\r\n const response = await fetch(`${this.baseUrl}/chat/completions`, {\r\n method: 'POST',\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Authorization': `Bearer ${this.apiKey}`,\r\n },\r\n body: JSON.stringify({\r\n model: this.model,\r\n messages: [\r\n { role: 'system', content: systemPrompt },\r\n { role: 'user', content: userPrompt }\r\n ],\r\n response_format: { type: 'json_object' },\r\n temperature: 0.1,\r\n }),\r\n });\r\n\r\n if (!response.ok) {\r\n const errorData = await response.json().catch(() => ({ error: 'Unknown error' }));\r\n throw new Error(`LLM API failed: ${errorData.error?.message || response.statusText}`);\r\n }\r\n\r\n const result = await response.json();\r\n return JSON.parse(result.choices[0].message.content);\r\n }\r\n\r\n // Handle simple schema format (backward compatibility)\r\n const systemPrompt = `You are an expert form-filling assistant. You will receive a voice transcription and a JSON form schema. Your task is to intelligently fill the form fields based on the spoken content.\r\n Rules:\r\n 1. Only fill fields that can be confidently determined from the transcription\r\n 2. Respect field types (string, number, date, boolean, select)\r\n 3. For datetime fields, use ISO format (YYYY-MM-DDTHH:MM)\r\n 4. For date fields, use the following format: DD/MM/YYY\r\n 5. For boolean fields, interpret yes/no, true/false, positive/negative responses\r\n 6. For select fields, match the closest option from the provided choices\r\n 7. Leave fields empty if no relevant information is found\r\n 8. Return the same schema structure with 'default' values filled\r\n 9. The current GMT datetime is ${(new Date() as any).toGMTString()}\r\n 10. Respect the constraints written between parenthesis for readonly status (readonly fields must not be filled with values), min and max values, whatever the transcription says\r\n\r\n Respond with JSON in this exact format: {\"schema\": {...}}`;\r\n\r\n let userPrompt = `\r\n Voice transcription: \"${data}\"\r\n\r\n Form schema to fill:\r\n ${JSON.stringify(schema, null, 2)}\r\n\r\n Please fill the form fields based on the Transcription and return the schema with default values populated.\r\n `;\r\n\r\n // const userPrompt = (\r\n // dataIsTranscription \r\n // ?\r\n // `Voice transcription: \"${data}\"`\r\n // : \r\n // `Json datas: \"${JSON.stringify(data)}\"`\r\n // )+`\r\n\r\n // Form schema to fill:\r\n // ${JSON.stringify(schema, null, 2)}\r\n\r\n // Please fill the form fields based on the ` + \r\n // (\r\n // dataIsTranscription \r\n // ?\r\n // `Transcription`\r\n // : \r\n // `Json generated file`\r\n // )+` nd return the schema with default values populated.`;\r\n\r\n const response = await fetch(`${this.baseUrl}/chat/completions`, {\r\n method: 'POST',\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Authorization': `Bearer ${this.apiKey}`,\r\n },\r\n body: JSON.stringify({\r\n model: this.model,\r\n messages: [\r\n { role: 'system', content: systemPrompt },\r\n { role: 'user', content: userPrompt }\r\n ],\r\n response_format: { type: 'json_object' },\r\n temperature: 0.1, // Low temperature for consistency\r\n }),\r\n });\r\n\r\n if (!response.ok) {\r\n const errorData = await response.json().catch(() => ({ error: 'Unknown error' }));\r\n throw new Error(`LLM API failed: ${errorData.error?.message || response.statusText}`);\r\n }\r\n\r\n const result = await response.json();\r\n const filledSchema = JSON.parse(result.choices[0].message.content);\r\n \r\n // Validate that the response has the correct structure\r\n if (!filledSchema.schema) {\r\n throw new Error('Invalid response format from LLM service');\r\n }\r\n\r\n return filledSchema;\r\n } catch (error) {\r\n throw new Error(`Form filling failed: ${error.message}`);\r\n }\r\n }\r\n}\r\n\r\nexport class LLMServiceFactory {\r\n static create(config: ServiceProviderConfig): LLMProvider {\r\n const provider = config.llm?.provider || 'openai';\r\n \r\n switch (provider) {\r\n case 'openai':\r\n return new OpenAILLMService(config.llm);\r\n default:\r\n throw new Error(`Unsupported LLM provider: ${provider}`);\r\n }\r\n }\r\n}\r\n","import { FormSchema, FormField, FormSchemaFieldsOnly, FormSchemaFieldsOnlyExtended, FormFieldExtended } from '../types/form-schema.types';\r\n\r\nexport class SchemaConverter {\r\n /**\r\n * Convert XML form definition to JSON schema\r\n */\r\n static convertXmlToJsonLegacy(xmlForm: string): FormSchema {\r\n try {\r\n const parser = new DOMParser();\r\n const xmlDoc = parser.parseFromString(xmlForm, 'text/xml');\r\n \r\n if (xmlDoc.querySelector('parsererror')) {\r\n throw new Error('Invalid XML format');\r\n }\r\n\r\n const schema: FormSchema = {\r\n schema: {}\r\n };\r\n\r\n // Extract form title and description\r\n const formElement = xmlDoc.querySelector('form');\r\n if (formElement) {\r\n schema.title = formElement.getAttribute('title') || undefined;\r\n schema.description = formElement.getAttribute('description') || undefined;\r\n }\r\n\r\n // Process input fields\r\n const inputs = xmlDoc.querySelectorAll('input, select, textarea');\r\n inputs.forEach(input => {\r\n const name = input.getAttribute('name');\r\n if (!name) return;\r\n\r\n const field: FormField = {\r\n type: this.mapXmlTypeToJsonTypeLegacy(input.tagName.toLowerCase(), input.getAttribute('type')),\r\n title: input.getAttribute('title') || input.getAttribute('placeholder') || name,\r\n description: input.getAttribute('description') || undefined,\r\n required: input.hasAttribute('required'),\r\n default: input.getAttribute('value') || undefined\r\n };\r\n\r\n // Handle select options\r\n if (input.tagName.toLowerCase() === 'select') {\r\n const options = Array.from(input.querySelectorAll('option')).map(option => \r\n option.textContent || option.getAttribute('value') || ''\r\n );\r\n if (options.length > 0) {\r\n field.options = options;\r\n }\r\n }\r\n\r\n // Handle validation attributes\r\n const min = input.getAttribute('min');\r\n const max = input.getAttribute('max');\r\n const pattern = input.getAttribute('pattern');\r\n\r\n if (min) field.min = parseFloat(min);\r\n if (max) field.max = parseFloat(max);\r\n if (pattern) field.pattern = pattern;\r\n\r\n schema.schema[name] = field;\r\n });\r\n\r\n return schema;\r\n } catch (error) {\r\n throw new Error(`XML to JSON conversion failed: ${error.message}`);\r\n }\r\n }\r\n\r\n /**\r\n * Convert JSON schema to XML form definition\r\n */\r\n static convertJsonToXmlLegacy(jsonForm: FormSchema): string {\r\n try {\r\n const doc = document.implementation.createDocument('', '', null);\r\n const form = doc.createElement('form');\r\n \r\n if (jsonForm.title) {\r\n form.setAttribute('title', jsonForm.title);\r\n }\r\n if (jsonForm.description) {\r\n form.setAttribute('description', jsonForm.description);\r\n }\r\n\r\n Object.entries(jsonForm.schema).forEach(([fieldName, field]) => {\r\n // Inject default value from root if present\r\n const valueFromRoot = (jsonForm as any)[fieldName];\r\n const fieldWithDefault = {\r\n ...field,\r\n default: field.default ?? valueFromRoot // field.default has priority\r\n };\r\n\r\n const element = this.createXmlElementLegacy(doc, fieldName, fieldWithDefault);\r\n if (element) {\r\n form.appendChild(element);\r\n }\r\n });\r\n\r\n doc.appendChild(form);\r\n\r\n const serializer = new XMLSerializer();\r\n return serializer.serializeToString(doc);\r\n } catch (error) {\r\n throw new Error(`JSON to XML conversion failed: ${error.message}`);\r\n }\r\n }\r\n\r\n private static mapXmlTypeToJsonTypeLegacy(tagName: string, type: string | null): FormField['type'] {\r\n switch (tagName) {\r\n case 'select':\r\n return 'select';\r\n case 'textarea':\r\n return 'string';\r\n case 'input':\r\n switch (type) {\r\n case 'number':\r\n case 'range':\r\n return 'number';\r\n case 'date':\r\n case 'datetime-local':\r\n case 'time':\r\n return 'date';\r\n case 'checkbox':\r\n return 'boolean';\r\n default:\r\n return 'string';\r\n }\r\n default:\r\n return 'string';\r\n }\r\n }\r\n\r\n private static createXmlElementLegacy(doc: Document, fieldName: string, field: FormField): Element | null {\r\n let element: Element;\r\n\r\n switch (field.type) {\r\n case 'select':\r\n element = doc.createElement('select');\r\n if (field.options) {\r\n field.options.forEach(option => {\r\n const optionElement = doc.createElement('option');\r\n optionElement.setAttribute('value', option);\r\n optionElement.textContent = option;\r\n // Set selected if it matches the default value\r\n if (field.default !== undefined && field.default === option) {\r\n optionElement.setAttribute('selected', 'true');\r\n }\r\n element.appendChild(optionElement);\r\n });\r\n }\r\n break;\r\n\r\n case 'boolean':\r\n element = doc.createElement('input');\r\n element.setAttribute('type', 'checkbox');\r\n if (field.default === true || field.default === 'true') {\r\n element.setAttribute('checked', 'true');\r\n }\r\n break;\r\n\r\n case 'number':\r\n element = doc.createElement('input');\r\n element.setAttribute('type', 'number');\r\n if (field.min !== undefined) element.setAttribute('min', field.min.toString());\r\n if (field.max !== undefined) element.setAttribute('max', field.max.toString());\r\n if (field.default !== undefined) element.setAttribute('value', field.default.toString());\r\n break;\r\n\r\n case 'date':\r\n element = doc.createElement('input');\r\n element.setAttribute('type', 'date');\r\n if (field.default !== undefined) element.setAttribute('value', field.default.toString());\r\n break;\r\n\r\n default: // string, text, etc.\r\n element = doc.createElement('input');\r\n element.setAttribute('type', 'text');\r\n if (field.default !== undefined) element.setAttribute('value', field.default.toString());\r\n }\r\n\r\n element.setAttribute('name', fieldName);\r\n element.setAttribute('title', field.title);\r\n\r\n if (field.description) {\r\n element.setAttribute('description', field.description);\r\n }\r\n if (field.required) {\r\n element.setAttribute('required', 'true');\r\n }\r\n if (field.pattern) {\r\n element.setAttribute('pattern', field.pattern);\r\n }\r\n\r\n return element;\r\n }\r\n\r\n \r\n /**\r\n * Convert new XML form definition to JSON schema\r\n */\r\n static async convertXmlToJson(xmlForm: string, classificationRootURL: string = \"http://localhost\", lang: 'fr'|'en' = 'en'): Promise<FormSchemaFieldsOnly> {\r\n try {\r\n const parser = new DOMParser();\r\n const xmlDoc = parser.parseFromString(xmlForm, 'text/xml');\r\n\r\n if (xmlDoc.querySelector('parsererror')) {\r\n throw new Error('Invalid XML format');\r\n }\r\n\r\n // Root Xforms element (optional)\r\n const xforms = xmlDoc.querySelector('Xforms');\r\n if (!xforms) throw new Error('No Xforms root element found');\r\n\r\n const fields = xforms.querySelectorAll('Fields');\r\n if (fields.length === 0) throw new Error('No Fields elements found');\r\n\r\n const schema: FormSchemaFieldsOnly = {\r\n fields: {}\r\n };\r\n\r\n for (const fieldEl of Array.from(fields)) {\r\n // Read key info\r\n const name = fieldEl.querySelector('SystemName')?.textContent?.trim();\r\n if (!name) return;\r\n\r\n const helpText = fieldEl.querySelector('HelpText')?.textContent?.trim();\r\n const defaultValue = fieldEl.querySelector('DefaultValue')?.textContent;\r\n const enabledText = fieldEl.querySelector('Enabled')?.textContent?.trim().toLowerCase() || 'true';\r\n const isEnabled = enabledText === 'true';\r\n\r\n // keep as memory\r\n const field_ID = fieldEl.querySelector('ID')?.textContent;\r\n const field_TFie_PK_ID = fieldEl.querySelector('TFie_PK_ID')?.textContent;\r\n const field_TVal_PK_ID = fieldEl.querySelector('TVal_PK_ID')?.textContent;\r\n const field_TFIn_PK_ID = fieldEl.querySelector('TFIn_PK_ID')?.textContent;\r\n const field_isForm = fieldEl.querySelector('isForm')?.textContent;\r\n const field_LabelText = fieldEl.querySelector('LabelText')?.textContent;\r\n const field_SystemName = fieldEl.querySelector('SystemName')?.textContent;\r\n const field_CssStyle = fieldEl.querySelector('CssStyle')?.textContent;\r\n const field_ControlType = fieldEl.querySelector('ControlType')?.textContent || 'TextBox';\r\n const field_ValidationRequired = fieldEl.querySelector('ValidationRequired')?.textContent;\r\n const field_ValidationMin = fieldEl.querySelector('ValidationMin')?.textContent;\r\n const field_ValidationMax = fieldEl.querySelector('ValidationMax')?.textContent;\r\n const field_Mask = fieldEl.querySelector('Mask')?.textContent;\r\n const field_TypeId = fieldEl.querySelector('TypeId')?.textContent;\r\n const field_Unit = fieldEl.querySelector('Unit')?.textContent;\r\n const field_TFie_Fullpath = fieldEl.querySelector('TFie_Fullpath')?.textContent;\r\n const field_TVal_FK_Parent_ID = fieldEl.querySelector('TVal_FK_Parent_ID')?.textContent;\r\n\r\n const field: FormFieldExtended = {\r\n type: this.mapControlTypeToJsonType(field_ControlType),\r\n title: field_LabelText,\r\n description: helpText,\r\n required: field_ValidationRequired?.toLowerCase() === 'required',\r\n default: defaultValue || undefined,\r\n\r\n realType: field_ControlType,\r\n\r\n Enabled: isEnabled,\r\n ID: field_ID,\r\n TFie_PK_ID: field_TFie_PK_ID,\r\n TVal_PK_ID: field_TVal_PK_ID,\r\n TFIn_PK_ID: field_TFIn_PK_ID,\r\n isForm: field_isForm,\r\n LabelText: field_LabelText,\r\n SystemName: field_SystemName,\r\n CssStyle: field_CssStyle,\r\n ControlType: field_ControlType,\r\n ValidationRequired: field_ValidationRequired,\r\n ValidationMin: field_ValidationMin,\r\n ValidationMax: field_ValidationMax,\r\n Mask: field_Mask,\r\n TypeId: field_TypeId,\r\n Unit: field_Unit,\r\n TFie_Fullpath: field_TFie_Fullpath,\r\n TVal_FK_Parent_ID: field_TVal_FK_Parent_ID\r\n };\r\n\r\n // Handle select options\r\n if (field.type.toLowerCase() === 'select') {\r\n try {\r\n const response = await fetch(`${classificationRootURL}/ng/api/v1/classification/getList/${field.ControlType.toLowerCase() == 'termpicker' ? \"Position\" : \"Thesaurus\"}/?StartNodeID=${field_TypeId}`);\r\n if (!response.ok) throw new Error(`HTTP error! status: ${response.status}`);\r\n\r\n const data = await response.json();\r\n if (Array.isArray(data)) {\r\n const options = data.map(item => ({\r\n value: item.ID,\r\n label: item.System_Name\r\n }));\r\n if (options.length > 0) {\r\n field.pickerOptions = options;\r\n // TODO on degage les quotes simples temporairement, a corriger\r\n field.options = options.map(option => option.label.replace(\"'\", \"\"));\r\n }\r\n } else {\r\n console.error(\"Unexpected API response format:\", data);\r\n }\r\n } catch (error) {\r\n console.error(\"Error fetching classification data:\", error);\r\n }\r\n }\r\n\r\n if (field_ValidationMin) field.min = parseFloat(field_ValidationMin);\r\n if (field_ValidationMax) field.max = parseFloat(field_ValidationMax);\r\n if (field_Mask) field.pattern = field_Mask;\r\n\r\n // Optional: Add any other fields you want to track, e.g. min, max, pattern (not clearly in your XML)\r\n // You could also add the raw ControlType for round-trip fidelity if you want\r\n\r\n schema.fields[field_ID] = field;\r\n };\r\n\r\n return schema;\r\n } catch (error) {\r\n throw new Error(`XML to JSON conversion failed: ${error.message}`);\r\n }\r\n }\r\n\r\n /**\r\n * Convert JSON schema back to your new XML form definition format\r\n */\r\n static convertJsonToXml(jsonForm: FormSchemaFieldsOnlyExtended): string {\r\n try {\r\n const doc = document.implementation.createDocument('', '', null);\r\n const xforms = doc.createElement('Xforms');\r\n\r\n Object.entries(( (jsonForm as any).schema ? (jsonForm as any).schema : (jsonForm as any).fields )).forEach(([fieldID, field]) => {\r\n const fieldEl = doc.createElement('Fields');\r\n const fieldToUse = (field as FormFieldExtended);\r\n\r\n // Set all subelements based on your XML structure\r\n // ID, PK IDs etc are missing here, so omit or generate dummy\r\n\r\n // <SystemName>\r\n const systemNameEl = doc.createElement('SystemName');\r\n systemNameEl.textContent = fieldToUse.SystemName;\r\n fieldEl.appendChild(systemNameEl);\r\n\r\n // <LabelText>\r\n const labelEl = doc.createElement('LabelText');\r\n labelEl.textContent = fieldToUse.title || fieldID;\r\n fieldEl.appendChild(labelEl);\r\n\r\n // <HelpText>\r\n const helpEl = doc.createElement('HelpText');\r\n helpEl.textContent = fieldToUse.description;\r\n fieldEl.appendChild(helpEl);\r\n\r\n // <ControlType>\r\n const controlTypeEl = doc.createElement('ControlType');\r\n controlTypeEl.textContent = fieldToUse.realType;\r\n fieldEl.appendChild(controlTypeEl);\r\n\r\n // <ValidationRequired>\r\n const validationEl = doc.createElement('ValidationRequired');\r\n validationEl.textContent = fieldToUse.required ? 'Required' : 'Not Required';\r\n fieldEl.appendChild(validationEl);\r\n\r\n // <DefaultValue>\r\n const defaultEl = doc.createElement('DefaultValue');\r\n const valueEl = doc.createElement('Value');\r\n if (jsonForm[fieldID] !== undefined) {\r\n defaultEl.textContent = jsonForm[fieldID].toString();\r\n valueEl.textContent = jsonForm[fieldID].toString();\r\n }\r\n else {\r\n defaultEl.textContent = fieldToUse.default || fieldToUse.value;\r\n valueEl.textContent = fieldToUse.value || fieldToUse.default;\r\n }\r\n fieldEl.appendChild(defaultEl);\r\n fieldEl.appendChild(valueEl);\r\n\r\n // <Enabled>\r\n const enabledEl = doc.createElement('Enabled');\r\n enabledEl.textContent = fieldToUse.Enabled === false ? 'False' : 'True';\r\n fieldEl.appendChild(enabledEl);\r\n\r\n // Add <isForm> Field to distinguish Field or Header etc\r\n const isFormEl = doc.createElement('isForm');\r\n isFormEl.textContent = fieldToUse.isForm;\r\n fieldEl.appendChild(isFormEl);\r\n\r\n if (fieldToUse.type === 'header') {\r\n const headerEl = doc.createElement('Header');\r\n headerEl.textContent = fieldToUse.title;\r\n fieldEl.appendChild(headerEl);\r\n }\r\n \r\n const idEl = doc.createElement('ID');\r\n idEl.textContent = fieldToUse.ID;\r\n fieldEl.appendChild(idEl);\r\n\r\n const tfiePkIdEl = doc.createElement('TFie_PK_ID');\r\n tfiePkIdEl.textContent = fieldToUse.TFie_PK_ID;\r\n fieldEl.appendChild(tfiePkIdEl);\r\n\r\n const tvalPkIdEl = doc.createElement('TVal_PK_ID');\r\n tvalPkIdEl.textContent = fieldToUse.TVal_PK_ID;\r\n fieldEl.appendChild(tvalPkIdEl);\r\n\r\n const tfInPkIdEl = doc.createElement('TFIn_PK_ID');\r\n tfInPkIdEl.textContent = fieldToUse.TFIn_PK_ID;\r\n fieldEl.appendChild(tfInPkIdEl);\r\n\r\n const cssStyleEl = doc.createElement('CssStyle');\r\n cssStyleEl.textContent = fieldToUse.CssStyle;\r\n fieldEl.appendChild(cssStyleEl);\r\n\r\n const typeIdEl = doc.createElement('TypeId');\r\n typeIdEl.textContent = fieldToUse.TypeId;\r\n fieldEl.appendChild(typeIdEl);\r\n\r\n const unitEl = doc.createElement('Unit');\r\n unitEl.textContent = fieldToUse.Unit;\r\n fieldEl.appendChild(unitEl);\r\n\r\n const tfieFullPathEl = doc.createElement('TFie_Fullpath');\r\n tfieFullPathEl.textContent = fieldToUse.TFie_Fullpath;\r\n fieldEl.appendChild(tfieFullPathEl);\r\n\r\n const tvalFkParentIdEl = doc.createElement('TVal_FK_Parent_ID');\r\n tvalFkParentIdEl.textContent = fieldToUse.TVal_FK_Parent_ID;\r\n fieldEl.appendChild(tvalFkParentIdEl);\r\n\r\n const validationMinEl = doc.createElement('ValidationMin');\r\n validationMinEl.textContent = fieldToUse.ValidationMin;\r\n fieldEl.appendChild(validationMinEl);\r\n\r\n const validationMaxEl = doc.createElement('ValidationMax');\r\n validationMaxEl.textContent = fieldToUse.ValidationMax;\r\n fieldEl.appendChild(validationMaxEl);\r\n\r\n const maskEl = doc.createElement('Mask');\r\n maskEl.textContent = fieldToUse.Mask;\r\n fieldEl.appendChild(maskEl);\r\n\r\n // Append to Xforms root\r\n xforms.appendChild(fieldEl);\r\n });\r\n\r\n doc.appendChild(xforms);\r\n\r\n const serializer = new XMLSerializer();\r\n return serializer.serializeToString(doc);\r\n } catch (error) {\r\n throw new Error(`JSON to XML conversion failed: ${error.message}`);\r\n }\r\n }\r\n\r\n private static mapControlTypeToJsonType(controlType: string): FormField['type'] {\r\n // Map your ControlType XML field to JSON field types\r\n switch (controlType.toLowerCase()) {\r\n case 'textbox':\r\n case 'text':\r\n return 'string';\r\n case 'datepicker':\r\n return 'date';\r\n case 'thesauruspicker':\r\n case 'thesauruspicker-ddl':\r\n case 'termpicker':\r\n return 'select';\r\n case 'dbpicker':\r\n return 'dbpicker'; // custom type if needed\r\n case 'header':\r\n return 'header'; // special type to handle header elements\r\n case 'checkbox':\r\n return 'boolean';\r\n case 'realpicker':\r\n return 'number';\r\n default:\r\n return 'string';\r\n }\r\n }\r\n\r\n // private static mapJsonTypeToControlType(type: string): string {\r\n // switch (type.toLowerCase()) {\r\n // case 'string':\r\n // return 'TextBox';\r\n // case 'date':\r\n // return 'DatePicker';\r\n // case 'select':\r\n // return 'ThesaurusPicker';\r\n // case 'dbpicker':\r\n // return 'DBPicker';\r\n // case 'boolean':\r\n // return 'CheckBox';\r\n // case 'header':\r\n // return 'Header';\r\n // default:\r\n // return 'TextBox';\r\n // }\r\n // }\r\n\r\n}\r\n",":host {\r\n display: block;\r\n font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;\r\n}\r\n\r\n.row-audio-area {\r\n display: flex;\r\n flex-direction: row;\r\n}\r\n\r\n.voice-recorder-container {\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n gap: 1rem;\r\n padding: 1rem;\r\n border: 1px solid #e5e7eb;\r\n border-radius: 0.5rem;\r\n background: #ffffff;\r\n max-width: 100px;\r\n margin: 0 auto;\r\n}\r\n\r\n.voice-recorder-container-debug {\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n gap: 1rem;\r\n padding: 1rem;\r\n border: 1px solid #e5e7eb;\r\n border-radius: 0.5rem;\r\n background: #ffffff;\r\n max-width: 800px;\r\n margin: 0 auto;\r\n}\r\n\r\n.upload-record-container {\r\n display: inline-block;\r\n cursor: pointer;\r\n width: 50px;\r\n height: 50px;\r\n}\r\n\r\n.upload-record-button {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n transition: transform 0.2s ease, box-shadow 0.2s ease;\r\n user-select: none;\r\n}\r\n\r\n.upload-record-button svg {\r\n width: 50px;\r\n height: 50px;\r\n stroke: #4444ee;\r\n}\r\n\r\n.upload-record-button svg path {\r\n fill: #4444ee;\r\n}\r\n\r\n.upload-record-button:hover svg {\r\n transform: scale(1.05);\r\n stroke: #4444ee;\r\n}\r\n\r\n.record-button {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n width: 50px;\r\n height: 50px;\r\n border: none;\r\n border-radius: 50%;\r\n background: #ee4444;\r\n color: white;\r\n cursor: pointer;\r\n transition: all 0.2s ease;\r\n position: relative;\r\n overflow: hidden;\r\n}\r\n\r\n.record-button:hover:not(:disabled) {\r\n background: #dd3333;\r\n transform: scale(1.05);\r\n}\r\n\r\n.record-button:disabled {\r\n opacity: 0.6;\r\n cursor: not-allowed;\r\n}\r\n\r\n.record-button.recording {\r\n background: #dd3333;\r\n animation: pulse 1.5s infinite;\r\n}\r\n\r\n.record-button.processing {\r\n background: #3b82f6;\r\n}\r\n\r\n@keyframes pulse {\r\n 0% {\r\n box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.7);\r\n }\r\n 70% {\r\n box-shadow: 0 0 0 10px rgba(239, 68, 68, 0);\r\n }\r\n 100% {\r\n box-shadow: 0 0 0 0 rgba(239, 68, 68, 0);\r\n }\r\n}\r\n\r\n.record-icon {\r\n width: 24px;\r\n height: 24px;\r\n fill: currentColor;\r\n}\r\n\r\n.status-text {\r\n font-size: 0.875rem;\r\n color: #6b7280;\r\n text-align: center;\r\n min-height: 1.25rem;\r\n}\r\n\r\n.status-text.error {\r\n color: #ee4444;\r\n}\r\n\r\n.status-text.success {\r\n color: #10b981;\r\n}\r\n\r\n.debug-panel {\r\n width: 100%;\r\n margin-top: 1rem;\r\n padding: 1rem;\r\n background: #f9fafb;\r\n border: 1px solid #e5e7eb;\r\n border-radius: 0.375rem;\r\n font-family: 'Monaco', 'Menlo', 'Ubuntu Mono', monospace;\r\n font-size: 0.75rem;\r\n}\r\n\r\n.debug-title {\r\n font-weight: 600;\r\n margin-bottom: 0.5rem;\r\n color: #374151;\r\n}\r\n\r\n.debug-content {\r\n white-space: pre-wrap;\r\n word-break: break-word;\r\n color: #6b7280;\r\n max-height: 200px;\r\n overflow-y: auto;\r\n}\r\n\r\n.permissions-warning {\r\n padding: 0.75rem;\r\n background: #fef3c7;\r\n border: 1px solid #f59e0b;\r\n border-radius: 0.375rem;\r\n color: #92400e;\r\n font-size: 0.875rem;\r\n text-align: center;\r\n}\r\n\r\n.form-preview {\r\n width: 100%;\r\n margin-top: 1rem;\r\n padding: 1rem;\r\n background: #f8fafc;\r\n border: 1px solid #e2e8f0;\r\n border-radius: 0.375rem;\r\n}\r\n\r\n.form-preview-title {\r\n font-weight: 600;\r\n margin-bottom: 0.5rem;\r\n color: #1e293b;\r\n}\r\n\r\n.form-field {\r\n margin-bottom: 0.5rem;\r\n font-size: 0.875rem;\r\n}\r\n\r\n.field-name {\r\n font-weight: 500;\r\n color: #475569;\r\n}\r\n\r\n.field-value {\r\n color: #64748b;\r\n margin-left: 0.5rem;\r\n}\r\n\r\n.field-value.filled {\r\n color: #059669;\r\n font-weight: 500;\r\n}\r\n\r\n.voice-filled-form {\r\n display: flex;\r\n flex-direction: column;\r\n gap: 1rem;\r\n margin-top: 1rem;\r\n}\r\n\r\n.form-group {\r\n display: flex;\r\n flex-direction: column;\r\n gap: 0.25rem;\r\n}\r\n\r\n.form-label {\r\n font-weight: 500;\r\n color: #374151;\r\n font-size: 0.875rem;\r\n}\r\n\r\n.required {\r\n color: #ee4444;\r\n margin-left: 0.125rem;\r\n}\r\n\r\n.form-input {\r\n padding: 0.5rem;\r\n border: 1px solid #d1d5db;\r\n border-radius: 0.375rem;\r\n font-size: 0.875rem;\r\n transition: border-color 0.2s ease;\r\n}\r\n\r\n.form-input:focus {\r\n outline: none;\r\n border-color: #3b82f6;\r\n box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);\r\n}\r\n\r\n.form-checkbox {\r\n width: auto;\r\n padding: 0;\r\n margin: 0;\r\n}\r\n\r\nselect.form-input {\r\n background-color: white;\r\n cursor: pointer;\r\n}\r\n\r\ninput[type=\"date\"].form-input {\r\n cursor: pointer;\r\n}\r\n\r\n.readonly-select {\r\n background: #f9fafb;\r\n border: 1px solid #d1d5db;\r\n border-radius: 0.375rem;\r\n padding: 0.5rem;\r\n}\r\n\r\n.select-placeholder {\r\n font-size: 0.875rem;\r\n color: #6b7280;\r\n margin-bottom: 0.5rem;\r\n}\r\n\r\n.select-options-list {\r\n list-style: none;\r\n margin: 0;\r\n padding: 0;\r\n display: flex;\r\n flex-wrap: wrap;\r\n gap: 0.25rem;\r\n}\r\n\r\n.select-option {\r\n background: #e5e7eb;\r\n padding: 0.25rem 0.5rem;\r\n border-radius: 0.25rem;\r\n font-size: 0.875rem;\r\n color: #374151;\r\n}","import { Component, Prop, Event, EventEmitter, State, h, Watch, Method } from '@stencil/core';\r\nimport { FormSchema, VoiceFormRecorderResult, FilledFormData, FormSchemaFieldsOnly, FormSchemaFieldsOnlyExtended } from '../../types/form-schema.types';\r\nimport { ServiceProviderConfig } from '../../types/service-providers.types';\r\nimport { AudioRecorderService } from '../../services/audio-recorder.service';\r\nimport { SpeechToTextServiceFactory } from '../../services/speech-to-text.service';\r\nimport { LLMServiceFactory } from '../../services/llm.service';\r\nimport { SchemaConverter } from '../../utils/schema-converter';\r\n\r\n@Component({\r\n tag: 'voice-input-module',\r\n styleUrl: 'voice-input-module.css',\r\n shadow: true,\r\n})\r\nexport class VoiceFormRecorder {\r\n @Prop() formJson: string = '{}';\r\n @Prop() serviceConfig: string = '{}';\r\n @Prop() apiKey: string;\r\n @Prop() context: 'track'|'ng'|'ecoll-veto'|'ecoteka' = undefined;\r\n @Prop() classificationRootUrl: string = 'http://localhost';\r\n @Prop() language: 'fr'|'en' = 'en';\r\n @Prop() inputTypes: ('voice' | 'ocr' | 'audio')[] = [];\r\n \r\n @Prop() debug: boolean = false;\r\n @Prop() renderForm: boolean = false;\r\n @Prop() displayStatus: boolean = false;\r\n \r\n @Event() formFilled: EventEmitter<VoiceFormRecorderResult>;\r\n @Event() recordingStateChanged: EventEmitter<{ isRecording: boolean; state: string }>;\r\n\r\n @State() isRecording: boolean = false;\r\n @State() isProcessing: boolean = false;\r\n @State() statusMessage: string;\r\n @State() hasError: boolean = false;\r\n @State() transcription: string = '';\r\n @State() filledData: FilledFormData | null = null;\r\n @State() debugInfo: any = {};\r\n @State() isReadonlyMode: boolean = true; // Start in readonly preview mode\r\n\r\n private audioRecorder: AudioRecorderService;\r\n private speechToTextService: any;\r\n private llmService: any;\r\n private parsedSchema: any; // Support both simple FormSchema and complex nested schema\r\n private parsedConfig: ServiceProviderConfig;\r\n\r\n constructor() {\r\n this.audioRecorder = new AudioRecorderService();\r\n }\r\n\r\n componentWillLoad() {\r\n this.initializeServices();\r\n }\r\n\r\n @Watch('formJson')\r\n @Watch('serviceConfig')\r\n initializeServices() {\r\n try {\r\n if (!this.context){\r\n this.hasError = true;\r\n const errorMessage = (this.language == 'en' ? `Initialization error: context is '${this.context}'` : `Erreur d'initialisation: le contexte est '${this.context}'`);\r\n this.statusMessage = errorMessage;\r\n this.updateDebugInfo(errorMessage, { error: errorMessage });\r\n }\r\n else{\r\n // Parse form schema\r\n this.parsedSchema = JSON.parse(this.formJson || '{}');\r\n \r\n // Parse service configuration\r\n this.parsedConfig = JSON.parse(this.serviceConfig || '{}');\r\n \r\n // Add API key to config if provided via prop\r\n if (this.apiKey) {\r\n this.parsedConfig = {\r\n ...this.parsedConfig,\r\n speechToText: { ...this.parsedConfig.speechToText, apiKey: this.apiKey },\r\n llm: { ...this.parsedConfig.llm, apiKey: this.apiKey }\r\n };\r\n }\r\n \r\n // Initialize services\r\n this.speechToTextService = SpeechToTextServiceFactory.create(this.parsedConfig);\r\n this.llmService = LLMServiceFactory.create(this.parsedConfig);\r\n \r\n this.updateDebugInfo('Initialized', {\r\n schema: this.parsedSchema,\r\n config: this.parsedConfig\r\n });\r\n \r\n this.hasError = false;\r\n this.statusMessage = (this.language == 'en' ? 'Click to start recording' : 'Cliquer pour enregistrer');\r\n if (this.inputTypes.length === 0){\r\n this.inputTypes = ['voice'];\r\n }\r\n }\r\n } catch (error) {\r\n this.hasError = true;\r\n this.statusMessage = (this.language == 'en' ? `Initialization error: ${error.message}` : `Erreur d'initialisation: ${error.message}`);\r\n this.updateDebugInfo('Initialization Error', { error: error.message });\r\n }\r\n }\r\n\r\n private updateDebugInfo(action: string, data: any) {\r\n if (this.debug) {\r\n this.debugInfo = {\r\n ...this.debugInfo,\r\n [action]: {\r\n timestamp: new Date().toISOString(),\r\n data\r\n }\r\n };\r\n }\r\n }\r\n\r\n private async handleRecordClick() {\r\n if (this.isProcessing) return;\r\n\r\n if (this.isRecording) {\r\n await this.stopRecordingAndProcess();\r\n } else {\r\n await this.startRecording();\r\n }\r\n }\r\n\r\n private async startRecording() {\r\n try {\r\n this.hasError = false;\r\n this.statusMessage = (this.language == 'en' ? 'Starting recording...' : `Enregistrement ...`);\r\n this.updateDebugInfo('Start Recording Attempt', {});\r\n\r\n await this.audioRecorder.startRecording();\r\n \r\n this.isRecording = true;\r\n this.statusMessage = (this.language == 'en' ? 'Recording... Click to stop' : 'Enregistrement ... Cliquer pour stopper');\r\n this.updateDebugInfo('Recording Started', {});\r\n \r\n this.recordingStateChanged.emit({ \r\n isRecording: true, \r\n state: 'recording' \r\n });\r\n } catch (error) {\r\n this.hasError = true;\r\n this.statusMessage = (this.language == 'en' ? `Recording failed: ${error.message}` : `Echec de l'enregistrement : ${error.message}`);\r\n this.updateDebugInfo('Recording Error', { error: error.message });\r\n \r\n this.formFilled.emit({\r\n success: false,\r\n error: error.message\r\n });\r\n }\r\n }\r\n\r\n private async processJsonForm(jsonForm: string){\r\n console.log(\"processJsonForm\", jsonForm);\r\n try {\r\n this.isProcessing = true;\r\n this.statusMessage = (this.language == 'en' ? 'Processing json...' : `Traitement du json ...`);\r\n\r\n // Fill form using LLM\r\n this.statusMessage = (this.language == 'en' ? 'Filling form fields...' : 'Remplissage du formulaire ...');\r\n const trimmedSchema = this.trimSchemaForAI(this.parsedSchema);\r\n const filledSchema = await this.llmService.fillFormFromJson(jsonForm, trimmedSchema);\r\n \r\n // Extract filled data\r\n this.filledData = this.extractFilledData(filledSchema);\r\n this.updateDebugInfo('Form Filled', { \r\n filledSchema, \r\n extractedData: this.filledData \r\n });\r\n \r\n this.parsedSchema = this.filledData;\r\n\r\n this.statusMessage = (this.language == 'en' ? 'Form completed!' : 'Formulaire remplis !');\r\n this.hasError = false;\r\n\r\n // Emit success event\r\n this.formFilled.emit({\r\n success: true,\r\n data: this.filledData,\r\n jsonForm: jsonForm\r\n });\r\n\r\n } catch (error) {\r\n this.hasError = true;\r\n this.statusMessage = (this.language == 'en' ? `Processing failed: ${error.message}` : `Erreur de traitement : ${error.message}`);\r\n \r\n this.formFilled.emit({\r\n success: false,\r\n error: error.message,\r\n jsonForm: jsonForm\r\n });\r\n } finally {\r\n this.isProcessing = false;\r\n }\r\n }\r\n\r\n private async processAudioContent(audioFile) {\r\n this.updateDebugInfo('Audio Captured', { \r\n size: audioFile.size, \r\n type: audioFile.type \r\n });\r\n\r\n // Transcribe audio\r\n this.statusMessage = (this.language == 'en' ? 'Transcribing speech...' : 'Transcription du texte ...');\r\n const transcription = await this.speechToTextService.transcribe(audioFile, this.language);\r\n this.transcription = transcription;\r\n this.updateDebugInfo('Transcription Complete', { transcription });\r\n\r\n if (!transcription.trim()) {\r\n throw new Error('No speech detected in the recording');\r\n }\r\n\r\n // Fill form using LLM\r\n this.statusMessage = (this.language == 'en' ? 'Filling form fields...' : 'Remplissage du formulaire ...');\r\n const trimmedSchema = this.trimSchemaForAI(this.parsedSchema);\r\n const filledSchema = await this.llmService.fillFormFromTranscription(transcription, trimmedSchema);\r\n \r\n // Extract filled data\r\n this.filledData = this.extractFilledData(filledSchema);\r\n this.updateDebugInfo('Form Filled', { \r\n filledSchema, \r\n extractedData: this.filledData \r\n });\r\n \r\n this.parsedSchema = this.filledData;\r\n\r\n this.statusMessage = (this.language == 'en' ? 'Form completed!' : 'Formulaire remplis !');\r\n this.hasError = false;\r\n\r\n // Emit success event\r\n this.formFilled.emit({\r\n success: true,\r\n data: this.filledData,\r\n transcription: transcription\r\n });\r\n }\r\n\r\n private async stopRecordingAndProcess() {\r\n try {\r\n this.isRecording = false;\r\n this.isProcessing = true;\r\n this.statusMessage = (this.language == 'en' ? 'Processing audio...' : `Traitement de l'audio ...`);\r\n this.updateDebugInfo('Stop Recording', {});\r\n\r\n this.recordingStateChanged.emit({ \r\n isRecording: false, \r\n state: 'processing' \r\n });\r\n\r\n // Stop recording and get audio blob\r\n const audioBlob = await this.audioRecorder.stopRecording();\r\n const audioContent = new File([audioBlob], 'audio.webm', { type: 'audio/webm' });\r\n this.processAudioContent(audioContent);\r\n\r\n } catch (error) {\r\n this.hasError = true;\r\n this.statusMessage = (this.language == 'en' ? `Processing failed: ${error.message}` : `Erreur de traitement : ${error.message}`);\r\n this.updateDebugInfo('Processing Error', { error: error.message });\r\n \r\n this.formFilled.emit({\r\n success: false,\r\n error: error.message,\r\n transcription: this.transcription\r\n });\r\n } finally {\r\n this.isProcessing = false;\r\n this.recordingStateChanged.emit({ \r\n isRecording: false, \r\n state: 'idle' \r\n });\r\n }\r\n }\r\n\r\n private extractFilledData(filledData: any): any {\r\n // console.log(\"extractFilledData\", filledData);\r\n const updatedSchema = JSON.parse(JSON.stringify(this.parsedSchema));\r\n switch(this.context){\r\n case \"ecoteka\":\r\n // console.log(\"TODO extractFilledData\", filledData);\r\n case \"ng\": \r\n if (filledData?.fields) {\r\n // Map AI response back to original schema structure\r\n filledData.fields.forEach((field: any) => {\r\n const originalField = updatedSchema.Children.find((child: any) => \r\n child.System_Name === field.name || child.Settings?.Label === field.name\r\n );\r\n \r\n if (originalField && field.value !== undefined && field.value !== null && field.value !== '') {\r\n if (!originalField.Settings) originalField.Settings = {};\r\n originalField.Settings.Default_Value = field.value;\r\n }\r\n });\r\n }\r\n \r\n break;\r\n case \"ecoll-veto\":\r\n // console.log(\"TODO extractFilledData\", filledData, updatedSchema);\r\n if (filledData?.fields) {\r\n // Map AI response back to original schema structure\r\n filledData.fields.forEach((field: any) => {\r\n let originalField = updatedSchema[0].items.find((child: any) => \r\n child.label === field.name\r\n );\r\n if (!originalField)\r\n originalField = updatedSchema[1].items.find((child: any) =>\r\n child.label === field.name\r\n );\r\n \r\n if (originalField && field.value !== undefined && field.value !== null && field.value !== '') {\r\n updatedSchema[2][originalField.name] = field.value;\r\n }\r\n });\r\n }\r\n break;\r\n case \"track\":\r\n default:\r\n const data: FilledFormData = {};\r\n \r\n Object.entries(filledData.fields).forEach(([fieldID, field]: [string, any]) => {\r\n if (field.default !== undefined && field.default !== null && field.default !== '') {\r\n updatedSchema[fieldID] = field.default;\r\n }\r\n if (field.value !== undefined && field.value !== null && field.value !== '') {\r\n for (const key in updatedSchema.fields) {\r\n const schemaField = updatedSchema.fields[key];\r\n if (schemaField.title === field.name) {\r\n schemaField.value = field.value || field.default;\r\n schemaField.default = field.value || field.default;\r\n break; // stop after finding the first match\r\n }\r\n }\r\n }\r\n });\r\n\r\n break;\r\n }\r\n \r\n // console.log(\"extractFilledData result\", updatedSchema);\r\n return updatedSchema;\r\n }\r\n\r\n private trimSchemaForAI(schema: any): any {\r\n // console.log(\"trimSchemaForAI\", schema);\r\n switch(this.context){\r\n case \"ecoteka\":\r\n // console.log(\"TODO trimSchemaForAI\", schema)\r\n case \"ng\":\r\n const trimmed = { fields: [] };\r\n schema.Children.forEach((child: any) => {\r\n if (!child.System_Name || !child.Type) return;\r\n \r\n const fieldData: any = {\r\n name: child.Label || child.Settings?.Label || child.System_Name,\r\n type: this.mapFieldType(child.Type)\r\n };\r\n \r\n // Add options for classification/select fields\r\n const selectTypes = ['InputClassification', 'select']\r\n if (selectTypes.includes(child.Type) && child.Children && child.Children.length > 0) {\r\n fieldData.options = child.Children.map((option: any) => \r\n option.System_Name || option.Label || option.toString()\r\n );\r\n }\r\n\r\n console.log(\"fieldData\", fieldData);\r\n \r\n trimmed.fields.push(fieldData);\r\n });\r\n \r\n // console.log(\"Schema apres transformation, contexte NG:\", trimmed);\r\n return trimmed;\r\n case \"ecoll-veto\":\r\n // console.log(\"TODO trimSchemaForAI\", schema)\r\n const mergedItemsSchema = (this.parsedSchema[0].items).concat(this.parsedSchema[1].items);\r\n\r\n if (mergedItemsSchema) {\r\n const trimmedSchema: FormSchema = {\r\n title: 'Form Name',\r\n description: 'Form Description',\r\n schema: {}\r\n };\r\n\r\n Object.entries(mergedItemsSchema).forEach(([key, field]: [string, any]) => {\r\n const fieldName = field.name;\r\n const fieldType = this.mapFieldType(field.type) as any;\r\n const fieldLabel = field.label || fieldName;\r\n const isRequired = field.required || false;\r\n const fieldValue = ''; //TODO\r\n \r\n trimmedSchema.schema[fieldName] = {\r\n type: fieldType,\r\n title: fieldLabel,\r\n options: field.options,\r\n readonly: field.readonly === true,\r\n default: '',\r\n };\r\n });\r\n\r\n // console.log(\"Schema apres transformation, contexte Track:\", trimmedSchema);\r\n return trimmedSchema;\r\n }\r\n case \"track\":\r\n default:\r\n // Handle simple schema format (backward compatibility)\r\n if (schema?.schema ?? schema?.fields) {\r\n const trimmedSchema: FormSchema = {\r\n title: schema.title,\r\n description: schema.description,\r\n schema: {}\r\n };\r\n\r\n const finalSchema = schema?.schema ?? schema?.fields;\r\n\r\n Object.entries(finalSchema).forEach(([fieldName, field]: [string, any]) => {\r\n trimmedSchema.schema[fieldName] = {\r\n type: field.type,\r\n title: field.title,\r\n options: field.options,\r\n readonly: field.Enabled === false,\r\n default: field.DefaultValue,\r\n pattern: field.Mask,\r\n min: field.ValidationMin,\r\n max: field.ValidationMax\r\n };\r\n });\r\n\r\n \r\n // console.log(\"Schema apres transformation, contexte Track:\", trimmedSchema);\r\n return trimmedSchema;\r\n }\r\n break;\r\n }\r\n \r\n return schema;\r\n }\r\n\r\n private mapFieldType(type: string): string {\r\n const typeMapping = {\r\n 'InputAutocomplete': 'string',\r\n 'InputInteger': 'number',\r\n 'InputTextArea': 'string',\r\n 'InputDateTimePicker': 'datetime',\r\n 'InputDecimal': 'number',\r\n 'InputClassification': 'select',\r\n 'InputCheckbox': 'boolean',\r\n 'InputTextTranslation': 'string',\r\n 'thesaurus': 'string',\r\n 'position': 'string',\r\n 'text': 'string',\r\n 'textarea': 'string',\r\n 'number': 'number',\r\n 'date': 'date',\r\n 'datetime': 'datetime',\r\n 'select': 'select',\r\n 'checkbox': 'checkbox'\r\n };\r\n \r\n return typeMapping[type] || 'string';\r\n }\r\n\r\n // Utility methods exposed as public API\r\n @Method() public async convertXmlToJson(xmlForm: string): Promise<FormSchemaFieldsOnly> {\r\n return SchemaConverter.convertXmlToJson(xmlForm, this.classificationRootUrl, this.language);\r\n }\r\n\r\n @Method() public async convertJsonToXml(jsonForm: FormSchemaFieldsOnlyExtended): Promise<string> {\r\n return SchemaConverter.convertJsonToXml(jsonForm);\r\n }\r\n\r\n // Utility methods exposed as public API\r\n @Method() public async convertXmlToJsonLegacy(xmlForm: string): Promise<FormSchema> {\r\n return SchemaConverter.convertXmlToJsonLegacy(xmlForm);\r\n }\r\n\r\n @Method() public async convertJsonToXmlLegacy(jsonForm: FormSchema): Promise<string> {\r\n return SchemaConverter.convertJsonToXmlLegacy(jsonForm);\r\n }\r\n\r\n private renderUploadButton() {\r\n if (!this.inputTypes.includes('ocr'))\r\n return;\r\n return(\r\n <ocr-file-uploader\r\n batch={false}\r\n callback={(data) => {this.processJsonForm(data);}}\r\n >\r\n </ocr-file-uploader>\r\n );\r\n }\r\n\r\n private fileInputAudioRecord!: HTMLInputElement;\r\n\r\n private triggerAudioRecordUpload = () => {\r\n this.fileInputAudioRecord.click();\r\n };\r\n\r\n private handleAudioRecordChange = async (event: Event) => {\r\n const input = event.target as HTMLInputElement;\r\n if (!input.files || input.files.length === 0) return;\r\n\r\n const file = input.files[0];\r\n\r\n // Here you can handle the file upload to your API\r\n console.log('Selected file:', file);\r\n\r\n this.processAudioContent(file);\r\n };\r\n\r\n private renderUploadRecordButton() {\r\n return (\r\n <div class=\"upload-record-container\" onClick={this.triggerAudioRecordUpload}>\r\n <input\r\n type=\"file\"\r\n ref={el => (this.fileInputAudioRecord = el!)}\r\n onChange={this.handleAudioRecordChange}\r\n style={{ display: 'none' }}\r\n />\r\n <div class='upload-record-button'>\r\n <svg width=\"800px\" height=\"800px\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12 2.75C6.89137 2.75 2.75 6.89137 2.75 12C2.75 17.1086 6.89137 21.25 12 21.25C12.6345 21.25 13.2534 21.1862 13.8508 21.065C14.2567 20.9826 14.6526 21.2448 14.735 21.6508C14.8174 22.0567 14.5551 22.4526 14.1492 22.535C13.4541 22.6761 12.7353 22.75 12 22.75C6.06294 22.75 1.25 17.9371 1.25 12C1.25 6.06294 6.06294 1.25 12 1.25C17.9371 1.25 22.75 6.06294 22.75 12C22.75 12.7353 22.6761 13.4541 22.535 14.1492C22.4526 14.5551 22.0567 14.8174 21.6508 14.735C21.2448 14.6526 20.9826 14.2567 21.065 13.8508C21.1862 13.2534 21.25 12.6345 21.25 12C21.25 6.89137 17.1086 2.75 12 2.75ZM12.7676 8.52584C12.7661 8.53409 12.7604 8.56729 12.7564 8.64336C12.7502 8.76101 12.75 8.91982 12.75 9.17082C12.75 9.27795 12.7501 9.33904 12.7518 9.38529C12.7528 9.41425 12.7542 9.42649 12.7546 9.42955C12.7662 9.48945 12.7993 9.54303 12.8477 9.58021C12.8502 9.58194 12.8606 9.58864 12.886 9.60252C12.9266 9.62468 12.9812 9.65209 13.0771 9.7L14.3938 10.3584C14.6183 10.4706 14.7604 10.5414 14.8684 10.5885C14.9382 10.6189 14.9705 10.6287 14.9785 10.631C15.0885 10.6405 15.1917 10.5767 15.2324 10.4742C15.2339 10.4659 15.2396 10.4327 15.2436 10.3566C15.2498 10.239 15.25 10.0802 15.25 9.82918C15.25 9.72205 15.2499 9.66096 15.2482 9.61471C15.2472 9.58575 15.2458 9.57351 15.2454 9.57045C15.2338 9.51055 15.2007 9.45697 15.1523 9.41979C15.1498 9.41805 15.1394 9.41136 15.114 9.39748C15.0734 9.37533 15.0188 9.34791 14.9229 9.3L13.6062 8.64164C13.3817 8.52939 13.2396 8.45859 13.1316 8.41151C13.0617 8.38107 13.0295 8.37131 13.0215 8.36896C12.9115 8.35945 12.8083 8.42327 12.7676 8.52584ZM12.75 11.2135L13.7396 11.7083C13.9425 11.8098 14.1204 11.8987 14.269 11.9635C14.4199 12.0293 14.5988 12.097 14.7972 12.1202C15.6037 12.2142 16.3689 11.7413 16.6454 10.978C16.7134 10.7901 16.7328 10.5998 16.7415 10.4355C16.75 10.2735 16.75 10.0747 16.75 9.8479V9.82918C16.75 9.81565 16.75 9.80205 16.75 9.78837C16.7503 9.62647 16.7505 9.45474 16.7188 9.28904C16.638 8.86674 16.4045 8.48898 16.0629 8.22783C15.9289 8.12535 15.7752 8.04877 15.6303 7.97658C15.618 7.97048 15.6059 7.96441 15.5938 7.95836L14.2603 7.29164C14.0575 7.19022 13.8796 7.10128 13.731 7.03647C13.5801 6.97071 13.4012 6.90297 13.2028 6.87982C12.3963 6.78575 11.6311 7.25868 11.3546 8.02203C11.2866 8.20986 11.2672 8.40019 11.2585 8.56454C11.2519 8.68919 11.2504 8.83571 11.2501 9L11.25 9.11944C11.25 9.13026 11.25 9.14115 11.25 9.1521V9.17082C11.25 9.18435 11.25 9.19795 11.25 9.21163C11.2499 9.23918 11.2499 9.26701 11.25 9.29505V12.5499C10.875 12.3581 10.4501 12.25 10 12.25C8.48122 12.25 7.25 13.4812 7.25 15C7.25 16.5188 8.48122 17.75 10 17.75C11.5188 17.75 12.75 16.5188 12.75 15V11.2135ZM11.25 15C11.25 14.3096 10.6904 13.75 10 13.75C9.30964 13.75 8.75 14.3096 8.75 15C8.75 15.6904 9.30964 16.25 10 16.25C10.6904 16.25 11.25 15.6904 11.25 15ZM17.4697 14.4697C17.7626 14.1768 18.2374 14.1768 18.5303 14.4697L21.0303 16.9697C21.3232 17.2626 21.3232 17.7374 21.0303 18.0303C20.7374 18.3232 20.2626 18.3232 19.9697 18.0303L18.75 16.8107V22C18.75 22.4142 18.4142 22.75 18 22.75C17.5858 22.75 17.25 22.4142 17.25 22V16.8107L16.0303 18.0303C15.7374 18.3232 15.2626 18.3232 14.9697 18.0303C14.6768 17.7374 14.6768 17.2626 14.9697 16.9697L17.4697 14.4697Z\" />\r\n </svg>\r\n </div>\r\n </div>\r\n )\r\n }\r\n\r\n private renderRecordButton() {\r\n if (!this.inputTypes.includes('voice'))\r\n return;\r\n\r\n const buttonClass = [\r\n 'record-button',\r\n this.isRecording && 'recording',\r\n this.isProcessing && 'processing'\r\n ].filter(Boolean).join(' ');\r\n\r\n const isDisabled = this.isProcessing || this.hasError;\r\n\r\n return (\r\n <button \r\n class={buttonClass}\r\n onClick={() => this.handleRecordClick()}\r\n disabled={isDisabled}\r\n aria-label={this.isRecording ? 'Stop recording' : 'Start recording'}\r\n >\r\n {this.isProcessing ? (\r\n <svg class=\"record-icon\" viewBox=\"0 0 24 24\">\r\n <circle cx=\"12\" cy=\"12\" r=\"3\">\r\n <animate attributeName=\"r\" values=\"3;6;3\" dur=\"1s\" repeatCount=\"indefinite\" />\r\n <animate attributeName=\"opacity\" values=\"1;0.3;1\" dur=\"1s\" repeatCount=\"indefinite\" />\r\n </circle>\r\n </svg>\r\n ) : this.isRecording ? (\r\n <svg class=\"record-icon\" viewBox=\"0 0 24 24\">\r\n <rect x=\"6\" y=\"6\" width=\"12\" height=\"12\" rx=\"2\" />\r\n </svg>\r\n ) : (\r\n <svg class=\"record-icon\" viewBox=\"0 0 24 24\">\r\n <circle cx=\"12\" cy=\"12\" r=\"8\" />\r\n </svg>\r\n )}\r\n </button>\r\n );\r\n }\r\n\r\n private renderStatusMessage() {\r\n const statusClass = [\r\n 'status-text',\r\n this.hasError && 'error',\r\n this.filledData && !this.hasError && 'success'\r\n ].filter(Boolean).join(' ');\r\n\r\n return <div class={statusClass}>{this.statusMessage}</div>;\r\n }\r\n\r\n private renderFormPreview() {\r\n if (!this.parsedSchema) return null;\r\n\r\n const isPreview = this.isReadonlyMode && !this.filledData;\r\n const title = isPreview ? 'Form Preview (Voice input to fill)' : 'Voice-Filled Form:';\r\n \r\n return (\r\n <div class=\"form-preview\">\r\n <div class=\"form-preview-title\">{title}</div>\r\n <form class=\"voice-filled-form\">\r\n {this.renderFormFields()}\r\n </form>\r\n </div>\r\n );\r\n }\r\n\r\n private renderFormFields() {\r\n // console.log(\"renderFormFields\", this.parsedSchema);\r\n if (!this.parsedSchema) return null;\r\n \r\n switch(this.context){\r\n case \"ecoteka\":\r\n // console.log(\"TODO renderFormFields\", this.parsedSchema);\r\n case \"ng\":\r\n return this.parsedSchema.Children.map((child: any) => {\r\n if (!child.System_Name || !child.Type) return null;\r\n \r\n const fieldName = child.System_Name;\r\n const fieldType = this.mapFieldType(child.Type);\r\n const fieldLabel = child.Settings?.Label || child.System_Name;\r\n const isRequired = child.Required || false;\r\n const fieldValue = child.Settings?.Default_Value;\r\n \r\n return (\r\n <div class=\"form-group\" key={fieldName}>\r\n <label htmlFor={fieldName} class=\"form-label\">\r\n {fieldLabel}\r\n {isRequired && <span class=\"required\">*</span>}\r\n </label>\r\n {this.renderFormField(fieldName, {\r\n type: fieldType,\r\n title: fieldLabel,\r\n required: isRequired,\r\n options: child.Children?.map((option: any) => \r\n option.System_Name || option.Label || option.toString()\r\n )\r\n }, fieldValue)}\r\n </div>\r\n );\r\n }).filter(Boolean);\r\n case \"ecoll-veto\":\r\n // NOTE STEP 2\r\n // console.log(\"TODO renderFormFields\", this.parsedSchema);\r\n const mergedItemsSchema = (this.parsedSchema[0].items).concat(this.parsedSchema[1].items);\r\n return Object.entries(mergedItemsSchema).map(([key, field]: [string, any]) => {\r\n \r\n const fieldName = field.name;\r\n field.type = this.mapFieldType(field.type);\r\n const fieldLabel = field.label || fieldName;\r\n const isRequired = field.required || false;\r\n const fieldValue = this.parsedSchema[2][fieldName];\r\n\r\n return (\r\n <div class=\"form-group\" key={fieldName}>\r\n <label htmlFor={fieldName} class=\"form-label\">\r\n { fieldLabel }\r\n {isRequired && <span class=\"required\">*</span>}\r\n </label>\r\n {this.renderFormField(fieldName, field, (this.filledData?.[fieldName] ?? fieldValue))}\r\n </div>\r\n );\r\n });\r\n case \"track\":\r\n default:\r\n return Object.entries(this.parsedSchema.fields).map(([fieldName, field]: [string, any]) => (\r\n <div class=\"form-group\" key={fieldName}>\r\n <label htmlFor={fieldName} class=\"form-label\">\r\n {field.title || fieldName}\r\n {field.required && <span class=\"required\">*</span>}\r\n </label>\r\n {this.renderFormField(fieldName, field, (this.filledData?.[fieldName] ?? field.value))}\r\n </div>\r\n ));\r\n }\r\n }\r\n\r\n private renderFormField(fieldName: string, field: any, value: any) {\r\n const isReadonly = this.isReadonlyMode && !this.filledData;\r\n const commonProps = {\r\n id: fieldName,\r\n name: fieldName,\r\n class: 'form-input',\r\n required: field.required,\r\n disabled: isReadonly\r\n };\r\n\r\n switch (field.type) {\r\n case 'select':\r\n if (isReadonly) {\r\n // In readonly mode, show all options as a list instead of dropdown\r\n return (\r\n <div class=\"readonly-select\">\r\n <div class=\"select-placeholder\">Available options:</div>\r\n <ul class=\"select-options-list\">\r\n {field.options?.map(option => (\r\n <li class=\"select-option\">{option}</li>\r\n ))}\r\n </ul>\r\n </div>\r\n );\r\n }\r\n return (\r\n <select id={fieldName} name={fieldName} class=\"form-input\" required={field.required}>\r\n <option value=\"\">-- Select --</option>\r\n {field.options?.map(option => (\r\n <option value={option} selected={value === option}>\r\n {option}\r\n </option>\r\n ))}\r\n </select>\r\n );\r\n \r\n case 'boolean':\r\n return (\r\n <input \r\n {...commonProps}\r\n type=\"checkbox\" \r\n class=\"form-checkbox\"\r\n checked={value === true || value === 'true'}\r\n />\r\n );\r\n \r\n case 'number':\r\n return (\r\n <input \r\n {...commonProps}\r\n type=\"number\" \r\n min={field.min}\r\n max={field.max}\r\n step=\"any\"\r\n value={value || ''}\r\n />\r\n );\r\n \r\n case 'date':\r\n return (\r\n <input \r\n {...commonProps}\r\n type='date'\r\n value={value ? (([d, m, y]) => `${y}-${m}-${d}`)(value.split(\"/\")) : ''}\r\n />\r\n );\r\n\r\n case 'datetime':\r\n return (\r\n <input \r\n {...commonProps}\r\n type='datetime-local'\r\n value={value || ''}\r\n />\r\n );\r\n \r\n default: // string\r\n return (\r\n <input \r\n {...commonProps}\r\n type=\"text\" \r\n pattern={field.pattern}\r\n placeholder={field.description}\r\n value={value || ''}\r\n />\r\n );\r\n }\r\n }\r\n\r\n private renderDebugPanel() {\r\n if (!this.debug) return null;\r\n\r\n return (\r\n <div class=\"debug-panel\">\r\n <div class=\"debug-title\">Debug Information:</div>\r\n <div class=\"debug-content\">\r\n {JSON.stringify(this.debugInfo, null, 2)}\r\n </div>\r\n </div>\r\n );\r\n }\r\n\r\n render() {\r\n return (\r\n <div>\r\n <div class={\"voice-recorder-container\" + (this.debug || this.renderForm ? \"-debug\" : \"\")}>\r\n <div class=\"row-audio-area\">\r\n {this.renderRecordButton()}\r\n {this.renderUploadRecordButton()}\r\n </div>\r\n {this.displayStatus ? this.renderStatusMessage() : \"\"}\r\n {this.renderUploadButton()}\r\n {this.renderForm ? this.renderFormPreview() : \"\"}\r\n {this.debug ? this.renderDebugPanel() : \"\"}\r\n </div>\r\n </div>\r\n );\r\n }\r\n}\r\n"],"names":[],"mappings":";;AAAA,MAAM,kBAAkB,GAAG,kVAAkV;;MCOhW,eAAe,GAAA,MAAA;AAL5B,IAAA,WAAA,CAAA,OAAA,EAAA;;AAMY,QAAA,IAAK,CAAA,KAAA,GAAY,KAAK;AAKtB,QAAA,IAAa,CAAA,aAAA,GAAG,MAAK;AACzB,YAAA,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE;AAC1B,SAAC;AAEO,QAAA,IAAA,CAAA,gBAAgB,GAAG,OAAO,KAAY,KAAI;AAC9C,YAAA,MAAM,KAAK,GAAG,KAAK,CAAC,MAA0B;YAC9C,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC;gBAAE;YAE9C,MAAM,IAAI,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;;AAG3B,YAAA,OAAO,CAAC,GAAG,CAAC,gBAAgB,EAAE,IAAI,CAAC;AAEnC,YAAA,MAAM,QAAQ,GAAG,IAAI,QAAQ,EAAE;AAC/B,YAAA,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC;AAE7B,YAAA,IAAI,IAAI,CAAC,KAAK,EAAE;AACZ,gBAAA,IAAI;AACA,oBAAA,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,0CAA0C,EAAE;AACrE,wBAAA,MAAM,EAAE,MAAM;AACd,wBAAA,IAAI,EAAE;AACT,qBAAA,CAAC;AAEF,oBAAA,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE;AACd,wBAAA,OAAO,CAAC,KAAK,CAAC,2BAA2B,EAAE,QAAQ,CAAC;wBACpD,MAAM,IAAI,KAAK,CAAC,CAAA,oBAAA,EAAuB,QAAQ,CAAC,MAAM,CAAE,CAAA,CAAC;;;AAG7D,oBAAA,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE;;oBAElC,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC;oBAC5C,MAAM,CAAC,GAAG,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC;AACrC,oBAAA,CAAC,CAAC,IAAI,GAAG,GAAG;AACZ,oBAAA,CAAC,CAAC,QAAQ,GAAG,SAAS,GAAC,IAAI,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,GAAC,OAAO,CAAC;AACrD,oBAAA,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;oBAC5B,CAAC,CAAC,KAAK,EAAE;oBACT,CAAC,CAAC,MAAM,EAAE;AACV,oBAAA,MAAM,CAAC,GAAG,CAAC,eAAe,CAAC,GAAG,CAAC;;gBACjC,OAAO,GAAG,EAAE;AACV,oBAAA,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC;oBAClB,KAAK,CAAC,sBAAsB,CAAC;;;iBAGhC;AACD,gBAAA,IAAI;AACA,oBAAA,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,2CAA2C,EAAE;AACtE,wBAAA,MAAM,EAAE,MAAM;AACd,wBAAA,IAAI,EAAE;AACT,qBAAA,CAAC;AAEF,oBAAA,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE;AACd,wBAAA,OAAO,CAAC,KAAK,CAAC,2BAA2B,EAAE,QAAQ,CAAC;wBACpD,MAAM,IAAI,KAAK,CAAC,CAAA,oBAAA,EAAuB,QAAQ,CAAC,MAAM,CAAE,CAAA,CAAC;;AAE7D,oBAAA,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE;AAClC,oBAAA,OAAO,CAAC,GAAG,CAAC,oBAAoB,EAAE,IAAI,CAAC;AAEvC,oBAAA,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,EAAC;wBAC5C,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;;;gBAEpC,OAAO,GAAG,EAAE;AACV,oBAAA,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC;oBAClB,KAAK,CAAC,sBAAsB,CAAC;;;AAIzC,SAAC;AAoBJ;IAlBG,MAAM,GAAA;AACF,QAAA,QACA,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,kBAAkB,EAAC,OAAO,EAAE,IAAI,CAAC,aAAa,EAAA,EACrD,CAAA,CAAA,OAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACI,IAAI,EAAC,MAAM,EACX,GAAG,EAAE,EAAE,KAAK,IAAI,CAAC,SAAS,GAAG,EAAG,CAAC,EACjC,QAAQ,EAAE,IAAI,CAAC,gBAAgB,EAC/B,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,EAC5B,CAAA,EACF,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,eAAe,EAAA,EACtB,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,OAAO,EAAC,WAAW,EAAC,IAAI,EAAC,MAAM,EAAC,KAAK,EAAC,4BAA4B,EAAA,EACvE,CAAM,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAC,EAAC,6JAA6J,EAAA,cAAA,EAAc,GAAG,EAAgB,gBAAA,EAAA,OAAO,EAAiB,iBAAA,EAAA,OAAO,EAAE,CAAA,EACvO,CAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAM,CAAC,EAAC,kDAAkD,EAAA,cAAA,EAAc,GAAG,EAAgB,gBAAA,EAAA,OAAO,EAAiB,iBAAA,EAAA,OAAO,EAAE,CAAA,CACtH,CACJ,CACJ;;;;;MChGD,oBAAoB,CAAA;AAAjC,IAAA,WAAA,GAAA;QACU,IAAa,CAAA,aAAA,GAAyB,IAAI;QAC1C,IAAW,CAAA,WAAA,GAAW,EAAE;QACxB,IAAM,CAAA,MAAA,GAAuB,IAAI;;AAEzC,IAAA,MAAM,cAAc,GAAA;AAClB,QAAA,IAAI;;AAEF,YAAA,IAAI,CAAC,SAAS,CAAC,YAAY,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,YAAY,EAAE;AACnE,gBAAA,OAAO,CAAC,KAAK,CACX,4BAA4B,EAAE,oGAAoG,CACnI;AACD,gBAAA,OAAO;;YAGT,IAAI,CAAC,MAAM,GAAG,MAAM,SAAS,CAAC,YAAY,CAAC,YAAY,CAAC;AACtD,gBAAA,KAAK,EAAE;AACL,oBAAA,gBAAgB,EAAE,IAAI;AACtB,oBAAA,gBAAgB,EAAE,IAAI;AACtB,oBAAA,eAAe,EAAE;AAClB;AACF,aAAA,CAAC;AAEF,YAAA,IAAI,CAAC,WAAW,GAAG,EAAE;YACrB,IAAI,CAAC,aAAa,GAAG,IAAI,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE;AAClD,gBAAA,QAAQ,EAAE;AACX,aAAA,CAAC;YAEF,IAAI,CAAC,aAAa,CAAC,eAAe,GAAG,CAAC,KAAK,KAAI;AAC7C,gBAAA,IAAI,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,EAAE;oBACrC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;;AAErC,aAAC;YAED,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;;QAC9B,OAAO,KAAU,EAAE;AACnB,YAAA,OAAO,CAAC,KAAK,CAAC,4BAA4B,EAAE,KAAK,CAAC;;;AAItD,IAAA,MAAM,aAAa,GAAA;QACjB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,KAAI;AACrC,YAAA,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;AACvB,gBAAA,MAAM,CAAC,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAC;gBAC9C;;AAGF,YAAA,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,MAAK;AAC/B,gBAAA,MAAM,SAAS,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;gBACpE,IAAI,CAAC,OAAO,EAAE;gBACd,OAAO,CAAC,SAAS,CAAC;AACpB,aAAC;YAED,IAAI,CAAC,aAAa,CAAC,OAAO,GAAG,CAAC,KAAK,KAAI;gBACrC,MAAM,CAAC,IAAI,KAAK,CAAC,oBAAoB,KAAK,CAAA,CAAE,CAAC,CAAC;AAChD,aAAC;AAED,YAAA,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE;AAC3B,SAAC,CAAC;;IAGJ,WAAW,GAAA;;QACT,OAAO,CAAA,MAAA,IAAI,CAAC,aAAa,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,KAAK,MAAK,WAAW;;IAG1C,OAAO,GAAA;AACb,QAAA,IAAI,IAAI,CAAC,MAAM,EAAE;AACf,YAAA,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,OAAO,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;AACtD,YAAA,IAAI,CAAC,MAAM,GAAG,IAAI;;AAEpB,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI;AACzB,QAAA,IAAI,CAAC,WAAW,GAAG,EAAE;;AAExB;;MCvEY,0BAA0B,CAAA;AAIrC,IAAA,WAAA,CAAY,MAA6C,EAAA;;QAEvD,IAAI,CAAC,MAAM,GAAG,CAAA,MAAM,KAAN,IAAA,IAAA,MAAM,uBAAN,MAAM,CAAE,MAAM,KAAI,IAAI,CAAC,sBAAsB,CAAC,gBAAgB,CAAC,IAAI,EAAE;AACnF,QAAA,IAAI,CAAC,OAAO,GAAG,CAAA,MAAM,KAAA,IAAA,IAAN,MAAM,KAAA,MAAA,GAAA,MAAA,GAAN,MAAM,CAAE,OAAO,KAAI,2BAA2B;AAE7D,QAAA,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;AAChB,YAAA,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC;;;AAI7D,IAAA,sBAAsB,CAAC,IAAY,EAAA;;QAEzC,IAAI,OAAO,OAAO,KAAK,WAAW,IAAI,OAAO,CAAC,GAAG,EAAE;AACjD,YAAA,OAAO,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC;;;AAG1B,QAAA,OAAQ,MAAc,CAAC,IAAI,CAAC,IAAI,SAAS;;AAG3C,IAAA,MAAM,UAAU,CAAC,YAAkB,EAAE,OAAe,IAAI,EAAA;;AACtD,QAAA,IAAI;AACF,YAAA,MAAM,QAAQ,GAAG,IAAI,QAAQ,EAAE;AAE/B,YAAA,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,YAAY,CAAC;YACrC,QAAQ,CAAC,MAAM,CAAC,OAAO,EAAE,mBAAmB,CAAC,CAAC;;;AAG9C,YAAA,QAAQ,CAAC,MAAM,CAAC,UAAU,EAAE,IAAI,CAAC;AACjC,YAAA,QAAQ,CAAC,MAAM,CAAC,iBAAiB,EAAE,MAAM,CAAC;AAC1C,YAAA,QAAQ,CAAC,MAAM,CAAC,mBAAmB,EAAE,MAAM,CAAC;YAE5C,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,CAAA,qBAAA,CAAuB,EAAE;AACnE,gBAAA,MAAM,EAAE,MAAM;AACd,gBAAA,OAAO,EAAE;AACP,oBAAA,eAAe,EAAE,CAAA,OAAA,EAAU,IAAI,CAAC,MAAM,CAAE,CAAA;AACzC,iBAAA;AACD,gBAAA,IAAI,EAAE,QAAQ;AACf,aAAA,CAAC;AAEF,YAAA,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE;gBAChB,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,EAAE,eAAe,EAAE,CAAC,CAAC;AACjF,gBAAA,MAAM,IAAI,KAAK,CAAC,CAAyB,sBAAA,EAAA,CAAA,MAAA,SAAS,CAAC,KAAK,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,OAAO,KAAI,QAAQ,CAAC,UAAU,CAAA,CAAE,CAAC;;AAG7F,YAAA,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE;AACpC,YAAA,OAAO,MAAM,CAAC,IAAI,IAAI,EAAE;;QACxB,OAAO,KAAK,EAAE;YACd,MAAM,IAAI,KAAK,CAAC,CAAA,qCAAA,EAAwC,KAAK,CAAC,OAAO,CAAE,CAAA,CAAC;;;AAG7E;MAEY,0BAA0B,CAAA;IACrC,OAAO,MAAM,CAAC,MAA6B,EAAA;;QACzC,MAAM,QAAQ,GAAG,CAAA,CAAA,EAAA,GAAA,MAAM,CAAC,YAAY,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,QAAQ,KAAI,SAAS;QAE3D,QAAQ,QAAQ;AACd,YAAA,KAAK,SAAS;AACZ,gBAAA,OAAO,IAAI,0BAA0B,CAAC,MAAM,CAAC,YAAY,CAAC;AAC5D,YAAA;AACE,gBAAA,MAAM,IAAI,KAAK,CAAC,wCAAwC,QAAQ,CAAA,CAAE,CAAC;;;AAG1E;;MClEY,gBAAgB,CAAA;AAK3B,IAAA,WAAA,CAAY,MAAoC,EAAA;;QAE9C,IAAI,CAAC,MAAM,GAAG,CAAA,MAAM,KAAN,IAAA,IAAA,MAAM,uBAAN,MAAM,CAAE,MAAM,KAAI,IAAI,CAAC,sBAAsB,CAAC,gBAAgB,CAAC,IAAI,EAAE;;;AAGnF,QAAA,IAAI,CAAC,KAAK,GAAG,CAAA,MAAM,KAAA,IAAA,IAAN,MAAM,KAAA,MAAA,GAAA,MAAA,GAAN,MAAM,CAAE,KAAK,KAAI,SAAS;AACvC,QAAA,IAAI,CAAC,OAAO,GAAG,CAAA,MAAM,KAAA,IAAA,IAAN,MAAM,KAAA,MAAA,GAAA,MAAA,GAAN,MAAM,CAAE,OAAO,KAAI,2BAA2B;AAE7D,QAAA,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;AAChB,YAAA,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC;;;AAIzD,IAAA,sBAAsB,CAAC,IAAY,EAAA;;QAEzC,IAAI,OAAO,OAAO,KAAK,WAAW,IAAI,OAAO,CAAC,GAAG,EAAE;AACjD,YAAA,OAAO,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC;;;AAG1B,QAAA,OAAQ,MAAc,CAAC,IAAI,CAAC,IAAI,SAAS;;AAGnC,IAAA,4BAA4B,CAAC,MAAW,EAAA;AAC9C,QAAA,OAAO,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,KAAU,KAAI;;YAC9C,OAAA,CAAA,EAAA,EAAK,MAAA,KAAK,CAAC,IAAI,MAAI,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAA,KAAK,CAAC,KAAK,CAAG,CAAA,CAAA;gBACjC,CAAI,CAAA,EAAA,KAAK,CAAC,IAAI,CAAE,CAAA;gBAChB,CAAG,EAAA,KAAK,CAAC,QAAQ,GAAG,YAAY,GAAG,EAAE,CAAE,CAAA;gBACvC,CAAG,EAAA,KAAK,CAAC,QAAQ,GAAG,YAAY,GAAG,EAAE,CAAE,CAAA;gBACvC,CAAG,EAAA,KAAK,CAAC,GAAG,IAAI,KAAK,CAAC,GAAG,KAAK,EAAE,GAAG,QAAQ,GAAC,KAAK,CAAC,GAAG,GAAG,EAAE,CAAE,CAAA;gBAC5D,CAAG,EAAA,KAAK,CAAC,GAAG,IAAI,KAAK,CAAC,GAAG,KAAK,EAAE,GAAG,QAAQ,GAAC,KAAK,CAAC,GAAG,GAAG,EAAE,CAAE,CAAA;gBAC5D,CAAG,CAAA,CAAA;gBACH,CAAG,EAAA,KAAK,CAAC,OAAO,GAAG,CAAA,YAAA,EAAe,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA,CAAE,GAAG,EAAE,CAAA,CAAE;AAAA,SAAA,CACpE,CAAC,IAAI,CAAC,IAAI,CAAC;;AAGd,IAAA,MAAM,yBAAyB,CAAC,aAAqB,EAAE,MAAW,EAAA;QAChE,OAAO,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,MAAM,EAAE,IAAI,CAAC;;AAGnD,IAAA,MAAM,gBAAgB,CAAC,IAAY,EAAE,MAAW,EAAA;QAC9C,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,CAAC;;IAGnC,MAAM,QAAQ,CAAC,IAAY,EAAE,MAAW,EAAE,sBAA+B,IAAI,EAAA;;AACnF,QAAA,IAAI;;AAEF,YAAA,IAAI,CAAA,MAAM,KAAA,IAAA,IAAN,MAAM,KAAN,MAAA,GAAA,MAAA,GAAA,MAAM,CAAE,MAAM,MAAI,MAAM,KAAA,IAAA,IAAN,MAAM,KAAN,MAAA,GAAA,MAAA,GAAA,MAAM,CAAE,MAAM,CAAA,EAAE;AACpC,gBAAA,MAAM,WAAW,GAAG,CAAA,MAAM,KAAN,IAAA,IAAA,MAAM,uBAAN,MAAM,CAAE,MAAM,MAAI,MAAM,aAAN,MAAM,KAAA,MAAA,GAAA,MAAA,GAAN,MAAM,CAAE,MAAM,CAAA;AACpD,gBAAA,MAAM,YAAY,GAAG,CAAA;;;;;;;;;AASe,yCAAA,EAAA,IAAI,IAAI,EAAU,CAAC,WAAW,EAAE,CAAA;;;mHAGuC;AAE3G,gBAAA,IAAI,UAAU,GAAG,CAAA;kCACS,IAAI,CAAA;;;AAG1B,UAAA,EAAA,IAAI,CAAC,4BAA4B,CAAC,WAAW,CAAC,CAAA;;;SAGjD;;;;;;;;;;;;;;;;;;;gBAwBD,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,CAAA,iBAAA,CAAmB,EAAE;AAC/D,oBAAA,MAAM,EAAE,MAAM;AACd,oBAAA,OAAO,EAAE;AACP,wBAAA,cAAc,EAAE,kBAAkB;AAClC,wBAAA,eAAe,EAAE,CAAA,OAAA,EAAU,IAAI,CAAC,MAAM,CAAE,CAAA;AACzC,qBAAA;AACD,oBAAA,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;wBACnB,KAAK,EAAE,IAAI,CAAC,KAAK;AACjB,wBAAA,QAAQ,EAAE;AACR,4BAAA,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,YAAY,EAAE;AACzC,4BAAA,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,UAAU;AACpC,yBAAA;AACD,wBAAA,eAAe,EAAE,EAAE,IAAI,EAAE,aAAa,EAAE;AACxC,wBAAA,WAAW,EAAE,GAAG;qBACjB,CAAC;AACH,iBAAA,CAAC;AAEF,gBAAA,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE;oBAChB,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,EAAE,eAAe,EAAE,CAAC,CAAC;AACjF,oBAAA,MAAM,IAAI,KAAK,CAAC,CAAmB,gBAAA,EAAA,CAAA,MAAA,SAAS,CAAC,KAAK,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,OAAO,KAAI,QAAQ,CAAC,UAAU,CAAA,CAAE,CAAC;;AAGvF,gBAAA,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE;AACpC,gBAAA,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC;;;AAItD,YAAA,MAAM,YAAY,GAAG,CAAA;;;;;;;;;;AAUe,uCAAA,EAAA,IAAI,IAAI,EAAU,CAAC,WAAW,EAAE,CAAA;;;kEAGR;AAE1D,YAAA,IAAI,UAAU,GAAG,CAAA;kCACS,IAAI,CAAA;;;YAG1B,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAA;;;SAGlC;;;;;;;;;;;;;;;;;;YAsBH,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,CAAA,iBAAA,CAAmB,EAAE;AAC/D,gBAAA,MAAM,EAAE,MAAM;AACd,gBAAA,OAAO,EAAE;AACP,oBAAA,cAAc,EAAE,kBAAkB;AAClC,oBAAA,eAAe,EAAE,CAAA,OAAA,EAAU,IAAI,CAAC,MAAM,CAAE,CAAA;AACzC,iBAAA;AACD,gBAAA,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;oBACnB,KAAK,EAAE,IAAI,CAAC,KAAK;AACjB,oBAAA,QAAQ,EAAE;AACR,wBAAA,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,YAAY,EAAE;AACzC,wBAAA,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,UAAU;AACpC,qBAAA;AACD,oBAAA,eAAe,EAAE,EAAE,IAAI,EAAE,aAAa,EAAE;oBACxC,WAAW,EAAE,GAAG;iBACjB,CAAC;AACH,aAAA,CAAC;AAEF,YAAA,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE;gBAChB,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,EAAE,eAAe,EAAE,CAAC,CAAC;AACjF,gBAAA,MAAM,IAAI,KAAK,CAAC,CAAmB,gBAAA,EAAA,CAAA,MAAA,SAAS,CAAC,KAAK,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,OAAO,KAAI,QAAQ,CAAC,UAAU,CAAA,CAAE,CAAC;;AAGvF,YAAA,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE;AACpC,YAAA,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC;;AAGlE,YAAA,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE;AACxB,gBAAA,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC;;AAG7D,YAAA,OAAO,YAAY;;QACnB,OAAO,KAAK,EAAE;YACd,MAAM,IAAI,KAAK,CAAC,CAAA,qBAAA,EAAwB,KAAK,CAAC,OAAO,CAAE,CAAA,CAAC;;;AAG7D;MAEY,iBAAiB,CAAA;IAC5B,OAAO,MAAM,CAAC,MAA6B,EAAA;;QACzC,MAAM,QAAQ,GAAG,CAAA,CAAA,EAAA,GAAA,MAAM,CAAC,GAAG,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,QAAQ,KAAI,QAAQ;QAEjD,QAAQ,QAAQ;AACd,YAAA,KAAK,QAAQ;AACX,gBAAA,OAAO,IAAI,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAAC;AACzC,YAAA;AACE,gBAAA,MAAM,IAAI,KAAK,CAAC,6BAA6B,QAAQ,CAAA,CAAE,CAAC;;;AAG/D;;MC1NY,eAAe,CAAA;AAC1B;;AAEG;IACH,OAAO,sBAAsB,CAAC,OAAe,EAAA;AAC3C,QAAA,IAAI;AACF,YAAA,MAAM,MAAM,GAAG,IAAI,SAAS,EAAE;YAC9B,MAAM,MAAM,GAAG,MAAM,CAAC,eAAe,CAAC,OAAO,EAAE,UAAU,CAAC;AAE1D,YAAA,IAAI,MAAM,CAAC,aAAa,CAAC,aAAa,CAAC,EAAE;AACvC,gBAAA,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC;;AAGvC,YAAA,MAAM,MAAM,GAAe;AACzB,gBAAA,MAAM,EAAE;aACT;;YAGD,MAAM,WAAW,GAAG,MAAM,CAAC,aAAa,CAAC,MAAM,CAAC;YAChD,IAAI,WAAW,EAAE;gBACf,MAAM,CAAC,KAAK,GAAG,WAAW,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,SAAS;gBAC7D,MAAM,CAAC,WAAW,GAAG,WAAW,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,SAAS;;;YAI3E,MAAM,MAAM,GAAG,MAAM,CAAC,gBAAgB,CAAC,yBAAyB,CAAC;AACjE,YAAA,MAAM,CAAC,OAAO,CAAC,KAAK,IAAG;gBACrB,MAAM,IAAI,GAAG,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC;AACvC,gBAAA,IAAI,CAAC,IAAI;oBAAE;AAEX,gBAAA,MAAM,KAAK,GAAc;AACvB,oBAAA,IAAI,EAAE,IAAI,CAAC,0BAA0B,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,EAAE,EAAE,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;AAC9F,oBAAA,KAAK,EAAE,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,KAAK,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,IAAI;oBAC/E,WAAW,EAAE,KAAK,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,SAAS;AAC3D,oBAAA,QAAQ,EAAE,KAAK,CAAC,YAAY,CAAC,UAAU,CAAC;oBACxC,OAAO,EAAE,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI;iBACzC;;gBAGD,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,EAAE,KAAK,QAAQ,EAAE;AAC5C,oBAAA,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,IACrE,MAAM,CAAC,WAAW,IAAI,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,EAAE,CACzD;AACD,oBAAA,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;AACtB,wBAAA,KAAK,CAAC,OAAO,GAAG,OAAO;;;;gBAK3B,MAAM,GAAG,GAAG,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC;gBACrC,MAAM,GAAG,GAAG,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC;gBACrC,MAAM,OAAO,GAAG,KAAK,CAAC,YAAY,CAAC,SAAS,CAAC;AAE7C,gBAAA,IAAI,GAAG;AAAE,oBAAA,KAAK,CAAC,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC;AACpC,gBAAA,IAAI,GAAG;AAAE,oBAAA,KAAK,CAAC,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC;AACpC,gBAAA,IAAI,OAAO;AAAE,oBAAA,KAAK,CAAC,OAAO,GAAG,OAAO;AAEpC,gBAAA,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,KAAK;AAC7B,aAAC,CAAC;AAEF,YAAA,OAAO,MAAM;;QACb,OAAO,KAAK,EAAE;YACd,MAAM,IAAI,KAAK,CAAC,CAAA,+BAAA,EAAkC,KAAK,CAAC,OAAO,CAAE,CAAA,CAAC;;;AAItE;;AAEG;IACH,OAAO,sBAAsB,CAAC,QAAoB,EAAA;AAChD,QAAA,IAAI;AACF,YAAA,MAAM,GAAG,GAAG,QAAQ,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC;YAChE,MAAM,IAAI,GAAG,GAAG,CAAC,aAAa,CAAC,MAAM,CAAC;AAEtC,YAAA,IAAI,QAAQ,CAAC,KAAK,EAAE;gBAClB,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,QAAQ,CAAC,KAAK,CAAC;;AAE5C,YAAA,IAAI,QAAQ,CAAC,WAAW,EAAE;gBACxB,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,QAAQ,CAAC,WAAW,CAAC;;AAGxD,YAAA,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,EAAE,KAAK,CAAC,KAAI;;;AAE7D,gBAAA,MAAM,aAAa,GAAI,QAAgB,CAAC,SAAS,CAAC;AAClD,gBAAA,MAAM,gBAAgB,GAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACjB,KAAK,CAAA,EAAA,EACR,OAAO,EAAE,CAAA,EAAA,GAAA,KAAK,CAAC,OAAO,MAAI,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAA,aAAa;mBACxC;AAED,gBAAA,MAAM,OAAO,GAAG,IAAI,CAAC,sBAAsB,CAAC,GAAG,EAAE,SAAS,EAAE,gBAAgB,CAAC;gBAC7E,IAAI,OAAO,EAAE;AACX,oBAAA,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;;AAE7B,aAAC,CAAC;AAEF,YAAA,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC;AAErB,YAAA,MAAM,UAAU,GAAG,IAAI,aAAa,EAAE;AACtC,YAAA,OAAO,UAAU,CAAC,iBAAiB,CAAC,GAAG,CAAC;;QACxC,OAAO,KAAK,EAAE;YACd,MAAM,IAAI,KAAK,CAAC,CAAA,+BAAA,EAAkC,KAAK,CAAC,OAAO,CAAE,CAAA,CAAC;;;AAI9D,IAAA,OAAO,0BAA0B,CAAC,OAAe,EAAE,IAAmB,EAAA;QAC5E,QAAQ,OAAO;AACb,YAAA,KAAK,QAAQ;AACX,gBAAA,OAAO,QAAQ;AACjB,YAAA,KAAK,UAAU;AACb,gBAAA,OAAO,QAAQ;AACjB,YAAA,KAAK,OAAO;gBACV,QAAQ,IAAI;AACV,oBAAA,KAAK,QAAQ;AACb,oBAAA,KAAK,OAAO;AACV,wBAAA,OAAO,QAAQ;AACjB,oBAAA,KAAK,MAAM;AACX,oBAAA,KAAK,gBAAgB;AACrB,oBAAA,KAAK,MAAM;AACT,wBAAA,OAAO,MAAM;AACf,oBAAA,KAAK,UAAU;AACb,wBAAA,OAAO,SAAS;AAClB,oBAAA;AACE,wBAAA,OAAO,QAAQ;;AAErB,YAAA;AACE,gBAAA,OAAO,QAAQ;;;AAIb,IAAA,OAAO,sBAAsB,CAAC,GAAa,EAAE,SAAiB,EAAE,KAAgB,EAAA;AACtF,QAAA,IAAI,OAAgB;AAEpB,QAAA,QAAQ,KAAK,CAAC,IAAI;AAChB,YAAA,KAAK,QAAQ;AACX,gBAAA,OAAO,GAAG,GAAG,CAAC,aAAa,CAAC,QAAQ,CAAC;AACrC,gBAAA,IAAI,KAAK,CAAC,OAAO,EAAE;AACjB,oBAAA,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,IAAG;wBAC7B,MAAM,aAAa,GAAG,GAAG,CAAC,aAAa,CAAC,QAAQ,CAAC;AACjD,wBAAA,aAAa,CAAC,YAAY,CAAC,OAAO,EAAE,MAAM,CAAC;AAC3C,wBAAA,aAAa,CAAC,WAAW,GAAG,MAAM;;AAElC,wBAAA,IAAI,KAAK,CAAC,OAAO,KAAK,SAAS,IAAI,KAAK,CAAC,OAAO,KAAK,MAAM,EAAE;AAC3D,4BAAA,aAAa,CAAC,YAAY,CAAC,UAAU,EAAE,MAAM,CAAC;;AAEhD,wBAAA,OAAO,CAAC,WAAW,CAAC,aAAa,CAAC;AACpC,qBAAC,CAAC;;gBAEJ;AAEF,YAAA,KAAK,SAAS;AACZ,gBAAA,OAAO,GAAG,GAAG,CAAC,aAAa,CAAC,OAAO,CAAC;AACpC,gBAAA,OAAO,CAAC,YAAY,CAAC,MAAM,EAAE,UAAU,CAAC;AACxC,gBAAA,IAAI,KAAK,CAAC,OAAO,KAAK,IAAI,IAAI,KAAK,CAAC,OAAO,KAAK,MAAM,EAAE;AACtD,oBAAA,OAAO,CAAC,YAAY,CAAC,SAAS,EAAE,MAAM,CAAC;;gBAEzC;AAEF,YAAA,KAAK,QAAQ;AACX,gBAAA,OAAO,GAAG,GAAG,CAAC,aAAa,CAAC,OAAO,CAAC;AACpC,gBAAA,OAAO,CAAC,YAAY,CAAC,MAAM,EAAE,QAAQ,CAAC;AACtC,gBAAA,IAAI,KAAK,CAAC,GAAG,KAAK,SAAS;AAAE,oBAAA,OAAO,CAAC,YAAY,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;AAC9E,gBAAA,IAAI,KAAK,CAAC,GAAG,KAAK,SAAS;AAAE,oBAAA,OAAO,CAAC,YAAY,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;AAC9E,gBAAA,IAAI,KAAK,CAAC,OAAO,KAAK,SAAS;AAAE,oBAAA,OAAO,CAAC,YAAY,CAAC,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;gBACxF;AAEF,YAAA,KAAK,MAAM;AACT,gBAAA,OAAO,GAAG,GAAG,CAAC,aAAa,CAAC,OAAO,CAAC;AACpC,gBAAA,OAAO,CAAC,YAAY,CAAC,MAAM,EAAE,MAAM,CAAC;AACpC,gBAAA,IAAI,KAAK,CAAC,OAAO,KAAK,SAAS;AAAE,oBAAA,OAAO,CAAC,YAAY,CAAC,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;gBACxF;AAEF,YAAA;AACE,gBAAA,OAAO,GAAG,GAAG,CAAC,aAAa,CAAC,OAAO,CAAC;AACpC,gBAAA,OAAO,CAAC,YAAY,CAAC,MAAM,EAAE,MAAM,CAAC;AACpC,gBAAA,IAAI,KAAK,CAAC,OAAO,KAAK,SAAS;AAAE,oBAAA,OAAO,CAAC,YAAY,CAAC,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;;AAG5F,QAAA,OAAO,CAAC,YAAY,CAAC,MAAM,EAAE,SAAS,CAAC;QACvC,OAAO,CAAC,YAAY,CAAC,OAAO,EAAE,KAAK,CAAC,KAAK,CAAC;AAE1C,QAAA,IAAI,KAAK,CAAC,WAAW,EAAE;YACrB,OAAO,CAAC,YAAY,CAAC,aAAa,EAAE,KAAK,CAAC,WAAW,CAAC;;AAExD,QAAA,IAAI,KAAK,CAAC,QAAQ,EAAE;AAClB,YAAA,OAAO,CAAC,YAAY,CAAC,UAAU,EAAE,MAAM,CAAC;;AAE1C,QAAA,IAAI,KAAK,CAAC,OAAO,EAAE;YACjB,OAAO,CAAC,YAAY,CAAC,SAAS,EAAE,KAAK,CAAC,OAAO,CAAC;;AAGhD,QAAA,OAAO,OAAO;;AAIhB;;AAEG;IACH,aAAa,gBAAgB,CAAC,OAAe,EAAE,qBAAgC,GAAA,kBAAkB,EAAE,IAAA,GAAkB,IAAI,EAAA;;AACvH,QAAA,IAAI;AACF,YAAA,MAAM,MAAM,GAAG,IAAI,SAAS,EAAE;YAC9B,MAAM,MAAM,GAAG,MAAM,CAAC,eAAe,CAAC,OAAO,EAAE,UAAU,CAAC;AAE1D,YAAA,IAAI,MAAM,CAAC,aAAa,CAAC,aAAa,CAAC,EAAE;AACvC,gBAAA,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC;;;YAIvC,MAAM,MAAM,GAAG,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC;AAC7C,YAAA,IAAI,CAAC,MAAM;AAAE,gBAAA,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC;YAE5D,MAAM,MAAM,GAAG,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC;AAChD,YAAA,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;AAAE,gBAAA,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC;AAEpE,YAAA,MAAM,MAAM,GAAyB;AACnC,gBAAA,MAAM,EAAE;aACT;YAED,KAAK,MAAM,OAAO,IAAI,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;;AAExC,gBAAA,MAAM,IAAI,GAAG,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,YAAY,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,IAAI,EAAE;AACrE,gBAAA,IAAI,CAAC,IAAI;oBAAE;AAEX,gBAAA,MAAM,QAAQ,GAAG,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,UAAU,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,IAAI,EAAE;gBACvE,MAAM,YAAY,GAAG,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,cAAc,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW;gBACvE,MAAM,WAAW,GAAG,CAAA,CAAA,EAAA,GAAA,MAAA,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW,0CAAE,IAAI,EAAA,CAAG,WAAW,EAAE,KAAI,MAAM;AACjG,gBAAA,MAAM,SAAS,GAAG,WAAW,KAAK,MAAM;;gBAGxC,MAAM,QAAQ,GAAG,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW;gBACzD,MAAM,gBAAgB,GAAG,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,YAAY,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW;gBACzE,MAAM,gBAAgB,GAAG,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,YAAY,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW;gBACzE,MAAM,gBAAgB,GAAG,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,YAAY,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW;gBACzE,MAAM,YAAY,GAAG,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,QAAQ,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW;gBACjE,MAAM,eAAe,GAAG,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,WAAW,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW;gBACvE,MAAM,gBAAgB,GAAG,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,YAAY,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW;gBACzE,MAAM,cAAc,GAAG,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,UAAU,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW;AACrE,gBAAA,MAAM,iBAAiB,GAAG,CAAA,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,WAAW,KAAI,SAAS;gBACxF,MAAM,wBAAwB,GAAG,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,oBAAoB,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW;gBACzF,MAAM,mBAAmB,GAAG,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,eAAe,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW;gBAC/E,MAAM,mBAAmB,GAAG,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,eAAe,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW;gBAC/E,MAAM,UAAU,GAAG,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW;gBAC7D,MAAM,YAAY,GAAG,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,QAAQ,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW;gBACjE,MAAM,UAAU,GAAG,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW;gBAC7D,MAAM,mBAAmB,GAAG,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,eAAe,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW;gBAC/E,MAAM,uBAAuB,GAAG,CAAA,EAAA,GAAA,OAAO,CAAC,aAAa,CAAC,mBAAmB,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,WAAW;AAEvF,gBAAA,MAAM,KAAK,GAAsB;AAC/B,oBAAA,IAAI,EAAE,IAAI,CAAC,wBAAwB,CAAC,iBAAiB,CAAC;AACtD,oBAAA,KAAK,EAAE,eAAe;AACtB,oBAAA,WAAW,EAAE,QAAQ;oBACrB,QAAQ,EAAE,CAAA,wBAAwB,KAAxB,IAAA,IAAA,wBAAwB,KAAxB,MAAA,GAAA,MAAA,GAAA,wBAAwB,CAAE,WAAW,EAAE,MAAK,UAAU;oBAChE,OAAO,EAAE,YAAY,IAAI,SAAS;AAElC,oBAAA,QAAQ,EAAE,iBAAiB;AAE3B,oBAAA,OAAO,EAAE,SAAS;AAClB,oBAAA,EAAE,EAAE,QAAQ;AACZ,oBAAA,UAAU,EAAE,gBAAgB;AAC5B,oBAAA,UAAU,EAAE,gBAAgB;AAC5B,oBAAA,UAAU,EAAE,gBAAgB;AAC5B,oBAAA,MAAM,EAAE,YAAY;AACpB,oBAAA,SAAS,EAAE,eAAe;AAC1B,oBAAA,UAAU,EAAE,gBAAgB;AAC5B,oBAAA,QAAQ,EAAE,cAAc;AACxB,oBAAA,WAAW,EAAE,iBAAiB;AAC9B,oBAAA,kBAAkB,EAAE,wBAAwB;AAC5C,oBAAA,aAAa,EAAE,mBAAmB;AAClC,oBAAA,aAAa,EAAE,mBAAmB;AAClC,oBAAA,IAAI,EAAE,UAAU;AAChB,oBAAA,MAAM,EAAE,YAAY;AACpB,oBAAA,IAAI,EAAE,UAAU;AAChB,oBAAA,aAAa,EAAE,mBAAmB;AAClC,oBAAA,iBAAiB,EAAE;iBACpB;;gBAGD,IAAI,KAAK,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,QAAQ,EAAE;AACzC,oBAAA,IAAI;AACF,wBAAA,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,CAAA,EAAG,qBAAqB,CAAA,kCAAA,EAAqC,KAAK,CAAC,WAAW,CAAC,WAAW,EAAE,IAAI,YAAY,GAAG,UAAU,GAAG,WAAW,CAAiB,cAAA,EAAA,YAAY,CAAE,CAAA,CAAC;wBACpM,IAAI,CAAC,QAAQ,CAAC,EAAE;4BAAE,MAAM,IAAI,KAAK,CAAC,CAAA,oBAAA,EAAuB,QAAQ,CAAC,MAAM,CAAE,CAAA,CAAC;AAE3E,wBAAA,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE;AAClC,wBAAA,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;4BACvB,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK;gCAChC,KAAK,EAAE,IAAI,CAAC,EAAE;gCACd,KAAK,EAAE,IAAI,CAAC;AACb,6BAAA,CAAC,CAAC;AACH,4BAAA,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;AACtB,gCAAA,KAAK,CAAC,aAAa,GAAG,OAAO;;gCAE7B,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,IAAI,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;;;6BAEjE;AACL,4BAAA,OAAO,CAAC,KAAK,CAAC,iCAAiC,EAAE,IAAI,CAAC;;;oBAExD,OAAO,KAAK,EAAE;AACd,wBAAA,OAAO,CAAC,KAAK,CAAC,qCAAqC,EAAE,KAAK,CAAC;;;AAI/D,gBAAA,IAAI,mBAAmB;AAAE,oBAAA,KAAK,CAAC,GAAG,GAAG,UAAU,CAAC,mBAAmB,CAAC;AACpE,gBAAA,IAAI,mBAAmB;AAAE,oBAAA,KAAK,CAAC,GAAG,GAAG,UAAU,CAAC,mBAAmB,CAAC;AACpE,gBAAA,IAAI,UAAU;AAAE,oBAAA,KAAK,CAAC,OAAO,GAAG,UAAU;;;AAK1C,gBAAA,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,KAAK;;AAGjC,YAAA,OAAO,MAAM;;QACb,OAAO,KAAK,EAAE;YACd,MAAM,IAAI,KAAK,CAAC,CAAA,+BAAA,EAAkC,KAAK,CAAC,OAAO,CAAE,CAAA,CAAC;;;AAItE;;AAEG;IACH,OAAO,gBAAgB,CAAC,QAAsC,EAAA;AAC5D,QAAA,IAAI;AACF,YAAA,MAAM,GAAG,GAAG,QAAQ,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC;YAChE,MAAM,MAAM,GAAG,GAAG,CAAC,aAAa,CAAC,QAAQ,CAAC;AAE1C,YAAA,MAAM,CAAC,OAAO,EAAI,QAAgB,CAAC,MAAM,GAAI,QAAgB,CAAC,MAAM,GAAI,QAAgB,CAAC,MAAM,EAAG,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,EAAE,KAAK,CAAC,KAAI;gBAC9H,MAAM,OAAO,GAAG,GAAG,CAAC,aAAa,CAAC,QAAQ,CAAC;gBAC3C,MAAM,UAAU,GAAI,KAA2B;;;;gBAM/C,MAAM,YAAY,GAAG,GAAG,CAAC,aAAa,CAAC,YAAY,CAAC;AACpD,gBAAA,YAAY,CAAC,WAAW,GAAG,UAAU,CAAC,UAAU;AAChD,gBAAA,OAAO,CAAC,WAAW,CAAC,YAAY,CAAC;;gBAGjC,MAAM,OAAO,GAAG,GAAG,CAAC,aAAa,CAAC,WAAW,CAAC;gBAC9C,OAAO,CAAC,WAAW,GAAG,UAAU,CAAC,KAAK,IAAI,OAAO;AACjD,gBAAA,OAAO,CAAC,WAAW,CAAC,OAAO,CAAC;;gBAG5B,MAAM,MAAM,GAAG,GAAG,CAAC,aAAa,CAAC,UAAU,CAAC;AAC5C,gBAAA,MAAM,CAAC,WAAW,GAAG,UAAU,CAAC,WAAW;AAC3C,gBAAA,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC;;gBAG3B,MAAM,aAAa,GAAG,GAAG,CAAC,aAAa,CAAC,aAAa,CAAC;AACtD,gBAAA,aAAa,CAAC,WAAW,GAAG,UAAU,CAAC,QAAQ;AAC/C,gBAAA,OAAO,CAAC,WAAW,CAAC,aAAa,CAAC;;gBAGlC,MAAM,YAAY,GAAG,GAAG,CAAC,aAAa,CAAC,oBAAoB,CAAC;AAC5D,gBAAA,YAAY,CAAC,WAAW,GAAG,UAAU,CAAC,QAAQ,GAAG,UAAU,GAAG,cAAc;AAC5E,gBAAA,OAAO,CAAC,WAAW,CAAC,YAAY,CAAC;;gBAGjC,MAAM,SAAS,GAAG,GAAG,CAAC,aAAa,CAAC,cAAc,CAAC;gBACnD,MAAM,OAAO,GAAG,GAAG,CAAC,aAAa,CAAC,OAAO,CAAC;AAC1C,gBAAA,IAAI,QAAQ,CAAC,OAAO,CAAC,KAAK,SAAS,EAAE;oBACnC,SAAS,CAAC,WAAW,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE;oBACpD,OAAO,CAAC,WAAW,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE;;qBAE/C;oBACH,SAAS,CAAC,WAAW,GAAG,UAAU,CAAC,OAAO,IAAI,UAAU,CAAC,KAAK;oBAC9D,OAAO,CAAC,WAAW,GAAG,UAAU,CAAC,KAAK,IAAI,UAAU,CAAC,OAAO;;AAE9D,gBAAA,OAAO,CAAC,WAAW,CAAC,SAAS,CAAC;AAC9B,gBAAA,OAAO,CAAC,WAAW,CAAC,OAAO,CAAC;;gBAG5B,MAAM,SAAS,GAAG,GAAG,CAAC,aAAa,CAAC,SAAS,CAAC;AAC9C,gBAAA,SAAS,CAAC,WAAW,GAAG,UAAU,CAAC,OAAO,KAAK,KAAK,GAAG,OAAO,GAAG,MAAM;AACvE,gBAAA,OAAO,CAAC,WAAW,CAAC,SAAS,CAAC;;gBAG9B,MAAM,QAAQ,GAAG,GAAG,CAAC,aAAa,CAAC,QAAQ,CAAC;AAC5C,gBAAA,QAAQ,CAAC,WAAW,GAAG,UAAU,CAAC,MAAM;AACxC,gBAAA,OAAO,CAAC,WAAW,CAAC,QAAQ,CAAC;AAE7B,gBAAA,IAAI,UAAU,CAAC,IAAI,KAAK,QAAQ,EAAE;oBAChC,MAAM,QAAQ,GAAG,GAAG,CAAC,aAAa,CAAC,QAAQ,CAAC;AAC5C,oBAAA,QAAQ,CAAC,WAAW,GAAG,UAAU,CAAC,KAAK;AACvC,oBAAA,OAAO,CAAC,WAAW,CAAC,QAAQ,CAAC;;gBAG/B,MAAM,IAAI,GAAG,GAAG,CAAC,aAAa,CAAC,IAAI,CAAC;AACpC,gBAAA,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC,EAAE;AAChC,gBAAA,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC;gBAEzB,MAAM,UAAU,GAAG,GAAG,CAAC,aAAa,CAAC,YAAY,CAAC;AAClD,gBAAA,UAAU,CAAC,WAAW,GAAG,UAAU,CAAC,UAAU;AAC9C,gBAAA,OAAO,CAAC,WAAW,CAAC,UAAU,CAAC;gBAE/B,MAAM,UAAU,GAAG,GAAG,CAAC,aAAa,CAAC,YAAY,CAAC;AAClD,gBAAA,UAAU,CAAC,WAAW,GAAG,UAAU,CAAC,UAAU;AAC9C,gBAAA,OAAO,CAAC,WAAW,CAAC,UAAU,CAAC;gBAE/B,MAAM,UAAU,GAAG,GAAG,CAAC,aAAa,CAAC,YAAY,CAAC;AAClD,gBAAA,UAAU,CAAC,WAAW,GAAG,UAAU,CAAC,UAAU;AAC9C,gBAAA,OAAO,CAAC,WAAW,CAAC,UAAU,CAAC;gBAE/B,MAAM,UAAU,GAAG,GAAG,CAAC,aAAa,CAAC,UAAU,CAAC;AAChD,gBAAA,UAAU,CAAC,WAAW,GAAG,UAAU,CAAC,QAAQ;AAC5C,gBAAA,OAAO,CAAC,WAAW,CAAC,UAAU,CAAC;gBAE/B,MAAM,QAAQ,GAAG,GAAG,CAAC,aAAa,CAAC,QAAQ,CAAC;AAC5C,gBAAA,QAAQ,CAAC,WAAW,GAAG,UAAU,CAAC,MAAM;AACxC,gBAAA,OAAO,CAAC,WAAW,CAAC,QAAQ,CAAC;gBAE7B,MAAM,MAAM,GAAG,GAAG,CAAC,aAAa,CAAC,MAAM,CAAC;AACxC,gBAAA,MAAM,CAAC,WAAW,GAAG,UAAU,CAAC,IAAI;AACpC,gBAAA,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC;gBAE3B,MAAM,cAAc,GAAG,GAAG,CAAC,aAAa,CAAC,eAAe,CAAC;AACzD,gBAAA,cAAc,CAAC,WAAW,GAAG,UAAU,CAAC,aAAa;AACrD,gBAAA,OAAO,CAAC,WAAW,CAAC,cAAc,CAAC;gBAEnC,MAAM,gBAAgB,GAAG,GAAG,CAAC,aAAa,CAAC,mBAAmB,CAAC;AAC/D,gBAAA,gBAAgB,CAAC,WAAW,GAAG,UAAU,CAAC,iBAAiB;AAC3D,gBAAA,OAAO,CAAC,WAAW,CAAC,gBAAgB,CAAC;gBAErC,MAAM,eAAe,GAAG,GAAG,CAAC,aAAa,CAAC,eAAe,CAAC;AAC1D,gBAAA,eAAe,CAAC,WAAW,GAAG,UAAU,CAAC,aAAa;AACtD,gBAAA,OAAO,CAAC,WAAW,CAAC,eAAe,CAAC;gBAEpC,MAAM,eAAe,GAAG,GAAG,CAAC,aAAa,CAAC,eAAe,CAAC;AAC1D,gBAAA,eAAe,CAAC,WAAW,GAAG,UAAU,CAAC,aAAa;AACtD,gBAAA,OAAO,CAAC,WAAW,CAAC,eAAe,CAAC;gBAEpC,MAAM,MAAM,GAAG,GAAG,CAAC,aAAa,CAAC,MAAM,CAAC;AACxC,gBAAA,MAAM,CAAC,WAAW,GAAG,UAAU,CAAC,IAAI;AACpC,gBAAA,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC;;AAG3B,gBAAA,MAAM,CAAC,WAAW,CAAC,OAAO,CAAC;AAC7B,aAAC,CAAC;AAEF,YAAA,GAAG,CAAC,WAAW,CAAC,MAAM,CAAC;AAEvB,YAAA,MAAM,UAAU,GAAG,IAAI,aAAa,EAAE;AACtC,YAAA,OAAO,UAAU,CAAC,iBAAiB,CAAC,GAAG,CAAC;;QACxC,OAAO,KAAK,EAAE;YACd,MAAM,IAAI,KAAK,CAAC,CAAA,+BAAA,EAAkC,KAAK,CAAC,OAAO,CAAE,CAAA,CAAC;;;IAI9D,OAAO,wBAAwB,CAAC,WAAmB,EAAA;;AAEzD,QAAA,QAAQ,WAAW,CAAC,WAAW,EAAE;AAC/B,YAAA,KAAK,SAAS;AACd,YAAA,KAAK,MAAM;AACT,gBAAA,OAAO,QAAQ;AACjB,YAAA,KAAK,YAAY;AACf,gBAAA,OAAO,MAAM;AACf,YAAA,KAAK,iBAAiB;AACtB,YAAA,KAAK,qBAAqB;AAC1B,YAAA,KAAK,YAAY;AACf,gBAAA,OAAO,QAAQ;AACjB,YAAA,KAAK,UAAU;gBACb,OAAO,UAAU,CAAC;AACpB,YAAA,KAAK,QAAQ;gBACX,OAAO,QAAQ,CAAC;AAClB,YAAA,KAAK,UAAU;AACb,gBAAA,OAAO,SAAS;AAClB,YAAA,KAAK,YAAY;AACf,gBAAA,OAAO,QAAQ;AACjB,YAAA;AACE,gBAAA,OAAO,QAAQ;;;AAuBtB;;AC7eD,MAAM,mBAAmB,GAAG,6mHAA6mH;;MCa5nH,iBAAiB,GAAA,MAAA;AA+B5B,IAAA,WAAA,CAAA,OAAA,EAAA;;;;AA9BQ,QAAA,IAAQ,CAAA,QAAA,GAAW,IAAI;AACvB,QAAA,IAAa,CAAA,aAAA,GAAW,IAAI;AAE5B,QAAA,IAAO,CAAA,OAAA,GAAwC,SAAS;AACxD,QAAA,IAAqB,CAAA,qBAAA,GAAW,kBAAkB;AAClD,QAAA,IAAQ,CAAA,QAAA,GAAc,IAAI;AAC1B,QAAA,IAAU,CAAA,UAAA,GAAkC,EAAE;AAE9C,QAAA,IAAK,CAAA,KAAA,GAAY,KAAK;AACtB,QAAA,IAAU,CAAA,UAAA,GAAY,KAAK;AAC3B,QAAA,IAAa,CAAA,aAAA,GAAY,KAAK;AAK7B,QAAA,IAAW,CAAA,WAAA,GAAY,KAAK;AAC5B,QAAA,IAAY,CAAA,YAAA,GAAY,KAAK;AAE7B,QAAA,IAAQ,CAAA,QAAA,GAAY,KAAK;AACzB,QAAA,IAAa,CAAA,aAAA,GAAW,EAAE;AAC1B,QAAA,IAAU,CAAA,UAAA,GAA0B,IAAI;AACxC,QAAA,IAAS,CAAA,SAAA,GAAQ,EAAE;AACnB,QAAA,IAAA,CAAA,cAAc,GAAY,IAAI,CAAC;AAschC,QAAA,IAAwB,CAAA,wBAAA,GAAG,MAAK;AACpC,YAAA,IAAI,CAAC,oBAAoB,CAAC,KAAK,EAAE;AACrC,SAAC;AAEO,QAAA,IAAA,CAAA,uBAAuB,GAAG,OAAO,KAAY,KAAI;AACvD,YAAA,MAAM,KAAK,GAAG,KAAK,CAAC,MAA0B;YAC9C,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC;gBAAE;YAE9C,MAAM,IAAI,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;;AAG3B,YAAA,OAAO,CAAC,GAAG,CAAC,gBAAgB,EAAE,IAAI,CAAC;AAEnC,YAAA,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC;AAChC,SAAC;AA3cC,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,oBAAoB,EAAE;AAChD;IAED,iBAAiB,GAAA;QACf,IAAI,CAAC,kBAAkB,EAAE;;IAK3B,kBAAkB,GAAA;AAChB,QAAA,IAAI;AACF,YAAA,IAAI,CAAC,IAAI,CAAC,OAAO,EAAC;AAChB,gBAAA,IAAI,CAAC,QAAQ,GAAG,IAAI;gBACpB,MAAM,YAAY,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,GAAG,CAAA,kCAAA,EAAqC,IAAI,CAAC,OAAO,CAAG,CAAA,CAAA,GAAG,CAA6C,0CAAA,EAAA,IAAI,CAAC,OAAO,CAAG,CAAA,CAAA,CAAC;AAClK,gBAAA,IAAI,CAAC,aAAa,GAAG,YAAY;gBACjC,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC;;iBAEzD;;AAEF,gBAAA,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC;;AAGrD,gBAAA,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC;;AAG1D,gBAAA,IAAI,IAAI,CAAC,MAAM,EAAE;AACf,oBAAA,IAAI,CAAC,YAAY,GACZ,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAA,IAAI,CAAC,YAAY,CAAA,EAAA,EACpB,YAAY,EAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAO,IAAI,CAAC,YAAY,CAAC,YAAY,KAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EACtE,CAAA,EAAA,GAAG,EAAO,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAA,IAAI,CAAC,YAAY,CAAC,GAAG,CAAA,EAAA,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,MACrD;;;gBAIH,IAAI,CAAC,mBAAmB,GAAG,0BAA0B,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC;gBAC/E,IAAI,CAAC,UAAU,GAAG,iBAAiB,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC;AAE7D,gBAAA,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE;oBAClC,MAAM,EAAE,IAAI,CAAC,YAAY;oBACzB,MAAM,EAAE,IAAI,CAAC;AACd,iBAAA,CAAC;AAEF,gBAAA,IAAI,CAAC,QAAQ,GAAG,KAAK;AACrB,gBAAA,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,GAAG,0BAA0B,GAAG,0BAA0B,CAAC;gBACtG,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,KAAK,CAAC,EAAC;AAC/B,oBAAA,IAAI,CAAC,UAAU,GAAG,CAAC,OAAO,CAAC;;;;QAG/B,OAAO,KAAK,EAAE;AACd,YAAA,IAAI,CAAC,QAAQ,GAAG,IAAI;YACpB,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,GAAG,CAAA,sBAAA,EAAyB,KAAK,CAAC,OAAO,CAAE,CAAA,GAAG,CAA4B,yBAAA,EAAA,KAAK,CAAC,OAAO,CAAE,CAAA,CAAC;AACrI,YAAA,IAAI,CAAC,eAAe,CAAC,sBAAsB,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC;;;IAIlE,eAAe,CAAC,MAAc,EAAE,IAAS,EAAA;AAC/C,QAAA,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,IAAI,CAAC,SAAS,GAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACT,IAAI,CAAC,SAAS,CACjB,EAAA,EAAA,CAAC,MAAM,GAAG;AACR,oBAAA,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;oBACnC;AACD,iBAAA,EAAA,CACF;;;AAIG,IAAA,MAAM,iBAAiB,GAAA;QAC7B,IAAI,IAAI,CAAC,YAAY;YAAE;AAEvB,QAAA,IAAI,IAAI,CAAC,WAAW,EAAE;AACpB,YAAA,MAAM,IAAI,CAAC,uBAAuB,EAAE;;aAC/B;AACL,YAAA,MAAM,IAAI,CAAC,cAAc,EAAE;;;AAIvB,IAAA,MAAM,cAAc,GAAA;AAC1B,QAAA,IAAI;AACF,YAAA,IAAI,CAAC,QAAQ,GAAG,KAAK;AACrB,YAAA,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,GAAG,uBAAuB,GAAG,CAAA,kBAAA,CAAoB,CAAC;AAC7F,YAAA,IAAI,CAAC,eAAe,CAAC,yBAAyB,EAAE,EAAE,CAAC;AAEnD,YAAA,MAAM,IAAI,CAAC,aAAa,CAAC,cAAc,EAAE;AAEzC,YAAA,IAAI,CAAC,WAAW,GAAG,IAAI;AACvB,YAAA,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,GAAG,4BAA4B,GAAG,yCAAyC,CAAC;AACvH,YAAA,IAAI,CAAC,eAAe,CAAC,mBAAmB,EAAE,EAAE,CAAC;AAE7C,YAAA,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC;AAC9B,gBAAA,WAAW,EAAE,IAAI;AACjB,gBAAA,KAAK,EAAE;AACR,aAAA,CAAC;;QACF,OAAO,KAAK,EAAE;AACd,YAAA,IAAI,CAAC,QAAQ,GAAG,IAAI;YACpB,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,GAAG,CAAA,kBAAA,EAAqB,KAAK,CAAC,OAAO,CAAE,CAAA,GAAG,CAA+B,4BAAA,EAAA,KAAK,CAAC,OAAO,CAAE,CAAA,CAAC;AACpI,YAAA,IAAI,CAAC,eAAe,CAAC,iBAAiB,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC;AAEjE,YAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;AACnB,gBAAA,OAAO,EAAE,KAAK;gBACd,KAAK,EAAE,KAAK,CAAC;AACd,aAAA,CAAC;;;IAIE,MAAM,eAAe,CAAC,QAAgB,EAAA;AAC5C,QAAA,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE,QAAQ,CAAC;AACxC,QAAA,IAAI;AACF,YAAA,IAAI,CAAC,YAAY,GAAG,IAAI;AACxB,YAAA,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,GAAG,oBAAoB,GAAG,CAAA,sBAAA,CAAwB,CAAC;;AAG9F,YAAA,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,GAAG,wBAAwB,GAAG,+BAA+B,CAAC;YACzG,MAAM,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC;AAC7D,YAAA,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,QAAQ,EAAE,aAAa,CAAC;;YAGpF,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC;AACtD,YAAA,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE;gBAClC,YAAY;gBACZ,aAAa,EAAE,IAAI,CAAC;AACrB,aAAA,CAAC;AAEF,YAAA,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU;AAEnC,YAAA,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,GAAG,iBAAiB,GAAG,sBAAsB,CAAC;AACzF,YAAA,IAAI,CAAC,QAAQ,GAAG,KAAK;;AAGrB,YAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;AACnB,gBAAA,OAAO,EAAE,IAAI;gBACb,IAAI,EAAE,IAAI,CAAC,UAAU;AACrB,gBAAA,QAAQ,EAAE;AACX,aAAA,CAAC;;QAEF,OAAO,KAAK,EAAE;AACd,YAAA,IAAI,CAAC,QAAQ,GAAG,IAAI;YACpB,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,GAAG,CAAA,mBAAA,EAAsB,KAAK,CAAC,OAAO,CAAE,CAAA,GAAG,CAA0B,uBAAA,EAAA,KAAK,CAAC,OAAO,CAAE,CAAA,CAAC;AAEhI,YAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;AACnB,gBAAA,OAAO,EAAE,KAAK;gBACd,KAAK,EAAE,KAAK,CAAC,OAAO;AACpB,gBAAA,QAAQ,EAAE;AACX,aAAA,CAAC;;gBACM;AACR,YAAA,IAAI,CAAC,YAAY,GAAG,KAAK;;;IAIrB,MAAM,mBAAmB,CAAC,SAAS,EAAA;AACzC,QAAA,IAAI,CAAC,eAAe,CAAC,gBAAgB,EAAE;YACrC,IAAI,EAAE,SAAS,CAAC,IAAI;YACpB,IAAI,EAAE,SAAS,CAAC;AACjB,SAAA,CAAC;;AAGF,QAAA,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,GAAG,wBAAwB,GAAG,4BAA4B,CAAC;AACtG,QAAA,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC;AACzF,QAAA,IAAI,CAAC,aAAa,GAAG,aAAa;QAClC,IAAI,CAAC,eAAe,CAAC,wBAAwB,EAAE,EAAE,aAAa,EAAE,CAAC;AAEjE,QAAA,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,EAAE;AACzB,YAAA,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC;;;AAIxD,QAAA,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,GAAG,wBAAwB,GAAG,+BAA+B,CAAC;QACzG,MAAM,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC;AAC7D,QAAA,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,yBAAyB,CAAC,aAAa,EAAE,aAAa,CAAC;;QAGlG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC;AACtD,QAAA,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE;YAClC,YAAY;YACZ,aAAa,EAAE,IAAI,CAAC;AACrB,SAAA,CAAC;AAEF,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU;AAEnC,QAAA,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,GAAG,iBAAiB,GAAG,sBAAsB,CAAC;AACzF,QAAA,IAAI,CAAC,QAAQ,GAAG,KAAK;;AAGrB,QAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;AACnB,YAAA,OAAO,EAAE,IAAI;YACb,IAAI,EAAE,IAAI,CAAC,UAAU;AACrB,YAAA,aAAa,EAAE;AAChB,SAAA,CAAC;;AAGI,IAAA,MAAM,uBAAuB,GAAA;AACnC,QAAA,IAAI;AACF,YAAA,IAAI,CAAC,WAAW,GAAG,KAAK;AACxB,YAAA,IAAI,CAAC,YAAY,GAAG,IAAI;AACxB,YAAA,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,GAAG,qBAAqB,GAAG,CAAA,yBAAA,CAA2B,CAAC;AAClG,YAAA,IAAI,CAAC,eAAe,CAAC,gBAAgB,EAAE,EAAE,CAAC;AAE1C,YAAA,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC;AAC9B,gBAAA,WAAW,EAAE,KAAK;AAClB,gBAAA,KAAK,EAAE;AACR,aAAA,CAAC;;YAGF,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE;AAC1D,YAAA,MAAM,YAAY,GAAG,IAAI,IAAI,CAAC,CAAC,SAAS,CAAC,EAAE,YAAY,EAAE,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;AAChF,YAAA,IAAI,CAAC,mBAAmB,CAAC,YAAY,CAAC;;QAEtC,OAAO,KAAK,EAAE;AACd,YAAA,IAAI,CAAC,QAAQ,GAAG,IAAI;YACpB,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,GAAG,CAAA,mBAAA,EAAsB,KAAK,CAAC,OAAO,CAAE,CAAA,GAAG,CAA0B,uBAAA,EAAA,KAAK,CAAC,OAAO,CAAE,CAAA,CAAC;AAChI,YAAA,IAAI,CAAC,eAAe,CAAC,kBAAkB,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC;AAElE,YAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;AACnB,gBAAA,OAAO,EAAE,KAAK;gBACd,KAAK,EAAE,KAAK,CAAC,OAAO;gBACpB,aAAa,EAAE,IAAI,CAAC;AACrB,aAAA,CAAC;;gBACM;AACR,YAAA,IAAI,CAAC,YAAY,GAAG,KAAK;AACzB,YAAA,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC;AAC9B,gBAAA,WAAW,EAAE,KAAK;AAClB,gBAAA,KAAK,EAAE;AACR,aAAA,CAAC;;;AAIE,IAAA,iBAAiB,CAAC,UAAe,EAAA;;AAEvC,QAAA,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;AACnE,QAAA,QAAO,IAAI,CAAC,OAAO;AACjB,YAAA,KAAK,SAAS;;AAEd,YAAA,KAAK,IAAI;gBACP,IAAI,UAAU,aAAV,UAAU,KAAA,MAAA,GAAA,MAAA,GAAV,UAAU,CAAE,MAAM,EAAE;;oBAEtB,UAAU,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAU,KAAI;AACvC,wBAAA,MAAM,aAAa,GAAG,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,KAAU,KAAI,EAAA,IAAA,EAAA,CAAA,CAC/D,OAAA,KAAK,CAAC,WAAW,KAAK,KAAK,CAAC,IAAI,IAAI,CAAA,CAAA,EAAA,GAAA,KAAK,CAAC,QAAQ,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,KAAK,MAAK,KAAK,CAAC,IAAI,CAAA,EAAA,CACzE;wBAED,IAAI,aAAa,IAAI,KAAK,CAAC,KAAK,KAAK,SAAS,IAAI,KAAK,CAAC,KAAK,KAAK,IAAI,IAAI,KAAK,CAAC,KAAK,KAAK,EAAE,EAAE;4BAC5F,IAAI,CAAC,aAAa,CAAC,QAAQ;AAAE,gCAAA,aAAa,CAAC,QAAQ,GAAG,EAAE;4BACxD,aAAa,CAAC,QAAQ,CAAC,aAAa,GAAG,KAAK,CAAC,KAAK;;AAEtD,qBAAC,CAAC;;gBAGJ;AACF,YAAA,KAAK,YAAY;;gBAEf,IAAI,UAAU,aAAV,UAAU,KAAA,MAAA,GAAA,MAAA,GAAV,UAAU,CAAE,MAAM,EAAE;;oBAEtB,UAAU,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAU,KAAI;wBACvC,IAAI,aAAa,GAAG,aAAa,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAU,KACzD,KAAK,CAAC,KAAK,KAAK,KAAK,CAAC,IAAI,CAC3B;AACD,wBAAA,IAAI,CAAC,aAAa;4BACf,aAAa,GAAG,aAAa,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAU,KACtD,KAAK,CAAC,KAAK,KAAK,KAAK,CAAC,IAAI,CAC3B;wBAEH,IAAI,aAAa,IAAI,KAAK,CAAC,KAAK,KAAK,SAAS,IAAI,KAAK,CAAC,KAAK,KAAK,IAAI,IAAI,KAAK,CAAC,KAAK,KAAK,EAAE,EAAE;AAC5F,4BAAA,aAAa,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,KAAK;;AAEtD,qBAAC,CAAC;;gBAEJ;AACF,YAAA,KAAK,OAAO;AACZ,YAAA;AAGE,gBAAA,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,EAAE,KAAK,CAAgB,KAAI;AAC5E,oBAAA,IAAI,KAAK,CAAC,OAAO,KAAK,SAAS,IAAI,KAAK,CAAC,OAAO,KAAK,IAAI,IAAI,KAAK,CAAC,OAAO,KAAK,EAAE,EAAE;AACjF,wBAAA,aAAa,CAAC,OAAO,CAAC,GAAG,KAAK,CAAC,OAAO;;AAExC,oBAAA,IAAI,KAAK,CAAC,KAAK,KAAK,SAAS,IAAI,KAAK,CAAC,KAAK,KAAK,IAAI,IAAI,KAAK,CAAC,KAAK,KAAK,EAAE,EAAE;AAC3E,wBAAA,KAAK,MAAM,GAAG,IAAI,aAAa,CAAC,MAAM,EAAE;4BACtC,MAAM,WAAW,GAAG,aAAa,CAAC,MAAM,CAAC,GAAG,CAAC;4BAC7C,IAAI,WAAW,CAAC,KAAK,KAAK,KAAK,CAAC,IAAI,EAAE;gCACpC,WAAW,CAAC,KAAK,GAAG,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,OAAO;gCAChD,WAAW,CAAC,OAAO,GAAG,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,OAAO;AAClD,gCAAA,MAAM;;;;AAId,iBAAC,CAAC;gBAEF;;;AAIJ,QAAA,OAAO,aAAa;;AAGd,IAAA,eAAe,CAAC,MAAW,EAAA;;;AAEjC,QAAA,QAAO,IAAI,CAAC,OAAO;AACjB,YAAA,KAAK,SAAS;;AAEd,YAAA,KAAK,IAAI;AACP,gBAAA,MAAM,OAAO,GAAG,EAAE,MAAM,EAAE,EAAE,EAAE;gBAC9B,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,KAAU,KAAI;;oBACrC,IAAI,CAAC,KAAK,CAAC,WAAW,IAAI,CAAC,KAAK,CAAC,IAAI;wBAAE;AAEvC,oBAAA,MAAM,SAAS,GAAQ;AACrB,wBAAA,IAAI,EAAE,KAAK,CAAC,KAAK,KAAI,CAAA,EAAA,GAAA,KAAK,CAAC,QAAQ,0CAAE,KAAK,CAAA,IAAI,KAAK,CAAC,WAAW;wBAC/D,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI;qBACnC;;AAGD,oBAAA,MAAM,WAAW,GAAG,CAAC,qBAAqB,EAAE,QAAQ,CAAC;oBACrD,IAAI,WAAW,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,QAAQ,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;wBACnF,SAAS,CAAC,OAAO,GAAG,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,MAAW,KACjD,MAAM,CAAC,WAAW,IAAI,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,QAAQ,EAAE,CACxD;;AAGH,oBAAA,OAAO,CAAC,GAAG,CAAC,WAAW,EAAE,SAAS,CAAC;AAEnC,oBAAA,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC;AAChC,iBAAC,CAAC;;AAGF,gBAAA,OAAO,OAAO;AAChB,YAAA,KAAK,YAAY;;gBAEf,MAAM,iBAAiB,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;gBAEzF,IAAI,iBAAiB,EAAE;AACrB,oBAAA,MAAM,aAAa,GAAe;AAChC,wBAAA,KAAK,EAAE,WAAW;AAClB,wBAAA,WAAW,EAAE,kBAAkB;AAC/B,wBAAA,MAAM,EAAE;qBACT;AAED,oBAAA,MAAM,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAgB,KAAI;AACxE,wBAAA,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI;wBAC5B,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAQ;AACtD,wBAAA,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK,IAAI,SAAS;AAI3C,wBAAA,aAAa,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG;AAChC,4BAAA,IAAI,EAAE,SAAS;AACf,4BAAA,KAAK,EAAE,UAAU;4BACjB,OAAO,EAAE,KAAK,CAAC,OAAO;AACtB,4BAAA,QAAQ,EAAE,KAAK,CAAC,QAAQ,KAAK,IAAI;AACjC,4BAAA,OAAO,EAAE,EAAE;yBACZ;AACH,qBAAC,CAAC;;AAGF,oBAAA,OAAO,aAAa;;AAExB,YAAA,KAAK,OAAO;AACZ,YAAA;;gBAEE,IAAI,MAAA,MAAM,KAAA,IAAA,IAAN,MAAM,KAAA,MAAA,GAAA,MAAA,GAAN,MAAM,CAAE,MAAM,MAAI,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAA,MAAM,aAAN,MAAM,KAAA,MAAA,GAAA,MAAA,GAAN,MAAM,CAAE,MAAM,EAAE;AACpC,oBAAA,MAAM,aAAa,GAAe;wBAChC,KAAK,EAAE,MAAM,CAAC,KAAK;wBACnB,WAAW,EAAE,MAAM,CAAC,WAAW;AAC/B,wBAAA,MAAM,EAAE;qBACT;oBAED,MAAM,WAAW,GAAG,CAAA,EAAA,GAAA,MAAM,KAAN,IAAA,IAAA,MAAM,uBAAN,MAAM,CAAE,MAAM,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAI,MAAM,KAAN,IAAA,IAAA,MAAM,uBAAN,MAAM,CAAE,MAAM;AAEpD,oBAAA,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,EAAE,KAAK,CAAgB,KAAI;AACxE,wBAAA,aAAa,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG;4BAChC,IAAI,EAAE,KAAK,CAAC,IAAI;4BAChB,KAAK,EAAE,KAAK,CAAC,KAAK;4BAClB,OAAO,EAAE,KAAK,CAAC,OAAO;AACtB,4BAAA,QAAQ,EAAE,KAAK,CAAC,OAAO,KAAK,KAAK;4BACjC,OAAO,EAAE,KAAK,CAAC,YAAY;4BAC3B,OAAO,EAAE,KAAK,CAAC,IAAI;4BACnB,GAAG,EAAE,KAAK,CAAC,aAAa;4BACxB,GAAG,EAAE,KAAK,CAAC;yBACZ;AACH,qBAAC,CAAC;;AAIF,oBAAA,OAAO,aAAa;;gBAEtB;;AAGJ,QAAA,OAAO,MAAM;;AAGP,IAAA,YAAY,CAAC,IAAY,EAAA;AAC/B,QAAA,MAAM,WAAW,GAAG;AAClB,YAAA,mBAAmB,EAAE,QAAQ;AAC7B,YAAA,cAAc,EAAE,QAAQ;AACxB,YAAA,eAAe,EAAE,QAAQ;AACzB,YAAA,qBAAqB,EAAE,UAAU;AACjC,YAAA,cAAc,EAAE,QAAQ;AACxB,YAAA,qBAAqB,EAAE,QAAQ;AAC/B,YAAA,eAAe,EAAE,SAAS;AAC1B,YAAA,sBAAsB,EAAE,QAAQ;AAChC,YAAA,WAAW,EAAE,QAAQ;AACrB,YAAA,UAAU,EAAE,QAAQ;AACpB,YAAA,MAAM,EAAE,QAAQ;AAChB,YAAA,UAAU,EAAE,QAAQ;AACpB,YAAA,QAAQ,EAAE,QAAQ;AAClB,YAAA,MAAM,EAAE,MAAM;AACd,YAAA,UAAU,EAAE,UAAU;AACtB,YAAA,QAAQ,EAAE,QAAQ;AAClB,YAAA,UAAU,EAAE;SACb;AAED,QAAA,OAAO,WAAW,CAAC,IAAI,CAAC,IAAI,QAAQ;;;IAIrB,MAAM,gBAAgB,CAAC,OAAe,EAAA;AACrD,QAAA,OAAO,eAAe,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,qBAAqB,EAAE,IAAI,CAAC,QAAQ,CAAC;;IAG5E,MAAM,gBAAgB,CAAC,QAAsC,EAAA;AAC5E,QAAA,OAAO,eAAe,CAAC,gBAAgB,CAAC,QAAQ,CAAC;;;IAIlC,MAAM,sBAAsB,CAAC,OAAe,EAAA;AAC3D,QAAA,OAAO,eAAe,CAAC,sBAAsB,CAAC,OAAO,CAAC;;IAGvC,MAAM,sBAAsB,CAAC,QAAoB,EAAA;AAChE,QAAA,OAAO,eAAe,CAAC,sBAAsB,CAAC,QAAQ,CAAC;;IAGjD,kBAAkB,GAAA;QACxB,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC;YAClC;AACF,QAAA,QACE,CACE,CAAA,mBAAA,EAAA,EAAA,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,CAAC,IAAI,KAAM,EAAA,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,EAAC,EAE/B,CAAA;;IAsBhB,wBAAwB,GAAA;QAC9B,QACE,CAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,yBAAyB,EAAC,OAAO,EAAE,IAAI,CAAC,wBAAwB,EAAA,EACzE,CAAA,CAAA,OAAA,EAAA,EACI,IAAI,EAAC,MAAM,EACX,GAAG,EAAE,EAAE,KAAK,IAAI,CAAC,oBAAoB,GAAG,EAAG,CAAC,EAC5C,QAAQ,EAAE,IAAI,CAAC,uBAAuB,EACtC,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,EAC5B,CAAA,EACF,CAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,sBAAsB,EAAA,EAC/B,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,OAAO,EAAC,MAAM,EAAC,OAAO,EAAC,OAAO,EAAC,WAAW,EAAC,IAAI,EAAC,MAAM,EAAC,KAAK,EAAC,4BAA4B,EAAA,EAClG,CAAA,CAAA,MAAA,EAAA,EAAA,WAAA,EAAgB,SAAS,EAAA,WAAA,EAAW,SAAS,EAAC,CAAC,EAAC,gnGAAgnG,EAAA,CAAG,CAC/pG,CACF,CACF;;IAIF,kBAAkB,GAAA;QACxB,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,OAAO,CAAC;YACpC;AAEF,QAAA,MAAM,WAAW,GAAG;YAClB,eAAe;YACf,IAAI,CAAC,WAAW,IAAI,WAAW;YAC/B,IAAI,CAAC,YAAY,IAAI;SACtB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;QAE3B,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,QAAQ;QAErD,QACE,cACE,KAAK,EAAE,WAAW,EAClB,OAAO,EAAE,MAAM,IAAI,CAAC,iBAAiB,EAAE,EACvC,QAAQ,EAAE,UAAU,EACR,YAAA,EAAA,IAAI,CAAC,WAAW,GAAG,gBAAgB,GAAG,iBAAiB,EAAA,EAElE,IAAI,CAAC,YAAY,IAChB,CAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,aAAa,EAAC,OAAO,EAAC,WAAW,EAAA,EAC1C,CAAQ,CAAA,QAAA,EAAA,EAAA,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,EAAC,CAAC,EAAC,GAAG,EAAA,EAC3B,CAAA,CAAA,SAAA,EAAA,EAAS,aAAa,EAAC,GAAG,EAAC,MAAM,EAAC,OAAO,EAAC,GAAG,EAAC,IAAI,EAAC,WAAW,EAAC,YAAY,EAAG,CAAA,EAC9E,CAAA,CAAA,SAAA,EAAA,EAAS,aAAa,EAAC,SAAS,EAAC,MAAM,EAAC,SAAS,EAAC,GAAG,EAAC,IAAI,EAAC,WAAW,EAAC,YAAY,GAAG,CAC/E,CACL,IACJ,IAAI,CAAC,WAAW,IAClB,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,aAAa,EAAC,OAAO,EAAC,WAAW,EAAA,EAC1C,CAAA,CAAA,MAAA,EAAA,EAAM,CAAC,EAAC,GAAG,EAAC,CAAC,EAAC,GAAG,EAAC,KAAK,EAAC,IAAI,EAAC,MAAM,EAAC,IAAI,EAAC,EAAE,EAAC,GAAG,EAAA,CAAG,CAC9C,KAEN,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,aAAa,EAAC,OAAO,EAAC,WAAW,EAAA,EAC1C,CAAA,CAAA,QAAA,EAAA,EAAQ,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,EAAC,CAAC,EAAC,GAAG,EAAG,CAAA,CAC5B,CACP,CACM;;IAIL,mBAAmB,GAAA;AACzB,QAAA,MAAM,WAAW,GAAG;YAClB,aAAa;YACb,IAAI,CAAC,QAAQ,IAAI,OAAO;YACxB,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI;SACtC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;AAE3B,QAAA,OAAO,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAE,WAAW,IAAG,IAAI,CAAC,aAAa,CAAO;;IAGpD,iBAAiB,GAAA;QACvB,IAAI,CAAC,IAAI,CAAC,YAAY;AAAE,YAAA,OAAO,IAAI;QAEnC,MAAM,SAAS,GAAG,IAAI,CAAC,cAAc,IAAI,CAAC,IAAI,CAAC,UAAU;QACzD,MAAM,KAAK,GAAG,SAAS,GAAG,oCAAoC,GAAG,oBAAoB;AAErF,QAAA,QACE,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,cAAc,EAAA,EACvB,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,oBAAoB,EAAA,EAAE,KAAK,CAAO,EAC7C,CAAM,CAAA,MAAA,EAAA,EAAA,KAAK,EAAC,mBAAmB,EAC5B,EAAA,IAAI,CAAC,gBAAgB,EAAE,CACnB,CACH;;IAIF,gBAAgB,GAAA;;QAEtB,IAAI,CAAC,IAAI,CAAC,YAAY;AAAE,YAAA,OAAO,IAAI;AAEnC,QAAA,QAAO,IAAI,CAAC,OAAO;AACjB,YAAA,KAAK,SAAS;;AAEd,YAAA,KAAK,IAAI;gBACP,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,KAAU,KAAI;;oBACnD,IAAI,CAAC,KAAK,CAAC,WAAW,IAAI,CAAC,KAAK,CAAC,IAAI;AAAE,wBAAA,OAAO,IAAI;AAElD,oBAAA,MAAM,SAAS,GAAG,KAAK,CAAC,WAAW;oBACnC,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC;AAC/C,oBAAA,MAAM,UAAU,GAAG,CAAA,CAAA,EAAA,GAAA,KAAK,CAAC,QAAQ,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,KAAK,KAAI,KAAK,CAAC,WAAW;AAC7D,oBAAA,MAAM,UAAU,GAAG,KAAK,CAAC,QAAQ,IAAI,KAAK;oBAC1C,MAAM,UAAU,GAAG,CAAA,EAAA,GAAA,KAAK,CAAC,QAAQ,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,aAAa;oBAEhD,QACE,WAAK,KAAK,EAAC,YAAY,EAAC,GAAG,EAAE,SAAS,EAAA,EACpC,CAAA,CAAA,OAAA,EAAA,EAAO,OAAO,EAAE,SAAS,EAAE,KAAK,EAAC,YAAY,EAAA,EAC1C,UAAU,EACV,UAAU,IAAI,CAAM,CAAA,MAAA,EAAA,EAAA,KAAK,EAAC,UAAU,QAAS,CACxC,EACP,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE;AAC/B,wBAAA,IAAI,EAAE,SAAS;AACf,wBAAA,KAAK,EAAE,UAAU;AACjB,wBAAA,QAAQ,EAAE,UAAU;wBACpB,OAAO,EAAE,CAAA,EAAA,GAAA,KAAK,CAAC,QAAQ,0CAAE,GAAG,CAAC,CAAC,MAAW,KACvC,MAAM,CAAC,WAAW,IAAI,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,QAAQ,EAAE;AAE1D,qBAAA,EAAE,UAAU,CAAC,CACV;AAEV,iBAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC;AACpB,YAAA,KAAK,YAAY;;;gBAGf,MAAM,iBAAiB,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;AACzF,gBAAA,OAAO,MAAM,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAgB,KAAI;;AAE3E,oBAAA,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI;oBAC5B,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC;AAC1C,oBAAA,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK,IAAI,SAAS;AAC3C,oBAAA,MAAM,UAAU,GAAG,KAAK,CAAC,QAAQ,IAAI,KAAK;oBAC1C,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;oBAElD,QACE,WAAK,KAAK,EAAC,YAAY,EAAC,GAAG,EAAE,SAAS,EAAA,EACpC,CAAA,CAAA,OAAA,EAAA,EAAO,OAAO,EAAE,SAAS,EAAE,KAAK,EAAC,YAAY,EAAA,EACzC,UAAU,EACX,UAAU,IAAI,CAAM,CAAA,MAAA,EAAA,EAAA,KAAK,EAAC,UAAU,QAAS,CACxC,EACP,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,KAAK,GAAG,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,IAAI,CAAC,UAAU,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAG,SAAS,CAAC,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAI,UAAU,EAAE,CACjF;AAEV,iBAAC,CAAC;AACJ,YAAA,KAAK,OAAO;AACZ,YAAA;gBACE,OAAO,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,KAAK,CAAgB,KAAI;;oBAAC,QACzF,WAAK,KAAK,EAAC,YAAY,EAAC,GAAG,EAAE,SAAS,EAAA,EACpC,CAAA,CAAA,OAAA,EAAA,EAAO,OAAO,EAAE,SAAS,EAAE,KAAK,EAAC,YAAY,EAAA,EAC1C,KAAK,CAAC,KAAK,IAAI,SAAS,EACxB,KAAK,CAAC,QAAQ,IAAI,CAAA,CAAA,MAAA,EAAA,EAAM,KAAK,EAAC,UAAU,QAAS,CAC5C,EACP,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,KAAK,GAAG,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,IAAI,CAAC,UAAU,MAAG,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,SAAS,CAAC,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAI,KAAK,CAAC,KAAK,EAAE,CAClF;AACP,iBAAA,CAAC;;;AAIA,IAAA,eAAe,CAAC,SAAiB,EAAE,KAAU,EAAE,KAAU,EAAA;;QAC/D,MAAM,UAAU,GAAG,IAAI,CAAC,cAAc,IAAI,CAAC,IAAI,CAAC,UAAU;AAC1D,QAAA,MAAM,WAAW,GAAG;AAClB,YAAA,EAAE,EAAE,SAAS;AACb,YAAA,IAAI,EAAE,SAAS;AACf,YAAA,KAAK,EAAE,YAAY;YACnB,QAAQ,EAAE,KAAK,CAAC,QAAQ;AACxB,YAAA,QAAQ,EAAE;SACX;AAED,QAAA,QAAQ,KAAK,CAAC,IAAI;AAChB,YAAA,KAAK,QAAQ;gBACX,IAAI,UAAU,EAAE;;AAEd,oBAAA,QACE,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,iBAAiB,EAAA,EAC1B,CAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,oBAAoB,EAAyB,EAAA,oBAAA,CAAA,EACxD,CAAA,CAAA,IAAA,EAAA,EAAI,KAAK,EAAC,qBAAqB,EAAA,EAC5B,CAAA,EAAA,GAAA,KAAK,CAAC,OAAO,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,GAAG,CAAC,MAAM,KACxB,CAAI,CAAA,IAAA,EAAA,EAAA,KAAK,EAAC,eAAe,EAAE,EAAA,MAAM,CAAM,CACxC,CAAC,CACC,CACD;;gBAGV,QACE,CAAQ,CAAA,QAAA,EAAA,EAAA,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAC,YAAY,EAAC,QAAQ,EAAE,KAAK,CAAC,QAAQ,EAAA,EACjF,CAAQ,CAAA,QAAA,EAAA,EAAA,KAAK,EAAC,EAAE,EAAA,EAAA,cAAA,CAAsB,EACrC,CAAA,EAAA,GAAA,KAAK,CAAC,OAAO,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA;uBAAE,GAAG,CAAC,MAAM,KACxB,CAAA,CAAA,QAAA,EAAA,EAAQ,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,KAAK,MAAM,EAC9C,EAAA,MAAM,CACA,CACV,CAAC,CACK;AAGb,YAAA,KAAK,SAAS;AACZ,gBAAA,QACE,6BACM,WAAW,EAAA,EACf,IAAI,EAAC,UAAU,EACf,KAAK,EAAC,eAAe,EACrB,OAAO,EAAE,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,MAAM,EAC3C,CAAA,CAAA;AAGN,YAAA,KAAK,QAAQ;AACX,gBAAA,QACE,CAAA,CAAA,OAAA,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACM,WAAW,EAAA,EACf,IAAI,EAAC,QAAQ,EACb,GAAG,EAAE,KAAK,CAAC,GAAG,EACd,GAAG,EAAE,KAAK,CAAC,GAAG,EACd,IAAI,EAAC,KAAK,EACV,KAAK,EAAE,KAAK,IAAI,EAAE,EAAA,CAAA,CAClB;AAGN,YAAA,KAAK,MAAM;AACT,gBAAA,QACE,6BACM,WAAW,EAAA,EACf,IAAI,EAAC,MAAM,EACX,KAAK,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,KAAK,CAAG,EAAA,CAAC,CAAI,CAAA,EAAA,CAAC,CAAI,CAAA,EAAA,CAAC,CAAE,CAAA,EAAE,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EACvE,CAAA,CAAA;AAGN,YAAA,KAAK,UAAU;gBACb,QACE,CAAA,CAAA,OAAA,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACM,WAAW,EAAA,EACf,IAAI,EAAC,gBAAgB,EACrB,KAAK,EAAE,KAAK,IAAI,EAAE,EAAA,CAAA,CAClB;AAGN,YAAA;AACE,gBAAA,QACE,CACM,CAAA,OAAA,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAA,WAAW,EACf,EAAA,IAAI,EAAC,MAAM,EACX,OAAO,EAAE,KAAK,CAAC,OAAO,EACtB,WAAW,EAAE,KAAK,CAAC,WAAW,EAC9B,KAAK,EAAE,KAAK,IAAI,EAAE,EAClB,CAAA,CAAA;;;IAKF,gBAAgB,GAAA;QACtB,IAAI,CAAC,IAAI,CAAC,KAAK;AAAE,YAAA,OAAO,IAAI;QAE5B,QACE,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,aAAa,EAAA,EACtB,CAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,aAAa,EAAyB,EAAA,oBAAA,CAAA,EACjD,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,eAAe,IACvB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC,CACpC,CACF;;IAIV,MAAM,GAAA;QACJ,QACE,CAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACE,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAE,0BAA0B,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,UAAU,GAAG,QAAQ,GAAG,EAAE,CAAC,EAAA,EACtF,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,gBAAgB,EAAA,EACxB,IAAI,CAAC,kBAAkB,EAAE,EACzB,IAAI,CAAC,wBAAwB,EAAE,CAC5B,EACL,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,mBAAmB,EAAE,GAAG,EAAE,EACpD,IAAI,CAAC,kBAAkB,EAAE,EACzB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,iBAAiB,EAAE,GAAG,EAAE,EAC/C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,EAAE,GAAG,EAAE,CACtC,CACF;;;;;;;;;;;"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{r as e,h as t,c as i}from"./p-jmc2yzBp.js";const r=".upload-container{display:inline-block;cursor:pointer;width:50px;height:50px}.upload-button{display:flex;align-items:center;justify-content:center;transition:transform 0.2s ease, box-shadow 0.2s ease;user-select:none}.upload-button svg{width:50px;height:50px;stroke:#44ee44}.upload-button:hover svg{transform:scale(1.05);stroke:#33dd33}";const o=class{constructor(t){e(this,t);this.batch=false;this.triggerUpload=()=>{this.fileInput.click()};this.handleFileChange=async e=>{const t=e.target;if(!t.files||t.files.length===0)return;const i=t.files[0];console.log("Selected file:",i);const r=new FormData;r.append("file",i);if(this.batch){try{const e=await fetch("http://127.0.0.1:5001/api/convert-to-xml",{method:"POST",body:r});if(!e.ok){console.error("There has been an error!:",e);throw new Error(`HTTP error! status: ${e.status}`)}const t=await e.blob();const i=window.URL.createObjectURL(t);const o=document.createElement("a");o.href=i;o.download="result-"+Date.now().toString()+".xlsx";document.body.appendChild(o);o.click();o.remove();window.URL.revokeObjectURL(i)}catch(e){console.error(e);alert("Error uploading file")}}else{try{const e=await fetch("http://127.0.0.1:5001/api/convert-to-json",{method:"POST",body:r});if(!e.ok){console.error("There has been an error!:",e);throw new Error(`HTTP error! status: ${e.status}`)}const t=await e.json();console.log("Upload successful:",t);if(this.callback&&t[0]&&t[0].content){this.callback(t[0].content)}}catch(e){console.error(e);alert("Error uploading file")}}}}render(){return t("div",{key:"07c2e2b8467309e2f37b4f2bfc8338a6e7d1bd70",class:"upload-container",onClick:this.triggerUpload},t("input",{key:"8695e980896c48212fe7d9ad7572151af2ef3e0f",type:"file",ref:e=>this.fileInput=e,onChange:this.handleFileChange,style:{display:"none"}}),t("div",{key:"57124a873b9e3e799f7417a4658cc8897a5ad1f5",class:"upload-button"},t("svg",{key:"5b0edb9ec28e727cd51849a3537ee8545cea2c6a",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg"},t("path",{key:"34ae339754cf34da6e835cb3de50b26668abed7d",d:"M13.5 3H12H8C6.34315 3 5 4.34315 5 6V18C5 19.6569 6.34315 21 8 21H12M13.5 3L19 8.625M13.5 3V7.625C13.5 8.17728 13.9477 8.625 14.5 8.625H19M19 8.625V11.8125","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round"}),t("path",{key:"a11dc06e9724e1a6b7bdfd6b7594ab2b9eb38013",d:"M17.5 21L17.5 15M17.5 15L20 17.5M17.5 15L15 17.5","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round"}))))}};o.style=r;class s{constructor(){this.mediaRecorder=null;this.audioChunks=[];this.stream=null}async startRecording(){try{if(!navigator.mediaDevices||!navigator.mediaDevices.getUserMedia){console.error("Failed to start recording:","Microphone access is not supported in this browser or the page is not served over HTTPS/localhost.");return}this.stream=await navigator.mediaDevices.getUserMedia({audio:{echoCancellation:true,noiseSuppression:true,autoGainControl:true}});this.audioChunks=[];this.mediaRecorder=new MediaRecorder(this.stream,{mimeType:"audio/webm;codecs=opus"});this.mediaRecorder.ondataavailable=e=>{if(e.data&&e.data.size>0){this.audioChunks.push(e.data)}};this.mediaRecorder.start(100)}catch(e){console.error("Failed to start recording:",e)}}async stopRecording(){return new Promise(((e,t)=>{if(!this.mediaRecorder){t(new Error("No active recording found"));return}this.mediaRecorder.onstop=()=>{const t=new Blob(this.audioChunks,{type:"audio/webm"});this.cleanup();e(t)};this.mediaRecorder.onerror=e=>{t(new Error(`Recording error: ${e}`))};this.mediaRecorder.stop()}))}isRecording(){var e;return((e=this.mediaRecorder)===null||e===void 0?void 0:e.state)==="recording"}cleanup(){if(this.stream){this.stream.getTracks().forEach((e=>e.stop()));this.stream=null}this.mediaRecorder=null;this.audioChunks=[]}}class n{constructor(e){this.apiKey=(e===null||e===void 0?void 0:e.apiKey)||this.getEnvironmentVariable("OPENAI_API_KEY")||"";this.baseUrl=(e===null||e===void 0?void 0:e.baseUrl)||"https://api.openai.com/v1";if(!this.apiKey){throw new Error("OpenAI API key is required for Whisper service")}}getEnvironmentVariable(e){if(typeof process!=="undefined"&&process.env){return process.env[e]}return window[e]||undefined}async transcribe(e,t="en"){var i;try{const r=new FormData;r.append("file",e);r.append("model","gpt-4o-transcribe");r.append("language",t);r.append("response_format","json");r.append("max_output_tokens","2000");const o=await fetch(`${this.baseUrl}/audio/transcriptions`,{method:"POST",headers:{Authorization:`Bearer ${this.apiKey}`},body:r});if(!o.ok){const e=await o.json().catch((()=>({error:"Unknown error"})));throw new Error(`Transcription failed: ${((i=e.error)===null||i===void 0?void 0:i.message)||o.statusText}`)}const s=await o.json();return s.text||""}catch(e){throw new Error(`Speech-to-text transcription failed: ${e.message}`)}}}class a{static create(e){var t;const i=((t=e.speechToText)===null||t===void 0?void 0:t.provider)||"whisper";switch(i){case"whisper":return new n(e.speechToText);default:throw new Error(`Unsupported speech-to-text provider: ${i}`)}}}class l{constructor(e){this.apiKey=(e===null||e===void 0?void 0:e.apiKey)||this.getEnvironmentVariable("OPENAI_API_KEY")||"";this.model=(e===null||e===void 0?void 0:e.model)||"gpt-4.1";this.baseUrl=(e===null||e===void 0?void 0:e.baseUrl)||"https://api.openai.com/v1";if(!this.apiKey){throw new Error("OpenAI API key is required for LLM service")}}getEnvironmentVariable(e){if(typeof process!=="undefined"&&process.env){return process.env[e]}return window[e]||undefined}getOptimizeFieldsDescription(e){return Object.values(e).map((e=>{var t;return`- ${(t=e.name)!==null&&t!==void 0?t:e.title} `+`(${e.type}`+`${e.required?", required":""}`+`${e.readonly?", readonly":""}`+`${e.min&&e.min!==""?", min="+e.min:""}`+`${e.max&&e.max!==""?", max="+e.max:""}`+`)`+`${e.options?` - options: ${e.options.join(", ")}`:""}`})).join("\n")}async fillFormFromTranscription(e,t){return this.fillForm(e,t,true)}async fillFormFromJson(e,t){return this.fillForm(e,t,false)}async fillForm(e,t,i=true){var r,o;try{if((t===null||t===void 0?void 0:t.fields)||(t===null||t===void 0?void 0:t.schema)){const i=(t===null||t===void 0?void 0:t.fields)||(t===null||t===void 0?void 0:t.schema);const o=`You are an expert form-filling assistant. You will receive a voice transcription and form field definitions. Your task is to extract values from the spoken content.\n Rules:\n 1. Only extract values that can be confidently determined from the transcription\n 2. Respect field types (string, number, datetime, boolean, select)\n 3. For datetime fields, use ISO format (YYYY-MM-DDTHH:MM)\n 4. For date fields, use the following format: DD/MM/YYY\n 5. For boolean fields, interpret yes/no, true/false, positive/negative responses\n 6. For select fields, use exact option values from the provided choices\n 7. Only include fields where relevant information is found\n 8. The current GMT datetime is ${(new Date).toGMTString()}\n 9. Respect the constraints written between parenthesis for readonly status (readonly fields must not be filled with values), min and max values, whatever the transcription says\n\n Respond with JSON in this exact format: {"fields": [{"name": "field_name", "value": "extracted_value"}]}`;let s=`\n Voice transcription: "${e}"\n\n Form fields:\n ${this.getOptimizeFieldsDescription(i)}\n\n Please extract values from the Transcription for these fields.\n `;const n=await fetch(`${this.baseUrl}/chat/completions`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${this.apiKey}`},body:JSON.stringify({model:this.model,messages:[{role:"system",content:o},{role:"user",content:s}],response_format:{type:"json_object"},temperature:.1})});if(!n.ok){const e=await n.json().catch((()=>({error:"Unknown error"})));throw new Error(`LLM API failed: ${((r=e.error)===null||r===void 0?void 0:r.message)||n.statusText}`)}const a=await n.json();return JSON.parse(a.choices[0].message.content)}const i=`You are an expert form-filling assistant. You will receive a voice transcription and a JSON form schema. Your task is to intelligently fill the form fields based on the spoken content.\n Rules:\n 1. Only fill fields that can be confidently determined from the transcription\n 2. Respect field types (string, number, date, boolean, select)\n 3. For datetime fields, use ISO format (YYYY-MM-DDTHH:MM)\n 4. For date fields, use the following format: DD/MM/YYY\n 5. For boolean fields, interpret yes/no, true/false, positive/negative responses\n 6. For select fields, match the closest option from the provided choices\n 7. Leave fields empty if no relevant information is found\n 8. Return the same schema structure with 'default' values filled\n 9. The current GMT datetime is ${(new Date).toGMTString()}\n 10. Respect the constraints written between parenthesis for readonly status (readonly fields must not be filled with values), min and max values, whatever the transcription says\n\n Respond with JSON in this exact format: {"schema": {...}}`;let s=`\n Voice transcription: "${e}"\n\n Form schema to fill:\n ${JSON.stringify(t,null,2)}\n\n Please fill the form fields based on the Transcription and return the schema with default values populated.\n `;const n=await fetch(`${this.baseUrl}/chat/completions`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${this.apiKey}`},body:JSON.stringify({model:this.model,messages:[{role:"system",content:i},{role:"user",content:s}],response_format:{type:"json_object"},temperature:.1})});if(!n.ok){const e=await n.json().catch((()=>({error:"Unknown error"})));throw new Error(`LLM API failed: ${((o=e.error)===null||o===void 0?void 0:o.message)||n.statusText}`)}const a=await n.json();const l=JSON.parse(a.choices[0].message.content);if(!l.schema){throw new Error("Invalid response format from LLM service")}return l}catch(e){throw new Error(`Form filling failed: ${e.message}`)}}}class c{static create(e){var t;const i=((t=e.llm)===null||t===void 0?void 0:t.provider)||"openai";switch(i){case"openai":return new l(e.llm);default:throw new Error(`Unsupported LLM provider: ${i}`)}}}class d{static convertXmlToJsonLegacy(e){try{const t=new DOMParser;const i=t.parseFromString(e,"text/xml");if(i.querySelector("parsererror")){throw new Error("Invalid XML format")}const r={schema:{}};const o=i.querySelector("form");if(o){r.title=o.getAttribute("title")||undefined;r.description=o.getAttribute("description")||undefined}const s=i.querySelectorAll("input, select, textarea");s.forEach((e=>{const t=e.getAttribute("name");if(!t)return;const i={type:this.mapXmlTypeToJsonTypeLegacy(e.tagName.toLowerCase(),e.getAttribute("type")),title:e.getAttribute("title")||e.getAttribute("placeholder")||t,description:e.getAttribute("description")||undefined,required:e.hasAttribute("required"),default:e.getAttribute("value")||undefined};if(e.tagName.toLowerCase()==="select"){const t=Array.from(e.querySelectorAll("option")).map((e=>e.textContent||e.getAttribute("value")||""));if(t.length>0){i.options=t}}const o=e.getAttribute("min");const s=e.getAttribute("max");const n=e.getAttribute("pattern");if(o)i.min=parseFloat(o);if(s)i.max=parseFloat(s);if(n)i.pattern=n;r.schema[t]=i}));return r}catch(e){throw new Error(`XML to JSON conversion failed: ${e.message}`)}}static convertJsonToXmlLegacy(e){try{const t=document.implementation.createDocument("","",null);const i=t.createElement("form");if(e.title){i.setAttribute("title",e.title)}if(e.description){i.setAttribute("description",e.description)}Object.entries(e.schema).forEach((([r,o])=>{var s;const n=e[r];const a=Object.assign(Object.assign({},o),{default:(s=o.default)!==null&&s!==void 0?s:n});const l=this.createXmlElementLegacy(t,r,a);if(l){i.appendChild(l)}}));t.appendChild(i);const r=new XMLSerializer;return r.serializeToString(t)}catch(e){throw new Error(`JSON to XML conversion failed: ${e.message}`)}}static mapXmlTypeToJsonTypeLegacy(e,t){switch(e){case"select":return"select";case"textarea":return"string";case"input":switch(t){case"number":case"range":return"number";case"date":case"datetime-local":case"time":return"date";case"checkbox":return"boolean";default:return"string"}default:return"string"}}static createXmlElementLegacy(e,t,i){let r;switch(i.type){case"select":r=e.createElement("select");if(i.options){i.options.forEach((t=>{const o=e.createElement("option");o.setAttribute("value",t);o.textContent=t;if(i.default!==undefined&&i.default===t){o.setAttribute("selected","true")}r.appendChild(o)}))}break;case"boolean":r=e.createElement("input");r.setAttribute("type","checkbox");if(i.default===true||i.default==="true"){r.setAttribute("checked","true")}break;case"number":r=e.createElement("input");r.setAttribute("type","number");if(i.min!==undefined)r.setAttribute("min",i.min.toString());if(i.max!==undefined)r.setAttribute("max",i.max.toString());if(i.default!==undefined)r.setAttribute("value",i.default.toString());break;case"date":r=e.createElement("input");r.setAttribute("type","date");if(i.default!==undefined)r.setAttribute("value",i.default.toString());break;default:r=e.createElement("input");r.setAttribute("type","text");if(i.default!==undefined)r.setAttribute("value",i.default.toString())}r.setAttribute("name",t);r.setAttribute("title",i.title);if(i.description){r.setAttribute("description",i.description)}if(i.required){r.setAttribute("required","true")}if(i.pattern){r.setAttribute("pattern",i.pattern)}return r}static async convertXmlToJson(e,t="http://localhost",i="en"){var r,o,s,n,a,l,c,d,u,h,f,p,m,v,b,g,w,y,x,C,k,T,F,M;try{const i=new DOMParser;const O=i.parseFromString(e,"text/xml");if(O.querySelector("parsererror")){throw new Error("Invalid XML format")}const I=O.querySelector("Xforms");if(!I)throw new Error("No Xforms root element found");const S=I.querySelectorAll("Fields");if(S.length===0)throw new Error("No Fields elements found");const $={fields:{}};for(const e of Array.from(S)){const i=(o=(r=e.querySelector("SystemName"))===null||r===void 0?void 0:r.textContent)===null||o===void 0?void 0:o.trim();if(!i)return;const O=(n=(s=e.querySelector("HelpText"))===null||s===void 0?void 0:s.textContent)===null||n===void 0?void 0:n.trim();const I=(a=e.querySelector("DefaultValue"))===null||a===void 0?void 0:a.textContent;const S=((c=(l=e.querySelector("Enabled"))===null||l===void 0?void 0:l.textContent)===null||c===void 0?void 0:c.trim().toLowerCase())||"true";const E=S==="true";const _=(d=e.querySelector("ID"))===null||d===void 0?void 0:d.textContent;const P=(u=e.querySelector("TFie_PK_ID"))===null||u===void 0?void 0:u.textContent;const D=(h=e.querySelector("TVal_PK_ID"))===null||h===void 0?void 0:h.textContent;const L=(f=e.querySelector("TFIn_PK_ID"))===null||f===void 0?void 0:f.textContent;const j=(p=e.querySelector("isForm"))===null||p===void 0?void 0:p.textContent;const R=(m=e.querySelector("LabelText"))===null||m===void 0?void 0:m.textContent;const V=(v=e.querySelector("SystemName"))===null||v===void 0?void 0:v.textContent;const N=(b=e.querySelector("CssStyle"))===null||b===void 0?void 0:b.textContent;const J=((g=e.querySelector("ControlType"))===null||g===void 0?void 0:g.textContent)||"TextBox";const A=(w=e.querySelector("ValidationRequired"))===null||w===void 0?void 0:w.textContent;const z=(y=e.querySelector("ValidationMin"))===null||y===void 0?void 0:y.textContent;const q=(x=e.querySelector("ValidationMax"))===null||x===void 0?void 0:x.textContent;const Y=(C=e.querySelector("Mask"))===null||C===void 0?void 0:C.textContent;const X=(k=e.querySelector("TypeId"))===null||k===void 0?void 0:k.textContent;const B=(T=e.querySelector("Unit"))===null||T===void 0?void 0:T.textContent;const K=(F=e.querySelector("TFie_Fullpath"))===null||F===void 0?void 0:F.textContent;const H=(M=e.querySelector("TVal_FK_Parent_ID"))===null||M===void 0?void 0:M.textContent;const U={type:this.mapControlTypeToJsonType(J),title:R,description:O,required:(A===null||A===void 0?void 0:A.toLowerCase())==="required",default:I||undefined,realType:J,Enabled:E,ID:_,TFie_PK_ID:P,TVal_PK_ID:D,TFIn_PK_ID:L,isForm:j,LabelText:R,SystemName:V,CssStyle:N,ControlType:J,ValidationRequired:A,ValidationMin:z,ValidationMax:q,Mask:Y,TypeId:X,Unit:B,TFie_Fullpath:K,TVal_FK_Parent_ID:H};if(U.type.toLowerCase()==="select"){try{const e=await fetch(`${t}/ng/api/v1/classification/getList/${U.ControlType.toLowerCase()=="termpicker"?"Position":"Thesaurus"}/?StartNodeID=${X}`);if(!e.ok)throw new Error(`HTTP error! status: ${e.status}`);const i=await e.json();if(Array.isArray(i)){const e=i.map((e=>({value:e.ID,label:e.System_Name})));if(e.length>0){U.pickerOptions=e;U.options=e.map((e=>e.label.replace("'","")))}}else{console.error("Unexpected API response format:",i)}}catch(e){console.error("Error fetching classification data:",e)}}if(z)U.min=parseFloat(z);if(q)U.max=parseFloat(q);if(Y)U.pattern=Y;$.fields[_]=U}return $}catch(e){throw new Error(`XML to JSON conversion failed: ${e.message}`)}}static convertJsonToXml(e){try{const t=document.implementation.createDocument("","",null);const i=t.createElement("Xforms");Object.entries(e.schema?e.schema:e.fields).forEach((([r,o])=>{const s=t.createElement("Fields");const n=o;const a=t.createElement("SystemName");a.textContent=n.SystemName;s.appendChild(a);const l=t.createElement("LabelText");l.textContent=n.title||r;s.appendChild(l);const c=t.createElement("HelpText");c.textContent=n.description;s.appendChild(c);const d=t.createElement("ControlType");d.textContent=n.realType;s.appendChild(d);const u=t.createElement("ValidationRequired");u.textContent=n.required?"Required":"Not Required";s.appendChild(u);const h=t.createElement("DefaultValue");const f=t.createElement("Value");if(e[r]!==undefined){h.textContent=e[r].toString();f.textContent=e[r].toString()}else{h.textContent=n.default||n.value;f.textContent=n.value||n.default}s.appendChild(h);s.appendChild(f);const p=t.createElement("Enabled");p.textContent=n.Enabled===false?"False":"True";s.appendChild(p);const m=t.createElement("isForm");m.textContent=n.isForm;s.appendChild(m);if(n.type==="header"){const e=t.createElement("Header");e.textContent=n.title;s.appendChild(e)}const v=t.createElement("ID");v.textContent=n.ID;s.appendChild(v);const b=t.createElement("TFie_PK_ID");b.textContent=n.TFie_PK_ID;s.appendChild(b);const g=t.createElement("TVal_PK_ID");g.textContent=n.TVal_PK_ID;s.appendChild(g);const w=t.createElement("TFIn_PK_ID");w.textContent=n.TFIn_PK_ID;s.appendChild(w);const y=t.createElement("CssStyle");y.textContent=n.CssStyle;s.appendChild(y);const x=t.createElement("TypeId");x.textContent=n.TypeId;s.appendChild(x);const C=t.createElement("Unit");C.textContent=n.Unit;s.appendChild(C);const k=t.createElement("TFie_Fullpath");k.textContent=n.TFie_Fullpath;s.appendChild(k);const T=t.createElement("TVal_FK_Parent_ID");T.textContent=n.TVal_FK_Parent_ID;s.appendChild(T);const F=t.createElement("ValidationMin");F.textContent=n.ValidationMin;s.appendChild(F);const M=t.createElement("ValidationMax");M.textContent=n.ValidationMax;s.appendChild(M);const O=t.createElement("Mask");O.textContent=n.Mask;s.appendChild(O);i.appendChild(s)}));t.appendChild(i);const r=new XMLSerializer;return r.serializeToString(t)}catch(e){throw new Error(`JSON to XML conversion failed: ${e.message}`)}}static mapControlTypeToJsonType(e){switch(e.toLowerCase()){case"textbox":case"text":return"string";case"datepicker":return"date";case"thesauruspicker":case"thesauruspicker-ddl":case"termpicker":return"select";case"dbpicker":return"dbpicker";case"header":return"header";case"checkbox":return"boolean";case"realpicker":return"number";default:return"string"}}}const u=":host{display:block;font-family:-apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif}.row-audio-area{display:flex;flex-direction:row}.voice-recorder-container{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1rem;border:1px solid #e5e7eb;border-radius:0.5rem;background:#ffffff;max-width:100px;margin:0 auto}.voice-recorder-container-debug{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1rem;border:1px solid #e5e7eb;border-radius:0.5rem;background:#ffffff;max-width:800px;margin:0 auto}.upload-record-container{display:inline-block;cursor:pointer;width:50px;height:50px}.upload-record-button{display:flex;align-items:center;justify-content:center;transition:transform 0.2s ease, box-shadow 0.2s ease;user-select:none}.upload-record-button svg{width:50px;height:50px;stroke:#4444ee}.upload-record-button svg path{fill:#4444ee}.upload-record-button:hover svg{transform:scale(1.05);stroke:#4444ee}.record-button{display:flex;align-items:center;justify-content:center;width:50px;height:50px;border:none;border-radius:50%;background:#ee4444;color:white;cursor:pointer;transition:all 0.2s ease;position:relative;overflow:hidden}.record-button:hover:not(:disabled){background:#dd3333;transform:scale(1.05)}.record-button:disabled{opacity:0.6;cursor:not-allowed}.record-button.recording{background:#dd3333;animation:pulse 1.5s infinite}.record-button.processing{background:#3b82f6}@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(239, 68, 68, 0.7)}70%{box-shadow:0 0 0 10px rgba(239, 68, 68, 0)}100%{box-shadow:0 0 0 0 rgba(239, 68, 68, 0)}}.record-icon{width:24px;height:24px;fill:currentColor}.status-text{font-size:0.875rem;color:#6b7280;text-align:center;min-height:1.25rem}.status-text.error{color:#ee4444}.status-text.success{color:#10b981}.debug-panel{width:100%;margin-top:1rem;padding:1rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:0.375rem;font-family:'Monaco', 'Menlo', 'Ubuntu Mono', monospace;font-size:0.75rem}.debug-title{font-weight:600;margin-bottom:0.5rem;color:#374151}.debug-content{white-space:pre-wrap;word-break:break-word;color:#6b7280;max-height:200px;overflow-y:auto}.permissions-warning{padding:0.75rem;background:#fef3c7;border:1px solid #f59e0b;border-radius:0.375rem;color:#92400e;font-size:0.875rem;text-align:center}.form-preview{width:100%;margin-top:1rem;padding:1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:0.375rem}.form-preview-title{font-weight:600;margin-bottom:0.5rem;color:#1e293b}.form-field{margin-bottom:0.5rem;font-size:0.875rem}.field-name{font-weight:500;color:#475569}.field-value{color:#64748b;margin-left:0.5rem}.field-value.filled{color:#059669;font-weight:500}.voice-filled-form{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.form-group{display:flex;flex-direction:column;gap:0.25rem}.form-label{font-weight:500;color:#374151;font-size:0.875rem}.required{color:#ee4444;margin-left:0.125rem}.form-input{padding:0.5rem;border:1px solid #d1d5db;border-radius:0.375rem;font-size:0.875rem;transition:border-color 0.2s ease}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59, 130, 246, 0.1)}.form-checkbox{width:auto;padding:0;margin:0}select.form-input{background-color:white;cursor:pointer}input[type=\"date\"].form-input{cursor:pointer}.readonly-select{background:#f9fafb;border:1px solid #d1d5db;border-radius:0.375rem;padding:0.5rem}.select-placeholder{font-size:0.875rem;color:#6b7280;margin-bottom:0.5rem}.select-options-list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:0.25rem}.select-option{background:#e5e7eb;padding:0.25rem 0.5rem;border-radius:0.25rem;font-size:0.875rem;color:#374151}";const h=class{constructor(t){e(this,t);this.formFilled=i(this,"formFilled");this.recordingStateChanged=i(this,"recordingStateChanged");this.formJson="{}";this.serviceConfig="{}";this.context=undefined;this.classificationRootUrl="http://localhost";this.language="en";this.inputTypes=[];this.debug=false;this.renderForm=false;this.displayStatus=false;this.isRecording=false;this.isProcessing=false;this.hasError=false;this.transcription="";this.filledData=null;this.debugInfo={};this.isReadonlyMode=true;this.triggerAudioRecordUpload=()=>{this.fileInputAudioRecord.click()};this.handleAudioRecordChange=async e=>{const t=e.target;if(!t.files||t.files.length===0)return;const i=t.files[0];console.log("Selected file:",i);this.processAudioContent(i)};this.audioRecorder=new s}componentWillLoad(){this.initializeServices()}initializeServices(){try{if(!this.context){this.hasError=true;const e=this.language=="en"?`Initialization error: context is '${this.context}'`:`Erreur d'initialisation: le contexte est '${this.context}'`;this.statusMessage=e;this.updateDebugInfo(e,{error:e})}else{this.parsedSchema=JSON.parse(this.formJson||"{}");this.parsedConfig=JSON.parse(this.serviceConfig||"{}");if(this.apiKey){this.parsedConfig=Object.assign(Object.assign({},this.parsedConfig),{speechToText:Object.assign(Object.assign({},this.parsedConfig.speechToText),{apiKey:this.apiKey}),llm:Object.assign(Object.assign({},this.parsedConfig.llm),{apiKey:this.apiKey})})}this.speechToTextService=a.create(this.parsedConfig);this.llmService=c.create(this.parsedConfig);this.updateDebugInfo("Initialized",{schema:this.parsedSchema,config:this.parsedConfig});this.hasError=false;this.statusMessage=this.language=="en"?"Click to start recording":"Cliquer pour enregistrer";if(this.inputTypes.length===0){this.inputTypes=["voice"]}}}catch(e){this.hasError=true;this.statusMessage=this.language=="en"?`Initialization error: ${e.message}`:`Erreur d'initialisation: ${e.message}`;this.updateDebugInfo("Initialization Error",{error:e.message})}}updateDebugInfo(e,t){if(this.debug){this.debugInfo=Object.assign(Object.assign({},this.debugInfo),{[e]:{timestamp:(new Date).toISOString(),data:t}})}}async handleRecordClick(){if(this.isProcessing)return;if(this.isRecording){await this.stopRecordingAndProcess()}else{await this.startRecording()}}async startRecording(){try{this.hasError=false;this.statusMessage=this.language=="en"?"Starting recording...":`Enregistrement ...`;this.updateDebugInfo("Start Recording Attempt",{});await this.audioRecorder.startRecording();this.isRecording=true;this.statusMessage=this.language=="en"?"Recording... Click to stop":"Enregistrement ... Cliquer pour stopper";this.updateDebugInfo("Recording Started",{});this.recordingStateChanged.emit({isRecording:true,state:"recording"})}catch(e){this.hasError=true;this.statusMessage=this.language=="en"?`Recording failed: ${e.message}`:`Echec de l'enregistrement : ${e.message}`;this.updateDebugInfo("Recording Error",{error:e.message});this.formFilled.emit({success:false,error:e.message})}}async processJsonForm(e){console.log("processJsonForm",e);try{this.isProcessing=true;this.statusMessage=this.language=="en"?"Processing json...":`Traitement du json ...`;this.statusMessage=this.language=="en"?"Filling form fields...":"Remplissage du formulaire ...";const t=this.trimSchemaForAI(this.parsedSchema);const i=await this.llmService.fillFormFromJson(e,t);this.filledData=this.extractFilledData(i);this.updateDebugInfo("Form Filled",{filledSchema:i,extractedData:this.filledData});this.parsedSchema=this.filledData;this.statusMessage=this.language=="en"?"Form completed!":"Formulaire remplis !";this.hasError=false;this.formFilled.emit({success:true,data:this.filledData,jsonForm:e})}catch(t){this.hasError=true;this.statusMessage=this.language=="en"?`Processing failed: ${t.message}`:`Erreur de traitement : ${t.message}`;this.formFilled.emit({success:false,error:t.message,jsonForm:e})}finally{this.isProcessing=false}}async processAudioContent(e){this.updateDebugInfo("Audio Captured",{size:e.size,type:e.type});this.statusMessage=this.language=="en"?"Transcribing speech...":"Transcription du texte ...";const t=await this.speechToTextService.transcribe(e,this.language);this.transcription=t;this.updateDebugInfo("Transcription Complete",{transcription:t});if(!t.trim()){throw new Error("No speech detected in the recording")}this.statusMessage=this.language=="en"?"Filling form fields...":"Remplissage du formulaire ...";const i=this.trimSchemaForAI(this.parsedSchema);const r=await this.llmService.fillFormFromTranscription(t,i);this.filledData=this.extractFilledData(r);this.updateDebugInfo("Form Filled",{filledSchema:r,extractedData:this.filledData});this.parsedSchema=this.filledData;this.statusMessage=this.language=="en"?"Form completed!":"Formulaire remplis !";this.hasError=false;this.formFilled.emit({success:true,data:this.filledData,transcription:t})}async stopRecordingAndProcess(){try{this.isRecording=false;this.isProcessing=true;this.statusMessage=this.language=="en"?"Processing audio...":`Traitement de l'audio ...`;this.updateDebugInfo("Stop Recording",{});this.recordingStateChanged.emit({isRecording:false,state:"processing"});const e=await this.audioRecorder.stopRecording();const t=new File([e],"audio.webm",{type:"audio/webm"});this.processAudioContent(t)}catch(e){this.hasError=true;this.statusMessage=this.language=="en"?`Processing failed: ${e.message}`:`Erreur de traitement : ${e.message}`;this.updateDebugInfo("Processing Error",{error:e.message});this.formFilled.emit({success:false,error:e.message,transcription:this.transcription})}finally{this.isProcessing=false;this.recordingStateChanged.emit({isRecording:false,state:"idle"})}}extractFilledData(e){const t=JSON.parse(JSON.stringify(this.parsedSchema));switch(this.context){case"ecoteka":case"ng":if(e===null||e===void 0?void 0:e.fields){e.fields.forEach((e=>{const i=t.Children.find((t=>{var i;return t.System_Name===e.name||((i=t.Settings)===null||i===void 0?void 0:i.Label)===e.name}));if(i&&e.value!==undefined&&e.value!==null&&e.value!==""){if(!i.Settings)i.Settings={};i.Settings.Default_Value=e.value}}))}break;case"ecoll-veto":if(e===null||e===void 0?void 0:e.fields){e.fields.forEach((e=>{let i=t[0].items.find((t=>t.label===e.name));if(!i)i=t[1].items.find((t=>t.label===e.name));if(i&&e.value!==undefined&&e.value!==null&&e.value!==""){t[2][i.name]=e.value}}))}break;case"track":default:Object.entries(e.fields).forEach((([e,i])=>{if(i.default!==undefined&&i.default!==null&&i.default!==""){t[e]=i.default}if(i.value!==undefined&&i.value!==null&&i.value!==""){for(const e in t.fields){const r=t.fields[e];if(r.title===i.name){r.value=i.value||i.default;r.default=i.value||i.default;break}}}}));break}return t}trimSchemaForAI(e){var t,i;switch(this.context){case"ecoteka":case"ng":const r={fields:[]};e.Children.forEach((e=>{var t;if(!e.System_Name||!e.Type)return;const i={name:e.Label||((t=e.Settings)===null||t===void 0?void 0:t.Label)||e.System_Name,type:this.mapFieldType(e.Type)};const o=["InputClassification","select"];if(o.includes(e.Type)&&e.Children&&e.Children.length>0){i.options=e.Children.map((e=>e.System_Name||e.Label||e.toString()))}console.log("fieldData",i);r.fields.push(i)}));return r;case"ecoll-veto":const o=this.parsedSchema[0].items.concat(this.parsedSchema[1].items);if(o){const e={title:"Form Name",description:"Form Description",schema:{}};Object.entries(o).forEach((([t,i])=>{const r=i.name;const o=this.mapFieldType(i.type);const s=i.label||r;e.schema[r]={type:o,title:s,options:i.options,readonly:i.readonly===true,default:""}}));return e}case"track":default:if((t=e===null||e===void 0?void 0:e.schema)!==null&&t!==void 0?t:e===null||e===void 0?void 0:e.fields){const t={title:e.title,description:e.description,schema:{}};const r=(i=e===null||e===void 0?void 0:e.schema)!==null&&i!==void 0?i:e===null||e===void 0?void 0:e.fields;Object.entries(r).forEach((([e,i])=>{t.schema[e]={type:i.type,title:i.title,options:i.options,readonly:i.Enabled===false,default:i.DefaultValue,pattern:i.Mask,min:i.ValidationMin,max:i.ValidationMax}}));return t}break}return e}mapFieldType(e){const t={InputAutocomplete:"string",InputInteger:"number",InputTextArea:"string",InputDateTimePicker:"datetime",InputDecimal:"number",InputClassification:"select",InputCheckbox:"boolean",InputTextTranslation:"string",thesaurus:"string",position:"string",text:"string",textarea:"string",number:"number",date:"date",datetime:"datetime",select:"select",checkbox:"checkbox"};return t[e]||"string"}async convertXmlToJson(e){return d.convertXmlToJson(e,this.classificationRootUrl,this.language)}async convertJsonToXml(e){return d.convertJsonToXml(e)}async convertXmlToJsonLegacy(e){return d.convertXmlToJsonLegacy(e)}async convertJsonToXmlLegacy(e){return d.convertJsonToXmlLegacy(e)}renderUploadButton(){if(!this.inputTypes.includes("ocr"))return;return t("ocr-file-uploader",{batch:false,callback:e=>{this.processJsonForm(e)}})}renderUploadRecordButton(){return t("div",{class:"upload-record-container",onClick:this.triggerAudioRecordUpload},t("input",{type:"file",ref:e=>this.fileInputAudioRecord=e,onChange:this.handleAudioRecordChange,style:{display:"none"}}),t("div",{class:"upload-record-button"},t("svg",{width:"800px",height:"800px",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg"},t("path",{"fill-rule":"evenodd","clip-rule":"evenodd",d:"M12 2.75C6.89137 2.75 2.75 6.89137 2.75 12C2.75 17.1086 6.89137 21.25 12 21.25C12.6345 21.25 13.2534 21.1862 13.8508 21.065C14.2567 20.9826 14.6526 21.2448 14.735 21.6508C14.8174 22.0567 14.5551 22.4526 14.1492 22.535C13.4541 22.6761 12.7353 22.75 12 22.75C6.06294 22.75 1.25 17.9371 1.25 12C1.25 6.06294 6.06294 1.25 12 1.25C17.9371 1.25 22.75 6.06294 22.75 12C22.75 12.7353 22.6761 13.4541 22.535 14.1492C22.4526 14.5551 22.0567 14.8174 21.6508 14.735C21.2448 14.6526 20.9826 14.2567 21.065 13.8508C21.1862 13.2534 21.25 12.6345 21.25 12C21.25 6.89137 17.1086 2.75 12 2.75ZM12.7676 8.52584C12.7661 8.53409 12.7604 8.56729 12.7564 8.64336C12.7502 8.76101 12.75 8.91982 12.75 9.17082C12.75 9.27795 12.7501 9.33904 12.7518 9.38529C12.7528 9.41425 12.7542 9.42649 12.7546 9.42955C12.7662 9.48945 12.7993 9.54303 12.8477 9.58021C12.8502 9.58194 12.8606 9.58864 12.886 9.60252C12.9266 9.62468 12.9812 9.65209 13.0771 9.7L14.3938 10.3584C14.6183 10.4706 14.7604 10.5414 14.8684 10.5885C14.9382 10.6189 14.9705 10.6287 14.9785 10.631C15.0885 10.6405 15.1917 10.5767 15.2324 10.4742C15.2339 10.4659 15.2396 10.4327 15.2436 10.3566C15.2498 10.239 15.25 10.0802 15.25 9.82918C15.25 9.72205 15.2499 9.66096 15.2482 9.61471C15.2472 9.58575 15.2458 9.57351 15.2454 9.57045C15.2338 9.51055 15.2007 9.45697 15.1523 9.41979C15.1498 9.41805 15.1394 9.41136 15.114 9.39748C15.0734 9.37533 15.0188 9.34791 14.9229 9.3L13.6062 8.64164C13.3817 8.52939 13.2396 8.45859 13.1316 8.41151C13.0617 8.38107 13.0295 8.37131 13.0215 8.36896C12.9115 8.35945 12.8083 8.42327 12.7676 8.52584ZM12.75 11.2135L13.7396 11.7083C13.9425 11.8098 14.1204 11.8987 14.269 11.9635C14.4199 12.0293 14.5988 12.097 14.7972 12.1202C15.6037 12.2142 16.3689 11.7413 16.6454 10.978C16.7134 10.7901 16.7328 10.5998 16.7415 10.4355C16.75 10.2735 16.75 10.0747 16.75 9.8479V9.82918C16.75 9.81565 16.75 9.80205 16.75 9.78837C16.7503 9.62647 16.7505 9.45474 16.7188 9.28904C16.638 8.86674 16.4045 8.48898 16.0629 8.22783C15.9289 8.12535 15.7752 8.04877 15.6303 7.97658C15.618 7.97048 15.6059 7.96441 15.5938 7.95836L14.2603 7.29164C14.0575 7.19022 13.8796 7.10128 13.731 7.03647C13.5801 6.97071 13.4012 6.90297 13.2028 6.87982C12.3963 6.78575 11.6311 7.25868 11.3546 8.02203C11.2866 8.20986 11.2672 8.40019 11.2585 8.56454C11.2519 8.68919 11.2504 8.83571 11.2501 9L11.25 9.11944C11.25 9.13026 11.25 9.14115 11.25 9.1521V9.17082C11.25 9.18435 11.25 9.19795 11.25 9.21163C11.2499 9.23918 11.2499 9.26701 11.25 9.29505V12.5499C10.875 12.3581 10.4501 12.25 10 12.25C8.48122 12.25 7.25 13.4812 7.25 15C7.25 16.5188 8.48122 17.75 10 17.75C11.5188 17.75 12.75 16.5188 12.75 15V11.2135ZM11.25 15C11.25 14.3096 10.6904 13.75 10 13.75C9.30964 13.75 8.75 14.3096 8.75 15C8.75 15.6904 9.30964 16.25 10 16.25C10.6904 16.25 11.25 15.6904 11.25 15ZM17.4697 14.4697C17.7626 14.1768 18.2374 14.1768 18.5303 14.4697L21.0303 16.9697C21.3232 17.2626 21.3232 17.7374 21.0303 18.0303C20.7374 18.3232 20.2626 18.3232 19.9697 18.0303L18.75 16.8107V22C18.75 22.4142 18.4142 22.75 18 22.75C17.5858 22.75 17.25 22.4142 17.25 22V16.8107L16.0303 18.0303C15.7374 18.3232 15.2626 18.3232 14.9697 18.0303C14.6768 17.7374 14.6768 17.2626 14.9697 16.9697L17.4697 14.4697Z"}))))}renderRecordButton(){if(!this.inputTypes.includes("voice"))return;const e=["record-button",this.isRecording&&"recording",this.isProcessing&&"processing"].filter(Boolean).join(" ");const i=this.isProcessing||this.hasError;return t("button",{class:e,onClick:()=>this.handleRecordClick(),disabled:i,"aria-label":this.isRecording?"Stop recording":"Start recording"},this.isProcessing?t("svg",{class:"record-icon",viewBox:"0 0 24 24"},t("circle",{cx:"12",cy:"12",r:"3"},t("animate",{attributeName:"r",values:"3;6;3",dur:"1s",repeatCount:"indefinite"}),t("animate",{attributeName:"opacity",values:"1;0.3;1",dur:"1s",repeatCount:"indefinite"}))):this.isRecording?t("svg",{class:"record-icon",viewBox:"0 0 24 24"},t("rect",{x:"6",y:"6",width:"12",height:"12",rx:"2"})):t("svg",{class:"record-icon",viewBox:"0 0 24 24"},t("circle",{cx:"12",cy:"12",r:"8"})))}renderStatusMessage(){const e=["status-text",this.hasError&&"error",this.filledData&&!this.hasError&&"success"].filter(Boolean).join(" ");return t("div",{class:e},this.statusMessage)}renderFormPreview(){if(!this.parsedSchema)return null;const e=this.isReadonlyMode&&!this.filledData;const i=e?"Form Preview (Voice input to fill)":"Voice-Filled Form:";return t("div",{class:"form-preview"},t("div",{class:"form-preview-title"},i),t("form",{class:"voice-filled-form"},this.renderFormFields()))}renderFormFields(){if(!this.parsedSchema)return null;switch(this.context){case"ecoteka":case"ng":return this.parsedSchema.Children.map((e=>{var i,r,o;if(!e.System_Name||!e.Type)return null;const s=e.System_Name;const n=this.mapFieldType(e.Type);const a=((i=e.Settings)===null||i===void 0?void 0:i.Label)||e.System_Name;const l=e.Required||false;const c=(r=e.Settings)===null||r===void 0?void 0:r.Default_Value;return t("div",{class:"form-group",key:s},t("label",{htmlFor:s,class:"form-label"},a,l&&t("span",{class:"required"},"*")),this.renderFormField(s,{type:n,title:a,required:l,options:(o=e.Children)===null||o===void 0?void 0:o.map((e=>e.System_Name||e.Label||e.toString()))},c))})).filter(Boolean);case"ecoll-veto":const e=this.parsedSchema[0].items.concat(this.parsedSchema[1].items);return Object.entries(e).map((([e,i])=>{var r,o;const s=i.name;i.type=this.mapFieldType(i.type);const n=i.label||s;const a=i.required||false;const l=this.parsedSchema[2][s];return t("div",{class:"form-group",key:s},t("label",{htmlFor:s,class:"form-label"},n,a&&t("span",{class:"required"},"*")),this.renderFormField(s,i,(o=(r=this.filledData)===null||r===void 0?void 0:r[s])!==null&&o!==void 0?o:l))}));case"track":default:return Object.entries(this.parsedSchema.fields).map((([e,i])=>{var r,o;return t("div",{class:"form-group",key:e},t("label",{htmlFor:e,class:"form-label"},i.title||e,i.required&&t("span",{class:"required"},"*")),this.renderFormField(e,i,(o=(r=this.filledData)===null||r===void 0?void 0:r[e])!==null&&o!==void 0?o:i.value))}))}}renderFormField(e,i,r){var o,s;const n=this.isReadonlyMode&&!this.filledData;const a={id:e,name:e,class:"form-input",required:i.required,disabled:n};switch(i.type){case"select":if(n){return t("div",{class:"readonly-select"},t("div",{class:"select-placeholder"},"Available options:"),t("ul",{class:"select-options-list"},(o=i.options)===null||o===void 0?void 0:o.map((e=>t("li",{class:"select-option"},e)))))}return t("select",{id:e,name:e,class:"form-input",required:i.required},t("option",{value:""},"-- Select --"),(s=i.options)===null||s===void 0?void 0:s.map((e=>t("option",{value:e,selected:r===e},e))));case"boolean":return t("input",Object.assign({},a,{type:"checkbox",class:"form-checkbox",checked:r===true||r==="true"}));case"number":return t("input",Object.assign({},a,{type:"number",min:i.min,max:i.max,step:"any",value:r||""}));case"date":return t("input",Object.assign({},a,{type:"date",value:r?(([e,t,i])=>`${i}-${t}-${e}`)(r.split("/")):""}));case"datetime":return t("input",Object.assign({},a,{type:"datetime-local",value:r||""}));default:return t("input",Object.assign({},a,{type:"text",pattern:i.pattern,placeholder:i.description,value:r||""}))}}renderDebugPanel(){if(!this.debug)return null;return t("div",{class:"debug-panel"},t("div",{class:"debug-title"},"Debug Information:"),t("div",{class:"debug-content"},JSON.stringify(this.debugInfo,null,2)))}render(){return t("div",{key:"6316d3928829e102feab372fbd2e669a38239d84"},t("div",{key:"65bebc70c371d8789566142dd27a1e102eeed0c3",class:"voice-recorder-container"+(this.debug||this.renderForm?"-debug":"")},t("div",{key:"c0926aa835ecc152bdbc5ac7779d9dfc7ea9b62f",class:"row-audio-area"},this.renderRecordButton(),this.renderUploadRecordButton()),this.displayStatus?this.renderStatusMessage():"",this.renderUploadButton(),this.renderForm?this.renderFormPreview():"",this.debug?this.renderDebugPanel():""))}static get watchers(){return{formJson:["initializeServices"],serviceConfig:["initializeServices"]}}};h.style=u;export{o as ocr_file_uploader,h as voice_input_module};
|
|
2
|
+
//# sourceMappingURL=p-52e59129.entry.js.map
|