<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>RAG Application</title>
    <style>
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }
        
        body {
            font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
            background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
            min-height: 100vh;
            padding: 20px;
        }
        
        .container {
            max-width: 1200px;
            margin: 0 auto;
            background: white;
            border-radius: 12px;
            box-shadow: 0 20px 40px rgba(0,0,0,0.1);
            overflow: hidden;
        }
        
        .header {
            background: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);
            color: white;
            padding: 30px;
            text-align: center;
        }
        
        .header h1 {
            font-size: 2.5rem;
            margin-bottom: 10px;
        }
        
        .header p {
            font-size: 1.1rem;
            opacity: 0.9;
        }
        
        .main-content {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 0;
            min-height: 600px;
        }
        
        .chat-section, .docs-section {
            padding: 30px;
        }
        
        .chat-section {
            border-right: 1px solid #eee;
        }
        
        .section-title {
            font-size: 1.5rem;
            margin-bottom: 20px;
            color: #333;
            display: flex;
            align-items: center;
        }
        
        .section-title::before {
            content: '';
            width: 4px;
            height: 20px;
            background: linear-gradient(135deg, #667eea, #764ba2);
            margin-right: 10px;
            border-radius: 2px;
        }
        
        .chat-container {
            height: 400px;
            border: 1px solid #ddd;
            border-radius: 8px;
            display: flex;
            flex-direction: column;
        }
        
        .chat-messages {
            flex: 1;
            padding: 20px;
            overflow-y: auto;
            background: #f8f9fa;
        }
        
        .message {
            margin-bottom: 15px;
            padding: 12px 16px;
            border-radius: 12px;
            max-width: 80%;
        }
        
        .user-message {
            background: #007bff;
            color: white;
            margin-left: auto;
        }
        
        .bot-message {
            background: white;
            border: 1px solid #ddd;
            margin-right: auto;
        }
        
        .chat-input-container {
            padding: 15px;
            background: white;
            border-top: 1px solid #ddd;
            display: flex;
            gap: 10px;
        }
        
        .chat-input {
            flex: 1;
            padding: 12px;
            border: 1px solid #ddd;
            border-radius: 6px;
            outline: none;
        }
        
        .send-btn, .upload-btn {
            padding: 12px 20px;
            background: linear-gradient(135deg, #667eea, #764ba2);
            color: white;
            border: none;
            border-radius: 6px;
            cursor: pointer;
            transition: transform 0.2s;
        }
        
        .send-btn:hover, .upload-btn:hover {
            transform: translateY(-1px);
        }
        
        .file-upload {
            margin-bottom: 20px;
        }
        
        .file-input {
            margin-bottom: 10px;
        }
        
        .status {
            padding: 10px;
            border-radius: 6px;
            margin-bottom: 20px;
            text-align: center;
        }
        
        .status.success {
            background: #d4edda;
            color: #155724;
            border: 1px solid #c3e6cb;
        }
        
        .status.error {
            background: #f8d7da;
            color: #721c24;
            border: 1px solid #f1aeb5;
        }
        
        .stats {
            background: #f8f9fa;
            padding: 20px;
            border-radius: 8px;
            margin-bottom: 20px;
        }
        
        .stats h3 {
            margin-bottom: 15px;
            color: #333;
        }
        
        .stat-item {
            display: flex;
            justify-content: space-between;
            margin-bottom: 8px;
        }
        
        .loading {
            display: none;
            text-align: center;
            padding: 20px;
        }
        
        .spinner {
            border: 3px solid #f3f3f3;
            border-top: 3px solid #667eea;
            border-radius: 50%;
            width: 30px;
            height: 30px;
            animation: spin 1s linear infinite;
            margin: 0 auto 10px;
        }
        
        @keyframes spin {
            0% { transform: rotate(0deg); }
            100% { transform: rotate(360deg); }
        }
        
        @media (max-width: 768px) {
            .main-content {
                grid-template-columns: 1fr;
            }
            
            .chat-section {
                border-right: none;
                border-bottom: 1px solid #eee;
            }
        }
    </style>
</head>
<body>
    <div class="container">
        <div class="header">
            <h1>RAG Application</h1>
            <p>Retrieval-Augmented Generation with LangGraph, ChromaDB, and Ollama</p>
        </div>
        
        <div class="main-content">
            <div class="chat-section">
                <h2 class="section-title">Chat Interface</h2>
                
                <div class="chat-container">
                    <div class="chat-messages" id="chatMessages">
                        <!-- Messages will be added here -->
                    </div>
                    <div class="chat-input-container">
                        <input type="text" class="chat-input" id="chatInput" placeholder="Ask a question about your documents...">
                        <button class="send-btn" onclick="sendMessage()">Send</button>
                    </div>
                </div>
                
                <div class="loading" id="loading">
                    <div class="spinner"></div>
                    <p>Processing your request...</p>
                </div>
            </div>
            
            <div class="docs-section">
                <h2 class="section-title">Document Management</h2>
                
                <div class="file-upload">
                    <div class="file-input">
                        <input type="file" id="fileInput" multiple accept=".txt,.md,.json">
                        <button class="upload-btn" onclick="uploadFiles()">Upload Documents</button>
                    </div>
                    <div id="uploadStatus"></div>
                </div>
                
                <div class="stats" id="stats">
                    <h3>System Status</h3>
                    <div class="stat-item">
                        <span>Health Status:</span>
                        <span id="healthStatus">Checking...</span>
                    </div>
                    <div class="stat-item">
                        <span>Collections:</span>
                        <span id="collectionCount">-</span>
                    </div>
                    <div class="stat-item">
                        <span>Documents:</span>
                        <span id="documentCount">-</span>
                    </div>
                </div>
                
                <div>
                    <h3>Quick Actions</h3>
                    <button class="upload-btn" onclick="addSampleDocs()" style="margin: 5px;">Add Sample Documents</button>
                    <button class="upload-btn" onclick="clearChat()" style="margin: 5px;">Clear Chat</button>
                    <button class="upload-btn" onclick="refreshStats()" style="margin: 5px;">Refresh Status</button>
                </div>
            </div>
        </div>
    </div>

    <script>
        const API_BASE = 'http://localhost:8080';
        const SESSION_ID = 'web_session_' + Date.now();
        
        // Initialize the app
        document.addEventListener('DOMContentLoaded', function() {
            refreshStats();
            
            // Enable Enter key for chat
            document.getElementById('chatInput').addEventListener('keypress', function(e) {
                if (e.key === 'Enter') {
                    sendMessage();
                }
            });
        });
        
        async function sendMessage() {
            const input = document.getElementById('chatInput');
            const message = input.value.trim();
            if (!message) return;
            
            // Add user message to chat
            addMessage(message, 'user');
            input.value = '';
            
            // Show loading
            document.getElementById('loading').style.display = 'block';
            
            try {
                const response = await fetch(`${API_BASE}/chat`, {
                    method: 'POST',
                    headers: {
                        'Content-Type': 'application/json',
                    },
                    body: JSON.stringify({
                        message: message,
                        session_id: SESSION_ID,
                        collection_name: 'rag_collection',
                        top_k: 3
                    })
                });
                
                if (response.ok) {
                    const data = await response.json();
                    addMessage(data.response, 'bot');
                    
                    // Show sources if available
                    if (data.sources && data.sources.length > 0) {
                        const sourcesText = `Sources: ${data.sources.length} documents referenced`;
                        addMessage(sourcesText, 'bot', true);
                    }
                } else {
                    addMessage('Sorry, I encountered an error processing your request.', 'bot');
                }
            } catch (error) {
                console.error('Error:', error);
                addMessage('Sorry, I cannot connect to the server right now.', 'bot');
            }
            
            // Hide loading
            document.getElementById('loading').style.display = 'none';
        }
        
        function addMessage(text, sender, isSmall = false) {
            const messagesContainer = document.getElementById('chatMessages');
            const messageDiv = document.createElement('div');
            messageDiv.className = `message ${sender}-message`;
            if (isSmall) messageDiv.style.fontSize = '0.9em';
            messageDiv.textContent = text;
            messagesContainer.appendChild(messageDiv);
            messagesContainer.scrollTop = messagesContainer.scrollHeight;
        }
        
        async function uploadFiles() {
            const fileInput = document.getElementById('fileInput');
            const files = fileInput.files;
            
            if (files.length === 0) {
                showUploadStatus('Please select files to upload.', 'error');
                return;
            }
            
            const documents = [];
            
            for (const file of files) {
                try {
                    const text = await file.text();
                    documents.push({
                        content: text,
                        metadata: {
                            source: file.name,
                            size: file.size,
                            type: file.type
                        }
                    });
                } catch (error) {
                    console.error('Error reading file:', file.name, error);
                }
            }
            
            if (documents.length === 0) {
                showUploadStatus('No valid documents to upload.', 'error');
                return;
            }
            
            try {
                const response = await fetch(`${API_BASE}/documents`, {
                    method: 'POST',
                    headers: {
                        'Content-Type': 'application/json',
                    },
                    body: JSON.stringify({
                        documents: documents,
                        collection_name: 'rag_collection'
                    })
                });
                
                if (response.ok) {
                    showUploadStatus(`Successfully uploaded ${documents.length} documents!`, 'success');
                    fileInput.value = '';
                    refreshStats();
                } else {
                    showUploadStatus('Failed to upload documents.', 'error');
                }
            } catch (error) {
                console.error('Upload error:', error);
                showUploadStatus('Error uploading documents.', 'error');
            }
        }
        
        async function addSampleDocs() {
            const sampleDocs = [
                {
                    content: "FastAPI is a modern, fast web framework for building APIs with Python 3.6+ based on standard Python type hints.",
                    metadata: { source: "fastapi_info", topic: "web_framework" }
                },
                {
                    content: "ChromaDB is an open-source embedding database that makes it easy to build AI applications with embeddings.",
                    metadata: { source: "chromadb_info", topic: "vector_database" }
                },
                {
                    content: "LangGraph is a library for building stateful, multi-actor applications with LLMs.",
                    metadata: { source: "langgraph_info", topic: "ai_framework" }
                }
            ];
            
            try {
                const response = await fetch(`${API_BASE}/documents`, {
                    method: 'POST',
                    headers: {
                        'Content-Type': 'application/json',
                    },
                    body: JSON.stringify({
                        documents: sampleDocs,
                        collection_name: 'rag_collection'
                    })
                });
                
                if (response.ok) {
                    showUploadStatus('Sample documents added successfully!', 'success');
                    refreshStats();
                } else {
                    showUploadStatus('Failed to add sample documents.', 'error');
                }
            } catch (error) {
                console.error('Error:', error);
                showUploadStatus('Error adding sample documents.', 'error');
            }
        }
        
        function showUploadStatus(message, type) {
            const statusDiv = document.getElementById('uploadStatus');
            statusDiv.innerHTML = `<div class="status ${type}">${message}</div>`;
            setTimeout(() => {
                statusDiv.innerHTML = '';
            }, 5000);
        }
        
        async function refreshStats() {
            try {
                // Check health
                const healthResponse = await fetch(`${API_BASE}/health`);
                if (healthResponse.ok) {
                    const healthData = await healthResponse.json();
                    document.getElementById('healthStatus').textContent = healthData.status;
                } else {
                    document.getElementById('healthStatus').textContent = 'Error';
                }
                
                // Get collections
                const collectionsResponse = await fetch(`${API_BASE}/collections`);
                if (collectionsResponse.ok) {
                    const collectionsData = await collectionsResponse.json();
                    document.getElementById('collectionCount').textContent = collectionsData.collections.length;
                    
                    // Get document count for main collection
                    if (collectionsData.collections.includes('rag_collection')) {
                        const docsResponse = await fetch(`${API_BASE}/documents/rag_collection`);
                        if (docsResponse.ok) {
                            const docsData = await docsResponse.json();
                            document.getElementById('documentCount').textContent = docsData.document_count;
                        }
                    }
                } else {
                    document.getElementById('collectionCount').textContent = 'Error';
                }
                
            } catch (error) {
                console.error('Error refreshing stats:', error);
                document.getElementById('healthStatus').textContent = 'Connection Error';
            }
        }
        
        function clearChat() {
            document.getElementById('chatMessages').innerHTML = '';
        }
    </script>
</body>
</html>
