@eclipse-lyra/extension-rag-system 0.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/api.d.ts +9 -0
- package/dist/api.d.ts.map +1 -0
- package/dist/api.js +90 -0
- package/dist/api.js.map +1 -0
- package/dist/chunkers/chunker-interface.d.ts +21 -0
- package/dist/chunkers/chunker-interface.d.ts.map +1 -0
- package/dist/chunkers/document-chunker.d.ts +12 -0
- package/dist/chunkers/document-chunker.d.ts.map +1 -0
- package/dist/chunkers/fallback-chunker.d.ts +10 -0
- package/dist/chunkers/fallback-chunker.d.ts.map +1 -0
- package/dist/chunkers/langchain-chunker.d.ts +12 -0
- package/dist/chunkers/langchain-chunker.d.ts.map +1 -0
- package/dist/document-index-service.d.ts +102 -0
- package/dist/document-index-service.d.ts.map +1 -0
- package/dist/embedding-service.d.ts +18 -0
- package/dist/embedding-service.d.ts.map +1 -0
- package/dist/extractors/document-extractor-interface.d.ts +26 -0
- package/dist/extractors/document-extractor-interface.d.ts.map +1 -0
- package/dist/extractors/document-extractor.d.ts +13 -0
- package/dist/extractors/document-extractor.d.ts.map +1 -0
- package/dist/extractors/llm-ocr-extractor.d.ts +16 -0
- package/dist/extractors/llm-ocr-extractor.d.ts.map +1 -0
- package/dist/extractors/pdfjs-extractor.d.ts +7 -0
- package/dist/extractors/pdfjs-extractor.d.ts.map +1 -0
- package/dist/i18n.json.d.ts +13 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +22 -0
- package/dist/index.js.map +1 -0
- package/dist/rag-integration-DO7-zvk2.js +191 -0
- package/dist/rag-integration-DO7-zvk2.js.map +1 -0
- package/dist/rag-integration.d.ts +6 -0
- package/dist/rag-integration.d.ts.map +1 -0
- package/dist/rag-service-BKBGCuO-.js +1872 -0
- package/dist/rag-service-BKBGCuO-.js.map +1 -0
- package/dist/rag-service.d.ts +25 -0
- package/dist/rag-service.d.ts.map +1 -0
- package/dist/rag-system-extension-DfD6H8Vr.js +1142 -0
- package/dist/rag-system-extension-DfD6H8Vr.js.map +1 -0
- package/dist/rag-system-extension.d.ts +2 -0
- package/dist/rag-system-extension.d.ts.map +1 -0
- package/dist/rag-system-manager.d.ts +41 -0
- package/dist/rag-system-manager.d.ts.map +1 -0
- package/dist/rxdb-loader.d.ts +9 -0
- package/dist/rxdb-loader.d.ts.map +1 -0
- package/dist/services/rag-result-formatter.d.ts +23 -0
- package/dist/services/rag-result-formatter.d.ts.map +1 -0
- package/dist/services/relevance-calculator.d.ts +7 -0
- package/dist/services/relevance-calculator.d.ts.map +1 -0
- package/dist/utils/constants.d.ts +35 -0
- package/dist/utils/constants.d.ts.map +1 -0
- package/dist/utils/context-scopes.d.ts +39 -0
- package/dist/utils/context-scopes.d.ts.map +1 -0
- package/dist/utils/query-utils.d.ts +7 -0
- package/dist/utils/query-utils.d.ts.map +1 -0
- package/dist/utils/snippet-extractor.d.ts +22 -0
- package/dist/utils/snippet-extractor.d.ts.map +1 -0
- package/dist/utils/workspace-utils.d.ts +8 -0
- package/dist/utils/workspace-utils.d.ts.map +1 -0
- package/dist/vector-utils.d.ts +28 -0
- package/dist/vector-utils.d.ts.map +1 -0
- package/package.json +39 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rag-system-extension-DfD6H8Vr.js","sources":["../src/rag-system-manager.ts","../src/rag-system-extension.ts"],"sourcesContent":["import { customElement, property, state } from 'lit/decorators.js';\nimport { css, html, TemplateResult, nothing } from 'lit';\nimport { createRef, ref } from 'lit/directives/ref.js';\nimport { LyraPart } from '@eclipse-lyra/core';\nimport { EditorInput } from '@eclipse-lyra/core';\nimport { documentIndexService, IndexedDocument } from './document-index-service';\nimport { searchWorkspaceDocuments, RAGSearchResult } from './rag-service';\nimport { workspaceService, File } from '@eclipse-lyra/core';\nimport { createLogger } from '@eclipse-lyra/core';\nimport { getWorkspacePath } from './utils/workspace-utils';\nimport { SnippetExtractor } from './utils/snippet-extractor';\nimport { CONTENT_PREVIEW_LENGTHS, SNIPPET_LENGTHS } from './utils/constants';\nimport { toastError, toastInfo } from '@eclipse-lyra/core';\nimport { taskService } from '@eclipse-lyra/core';\nimport { editorRegistry } from '@eclipse-lyra/core';\n\nconst logger = createLogger('RAGSystemManager');\nconst snippetExtractor = new SnippetExtractor();\n\n@customElement('lyra-rag-system-manager')\nexport class LyraRAGSystemManager extends LyraPart {\n @property({ attribute: false })\n public input?: EditorInput;\n\n @state()\n private documents: IndexedDocument[] = [];\n\n\n @state()\n private stats: { totalDocuments: number; byWorkspace: Record<string, number> } = {\n totalDocuments: 0,\n byWorkspace: {}\n };\n\n @state()\n private loading = false;\n\n @state()\n private selectedDocument: IndexedDocument | null = null;\n\n @state()\n private searchQuery = '';\n\n @state()\n private filterWorkspace: string | null = null;\n\n @state()\n private filterByActiveWorkspace = true;\n\n @state()\n private filteredDocuments: IndexedDocument[] = [];\n \n @state()\n private searchResults: Map<string, RAGSearchResult> = new Map();\n\n @state()\n private reindexing = false;\n\n private treeRef = createRef<HTMLElement>();\n private searchDebounceTimer?: number;\n private searchInputValue = '';\n\n protected async doInitUI() {\n try {\n await documentIndexService.initialize();\n await Promise.all([\n this.loadDocuments(),\n this.loadStats()\n ]);\n } catch (error) {\n logger.error(`Failed to initialize document index manager: ${error}`);\n toastError(`Failed to initialize: ${error}`);\n }\n }\n\n private async loadDocuments() {\n this.loading = true;\n this.requestUpdate();\n try {\n let workspacePath: string | undefined;\n if (this.filterByActiveWorkspace) {\n const workspaceResult = await getWorkspacePath();\n workspacePath = workspaceResult?.workspacePath;\n }\n this.documents = await documentIndexService.listDocuments(workspacePath);\n await this.updateFilteredDocuments();\n } catch (error) {\n logger.error(`Failed to load documents: ${error}`);\n toastError(`Failed to load documents: ${error}`);\n } finally {\n this.loading = false;\n }\n }\n\n private async updateFilteredDocuments() {\n this.filteredDocuments = await this.getFilteredDocuments();\n this.requestUpdate();\n }\n\n private async loadStats() {\n try {\n this.stats = await documentIndexService.getStats();\n this.requestUpdate();\n } catch (error) {\n logger.error(`Failed to load stats: ${error}`);\n }\n }\n\n private handleTreeSelection(e: CustomEvent) {\n // Try getting from event detail first (as per extensions pattern)\n let selection = e.detail?.selection || [];\n\n // If no selection in detail, try getting from tree element directly (as per lyra-filebrowser pattern)\n if (selection.length === 0 && this.treeRef.value) {\n // @ts-ignore\n selection = this.treeRef.value.selectedItems || [];\n }\n\n if (selection.length > 0) {\n const selectedItem = selection[0];\n if (selectedItem?.model) {\n this.selectedDocument = selectedItem.model;\n } else {\n this.selectedDocument = null;\n }\n } else {\n this.selectedDocument = null;\n }\n }\n\n private async getFilteredDocuments(): Promise<IndexedDocument[]> {\n if (!this.documents || this.documents.length === 0) {\n return [];\n }\n\n if (this.searchQuery.trim()) {\n try {\n const searchResults = await searchWorkspaceDocuments(this.searchQuery, {\n limit: 50,\n workspacePath: this.filterWorkspace || undefined\n });\n\n this.searchResults.clear();\n const uniqueDocs = new Map<string, IndexedDocument>();\n const aggregatedResults = new Map<string, RAGSearchResult>();\n \n for (const result of searchResults) {\n const docId = result.document.id;\n uniqueDocs.set(docId, result.document);\n \n const existing = aggregatedResults.get(docId);\n if (!existing) {\n aggregatedResults.set(docId, {\n document: result.document,\n relevance: result.relevance,\n matchedSnippets: [...result.matchedSnippets]\n });\n } else {\n if (result.relevance > existing.relevance) {\n existing.relevance = result.relevance;\n }\n const seenSnippets = new Set(existing.matchedSnippets);\n for (const snippet of result.matchedSnippets) {\n if (!seenSnippets.has(snippet)) {\n existing.matchedSnippets.push(snippet);\n seenSnippets.add(snippet);\n }\n }\n }\n }\n \n for (const [docId, result] of aggregatedResults) {\n this.searchResults.set(docId, result);\n }\n\n const resultDocs = Array.from(uniqueDocs.values());\n \n if (this.filterWorkspace) {\n return resultDocs.filter(doc => doc.workspacePath === this.filterWorkspace);\n }\n \n return resultDocs;\n } catch (error) {\n logger.debug(`RAG search failed in document manager: ${error}`);\n this.searchResults.clear();\n return [];\n }\n } else {\n this.searchResults.clear();\n }\n\n let filtered = [...this.documents];\n\n if (this.filterWorkspace) {\n filtered = filtered.filter(doc => doc.workspacePath === this.filterWorkspace);\n }\n\n return filtered;\n }\n\n private highlightMatches(text: string, query: string): TemplateResult {\n if (!query || !query.trim()) {\n return html`${text}`;\n }\n\n const queryLower = query.toLowerCase();\n const textLower = text.toLowerCase();\n const parts: Array<string | TemplateResult> = [];\n let lastIndex = 0;\n let index = textLower.indexOf(queryLower, lastIndex);\n\n while (index !== -1) {\n if (index > lastIndex) {\n parts.push(text.substring(lastIndex, index));\n }\n parts.push(html`<mark class=\"search-match\">${text.substring(index, index + query.length)}</mark>`);\n lastIndex = index + query.length;\n index = textLower.indexOf(queryLower, lastIndex);\n }\n\n if (lastIndex < text.length) {\n parts.push(text.substring(lastIndex));\n }\n\n return html`${parts}`;\n }\n\n private getContentPreview(doc: IndexedDocument): TemplateResult {\n const searchResult = this.searchResults.get(doc.id);\n \n if (searchResult && searchResult.matchedSnippets.length > 0) {\n return html`\n <table class=\"snippets-table\">\n <thead>\n <tr>\n <th class=\"snippet-number-col\">#</th>\n <th class=\"snippet-content-col\">Content</th>\n </tr>\n </thead>\n <tbody>\n ${searchResult.matchedSnippets.map((snippet, idx) => html`\n <tr>\n <td class=\"snippet-number\">${idx + 1}</td>\n <td class=\"snippet-content\">${this.highlightMatches(snippet, this.searchQuery)}</td>\n </tr>\n `)}\n </tbody>\n </table>\n `;\n }\n\n if (this.searchQuery && this.searchQuery.trim()) {\n const snippets = snippetExtractor.extractContextSnippets(\n doc.content,\n this.searchQuery,\n SNIPPET_LENGTHS.CONTEXT\n );\n\n if (snippets.length > 0) {\n return html`\n <table class=\"snippets-table\">\n <thead>\n <tr>\n <th class=\"snippet-number-col\">#</th>\n <th class=\"snippet-content-col\">Content</th>\n </tr>\n </thead>\n <tbody>\n ${snippets.map((snippet, idx) => html`\n <tr>\n <td class=\"snippet-number\">${idx + 1}</td>\n <td class=\"snippet-content\">${this.highlightMatches(doc.content.substring(snippet.start, snippet.end), this.searchQuery)}</td>\n </tr>\n `)}\n </tbody>\n </table>\n `;\n }\n }\n\n const preview = snippetExtractor.extractSimpleSnippet(doc.content, CONTENT_PREVIEW_LENGTHS.LONG);\n return html`\n <div class=\"snippet-preview\">${preview}</div>\n `;\n }\n\n private async deleteDocument(doc: IndexedDocument) {\n try {\n await documentIndexService.deleteDocument(doc.id);\n toastInfo(`Deleted: ${doc.fileName}`);\n await this.loadDocuments();\n await this.loadStats();\n if (this.selectedDocument?.id === doc.id) {\n this.selectedDocument = null;\n }\n } catch (error) {\n toastError(`Failed to delete document: ${error}`);\n }\n }\n\n private async reindexDocument(doc: IndexedDocument) {\n try {\n const workspaceResult = await getWorkspacePath();\n if (!workspaceResult) {\n toastError('No workspace connected');\n return;\n }\n\n const resource = await workspaceResult.workspace.getResource(doc.filePath);\n if (!resource) {\n toastError(`File not found: ${doc.filePath}`);\n return;\n }\n\n if (!(resource instanceof File)) {\n toastError(`Resource is not a file: ${doc.filePath}`);\n return;\n }\n\n const file: File = resource;\n\n await taskService.runAsync('Reindexing document', async progress => {\n progress.message = `Reindexing ${doc.fileName}...`;\n await documentIndexService.reindexDocument(file);\n progress.progress = 100;\n });\n\n toastInfo(`Reindexed: ${doc.fileName}`);\n await this.loadDocuments();\n if (this.selectedDocument?.id === doc.id) {\n this.selectedDocument = await documentIndexService.getDocument(doc.id);\n }\n } catch (error) {\n toastError(`Failed to reindex document: ${error}`);\n }\n }\n\n private async reindexAllDocuments() {\n if (this.reindexing) {\n return;\n }\n\n const stats = await documentIndexService.getStats();\n if (stats.totalDocuments === 0) {\n toastInfo('No documents to reindex');\n return;\n }\n\n this.reindexing = true;\n this.requestUpdate();\n\n try {\n const result = await taskService.runAsync('Reindexing all documents', async progress => {\n progress.message = 'Starting reindexing...';\n \n const total = stats.totalDocuments;\n\n const reindexResult = await documentIndexService.reindexAllDocuments();\n \n const processed = reindexResult.succeeded + reindexResult.failed;\n progress.progress = total > 0 ? (processed / total) * 100 : 100;\n progress.message = `Reindexed ${reindexResult.succeeded}/${total} documents${reindexResult.failed > 0 ? ` (${reindexResult.failed} failed)` : ''}`;\n \n return reindexResult;\n });\n\n await this.loadDocuments();\n await this.loadStats();\n toastInfo(`Reindexing completed: ${result.succeeded} succeeded, ${result.failed} failed`);\n } catch (error) {\n logger.error(`Failed to reindex all documents: ${error}`);\n toastError(`Failed to reindex all documents: ${error}`);\n } finally {\n this.reindexing = false;\n this.requestUpdate();\n }\n }\n\n private formatFileSize(bytes: number): string {\n if (bytes < 1024) return `${bytes} B`;\n if (bytes < 1024 * 1024) return `${(bytes / 1024).toFixed(1)} LyraB`;\n return `${(bytes / (1024 * 1024)).toFixed(1)} MB`;\n }\n\n private formatDate(timestamp: number): string {\n return new Date(timestamp).toLocaleString();\n }\n\n private getFileIcon(fileType: string): string {\n return editorRegistry.getFileIcon(fileType);\n }\n\n protected renderToolbar(): TemplateResult {\n const workspaces = Object.keys(this.stats?.byWorkspace || {});\n\n return html`\n <wa-input\n type=\"search\"\n placeholder=\"Search documents...\"\n .value=${this.searchInputValue}\n @input=${(e: any) => {\n this.searchInputValue = e.target.value;\n \n if (this.searchDebounceTimer) {\n clearTimeout(this.searchDebounceTimer);\n }\n \n this.searchDebounceTimer = window.setTimeout(async () => {\n this.searchQuery = this.searchInputValue;\n await this.updateFilteredDocuments();\n }, 200);\n }}\n @wa-clear=${async () => {\n if (this.searchDebounceTimer) {\n clearTimeout(this.searchDebounceTimer);\n }\n this.searchInputValue = '';\n this.searchQuery = '';\n await this.updateFilteredDocuments();\n }}\n size=\"small\"\n with-clear\n autocomplete=\"off\"\n style=\"flex: 1; max-width: 400px;\">\n <wa-icon name=\"magnifying-glass\" slot=\"start\"></wa-icon>\n </wa-input>\n \n <wa-switch\n .checked=${this.filterByActiveWorkspace}\n @change=${async (e: any) => {\n this.filterByActiveWorkspace = e.target.checked;\n await this.loadDocuments();\n }}\n size=\"small\">\n Active workspace only\n </wa-switch>\n \n ${workspaces.length > 1 ? html`\n <wa-select \n .value=${this.filterWorkspace || ''}\n @change=${async (e: any) => {\n this.filterWorkspace = e.target.value || null;\n await this.updateFilteredDocuments();\n }}\n size=\"small\"\n style=\"width: 200px;\">\n <wa-option value=\"\">All Workspaces</wa-option>\n ${workspaces.map(ws => html`\n <wa-option value=\"${ws}\">${ws} (${this.stats.byWorkspace[ws]})</wa-option>\n `)}\n </wa-select>\n ` : nothing}\n \n <lyra-command \n size=\"small\" \n icon=\"arrow-rotate-right\"\n title=\"Refresh document list\"\n .action=${() => this.loadDocuments()}\n ?disabled=${this.reindexing}>\n Refresh\n </lyra-command>\n \n <lyra-command \n size=\"small\" \n icon=\"database\"\n title=\"Re-index all documents\"\n .action=${() => this.reindexAllDocuments()}\n ?disabled=${this.reindexing || this.loading}>\n ${this.reindexing ? 'Reindexing...' : 'Re-index All'}\n </lyra-command>\n `;\n }\n\n protected render(): TemplateResult {\n if (!this.stats) {\n this.stats = { totalDocuments: 0, byWorkspace: {} };\n }\n\n const filteredDocs = this.filteredDocuments;\n const workspaces = Object.keys(this.stats.byWorkspace || {});\n\n return html`\n <div class=\"rag-system-manager\">\n <div class=\"header\">\n <div class=\"header-content\">\n <div class=\"stats\">\n <span>Total: ${this.stats.totalDocuments} documents</span>\n ${workspaces.length > 0 ? html`\n <span>Workspaces: ${workspaces.length}</span>\n ` : nothing}\n </div>\n </div>\n </div>\n\n <wa-split-panel position=\"40\" style=\"height: 100%;\">\n <div class=\"document-list\" slot=\"start\">\n ${this.loading ? html`\n <div class=\"loading\">\n <wa-spinner></wa-spinner>\n <span>Loading documents...</span>\n </div>\n ` : filteredDocs.length === 0 ? html`\n <div class=\"empty\">\n <wa-icon name=\"inbox\" style=\"font-size: 3rem; opacity: 0.3;\"></wa-icon>\n <p>${this.searchQuery || this.filterWorkspace ? 'No documents match your filters' : 'No documents indexed yet'}</p>\n </div>\n ` : html`\n <wa-tree \n ${ref(this.treeRef)}\n selection=\"leaf\"\n style=\"--indent-guide-width: 1px;\"\n @wa-selection-change=${(e: CustomEvent) => {\n this.handleTreeSelection(e);\n }}>\n ${filteredDocs.map(doc => html`\n <wa-tree-item \n .model=${doc}\n ?selected=${this.selectedDocument?.id === doc.id}>\n <wa-icon name=\"${this.getFileIcon(doc.fileType)}\"></wa-icon>\n <div class=\"tree-item-info\">\n <strong class=\"tree-item-path\">${doc.filePath}</strong>\n <div class=\"tree-item-meta\">\n <small class=\"meta-size\">${this.formatFileSize(doc.metadata.size)}</small>\n <small class=\"meta-date\">${this.formatDate(doc.indexedAt)}</small>\n </div>\n </div>\n <div class=\"tree-item-actions\" @click=${(e: Event) => e.stopPropagation()}>\n <wa-button\n variant=\"neutral\"\n appearance=\"plain\"\n size=\"small\"\n title=\"Reindex\"\n @click=${() => this.reindexDocument(doc)}>\n <wa-icon name=\"arrow-rotate-right\"></wa-icon>\n </wa-button>\n <wa-button\n variant=\"danger\"\n appearance=\"plain\"\n size=\"small\"\n title=\"Delete\"\n @click=${() => this.deleteDocument(doc)}>\n <wa-icon name=\"trash\"></wa-icon>\n </wa-button>\n </div>\n </wa-tree-item>\n `)}\n </wa-tree>\n `}\n </div>\n\n <div slot=\"end\">\n ${this.selectedDocument ? html`\n <div class=\"document-details\">\n <div class=\"details-content\">\n <div class=\"metadata-grid\">\n <wa-input\n label=\"File Path\"\n .value=${this.selectedDocument.filePath}\n readonly\n size=\"small\">\n <wa-copy-button\n slot=\"end\"\n .value=${this.selectedDocument.filePath}\n size=\"small\"\n label=\"Copy file path\">\n </wa-copy-button>\n </wa-input>\n \n <wa-input\n label=\"Workspace\"\n .value=${this.selectedDocument.workspacePath}\n readonly\n size=\"small\">\n <wa-copy-button\n slot=\"end\"\n .value=${this.selectedDocument.workspacePath}\n size=\"small\"\n label=\"Copy workspace\">\n </wa-copy-button>\n </wa-input>\n \n <wa-input\n label=\"File Type\"\n .value=${this.selectedDocument.fileType}\n readonly\n size=\"small\">\n <wa-copy-button\n slot=\"end\"\n .value=${this.selectedDocument.fileType}\n size=\"small\"\n label=\"Copy file type\">\n </wa-copy-button>\n </wa-input>\n \n <wa-input\n label=\"Size\"\n .value=${this.formatFileSize(this.selectedDocument.metadata.size)}\n readonly\n size=\"small\">\n <wa-copy-button\n slot=\"end\"\n .value=${this.formatFileSize(this.selectedDocument.metadata.size)}\n size=\"small\"\n label=\"Copy size\">\n </wa-copy-button>\n </wa-input>\n \n <wa-input\n label=\"Indexed At\"\n .value=${this.formatDate(this.selectedDocument.indexedAt)}\n readonly\n size=\"small\">\n <wa-copy-button\n slot=\"end\"\n .value=${this.formatDate(this.selectedDocument.indexedAt)}\n size=\"small\"\n label=\"Copy indexed date\">\n </wa-copy-button>\n </wa-input>\n \n <wa-input\n label=\"Last Updated\"\n .value=${this.formatDate(this.selectedDocument.updatedAt)}\n readonly\n size=\"small\">\n <wa-copy-button\n slot=\"end\"\n .value=${this.formatDate(this.selectedDocument.updatedAt)}\n size=\"small\"\n label=\"Copy updated date\">\n </wa-copy-button>\n </wa-input>\n </div>\n \n ${this.selectedDocument.metadata.tags && this.selectedDocument.metadata.tags.length > 0 ? html`\n <div class=\"tags-section\">\n <wa-input\n label=\"Tags\"\n .value=${this.selectedDocument.metadata.tags.join(', ')}\n readonly\n size=\"small\">\n <wa-copy-button\n slot=\"end\"\n .value=${this.selectedDocument.metadata.tags.join(', ')}\n size=\"small\"\n label=\"Copy tags\">\n </wa-copy-button>\n </wa-input>\n </div>\n ` : nothing}\n \n <div class=\"detail-section\">\n <label>Content Preview${this.searchQuery ? html` <span class=\"search-hint\">(showing matches for \"${this.searchQuery}\")</span>` : nothing}</label>\n <wa-scroller class=\"content-preview\" orientation=\"vertical\">\n <div class=\"content-preview-inner\">\n ${this.getContentPreview(this.selectedDocument)}\n </div>\n </wa-scroller>\n </div>\n </div>\n </div>\n ` : html`\n <div class=\"document-details empty\">\n <wa-icon name=\"file-lines\" style=\"font-size: 3rem; opacity: 0.3;\"></wa-icon>\n <p>Select a document to view details</p>\n </div>\n `}\n </div>\n </wa-split-panel>\n </div>\n `;\n }\n\n static styles = css`\n :host {\n display: flex;\n flex-direction: column;\n height: 100%;\n overflow: hidden;\n min-height: 0;\n }\n\n .rag-system-manager {\n display: flex;\n flex-direction: column;\n height: 100%;\n min-height: 0;\n overflow: hidden;\n }\n\n wa-split-panel {\n flex: 1;\n min-height: 0;\n overflow: hidden;\n }\n\n .document-list {\n height: 100%;\n overflow-y: auto;\n }\n\n .tree-item-info {\n flex: 1;\n min-width: 0;\n }\n\n .tree-item-path {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n\n .tree-item-meta {\n display: flex;\n align-items: center;\n gap: var(--wa-space-xs);\n flex-wrap: wrap;\n margin-top: var(--wa-space-xs);\n }\n\n .tree-item-actions {\n opacity: 0;\n }\n\n wa-tree-item:hover .tree-item-actions {\n opacity: 1;\n }\n\n .document-details {\n height: 100%;\n display: flex;\n flex-direction: column;\n min-height: 0;\n overflow: hidden;\n }\n\n .details-content {\n flex: 1;\n display: flex;\n flex-direction: column;\n padding: var(--wa-space-s);\n min-height: 0;\n overflow: hidden;\n }\n\n .metadata-grid {\n display: grid;\n grid-template-columns: 1fr 1fr;\n gap: var(--wa-space-s);\n flex-shrink: 0;\n }\n\n .tags-section {\n margin-top: var(--wa-space-s);\n flex-shrink: 0;\n margin-bottom: var(--wa-space-s);\n }\n\n .detail-section {\n flex: 1;\n display: flex;\n flex-direction: column;\n min-height: 0;\n position: relative;\n }\n\n .detail-section label {\n flex-shrink: 0;\n margin-bottom: var(--wa-space-xs);\n }\n\n .content-preview {\n position: absolute;\n top: 0;\n right: 0;\n left: 0;\n bottom: 0;\n }\n\n .content-preview-inner {\n width: 100%;\n }\n\n .snippets-table {\n width: 100%;\n border-collapse: collapse;\n background-color: var(--wa-color-surface-raised);\n }\n\n .snippets-table thead {\n background-color: var(--wa-color-neutral-fill-quiet);\n }\n\n .snippets-table th {\n padding: var(--wa-space-xs) var(--wa-space-s);\n text-align: left;\n font-size: 0.75rem;\n font-weight: 600;\n color: var(--wa-color-text-quiet);\n border-bottom: 1px solid var(--wa-color-surface-border);\n }\n\n .snippets-table td {\n padding: var(--wa-space-s);\n border-bottom: 1px solid var(--wa-color-surface-border);\n vertical-align: top;\n }\n\n .snippets-table tbody tr:last-child td {\n border-bottom: none;\n }\n\n .snippets-table tbody tr:hover {\n background-color: var(--wa-color-neutral-fill-quiet);\n }\n\n .snippet-number-col {\n width: 3rem;\n text-align: center;\n }\n\n .snippet-content-col {\n width: auto;\n }\n\n .snippet-number {\n font-size: 0.75rem;\n font-weight: 600;\n color: var(--wa-color-text-quiet);\n text-align: center;\n }\n\n .snippet-content {\n white-space: pre-wrap;\n word-wrap: breaword;\n overflow-wrap: breaword;\n font-family: monospace;\n font-size: 0.875rem;\n line-height: 1.5;\n color: var(--wa-color-text-normal);\n }\n\n .snippet-preview {\n white-space: pre-wrap;\n word-wrap: breaword;\n overflow-wrap: breaword;\n font-family: monospace;\n font-size: 0.875rem;\n line-height: 1.5;\n color: var(--wa-color-text-normal);\n padding: var(--wa-space-s);\n background-color: var(--wa-color-surface-raised);\n border-radius: var(--wa-border-radius-medium);\n }\n\n .snippet-content mark.search-match {\n background: var(--wa-color-warning-fill-loud);\n color: var(--wa-color-warning-text-loud);\n padding: 0 2px;\n border-radius: 2px;\n font-weight: 600;\n }\n `;\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'lyra-rag-system-manager': LyraRAGSystemManager;\n }\n}\n\n","import { documentIndexService } from './document-index-service';\nimport { registerAll } from '@eclipse-lyra/core';\nimport { workspaceService, File } from '@eclipse-lyra/core';\nimport { toastError, toastInfo } from '@eclipse-lyra/core';\nimport { taskService } from '@eclipse-lyra/core';\nimport { activeSelectionSignal } from '@eclipse-lyra/core';\nimport { createLogger } from '@eclipse-lyra/core';\nimport { contributionRegistry } from '@eclipse-lyra/core';\nimport { editorRegistry, EditorInput } from '@eclipse-lyra/core';\nimport { html } from 'lit';\nimport { TOOLBAR_MAIN_RIGHT } from '@eclipse-lyra/core';\n// Import the component to ensure it's registered\nimport './rag-system-manager';\n\nconst logger = createLogger('RAGSystemExtension');\n\nexport default function ragSystemExtension(context: any) {\n documentIndexService.initialize().catch(err => {\n logger.error(`Failed to initialize document index service: ${err}`);\n });\n\n registerAll({\n command: {\n id: 'rag-system.index-file',\n name: 'Index Document',\n description: 'Index the currently selected file for search and retrieval',\n parameters: [\n {\n name: 'includeContent',\n description: 'Whether to include full content in index (default: true)',\n required: false\n }\n ]\n },\n handler: {\n canExecute: context => {\n const selection = activeSelectionSignal.get();\n return selection instanceof File;\n },\n execute: async context => {\n const selection = activeSelectionSignal.get();\n \n if (!(selection instanceof File)) {\n toastError('Please select a file to index');\n return;\n }\n\n const includeContent = context.params?.includeContent !== false;\n\n await taskService.runAsync('Indexing document', async progress => {\n progress.message = `Indexing ${selection.getName()}...`;\n \n try {\n const document = await documentIndexService.indexDocument(selection, {\n includeContent\n });\n \n progress.progress = 100;\n toastInfo(`Document indexed: ${document.fileName}`);\n } catch (error) {\n toastError(`Failed to index document: ${error}`);\n throw error;\n }\n });\n }\n }\n });\n\n registerAll({\n command: {\n id: 'rag-system.index-workspace',\n name: 'Index Workspace',\n description: 'Index all indexable files in the current workspace',\n parameters: [\n {\n name: 'includeContent',\n description: 'Whether to include full content in index (default: true)',\n required: false\n },\n {\n name: 'maxFileSize',\n description: 'Maximum file size in bytes to index (default: 5MB)',\n required: false\n }\n ]\n },\n handler: {\n canExecute: context => {\n return true;\n },\n execute: async context => {\n const workspace = await workspaceService.getWorkspace();\n \n if (!workspace) {\n toastError('No workspace selected');\n return;\n }\n\n const includeContent = context.params?.includeContent !== false;\n const maxFileSize = context.params?.maxFileSize \n ? parseInt(context.params.maxFileSize) \n : undefined;\n\n await taskService.runAsync('Indexing workspace', async progress => {\n progress.message = 'Collecting files...';\n progress.progress = 0;\n\n try {\n const result = await documentIndexService.indexWorkspace(workspace, {\n includeContent,\n maxFileSize\n });\n\n progress.progress = 100;\n \n if (result.failed > 0) {\n toastError(\n `Indexing complete: ${result.indexed} indexed, ${result.failed} failed. ` +\n `Check console for details.`\n );\n } else {\n toastInfo(`Workspace indexed: ${result.indexed} documents`);\n }\n } catch (error) {\n toastError(`Failed to index workspace: ${error}`);\n throw error;\n }\n });\n }\n }\n });\n\n registerAll({\n command: {\n id: 'rag-system.list-documents',\n name: 'List Indexed Documents',\n description: 'List all indexed documents in the current workspace',\n parameters: []\n },\n handler: {\n canExecute: context => {\n return true;\n },\n execute: async context => {\n const workspace = await workspaceService.getWorkspace();\n const workspacePath = workspace?.getName();\n\n await taskService.runAsync('Loading indexed documents', async progress => {\n try {\n const documents = await documentIndexService.listDocuments(workspacePath);\n \n progress.progress = 100;\n \n if (documents.length === 0) {\n toastInfo('No documents indexed in this workspace');\n } else {\n logger.info(`Found ${documents.length} indexed documents`);\n toastInfo(`Found ${documents.length} indexed documents (check console for details)`);\n }\n } catch (error) {\n toastError(`Failed to list documents: ${error}`);\n throw error;\n }\n });\n }\n }\n });\n\n registerAll({\n command: {\n id: 'rag-system.delete-document',\n name: 'Delete Document from Index',\n description: 'Remove the selected file from the document index',\n parameters: []\n },\n handler: {\n canExecute: context => {\n const selection = activeSelectionSignal.get();\n return selection instanceof File;\n },\n execute: async context => {\n const selection = activeSelectionSignal.get();\n \n if (!(selection instanceof File)) {\n toastError('Please select a file to remove from index');\n return;\n }\n\n const workspace = selection.getWorkspace();\n const workspacePath = workspace.getName();\n const filePath = selection.getWorkspacePath();\n\n await taskService.runAsync('Deleting document from index', async progress => {\n try {\n const deleted = await documentIndexService.deleteDocumentByPath(\n workspacePath,\n filePath\n );\n\n progress.progress = 100;\n\n if (deleted) {\n toastInfo(`Document removed from index: ${selection.getName()}`);\n } else {\n toastInfo(`Document not found in index: ${selection.getName()}`);\n }\n } catch (error) {\n toastError(`Failed to delete document from index: ${error}`);\n throw error;\n }\n });\n }\n }\n });\n\n registerAll({\n command: {\n id: 'rag-system.clear-workspace',\n name: 'Clear Workspace Index',\n description: 'Remove all indexed documents from the current workspace',\n parameters: []\n },\n handler: {\n canExecute: context => {\n return true;\n },\n execute: async context => {\n const workspace = await workspaceService.getWorkspace();\n \n if (!workspace) {\n toastError('No workspace selected');\n return;\n }\n\n const workspacePath = workspace.getName();\n\n await taskService.runAsync('Clearing workspace index', async progress => {\n try {\n const deleted = await documentIndexService.deleteWorkspace(workspacePath);\n\n progress.progress = 100;\n toastInfo(`Removed ${deleted} documents from index`);\n } catch (error) {\n toastError(`Failed to clear workspace index: ${error}`);\n throw error;\n }\n });\n }\n }\n });\n\n registerAll({\n command: {\n id: 'rag-system.get-stats',\n name: 'Document Index Statistics',\n description: 'Get statistics about the document index',\n parameters: []\n },\n handler: {\n canExecute: context => {\n return true;\n },\n execute: async context => {\n await taskService.runAsync('Loading statistics', async progress => {\n try {\n const stats = await documentIndexService.getStats();\n \n progress.progress = 100;\n \n logger.info(`Document index statistics: ${JSON.stringify(stats)}`);\n toastInfo(\n `Index statistics: ${stats.totalDocuments} total documents. ` +\n `Check console for details.`\n );\n } catch (error) {\n toastError(`Failed to get statistics: ${error}`);\n throw error;\n }\n });\n }\n }\n });\n\n registerAll({\n command: {\n id: 'rag-system.reindex-file',\n name: 'Reindex Document',\n description: 'Reindex the selected file (useful after file changes)',\n parameters: []\n },\n handler: {\n canExecute: context => {\n const selection = activeSelectionSignal.get();\n return selection instanceof File;\n },\n execute: async context => {\n const selection = activeSelectionSignal.get();\n \n if (!(selection instanceof File)) {\n toastError('Please select a file to reindex');\n return;\n }\n\n await taskService.runAsync('Reindexing document', async progress => {\n progress.message = `Reindexing ${selection.getName()}...`;\n \n try {\n const document = await documentIndexService.reindexDocument(selection);\n \n progress.progress = 100;\n toastInfo(`Document reindexed: ${document.fileName}`);\n } catch (error) {\n toastError(`Failed to reindex document: ${error}`);\n throw error;\n }\n });\n }\n }\n });\n\n logger.info('RAG system extension loaded');\n\n // Register editor for document index manager\n editorRegistry.registerEditorInputHandler({\n editorId: 'system.rag-system-manager',\n label: 'RAG System Manager',\n ranking: 1000,\n canHandle: (input: EditorInput) => {\n return input.key === '.system.rag-system';\n },\n handle: async (input: EditorInput) => {\n input.widgetFactory = () => html`\n <lyra-rag-system-manager .input=${input}></lyra-rag-system-manager>\n `;\n return input;\n }\n });\n\n // Register command and toolbar button to open document index manager\n registerAll({\n command: {\n id: 'open-rag-system-manager',\n name: 'Open RAG System Manager',\n description: 'Opens the RAG system manager to view and manage indexed documents',\n parameters: []\n },\n handler: {\n execute: _context => {\n const editorInput: Partial<EditorInput> = {\n title: 'RAG System Manager',\n data: {},\n key: '.system.rag-system',\n icon: 'database',\n state: {},\n };\n editorRegistry.loadEditor(editorInput as EditorInput).catch(err => {\n logger.error(`Failed to open document index manager: ${err}`);\n });\n }\n },\n contribution: {\n target: TOOLBAR_MAIN_RIGHT,\n icon: 'database',\n label: 'RAG System',\n }\n });\n\n // Register context menu entry for indexing documents\n contributionRegistry.registerContribution('contextmenu:filebrowser', {\n command: 'rag-system.index-file',\n icon: 'database',\n label: 'Index Document',\n disabled: () => {\n const selection = activeSelectionSignal.get();\n return !(selection instanceof File);\n }\n });\n\n // Integrate RAG with AI system\n import('./rag-integration').then(rag => {\n rag.integrateRAGWithAI();\n logger.info('RAG integration enabled');\n }).catch(err => {\n logger.warn(`Failed to load RAG integration: ${err}`);\n });\n}\n\n"],"names":["logger","context"],"mappings":";;;;;;;;;;;;;;;AAgBA,MAAMA,WAAS,aAAa,kBAAkB;AAC9C,MAAM,mBAAmB,IAAI,iBAAA;AAGtB,IAAM,uBAAN,cAAmC,SAAS;AAAA,EAA5C,cAAA;AAAA,UAAA,GAAA,SAAA;AAKH,SAAQ,YAA+B,CAAA;AAIvC,SAAQ,QAAyE;AAAA,MAC7E,gBAAgB;AAAA,MAChB,aAAa,CAAA;AAAA,IAAC;AAIlB,SAAQ,UAAU;AAGlB,SAAQ,mBAA2C;AAGnD,SAAQ,cAAc;AAGtB,SAAQ,kBAAiC;AAGzC,SAAQ,0BAA0B;AAGlC,SAAQ,oBAAuC,CAAA;AAG/C,SAAQ,oCAAkD,IAAA;AAG1D,SAAQ,aAAa;AAErB,SAAQ,UAAU,UAAA;AAElB,SAAQ,mBAAmB;AAAA,EAAA;AAAA,EAE3B,MAAgB,WAAW;AACvB,QAAI;AACA,YAAM,qBAAqB,WAAA;AAC3B,YAAM,QAAQ,IAAI;AAAA,QACd,KAAK,cAAA;AAAA,QACL,KAAK,UAAA;AAAA,MAAU,CAClB;AAAA,IACL,SAAS,OAAO;AACZA,eAAO,MAAM,gDAAgD,KAAK,EAAE;AACpE,iBAAW,yBAAyB,KAAK,EAAE;AAAA,IAC/C;AAAA,EACJ;AAAA,EAEA,MAAc,gBAAgB;AAC1B,SAAK,UAAU;AACf,SAAK,cAAA;AACL,QAAI;AACA,UAAI;AACJ,UAAI,KAAK,yBAAyB;AAC9B,cAAM,kBAAkB,MAAM,iBAAA;AAC9B,wBAAgB,iBAAiB;AAAA,MACrC;AACA,WAAK,YAAY,MAAM,qBAAqB,cAAc,aAAa;AACvE,YAAM,KAAK,wBAAA;AAAA,IACf,SAAS,OAAO;AACZA,eAAO,MAAM,6BAA6B,KAAK,EAAE;AACjD,iBAAW,6BAA6B,KAAK,EAAE;AAAA,IACnD,UAAA;AACI,WAAK,UAAU;AAAA,IACnB;AAAA,EACJ;AAAA,EAEA,MAAc,0BAA0B;AACpC,SAAK,oBAAoB,MAAM,KAAK,qBAAA;AACpC,SAAK,cAAA;AAAA,EACT;AAAA,EAEA,MAAc,YAAY;AACtB,QAAI;AACA,WAAK,QAAQ,MAAM,qBAAqB,SAAA;AACxC,WAAK,cAAA;AAAA,IACT,SAAS,OAAO;AACZA,eAAO,MAAM,yBAAyB,KAAK,EAAE;AAAA,IACjD;AAAA,EACJ;AAAA,EAEQ,oBAAoB,GAAgB;AAExC,QAAI,YAAY,EAAE,QAAQ,aAAa,CAAA;AAGvC,QAAI,UAAU,WAAW,KAAK,KAAK,QAAQ,OAAO;AAE9C,kBAAY,KAAK,QAAQ,MAAM,iBAAiB,CAAA;AAAA,IACpD;AAEA,QAAI,UAAU,SAAS,GAAG;AACtB,YAAM,eAAe,UAAU,CAAC;AAChC,UAAI,cAAc,OAAO;AACrB,aAAK,mBAAmB,aAAa;AAAA,MACzC,OAAO;AACH,aAAK,mBAAmB;AAAA,MAC5B;AAAA,IACJ,OAAO;AACH,WAAK,mBAAmB;AAAA,IAC5B;AAAA,EACJ;AAAA,EAEA,MAAc,uBAAmD;AAC7D,QAAI,CAAC,KAAK,aAAa,KAAK,UAAU,WAAW,GAAG;AAChD,aAAO,CAAA;AAAA,IACX;AAEA,QAAI,KAAK,YAAY,QAAQ;AACzB,UAAI;AACA,cAAM,gBAAgB,MAAM,yBAAyB,KAAK,aAAa;AAAA,UACnE,OAAO;AAAA,UACP,eAAe,KAAK,mBAAmB;AAAA,QAAA,CAC1C;AAED,aAAK,cAAc,MAAA;AACnB,cAAM,iCAAiB,IAAA;AACvB,cAAM,wCAAwB,IAAA;AAE9B,mBAAW,UAAU,eAAe;AAChC,gBAAM,QAAQ,OAAO,SAAS;AAC9B,qBAAW,IAAI,OAAO,OAAO,QAAQ;AAErC,gBAAM,WAAW,kBAAkB,IAAI,KAAK;AAC5C,cAAI,CAAC,UAAU;AACX,8BAAkB,IAAI,OAAO;AAAA,cACzB,UAAU,OAAO;AAAA,cACjB,WAAW,OAAO;AAAA,cAClB,iBAAiB,CAAC,GAAG,OAAO,eAAe;AAAA,YAAA,CAC9C;AAAA,UACL,OAAO;AACH,gBAAI,OAAO,YAAY,SAAS,WAAW;AACvC,uBAAS,YAAY,OAAO;AAAA,YAChC;AACA,kBAAM,eAAe,IAAI,IAAI,SAAS,eAAe;AACrD,uBAAW,WAAW,OAAO,iBAAiB;AAC1C,kBAAI,CAAC,aAAa,IAAI,OAAO,GAAG;AAC5B,yBAAS,gBAAgB,KAAK,OAAO;AACrC,6BAAa,IAAI,OAAO;AAAA,cAC5B;AAAA,YACJ;AAAA,UACJ;AAAA,QACJ;AAEA,mBAAW,CAAC,OAAO,MAAM,KAAK,mBAAmB;AAC7C,eAAK,cAAc,IAAI,OAAO,MAAM;AAAA,QACxC;AAEA,cAAM,aAAa,MAAM,KAAK,WAAW,QAAQ;AAEjD,YAAI,KAAK,iBAAiB;AACtB,iBAAO,WAAW,OAAO,CAAA,QAAO,IAAI,kBAAkB,KAAK,eAAe;AAAA,QAC9E;AAEA,eAAO;AAAA,MACX,SAAS,OAAO;AACZA,iBAAO,MAAM,0CAA0C,KAAK,EAAE;AAC9D,aAAK,cAAc,MAAA;AACnB,eAAO,CAAA;AAAA,MACX;AAAA,IACJ,OAAO;AACH,WAAK,cAAc,MAAA;AAAA,IACvB;AAEA,QAAI,WAAW,CAAC,GAAG,KAAK,SAAS;AAEjC,QAAI,KAAK,iBAAiB;AACtB,iBAAW,SAAS,OAAO,CAAA,QAAO,IAAI,kBAAkB,KAAK,eAAe;AAAA,IAChF;AAEA,WAAO;AAAA,EACX;AAAA,EAEQ,iBAAiB,MAAc,OAA+B;AAClE,QAAI,CAAC,SAAS,CAAC,MAAM,QAAQ;AACzB,aAAO,OAAO,IAAI;AAAA,IACtB;AAEA,UAAM,aAAa,MAAM,YAAA;AACzB,UAAM,YAAY,KAAK,YAAA;AACvB,UAAM,QAAwC,CAAA;AAC9C,QAAI,YAAY;AAChB,QAAI,QAAQ,UAAU,QAAQ,YAAY,SAAS;AAEnD,WAAO,UAAU,IAAI;AACjB,UAAI,QAAQ,WAAW;AACnB,cAAM,KAAK,KAAK,UAAU,WAAW,KAAK,CAAC;AAAA,MAC/C;AACA,YAAM,KAAK,kCAAkC,KAAK,UAAU,OAAO,QAAQ,MAAM,MAAM,CAAC,SAAS;AACjG,kBAAY,QAAQ,MAAM;AAC1B,cAAQ,UAAU,QAAQ,YAAY,SAAS;AAAA,IACnD;AAEA,QAAI,YAAY,KAAK,QAAQ;AACzB,YAAM,KAAK,KAAK,UAAU,SAAS,CAAC;AAAA,IACxC;AAEA,WAAO,OAAO,KAAK;AAAA,EACvB;AAAA,EAEQ,kBAAkB,KAAsC;AAC5D,UAAM,eAAe,KAAK,cAAc,IAAI,IAAI,EAAE;AAElD,QAAI,gBAAgB,aAAa,gBAAgB,SAAS,GAAG;AACzD,aAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,0BASO,aAAa,gBAAgB,IAAI,CAAC,SAAS,QAAQ;AAAA;AAAA,6DAEhB,MAAM,CAAC;AAAA,8DACN,KAAK,iBAAiB,SAAS,KAAK,WAAW,CAAC;AAAA;AAAA,yBAErF,CAAC;AAAA;AAAA;AAAA;AAAA,IAIlB;AAEA,QAAI,KAAK,eAAe,KAAK,YAAY,QAAQ;AAC7C,YAAM,WAAW,iBAAiB;AAAA,QAC9B,IAAI;AAAA,QACJ,KAAK;AAAA,QACL,gBAAgB;AAAA,MAAA;AAGpB,UAAI,SAAS,SAAS,GAAG;AACrB,eAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,8BASO,SAAS,IAAI,CAAC,SAAS,QAAQ;AAAA;AAAA,iEAEI,MAAM,CAAC;AAAA,kEACN,KAAK,iBAAiB,IAAI,QAAQ,UAAU,QAAQ,OAAO,QAAQ,GAAG,GAAG,KAAK,WAAW,CAAC;AAAA;AAAA,6BAE/H,CAAC;AAAA;AAAA;AAAA;AAAA,MAIlB;AAAA,IACJ;AAEA,UAAM,UAAU,iBAAiB,qBAAqB,IAAI,SAAS,wBAAwB,IAAI;AAC/F,WAAO;AAAA,2CAC4B,OAAO;AAAA;AAAA,EAE9C;AAAA,EAEA,MAAc,eAAe,KAAsB;AAC/C,QAAI;AACA,YAAM,qBAAqB,eAAe,IAAI,EAAE;AAChD,gBAAU,YAAY,IAAI,QAAQ,EAAE;AACpC,YAAM,KAAK,cAAA;AACX,YAAM,KAAK,UAAA;AACX,UAAI,KAAK,kBAAkB,OAAO,IAAI,IAAI;AACtC,aAAK,mBAAmB;AAAA,MAC5B;AAAA,IACJ,SAAS,OAAO;AACZ,iBAAW,8BAA8B,KAAK,EAAE;AAAA,IACpD;AAAA,EACJ;AAAA,EAEA,MAAc,gBAAgB,KAAsB;AAChD,QAAI;AACA,YAAM,kBAAkB,MAAM,iBAAA;AAC9B,UAAI,CAAC,iBAAiB;AAClB,mBAAW,wBAAwB;AACnC;AAAA,MACJ;AAEA,YAAM,WAAW,MAAM,gBAAgB,UAAU,YAAY,IAAI,QAAQ;AACzE,UAAI,CAAC,UAAU;AACX,mBAAW,mBAAmB,IAAI,QAAQ,EAAE;AAC5C;AAAA,MACJ;AAEA,UAAI,EAAE,oBAAoB,OAAO;AAC7B,mBAAW,2BAA2B,IAAI,QAAQ,EAAE;AACpD;AAAA,MACJ;AAEA,YAAM,OAAa;AAEnB,YAAM,YAAY,SAAS,uBAAuB,OAAM,aAAY;AAChE,iBAAS,UAAU,cAAc,IAAI,QAAQ;AAC7C,cAAM,qBAAqB,gBAAgB,IAAI;AAC/C,iBAAS,WAAW;AAAA,MACxB,CAAC;AAED,gBAAU,cAAc,IAAI,QAAQ,EAAE;AACtC,YAAM,KAAK,cAAA;AACX,UAAI,KAAK,kBAAkB,OAAO,IAAI,IAAI;AACtC,aAAK,mBAAmB,MAAM,qBAAqB,YAAY,IAAI,EAAE;AAAA,MACzE;AAAA,IACJ,SAAS,OAAO;AACZ,iBAAW,+BAA+B,KAAK,EAAE;AAAA,IACrD;AAAA,EACJ;AAAA,EAEA,MAAc,sBAAsB;AAChC,QAAI,KAAK,YAAY;AACjB;AAAA,IACJ;AAEA,UAAM,QAAQ,MAAM,qBAAqB,SAAA;AACzC,QAAI,MAAM,mBAAmB,GAAG;AAC5B,gBAAU,yBAAyB;AACnC;AAAA,IACJ;AAEA,SAAK,aAAa;AAClB,SAAK,cAAA;AAEL,QAAI;AACA,YAAM,SAAS,MAAM,YAAY,SAAS,4BAA4B,OAAM,aAAY;AACpF,iBAAS,UAAU;AAEnB,cAAM,QAAQ,MAAM;AAEpB,cAAM,gBAAgB,MAAM,qBAAqB,oBAAA;AAEjD,cAAM,YAAY,cAAc,YAAY,cAAc;AAC1D,iBAAS,WAAW,QAAQ,IAAK,YAAY,QAAS,MAAM;AAC5D,iBAAS,UAAU,aAAa,cAAc,SAAS,IAAI,KAAK,aAAa,cAAc,SAAS,IAAI,KAAK,cAAc,MAAM,aAAa,EAAE;AAEhJ,eAAO;AAAA,MACX,CAAC;AAED,YAAM,KAAK,cAAA;AACX,YAAM,KAAK,UAAA;AACX,gBAAU,yBAAyB,OAAO,SAAS,eAAe,OAAO,MAAM,SAAS;AAAA,IAC5F,SAAS,OAAO;AACZA,eAAO,MAAM,oCAAoC,KAAK,EAAE;AACxD,iBAAW,oCAAoC,KAAK,EAAE;AAAA,IAC1D,UAAA;AACI,WAAK,aAAa;AAClB,WAAK,cAAA;AAAA,IACT;AAAA,EACJ;AAAA,EAEQ,eAAe,OAAuB;AAC1C,QAAI,QAAQ,KAAM,QAAO,GAAG,KAAK;AACjC,QAAI,QAAQ,OAAO,KAAM,QAAO,IAAI,QAAQ,MAAM,QAAQ,CAAC,CAAC;AAC5D,WAAO,IAAI,SAAS,OAAO,OAAO,QAAQ,CAAC,CAAC;AAAA,EAChD;AAAA,EAEQ,WAAW,WAA2B;AAC1C,WAAO,IAAI,KAAK,SAAS,EAAE,eAAA;AAAA,EAC/B;AAAA,EAEQ,YAAY,UAA0B;AAC1C,WAAO,eAAe,YAAY,QAAQ;AAAA,EAC9C;AAAA,EAEU,gBAAgC;AACtC,UAAM,aAAa,OAAO,KAAK,KAAK,OAAO,eAAe,EAAE;AAE5D,WAAO;AAAA;AAAA;AAAA;AAAA,yBAIU,KAAK,gBAAgB;AAAA,yBACrB,CAAC,MAAW;AACjB,WAAK,mBAAmB,EAAE,OAAO;AAEjC,UAAI,KAAK,qBAAqB;AAC1B,qBAAa,KAAK,mBAAmB;AAAA,MACzC;AAEA,WAAK,sBAAsB,OAAO,WAAW,YAAY;AACrD,aAAK,cAAc,KAAK;AACxB,cAAM,KAAK,wBAAA;AAAA,MACf,GAAG,GAAG;AAAA,IACV,CAAC;AAAA,4BACW,YAAY;AACpB,UAAI,KAAK,qBAAqB;AAC1B,qBAAa,KAAK,mBAAmB;AAAA,MACzC;AACA,WAAK,mBAAmB;AACxB,WAAK,cAAc;AACnB,YAAM,KAAK,wBAAA;AAAA,IACf,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,2BASU,KAAK,uBAAuB;AAAA,0BAC7B,OAAO,MAAW;AACxB,WAAK,0BAA0B,EAAE,OAAO;AACxC,YAAM,KAAK,cAAA;AAAA,IACf,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,cAKH,WAAW,SAAS,IAAI;AAAA;AAAA,6BAET,KAAK,mBAAmB,EAAE;AAAA,8BACzB,OAAO,MAAW;AAC5B,WAAK,kBAAkB,EAAE,OAAO,SAAS;AACzC,YAAM,KAAK,wBAAA;AAAA,IACf,CAAC;AAAA;AAAA;AAAA;AAAA,sBAIK,WAAW,IAAI,CAAA,OAAM;AAAA,4CACC,EAAE,KAAK,EAAE,KAAK,KAAK,MAAM,YAAY,EAAE,CAAC;AAAA,qBAC/D,CAAC;AAAA;AAAA,gBAEN,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,0BAMG,MAAM,KAAK,cAAA,CAAe;AAAA,4BACxB,KAAK,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,0BAQjB,MAAM,KAAK,oBAAA,CAAqB;AAAA,4BAC9B,KAAK,cAAc,KAAK,OAAO;AAAA,kBACzC,KAAK,aAAa,kBAAkB,cAAc;AAAA;AAAA;AAAA,EAGhE;AAAA,EAEU,SAAyB;AAC/B,QAAI,CAAC,KAAK,OAAO;AACb,WAAK,QAAQ,EAAE,gBAAgB,GAAG,aAAa,CAAA,EAAC;AAAA,IACpD;AAEA,UAAM,eAAe,KAAK;AAC1B,UAAM,aAAa,OAAO,KAAK,KAAK,MAAM,eAAe,EAAE;AAE3D,WAAO;AAAA;AAAA;AAAA;AAAA;AAAA,2CAK4B,KAAK,MAAM,cAAc;AAAA,8BACtC,WAAW,SAAS,IAAI;AAAA,oDACF,WAAW,MAAM;AAAA,gCACrC,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,0BAOb,KAAK,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA,4BAKb,aAAa,WAAW,IAAI;AAAA;AAAA;AAAA,qCAGnB,KAAK,eAAe,KAAK,kBAAkB,oCAAoC,0BAA0B;AAAA;AAAA,4BAElH;AAAA;AAAA,kCAEM,IAAI,KAAK,OAAO,CAAC;AAAA;AAAA;AAAA,uDAGI,CAAC,MAAmB;AACvD,WAAK,oBAAoB,CAAC;AAAA,IAC9B,CAAC;AAAA,kCACiB,aAAa,IAAI,CAAA,QAAO;AAAA;AAAA,iDAET,GAAG;AAAA,oDACA,KAAK,kBAAkB,OAAO,IAAI,EAAE;AAAA,yDAC/B,KAAK,YAAY,IAAI,QAAQ,CAAC;AAAA;AAAA,iFAEN,IAAI,QAAQ;AAAA;AAAA,+EAEd,KAAK,eAAe,IAAI,SAAS,IAAI,CAAC;AAAA,+EACtC,KAAK,WAAW,IAAI,SAAS,CAAC;AAAA;AAAA;AAAA,oFAGzB,CAAC,MAAa,EAAE,iBAAiB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,6DAMxD,MAAM,KAAK,gBAAgB,GAAG,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,6DAQ/B,MAAM,KAAK,eAAe,GAAG,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,iCAK1D,CAAC;AAAA;AAAA,yBAET;AAAA;AAAA;AAAA;AAAA,0BAIC,KAAK,mBAAmB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,qDAMG,KAAK,iBAAiB,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA,yDAK1B,KAAK,iBAAiB,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,qDAQlC,KAAK,iBAAiB,aAAa;AAAA;AAAA;AAAA;AAAA;AAAA,yDAK/B,KAAK,iBAAiB,aAAa;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,qDAQvC,KAAK,iBAAiB,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA,yDAK1B,KAAK,iBAAiB,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,qDAQlC,KAAK,eAAe,KAAK,iBAAiB,SAAS,IAAI,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,yDAKpD,KAAK,eAAe,KAAK,iBAAiB,SAAS,IAAI,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,qDAQ5D,KAAK,WAAW,KAAK,iBAAiB,SAAS,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,yDAK5C,KAAK,WAAW,KAAK,iBAAiB,SAAS,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,qDAQpD,KAAK,WAAW,KAAK,iBAAiB,SAAS,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,yDAK5C,KAAK,WAAW,KAAK,iBAAiB,SAAS,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,sCAOnE,KAAK,iBAAiB,SAAS,QAAQ,KAAK,iBAAiB,SAAS,KAAK,SAAS,IAAI;AAAA;AAAA;AAAA;AAAA,yDAIrE,KAAK,iBAAiB,SAAS,KAAK,KAAK,IAAI,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,6DAK1C,KAAK,iBAAiB,SAAS,KAAK,KAAK,IAAI,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,wCAMnE,OAAO;AAAA;AAAA;AAAA,gEAGiB,KAAK,cAAc,wDAAwD,KAAK,WAAW,cAAc,OAAO;AAAA;AAAA;AAAA,kDAG9H,KAAK,kBAAkB,KAAK,gBAAgB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,wBAMvE;AAAA;AAAA;AAAA;AAAA;AAAA,yBAKC;AAAA;AAAA;AAAA;AAAA;AAAA,EAKrB;AAgMJ;AA30Ba,qBA6oBF,SAAS;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AA3oBT,gBAAA;AAAA,EADN,SAAS,EAAE,WAAW,MAAA,CAAO;AAAA,GADrB,qBAEF,WAAA,SAAA,CAAA;AAGC,gBAAA;AAAA,EADP,MAAA;AAAM,GAJE,qBAKD,WAAA,aAAA,CAAA;AAIA,gBAAA;AAAA,EADP,MAAA;AAAM,GARE,qBASD,WAAA,SAAA,CAAA;AAMA,gBAAA;AAAA,EADP,MAAA;AAAM,GAdE,qBAeD,WAAA,WAAA,CAAA;AAGA,gBAAA;AAAA,EADP,MAAA;AAAM,GAjBE,qBAkBD,WAAA,oBAAA,CAAA;AAGA,gBAAA;AAAA,EADP,MAAA;AAAM,GApBE,qBAqBD,WAAA,eAAA,CAAA;AAGA,gBAAA;AAAA,EADP,MAAA;AAAM,GAvBE,qBAwBD,WAAA,mBAAA,CAAA;AAGA,gBAAA;AAAA,EADP,MAAA;AAAM,GA1BE,qBA2BD,WAAA,2BAAA,CAAA;AAGA,gBAAA;AAAA,EADP,MAAA;AAAM,GA7BE,qBA8BD,WAAA,qBAAA,CAAA;AAGA,gBAAA;AAAA,EADP,MAAA;AAAM,GAhCE,qBAiCD,WAAA,iBAAA,CAAA;AAGA,gBAAA;AAAA,EADP,MAAA;AAAM,GAnCE,qBAoCD,WAAA,cAAA,CAAA;AApCC,uBAAN,gBAAA;AAAA,EADN,cAAc,yBAAyB;AAAA,GAC3B,oBAAA;ACNb,MAAM,SAAS,aAAa,oBAAoB;AAEhD,SAAwB,mBAAmB,SAAc;AACrD,uBAAqB,WAAA,EAAa,MAAM,CAAA,QAAO;AAC3C,WAAO,MAAM,gDAAgD,GAAG,EAAE;AAAA,EACtE,CAAC;AAED,cAAY;AAAA,IACR,SAAS;AAAA,MACL,IAAI;AAAA,MACJ,MAAM;AAAA,MACN,aAAa;AAAA,MACb,YAAY;AAAA,QACR;AAAA,UACI,MAAM;AAAA,UACN,aAAa;AAAA,UACb,UAAU;AAAA,QAAA;AAAA,MACd;AAAA,IACJ;AAAA,IAEJ,SAAS;AAAA,MACL,YAAY,CAAAC,aAAW;AACnB,cAAM,YAAY,sBAAsB,IAAA;AACxC,eAAO,qBAAqB;AAAA,MAChC;AAAA,MACA,SAAS,OAAMA,aAAW;AACtB,cAAM,YAAY,sBAAsB,IAAA;AAExC,YAAI,EAAE,qBAAqB,OAAO;AAC9B,qBAAW,+BAA+B;AAC1C;AAAA,QACJ;AAEA,cAAM,iBAAiBA,SAAQ,QAAQ,mBAAmB;AAE1D,cAAM,YAAY,SAAS,qBAAqB,OAAM,aAAY;AAC9D,mBAAS,UAAU,YAAY,UAAU,QAAA,CAAS;AAElD,cAAI;AACA,kBAAM,WAAW,MAAM,qBAAqB,cAAc,WAAW;AAAA,cACjE;AAAA,YAAA,CACH;AAED,qBAAS,WAAW;AACpB,sBAAU,qBAAqB,SAAS,QAAQ,EAAE;AAAA,UACtD,SAAS,OAAO;AACZ,uBAAW,6BAA6B,KAAK,EAAE;AAC/C,kBAAM;AAAA,UACV;AAAA,QACJ,CAAC;AAAA,MACL;AAAA,IAAA;AAAA,EACJ,CACH;AAED,cAAY;AAAA,IACR,SAAS;AAAA,MACL,IAAI;AAAA,MACJ,MAAM;AAAA,MACN,aAAa;AAAA,MACb,YAAY;AAAA,QACR;AAAA,UACI,MAAM;AAAA,UACN,aAAa;AAAA,UACb,UAAU;AAAA,QAAA;AAAA,QAEd;AAAA,UACI,MAAM;AAAA,UACN,aAAa;AAAA,UACb,UAAU;AAAA,QAAA;AAAA,MACd;AAAA,IACJ;AAAA,IAEJ,SAAS;AAAA,MACL,YAAY,CAAAA,aAAW;AACnB,eAAO;AAAA,MACX;AAAA,MACA,SAAS,OAAMA,aAAW;AACtB,cAAM,YAAY,MAAM,iBAAiB,aAAA;AAEzC,YAAI,CAAC,WAAW;AACZ,qBAAW,uBAAuB;AAClC;AAAA,QACJ;AAEA,cAAM,iBAAiBA,SAAQ,QAAQ,mBAAmB;AAC1D,cAAM,cAAcA,SAAQ,QAAQ,cAC9B,SAASA,SAAQ,OAAO,WAAW,IACnC;AAEN,cAAM,YAAY,SAAS,sBAAsB,OAAM,aAAY;AAC/D,mBAAS,UAAU;AACnB,mBAAS,WAAW;AAEpB,cAAI;AACA,kBAAM,SAAS,MAAM,qBAAqB,eAAe,WAAW;AAAA,cAChE;AAAA,cACA;AAAA,YAAA,CACH;AAED,qBAAS,WAAW;AAEpB,gBAAI,OAAO,SAAS,GAAG;AACnB;AAAA,gBACI,sBAAsB,OAAO,OAAO,aAAa,OAAO,MAAM;AAAA,cAAA;AAAA,YAGtE,OAAO;AACH,wBAAU,sBAAsB,OAAO,OAAO,YAAY;AAAA,YAC9D;AAAA,UACJ,SAAS,OAAO;AACZ,uBAAW,8BAA8B,KAAK,EAAE;AAChD,kBAAM;AAAA,UACV;AAAA,QACJ,CAAC;AAAA,MACL;AAAA,IAAA;AAAA,EACJ,CACH;AAED,cAAY;AAAA,IACR,SAAS;AAAA,MACL,IAAI;AAAA,MACJ,MAAM;AAAA,MACN,aAAa;AAAA,MACb,YAAY,CAAA;AAAA,IAAC;AAAA,IAEjB,SAAS;AAAA,MACL,YAAY,CAAAA,aAAW;AACnB,eAAO;AAAA,MACX;AAAA,MACA,SAAS,OAAMA,aAAW;AACtB,cAAM,YAAY,MAAM,iBAAiB,aAAA;AACzC,cAAM,gBAAgB,WAAW,QAAA;AAEjC,cAAM,YAAY,SAAS,6BAA6B,OAAM,aAAY;AACtE,cAAI;AACA,kBAAM,YAAY,MAAM,qBAAqB,cAAc,aAAa;AAExE,qBAAS,WAAW;AAEpB,gBAAI,UAAU,WAAW,GAAG;AACxB,wBAAU,wCAAwC;AAAA,YACtD,OAAO;AACH,qBAAO,KAAK,SAAS,UAAU,MAAM,oBAAoB;AACzD,wBAAU,SAAS,UAAU,MAAM,gDAAgD;AAAA,YACvF;AAAA,UACJ,SAAS,OAAO;AACZ,uBAAW,6BAA6B,KAAK,EAAE;AAC/C,kBAAM;AAAA,UACV;AAAA,QACJ,CAAC;AAAA,MACL;AAAA,IAAA;AAAA,EACJ,CACH;AAED,cAAY;AAAA,IACR,SAAS;AAAA,MACL,IAAI;AAAA,MACJ,MAAM;AAAA,MACN,aAAa;AAAA,MACb,YAAY,CAAA;AAAA,IAAC;AAAA,IAEjB,SAAS;AAAA,MACL,YAAY,CAAAA,aAAW;AACnB,cAAM,YAAY,sBAAsB,IAAA;AACxC,eAAO,qBAAqB;AAAA,MAChC;AAAA,MACA,SAAS,OAAMA,aAAW;AACtB,cAAM,YAAY,sBAAsB,IAAA;AAExC,YAAI,EAAE,qBAAqB,OAAO;AAC9B,qBAAW,2CAA2C;AACtD;AAAA,QACJ;AAEA,cAAM,YAAY,UAAU,aAAA;AAC5B,cAAM,gBAAgB,UAAU,QAAA;AAChC,cAAM,WAAW,UAAU,iBAAA;AAE3B,cAAM,YAAY,SAAS,gCAAgC,OAAM,aAAY;AACzE,cAAI;AACA,kBAAM,UAAU,MAAM,qBAAqB;AAAA,cACvC;AAAA,cACA;AAAA,YAAA;AAGJ,qBAAS,WAAW;AAEpB,gBAAI,SAAS;AACT,wBAAU,gCAAgC,UAAU,QAAA,CAAS,EAAE;AAAA,YACnE,OAAO;AACH,wBAAU,gCAAgC,UAAU,QAAA,CAAS,EAAE;AAAA,YACnE;AAAA,UACJ,SAAS,OAAO;AACZ,uBAAW,yCAAyC,KAAK,EAAE;AAC3D,kBAAM;AAAA,UACV;AAAA,QACJ,CAAC;AAAA,MACL;AAAA,IAAA;AAAA,EACJ,CACH;AAED,cAAY;AAAA,IACR,SAAS;AAAA,MACL,IAAI;AAAA,MACJ,MAAM;AAAA,MACN,aAAa;AAAA,MACb,YAAY,CAAA;AAAA,IAAC;AAAA,IAEjB,SAAS;AAAA,MACL,YAAY,CAAAA,aAAW;AACnB,eAAO;AAAA,MACX;AAAA,MACA,SAAS,OAAMA,aAAW;AACtB,cAAM,YAAY,MAAM,iBAAiB,aAAA;AAEzC,YAAI,CAAC,WAAW;AACZ,qBAAW,uBAAuB;AAClC;AAAA,QACJ;AAEA,cAAM,gBAAgB,UAAU,QAAA;AAEhC,cAAM,YAAY,SAAS,4BAA4B,OAAM,aAAY;AACrE,cAAI;AACA,kBAAM,UAAU,MAAM,qBAAqB,gBAAgB,aAAa;AAExE,qBAAS,WAAW;AACpB,sBAAU,WAAW,OAAO,uBAAuB;AAAA,UACvD,SAAS,OAAO;AACZ,uBAAW,oCAAoC,KAAK,EAAE;AACtD,kBAAM;AAAA,UACV;AAAA,QACJ,CAAC;AAAA,MACL;AAAA,IAAA;AAAA,EACJ,CACH;AAED,cAAY;AAAA,IACR,SAAS;AAAA,MACL,IAAI;AAAA,MACJ,MAAM;AAAA,MACN,aAAa;AAAA,MACb,YAAY,CAAA;AAAA,IAAC;AAAA,IAEjB,SAAS;AAAA,MACL,YAAY,CAAAA,aAAW;AACnB,eAAO;AAAA,MACX;AAAA,MACA,SAAS,OAAMA,aAAW;AACtB,cAAM,YAAY,SAAS,sBAAsB,OAAM,aAAY;AAC/D,cAAI;AACA,kBAAM,QAAQ,MAAM,qBAAqB,SAAA;AAEzC,qBAAS,WAAW;AAEpB,mBAAO,KAAK,8BAA8B,KAAK,UAAU,KAAK,CAAC,EAAE;AACjE;AAAA,cACI,qBAAqB,MAAM,cAAc;AAAA,YAAA;AAAA,UAGjD,SAAS,OAAO;AACZ,uBAAW,6BAA6B,KAAK,EAAE;AAC/C,kBAAM;AAAA,UACV;AAAA,QACJ,CAAC;AAAA,MACL;AAAA,IAAA;AAAA,EACJ,CACH;AAED,cAAY;AAAA,IACR,SAAS;AAAA,MACL,IAAI;AAAA,MACJ,MAAM;AAAA,MACN,aAAa;AAAA,MACb,YAAY,CAAA;AAAA,IAAC;AAAA,IAEjB,SAAS;AAAA,MACL,YAAY,CAAAA,aAAW;AACnB,cAAM,YAAY,sBAAsB,IAAA;AACxC,eAAO,qBAAqB;AAAA,MAChC;AAAA,MACA,SAAS,OAAMA,aAAW;AACtB,cAAM,YAAY,sBAAsB,IAAA;AAExC,YAAI,EAAE,qBAAqB,OAAO;AAC9B,qBAAW,iCAAiC;AAC5C;AAAA,QACJ;AAEA,cAAM,YAAY,SAAS,uBAAuB,OAAM,aAAY;AAChE,mBAAS,UAAU,cAAc,UAAU,QAAA,CAAS;AAEpD,cAAI;AACA,kBAAM,WAAW,MAAM,qBAAqB,gBAAgB,SAAS;AAErE,qBAAS,WAAW;AACpB,sBAAU,uBAAuB,SAAS,QAAQ,EAAE;AAAA,UACxD,SAAS,OAAO;AACZ,uBAAW,+BAA+B,KAAK,EAAE;AACjD,kBAAM;AAAA,UACV;AAAA,QACJ,CAAC;AAAA,MACL;AAAA,IAAA;AAAA,EACJ,CACH;AAED,SAAO,KAAK,6BAA6B;AAGzC,iBAAe,2BAA2B;AAAA,IACtC,UAAU;AAAA,IACV,OAAO;AAAA,IACP,SAAS;AAAA,IACT,WAAW,CAAC,UAAuB;AACvB,aAAO,MAAM,QAAQ;AAAA,IACjC;AAAA,IACA,QAAQ,OAAO,UAAuB;AAClC,YAAM,gBAAgB,MAAM;AAAA,kDACU,KAAK;AAAA;AAE3C,aAAO;AAAA,IACX;AAAA,EAAA,CACH;AAGD,cAAY;AAAA,IACR,SAAS;AAAA,MACL,IAAI;AAAA,MACJ,MAAM;AAAA,MACN,aAAa;AAAA,MACb,YAAY,CAAA;AAAA,IAAC;AAAA,IAEjB,SAAS;AAAA,MACL,SAAS,CAAA,aAAY;AACjB,cAAM,cAAoC;AAAA,UACtC,OAAO;AAAA,UACP,MAAM,CAAA;AAAA,UACN,KAAK;AAAA,UACL,MAAM;AAAA,UACN,OAAO,CAAA;AAAA,QAAC;AAEZ,uBAAe,WAAW,WAA0B,EAAE,MAAM,CAAA,QAAO;AAC/D,iBAAO,MAAM,0CAA0C,GAAG,EAAE;AAAA,QAChE,CAAC;AAAA,MACL;AAAA,IAAA;AAAA,IAEJ,cAAc;AAAA,MACV,QAAQ;AAAA,MACR,MAAM;AAAA,MACN,OAAO;AAAA,IAAA;AAAA,EACX,CACH;AAGD,uBAAqB,qBAAqB,2BAA2B;AAAA,IACjE,SAAS;AAAA,IACT,MAAM;AAAA,IACN,OAAO;AAAA,IACP,UAAU,MAAM;AACZ,YAAM,YAAY,sBAAsB,IAAA;AACxC,aAAO,EAAE,qBAAqB;AAAA,IAClC;AAAA,EAAA,CACH;AAGD,SAAO,+BAAmB,EAAE,KAAK,CAAA,QAAO;AACpC,QAAI,mBAAA;AACJ,WAAO,KAAK,yBAAyB;AAAA,EACzC,CAAC,EAAE,MAAM,CAAA,QAAO;AACZ,WAAO,KAAK,mCAAmC,GAAG,EAAE;AAAA,EACxD,CAAC;AACL;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rag-system-extension.d.ts","sourceRoot":"","sources":["../src/rag-system-extension.ts"],"names":[],"mappings":"AAYA,OAAO,sBAAsB,CAAC;AAI9B,MAAM,CAAC,OAAO,UAAU,kBAAkB,CAAC,OAAO,EAAE,GAAG,QAiXtD"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { TemplateResult } from 'lit';
|
|
2
|
+
import { LyraPart, EditorInput } from '@eclipse-lyra/core';
|
|
3
|
+
export declare class LyraRAGSystemManager extends LyraPart {
|
|
4
|
+
input?: EditorInput;
|
|
5
|
+
private documents;
|
|
6
|
+
private stats;
|
|
7
|
+
private loading;
|
|
8
|
+
private selectedDocument;
|
|
9
|
+
private searchQuery;
|
|
10
|
+
private filterWorkspace;
|
|
11
|
+
private filterByActiveWorkspace;
|
|
12
|
+
private filteredDocuments;
|
|
13
|
+
private searchResults;
|
|
14
|
+
private reindexing;
|
|
15
|
+
private treeRef;
|
|
16
|
+
private searchDebounceTimer?;
|
|
17
|
+
private searchInputValue;
|
|
18
|
+
protected doInitUI(): Promise<void>;
|
|
19
|
+
private loadDocuments;
|
|
20
|
+
private updateFilteredDocuments;
|
|
21
|
+
private loadStats;
|
|
22
|
+
private handleTreeSelection;
|
|
23
|
+
private getFilteredDocuments;
|
|
24
|
+
private highlightMatches;
|
|
25
|
+
private getContentPreview;
|
|
26
|
+
private deleteDocument;
|
|
27
|
+
private reindexDocument;
|
|
28
|
+
private reindexAllDocuments;
|
|
29
|
+
private formatFileSize;
|
|
30
|
+
private formatDate;
|
|
31
|
+
private getFileIcon;
|
|
32
|
+
protected renderToolbar(): TemplateResult;
|
|
33
|
+
protected render(): TemplateResult;
|
|
34
|
+
static styles: import('lit').CSSResult;
|
|
35
|
+
}
|
|
36
|
+
declare global {
|
|
37
|
+
interface HTMLElementTagNameMap {
|
|
38
|
+
'lyra-rag-system-manager': LyraRAGSystemManager;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=rag-system-manager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rag-system-manager.d.ts","sourceRoot":"","sources":["../src/rag-system-manager.ts"],"names":[],"mappings":"AACA,OAAO,EAAa,cAAc,EAAW,MAAM,KAAK,CAAC;AAEzD,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAejD,qBACa,oBAAqB,SAAQ,QAAQ;IAEvC,KAAK,CAAC,EAAE,WAAW,CAAC;IAG3B,OAAO,CAAC,SAAS,CAAyB;IAI1C,OAAO,CAAC,KAAK,CAGX;IAGF,OAAO,CAAC,OAAO,CAAS;IAGxB,OAAO,CAAC,gBAAgB,CAAgC;IAGxD,OAAO,CAAC,WAAW,CAAM;IAGzB,OAAO,CAAC,eAAe,CAAuB;IAG9C,OAAO,CAAC,uBAAuB,CAAQ;IAGvC,OAAO,CAAC,iBAAiB,CAAyB;IAGlD,OAAO,CAAC,aAAa,CAA2C;IAGhE,OAAO,CAAC,UAAU,CAAS;IAE3B,OAAO,CAAC,OAAO,CAA4B;IAC3C,OAAO,CAAC,mBAAmB,CAAC,CAAS;IACrC,OAAO,CAAC,gBAAgB,CAAM;cAEd,QAAQ;YAaV,aAAa;YAmBb,uBAAuB;YAKvB,SAAS;IASvB,OAAO,CAAC,mBAAmB;YAsBb,oBAAoB;IAsElC,OAAO,CAAC,gBAAgB;IA2BxB,OAAO,CAAC,iBAAiB;YA2DX,cAAc;YAcd,eAAe;YAqCf,mBAAmB;IAyCjC,OAAO,CAAC,cAAc;IAMtB,OAAO,CAAC,UAAU;IAIlB,OAAO,CAAC,WAAW;IAInB,SAAS,CAAC,aAAa,IAAI,cAAc;IAiFzC,SAAS,CAAC,MAAM,IAAI,cAAc;IAwMlC,MAAM,CAAC,MAAM,0BA6LX;CACL;AAED,OAAO,CAAC,MAAM,CAAC;IACX,UAAU,qBAAqB;QAC3B,yBAAyB,EAAE,oBAAoB,CAAC;KACnD;CACJ"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
type RxdbModule = typeof import('rxdb');
|
|
2
|
+
type RxdbStorageDexieModule = typeof import('rxdb/plugins/storage-dexie');
|
|
3
|
+
interface RxDbModules {
|
|
4
|
+
rxdb: RxdbModule;
|
|
5
|
+
storageDexie: RxdbStorageDexieModule;
|
|
6
|
+
}
|
|
7
|
+
export declare function getRxDbModules(): Promise<RxDbModules>;
|
|
8
|
+
export {};
|
|
9
|
+
//# sourceMappingURL=rxdb-loader.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rxdb-loader.d.ts","sourceRoot":"","sources":["../src/rxdb-loader.ts"],"names":[],"mappings":"AAAA,KAAK,UAAU,GAAG,cAAc,MAAM,CAAC,CAAC;AACxC,KAAK,sBAAsB,GAAG,cAAc,4BAA4B,CAAC,CAAC;AAK1E,UAAU,WAAW;IACjB,IAAI,EAAE,UAAU,CAAC;IACjB,YAAY,EAAE,sBAAsB,CAAC;CACxC;AAqBD,wBAAsB,cAAc,IAAI,OAAO,CAAC,WAAW,CAAC,CAwB3D"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { RAGSearchResult } from '../rag-service';
|
|
2
|
+
import { SnippetExtractor } from '../utils/snippet-extractor';
|
|
3
|
+
export declare class RAGResultFormatter {
|
|
4
|
+
private snippetExtractor;
|
|
5
|
+
constructor(snippetExtractor: SnippetExtractor);
|
|
6
|
+
formatRAGContext(results: RAGSearchResult[]): string;
|
|
7
|
+
formatSearchResults(results: RAGSearchResult[]): Array<{
|
|
8
|
+
file: string;
|
|
9
|
+
path: string;
|
|
10
|
+
relevance: string;
|
|
11
|
+
language?: string;
|
|
12
|
+
size: number;
|
|
13
|
+
snippets: string[];
|
|
14
|
+
preview: string;
|
|
15
|
+
}>;
|
|
16
|
+
formatCommandResults(results: RAGSearchResult[]): Array<{
|
|
17
|
+
file: string;
|
|
18
|
+
path: string;
|
|
19
|
+
relevance: number;
|
|
20
|
+
snippets: string[];
|
|
21
|
+
}>;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=rag-result-formatter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rag-result-formatter.d.ts","sourceRoot":"","sources":["../../src/services/rag-result-formatter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAG9D,qBAAa,kBAAkB;IACf,OAAO,CAAC,gBAAgB;gBAAhB,gBAAgB,EAAE,gBAAgB;IAEtD,gBAAgB,CAAC,OAAO,EAAE,eAAe,EAAE,GAAG,MAAM;IAwBpD,mBAAmB,CAAC,OAAO,EAAE,eAAe,EAAE,GAAG,KAAK,CAAC;QACnD,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,SAAS,EAAE,MAAM,CAAC;QAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,IAAI,EAAE,MAAM,CAAC;QACb,QAAQ,EAAE,MAAM,EAAE,CAAC;QACnB,OAAO,EAAE,MAAM,CAAC;KACnB,CAAC;IAYF,oBAAoB,CAAC,OAAO,EAAE,eAAe,EAAE,GAAG,KAAK,CAAC;QACpD,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,SAAS,EAAE,MAAM,CAAC;QAClB,QAAQ,EAAE,MAAM,EAAE,CAAC;KACtB,CAAC;CAQL"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { IndexedDocument } from '../document-index-service';
|
|
2
|
+
export declare class RelevanceCalculator {
|
|
3
|
+
calculateRelevance(doc: IndexedDocument, query: string): number;
|
|
4
|
+
calculateFileNameRelevance(doc: IndexedDocument, fileName: string): number;
|
|
5
|
+
}
|
|
6
|
+
export declare const relevanceCalculator: RelevanceCalculator;
|
|
7
|
+
//# sourceMappingURL=relevance-calculator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"relevance-calculator.d.ts","sourceRoot":"","sources":["../../src/services/relevance-calculator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAI5D,qBAAa,mBAAmB;IAC5B,kBAAkB,CACd,GAAG,EAAE,eAAe,EACpB,KAAK,EAAE,MAAM,GACd,MAAM;IAuCT,0BAA0B,CACtB,GAAG,EAAE,eAAe,EACpB,QAAQ,EAAE,MAAM,GACjB,MAAM;CAYZ;AAED,eAAO,MAAM,mBAAmB,qBAA4B,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
export declare const SNIPPET_LENGTHS: {
|
|
2
|
+
readonly DEFAULT: 400;
|
|
3
|
+
readonly PREVIEW: 500;
|
|
4
|
+
readonly LONG_PREVIEW: 1000;
|
|
5
|
+
readonly CONTEXT: 150;
|
|
6
|
+
};
|
|
7
|
+
export declare const RELEVANCE_WEIGHTS: {
|
|
8
|
+
readonly FILE_NAME_MATCH: 10;
|
|
9
|
+
readonly FILE_PATH_MATCH: 5;
|
|
10
|
+
readonly CONTENT_MATCH: 1;
|
|
11
|
+
readonly FILE_NAME_EXACT: 20;
|
|
12
|
+
readonly FILE_PATH_EXACT: 10;
|
|
13
|
+
readonly EXACT_PHRASE: 5;
|
|
14
|
+
readonly TERM_COVERAGE: 15;
|
|
15
|
+
};
|
|
16
|
+
export declare const SEARCH_CONFIG: {
|
|
17
|
+
readonly DEFAULT_LIMIT: 5;
|
|
18
|
+
readonly MAX_LIMIT: 20;
|
|
19
|
+
readonly DEFAULT_MIN_RELEVANCE: 0;
|
|
20
|
+
readonly QUERY_TERM_MIN_LENGTH: 2;
|
|
21
|
+
};
|
|
22
|
+
export declare const VECTOR_SEARCH_CONFIG: {
|
|
23
|
+
readonly DEFAULT_INDEX_DISTANCE: 2;
|
|
24
|
+
readonly DEFAULT_DOCS_PER_INDEX_SIDE: 100;
|
|
25
|
+
readonly DEFAULT_LIMIT: 10;
|
|
26
|
+
readonly SAMPLE_VECTOR_COUNT: 5;
|
|
27
|
+
};
|
|
28
|
+
export declare const INDEX_FIELD_NAMES: readonly ["idx0", "idx1", "idx2", "idx3", "idx4"];
|
|
29
|
+
export type IndexFieldName = typeof INDEX_FIELD_NAMES[number];
|
|
30
|
+
export declare const CONTENT_PREVIEW_LENGTHS: {
|
|
31
|
+
readonly SHORT: 200;
|
|
32
|
+
readonly MEDIUM: 500;
|
|
33
|
+
readonly LONG: 1000;
|
|
34
|
+
};
|
|
35
|
+
//# sourceMappingURL=constants.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../src/utils/constants.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,eAAe;;;;;CAKlB,CAAC;AAEX,eAAO,MAAM,iBAAiB;;;;;;;;CAQpB,CAAC;AAEX,eAAO,MAAM,aAAa;;;;;CAKhB,CAAC;AAEX,eAAO,MAAM,oBAAoB;;;;;CAKvB,CAAC;AAEX,eAAO,MAAM,iBAAiB,mDAEpB,CAAC;AAEX,MAAM,MAAM,cAAc,GAAG,OAAO,iBAAiB,CAAC,MAAM,CAAC,CAAC;AAE9D,eAAO,MAAM,uBAAuB;;;;CAI1B,CAAC"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { DocumentSearchScope } from '../document-index-service';
|
|
2
|
+
export interface ContextScopeProvider {
|
|
3
|
+
getScope(): DocumentSearchScope | null;
|
|
4
|
+
getName(): string;
|
|
5
|
+
}
|
|
6
|
+
export declare class PathBasedScope implements ContextScopeProvider {
|
|
7
|
+
private includePaths;
|
|
8
|
+
private excludePaths;
|
|
9
|
+
private name;
|
|
10
|
+
constructor(includePaths: string[], excludePaths?: string[], name?: string);
|
|
11
|
+
getScope(): DocumentSearchScope;
|
|
12
|
+
getName(): string;
|
|
13
|
+
}
|
|
14
|
+
export declare class PatternBasedScope implements ContextScopeProvider {
|
|
15
|
+
private pattern;
|
|
16
|
+
private name;
|
|
17
|
+
constructor(pattern: string | RegExp, name?: string);
|
|
18
|
+
getScope(): DocumentSearchScope;
|
|
19
|
+
getName(): string;
|
|
20
|
+
}
|
|
21
|
+
export declare class TagBasedScope implements ContextScopeProvider {
|
|
22
|
+
private tags;
|
|
23
|
+
private name;
|
|
24
|
+
constructor(tags: string[], name?: string);
|
|
25
|
+
getScope(): DocumentSearchScope;
|
|
26
|
+
getName(): string;
|
|
27
|
+
}
|
|
28
|
+
export declare class CustomScope implements ContextScopeProvider {
|
|
29
|
+
private scope;
|
|
30
|
+
private name;
|
|
31
|
+
constructor(scope: DocumentSearchScope, name?: string);
|
|
32
|
+
getScope(): DocumentSearchScope;
|
|
33
|
+
getName(): string;
|
|
34
|
+
}
|
|
35
|
+
export declare function createEditorScope(openFiles: string[]): DocumentSearchScope;
|
|
36
|
+
export declare function createDirectoryScope(directoryPath: string, recursive?: boolean): DocumentSearchScope;
|
|
37
|
+
export declare function createFileTypeScope(fileTypes: string[]): DocumentSearchScope;
|
|
38
|
+
export declare function combineScopes(...scopes: (DocumentSearchScope | null)[]): DocumentSearchScope | null;
|
|
39
|
+
//# sourceMappingURL=context-scopes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context-scopes.d.ts","sourceRoot":"","sources":["../../src/utils/context-scopes.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAGhE,MAAM,WAAW,oBAAoB;IACjC,QAAQ,IAAI,mBAAmB,GAAG,IAAI,CAAC;IACvC,OAAO,IAAI,MAAM,CAAC;CACrB;AAED,qBAAa,cAAe,YAAW,oBAAoB;IAEnD,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,IAAI;gBAFJ,YAAY,EAAE,MAAM,EAAE,EACtB,YAAY,GAAE,MAAM,EAAO,EAC3B,IAAI,GAAE,MAA2B;IAG7C,QAAQ,IAAI,mBAAmB;IAO/B,OAAO,IAAI,MAAM;CAGpB;AAED,qBAAa,iBAAkB,YAAW,oBAAoB;IAEtD,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,IAAI;gBADJ,OAAO,EAAE,MAAM,GAAG,MAAM,EACxB,IAAI,GAAE,MAA8B;IAGhD,QAAQ,IAAI,mBAAmB;IAM/B,OAAO,IAAI,MAAM;CAGpB;AAED,qBAAa,aAAc,YAAW,oBAAoB;IAElD,OAAO,CAAC,IAAI;IACZ,OAAO,CAAC,IAAI;gBADJ,IAAI,EAAE,MAAM,EAAE,EACd,IAAI,GAAE,MAA0B;IAG5C,QAAQ,IAAI,mBAAmB;IAM/B,OAAO,IAAI,MAAM;CAGpB;AAED,qBAAa,WAAY,YAAW,oBAAoB;IAEhD,OAAO,CAAC,KAAK;IACb,OAAO,CAAC,IAAI;gBADJ,KAAK,EAAE,mBAAmB,EAC1B,IAAI,GAAE,MAAuB;IAGzC,QAAQ,IAAI,mBAAmB;IAI/B,OAAO,IAAI,MAAM;CAGpB;AAED,wBAAgB,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,mBAAmB,CAI1E;AAED,wBAAgB,oBAAoB,CAAC,aAAa,EAAE,MAAM,EAAE,SAAS,GAAE,OAAc,GAAG,mBAAmB,CAO1G;AAED,wBAAgB,mBAAmB,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,mBAAmB,CAK5E;AAED,wBAAgB,aAAa,CAAC,GAAG,MAAM,EAAE,CAAC,mBAAmB,GAAG,IAAI,CAAC,EAAE,GAAG,mBAAmB,GAAG,IAAI,CA0DnG"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export interface QueryTermsOptions {
|
|
2
|
+
minTermLength?: number;
|
|
3
|
+
caseSensitive?: boolean;
|
|
4
|
+
}
|
|
5
|
+
export declare function extractQueryTerms(query: string, options?: QueryTermsOptions): string[];
|
|
6
|
+
export declare function normalizeQuery(query: string): string;
|
|
7
|
+
//# sourceMappingURL=query-utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"query-utils.d.ts","sourceRoot":"","sources":["../../src/utils/query-utils.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,iBAAiB;IAC9B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,aAAa,CAAC,EAAE,OAAO,CAAC;CAC3B;AAID,wBAAgB,iBAAiB,CAC7B,KAAK,EAAE,MAAM,EACb,OAAO,GAAE,iBAAsB,GAChC,MAAM,EAAE,CAWV;AAED,wBAAgB,cAAc,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAEpD"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
export interface SnippetExtractionOptions {
|
|
2
|
+
maxSnippets?: number;
|
|
3
|
+
snippetLength?: number;
|
|
4
|
+
minGap?: number;
|
|
5
|
+
}
|
|
6
|
+
export declare class SnippetExtractor {
|
|
7
|
+
private readonly maxSnippets;
|
|
8
|
+
private readonly snippetLength;
|
|
9
|
+
private readonly minGap;
|
|
10
|
+
constructor(options?: SnippetExtractionOptions);
|
|
11
|
+
extractSnippets(content: string, queryTerms: string[], maxSnippets?: number): string[];
|
|
12
|
+
private calculateSnippetScore;
|
|
13
|
+
private selectNonOverlappingSnippets;
|
|
14
|
+
extractSimpleSnippet(content: string, maxLength?: number): string;
|
|
15
|
+
extractContextSnippets(content: string, query: string, contextLength?: number): Array<{
|
|
16
|
+
start: number;
|
|
17
|
+
end: number;
|
|
18
|
+
matchIndex: number;
|
|
19
|
+
}>;
|
|
20
|
+
}
|
|
21
|
+
export declare const defaultSnippetExtractor: SnippetExtractor;
|
|
22
|
+
//# sourceMappingURL=snippet-extractor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"snippet-extractor.d.ts","sourceRoot":"","sources":["../../src/utils/snippet-extractor.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,wBAAwB;IACrC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,MAAM,CAAC,EAAE,MAAM,CAAC;CACnB;AAYD,qBAAa,gBAAgB;IACzB,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAS;IACrC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAS;IACvC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;gBAEpB,OAAO,GAAE,wBAA6B;IAMlD,eAAe,CACX,OAAO,EAAE,MAAM,EACf,UAAU,EAAE,MAAM,EAAE,EACpB,WAAW,CAAC,EAAE,MAAM,GACrB,MAAM,EAAE;IAsDX,OAAO,CAAC,qBAAqB;IAyB7B,OAAO,CAAC,4BAA4B;IA0BpC,oBAAoB,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,GAAE,MAAY,GAAG,MAAM;IAKtE,sBAAsB,CAClB,OAAO,EAAE,MAAM,EACf,KAAK,EAAE,MAAM,EACb,aAAa,GAAE,MAAY,GAC5B,KAAK,CAAC;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAA;KAAE,CAAC;CAwB/D;AAED,eAAO,MAAM,uBAAuB,kBAAyB,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Directory } from '@eclipse-lyra/core';
|
|
2
|
+
export interface WorkspacePathResult {
|
|
3
|
+
workspace: Directory;
|
|
4
|
+
workspacePath: string;
|
|
5
|
+
}
|
|
6
|
+
export declare function getWorkspacePath(providedPath?: string): Promise<WorkspacePathResult | null>;
|
|
7
|
+
export declare function requireWorkspacePath(providedPath?: string): Promise<WorkspacePathResult>;
|
|
8
|
+
//# sourceMappingURL=workspace-utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workspace-utils.d.ts","sourceRoot":"","sources":["../../src/utils/workspace-utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAKjE,MAAM,WAAW,mBAAmB;IAChC,SAAS,EAAE,SAAS,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;CACzB;AAED,wBAAsB,gBAAgB,CAClC,YAAY,CAAC,EAAE,MAAM,GACtB,OAAO,CAAC,mBAAmB,GAAG,IAAI,CAAC,CAgBrC;AAED,wBAAsB,oBAAoB,CACtC,YAAY,CAAC,EAAE,MAAM,GACtB,OAAO,CAAC,mBAAmB,CAAC,CAM9B"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { INDEX_FIELD_NAMES } from './utils/constants';
|
|
2
|
+
export interface VectorEmbedding {
|
|
3
|
+
id: string;
|
|
4
|
+
documentId: string;
|
|
5
|
+
chunkIndex?: number;
|
|
6
|
+
chunkStartOffset?: number;
|
|
7
|
+
chunkEndOffset?: number;
|
|
8
|
+
embedding: number[];
|
|
9
|
+
idx0: number;
|
|
10
|
+
idx1: number;
|
|
11
|
+
idx2: number;
|
|
12
|
+
idx3: number;
|
|
13
|
+
idx4: number;
|
|
14
|
+
}
|
|
15
|
+
export type IndexValues = {
|
|
16
|
+
[K in typeof INDEX_FIELD_NAMES[number]]: number;
|
|
17
|
+
};
|
|
18
|
+
export interface SampleVector {
|
|
19
|
+
vector: number[];
|
|
20
|
+
idx: number;
|
|
21
|
+
}
|
|
22
|
+
export declare function euclideanDistance(vec1: number[], vec2: number[]): number;
|
|
23
|
+
export declare function generateSampleVectors(count: number, dimension: number, existingEmbeddings?: number[][]): SampleVector[];
|
|
24
|
+
export declare function calculateIndexValues(embedding: number[], sampleVectors: SampleVector[]): IndexValues;
|
|
25
|
+
export declare function getIndexValueArray(indexValues: IndexValues): number[];
|
|
26
|
+
export declare function createIndexValuesFromArray(values: number[]): IndexValues;
|
|
27
|
+
export declare function cosineSimilarity(vec1: number[], vec2: number[]): number;
|
|
28
|
+
//# sourceMappingURL=vector-utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vector-utils.d.ts","sourceRoot":"","sources":["../src/vector-utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAwB,MAAM,mBAAmB,CAAC;AAE5E,MAAM,WAAW,eAAe;IAC5B,EAAE,EAAE,MAAM,CAAC;IACX,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,MAAM,WAAW,GAAG;KACrB,CAAC,IAAI,OAAO,iBAAiB,CAAC,MAAM,CAAC,GAAG,MAAM;CAClD,CAAC;AAEF,MAAM,WAAW,YAAY;IACzB,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,GAAG,EAAE,MAAM,CAAC;CACf;AAED,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,MAAM,CAWxE;AAED,wBAAgB,qBAAqB,CACjC,KAAK,EAAE,MAAM,EACb,SAAS,EAAE,MAAM,EACjB,kBAAkB,CAAC,EAAE,MAAM,EAAE,EAAE,GAChC,YAAY,EAAE,CAmChB;AAED,wBAAgB,oBAAoB,CAChC,SAAS,EAAE,MAAM,EAAE,EACnB,aAAa,EAAE,YAAY,EAAE,GAC9B,WAAW,CAYb;AAED,wBAAgB,kBAAkB,CAAC,WAAW,EAAE,WAAW,GAAG,MAAM,EAAE,CAErE;AAED,wBAAgB,0BAA0B,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,WAAW,CAWxE;AAED,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,MAAM,CAqBvE"}
|
package/package.json
ADDED
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@eclipse-lyra/extension-rag-system",
|
|
3
|
+
"version": "0.0.0",
|
|
4
|
+
"type": "module",
|
|
5
|
+
"main": "./dist/index.js",
|
|
6
|
+
"exports": {
|
|
7
|
+
".": {
|
|
8
|
+
"types": "./dist/index.d.ts",
|
|
9
|
+
"import": "./dist/index.js"
|
|
10
|
+
},
|
|
11
|
+
"./api": {
|
|
12
|
+
"types": "./dist/api.d.ts",
|
|
13
|
+
"import": "./dist/api.js"
|
|
14
|
+
}
|
|
15
|
+
},
|
|
16
|
+
"dependencies": {
|
|
17
|
+
"@eclipse-lyra/core": "*",
|
|
18
|
+
"@eclipse-lyra/extension-ai-system": "*",
|
|
19
|
+
"@eclipse-lyra/extension-in-browser-ml": "*",
|
|
20
|
+
"@langchain/core": "^1.0.0",
|
|
21
|
+
"@langchain/textsplitters": "^1.0.0",
|
|
22
|
+
"pdfjs-dist": "^4.0.0",
|
|
23
|
+
"rxdb": "^15.0.0",
|
|
24
|
+
"rxjs": "^7.8.0"
|
|
25
|
+
},
|
|
26
|
+
"devDependencies": {
|
|
27
|
+
"typescript": "^5.9.3",
|
|
28
|
+
"vite": "^7.1.12",
|
|
29
|
+
"vite-plugin-dts": "^4.5.4"
|
|
30
|
+
},
|
|
31
|
+
"module": "./dist/index.js",
|
|
32
|
+
"types": "./dist/index.d.ts",
|
|
33
|
+
"files": [
|
|
34
|
+
"dist"
|
|
35
|
+
],
|
|
36
|
+
"scripts": {
|
|
37
|
+
"build": "vite build"
|
|
38
|
+
}
|
|
39
|
+
}
|