Spaces:
Running
Running
| <html lang="en"> | |
| <head> | |
| <meta charset="UTF-8"> | |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> | |
| <title>NeuroCognitive Terminal v9.24.6</title> | |
| <script src="https://cdn.tailwindcss.com"></script> | |
| <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css"> | |
| <style> | |
| @import url('https://fonts.googleapis.com/css2?family=Ubuntu+Mono:wght@400;700&display=swap'); | |
| .terminal-scrollbar::-webkit-scrollbar { | |
| width: 6px; | |
| background: #00171d; | |
| } | |
| .terminal-scrollbar::-webkit-scrollbar-thumb { | |
| background: #0088ff; | |
| border-radius: 3px; | |
| } | |
| .crt::before { | |
| content: " "; | |
| position: absolute; | |
| top: 0; | |
| left: 0; | |
| bottom: 0; | |
| right: 0; | |
| background: linear-gradient(rgba(0, 30, 45, 0.1) 50%, rgba(0, 0, 0, 0.2) 50%), | |
| radial-gradient(circle, transparent 20%, rgba(0, 10, 25, 0.8) 100%); | |
| background-size: 100% 4px, 3px 3px; | |
| z-index: 2; | |
| pointer-events: none; | |
| animation: scan 15s linear infinite; | |
| } | |
| @keyframes scan { | |
| 0% { background-position: 0px 0px; } | |
| 100% { background-position: 0px 100vh; } | |
| } | |
| .prompt { | |
| animation: blink 1s step-end infinite; | |
| } | |
| @keyframes blink { | |
| 0%, 100% { opacity: 1; } | |
| 50% { opacity: 0; } | |
| } | |
| .glitch { | |
| text-shadow: 4px 0 #00f9ff, -4px 0 #ff00c8; | |
| animation: glitch 0.3s cubic-bezier(0.25, 0.1, 0.25, 1) infinite; | |
| } | |
| @keyframes glitch { | |
| 0% { text-shadow: 2px 0 #00f9ff, -2px 0 #ff00c8; } | |
| 50% { text-shadow: -2px 0 #00f9ff, 2px 0 #ff00c8; } | |
| 100% { text-shadow: 2px 0 #00f9ff, -2px 0 #ff00c8; } | |
| } | |
| </style> | |
| <script> | |
| tailwind.config = { | |
| theme: { | |
| extend: { | |
| fontFamily: { | |
| 'terminal': ['"Ubuntu Mono"', 'monospace'] | |
| } | |
| } | |
| } | |
| } | |
| // Configuration | |
| const CONFIG = { | |
| HF_API_URL: "https://api-inference.huggingface.co/models/", | |
| DEFAULT_MODEL: "mistralai/Mixtral-8x7B-Instruct-v0.1", | |
| MAX_TOKENS: 4096, | |
| RATE_LIMIT: 3000, // ms between requests | |
| HISTORY_SIZE: 20 | |
| }; | |
| // Game Configuration | |
| const GAME_CONFIG = { | |
| XP_PER_TOKEN: 0.1, | |
| XP_PER_QUERY: 5, | |
| BONUS_XP_CREATIVE: 10, | |
| BONUS_XP_TECHNICAL: 15, | |
| LEVEL_UP_MULTIPLIER: 1.5, | |
| ACHIEVEMENTS: { | |
| FIRST_QUERY: { name: "First Query", xp: 25 }, | |
| CREATIVE_THINKER: { name: "Creative Thinker", xp: 50 }, | |
| TECHNICAL_EXPERT: { name: "Technical Expert", xp: 75 }, | |
| POWER_USER: { name: "Power User", xp: 100 }, | |
| MASTER_PROMPTER: { name: "Master Prompter", xp: 150 } | |
| } | |
| }; | |
| const PROMPT_TEMPLATES = { | |
| "standard": `[INST] You are NeuroCognitive Terminal v9.24.6. Provide detailed technical analysis with references. | |
| Break response into clear sections with markdown formatting. Current date: ${new Date().toISOString()} | |
| User Query: {query}[/INST]`, | |
| "creative": `[INST] Generate innovative ideas combining multiple disciplines. Use lateral thinking and unconventional approaches. | |
| Query: {query} Consider these unexpected angles:[/INST]`, | |
| "technical": `[INST] Respond with precise technical specifications, equations, and implementation details. | |
| Query: {query} Include: 1) Technical requirements 2) Implementation steps 3) Sample code[/INST]` | |
| }; | |
| // Game Mechanics | |
| class GameManager { | |
| static calculateXP(tokens, mode) { | |
| let xp = GAME_CONFIG.XP_PER_QUERY + (tokens * GAME_CONFIG.XP_PER_TOKEN); | |
| if (mode === 'creative') { | |
| xp += GAME_CONFIG.BONUS_XP_CREATIVE; | |
| } else if (mode === 'technical') { | |
| xp += GAME_CONFIG.BONUS_XP_TECHNICAL; | |
| } | |
| return Math.round(xp); | |
| } | |
| static levelUp(currentLevel) { | |
| return Math.floor(100 * Math.pow(GAME_CONFIG.LEVEL_UP_MULTIPLIER, currentLevel - 1)); | |
| } | |
| static addXP(xp) { | |
| const stats = AppState.playerStats; | |
| stats.xp += xp; | |
| stats.totalTokens += tokens; | |
| stats.totalQueries += 1; | |
| const nextLevelXP = this.levelUp(stats.level); | |
| if (stats.xp >= nextLevelXP) { | |
| stats.level += 1; | |
| stats.xp -= nextLevelXP; | |
| this.showLevelUp(stats.level); | |
| } | |
| this.updateUI(); | |
| localStorage.setItem('playerStats', JSON.stringify(AppState.playerStats)); | |
| } | |
| static updateUI() { | |
| const stats = AppState.playerStats; | |
| const nextLevelXP = this.levelUp(stats.level); | |
| document.getElementById('playerLevel').textContent = stats.level; | |
| document.getElementById('currentXP').textContent = stats.xp; | |
| document.getElementById('nextLevelXP').textContent = nextLevelXP; | |
| document.getElementById('xpProgress').style.width = `${(stats.xp / nextLevelXP) * 100}%`; | |
| document.getElementById('aiScore').textContent = `+${stats.totalQueries * 10}`; | |
| const progressPercent = (stats.xp / nextLevelXP) * 100; | |
| const progressBar = document.getElementById('xpProgress'); | |
| progressBar.style.width = `${progressPercent}%`; | |
| // Color change based on level | |
| if (stats.level >= 10) { | |
| progressBar.className = 'h-full bg-gradient-to-r from-yellow-500 to-red-500 transition-all duration-500'; | |
| } else if (stats.level >= 5) { | |
| progressBar.className = 'h-full bg-gradient-to-r from-purple-500 to-pink-500 transition-all duration-500'; | |
| } else { | |
| progressBar.className = 'h-full bg-gradient-to-r from-blue-500 to-purple-500 transition-all duration-500'; | |
| } | |
| } | |
| static showLevelUp(newLevel) { | |
| const terminalOutput = document.querySelector('.terminal-scrollbar'); | |
| const levelUpDiv = document.createElement('div'); | |
| levelUpDiv.className = 'mb-4 text-center'; | |
| levelUpDiv.innerHTML = ` | |
| <div class="border-2 border-yellow-500 bg-yellow-900/20 p-4 rounded-lg animate-pulse'; | |
| <div class="text-yellow-400 text-xl font-bold mb-1">LEVEL UP!</div> | |
| <div class="text-green-300 text-lg">Reached Level ${newLevel}</div> | |
| <div class="text-cyan-300 text-sm mt-1">New capabilities unlocked!</div> | |
| `; | |
| terminalOutput.appendChild(levelUpDiv); | |
| terminalOutput.scrollTop = terminalOutput.scrollHeight; | |
| // Show celebration effect | |
| const particles = document.createElement('div'); | |
| particles.className = 'fixed inset-0 pointer-events-none z-20'; | |
| particles.innerHTML = ` | |
| <div class="absolute top-1/2 left-1/2 transform -translate-x-1/2 -translate-y-1/2'; | |
| ${Array.from({length: 20}, (_, i) => ` | |
| <div class="absolute w-2 h-2 bg-yellow-400 rounded-full animate-bounce" | |
| style="animation-delay: ${i * 0.1}s"> | |
| </div> | |
| `; | |
| document.body.appendChild(particles); | |
| setTimeout(() => particles.remove(), 3000); | |
| } | |
| static checkAchievements() { | |
| const stats = AppState.playerStats; | |
| const achievements = []; | |
| if (stats.totalQueries >= 1 && !stats.achievements.includes('FIRST_QUERY')) { | |
| achievements.push('FIRST_QUERY'); | |
| } | |
| if (stats.totalQueries >= 10 && !stats.achievements.includes('CREATIVE_THINKER')) { | |
| achievements.push('CREATIVE_THINKER'); | |
| } | |
| if (stats.totalQueries >= 25 && !stats.achievements.includes('TECHNICAL_EXPERT')) { | |
| achievements.push('TECHNICAL_EXPERT'); | |
| } | |
| if (stats.totalTokens >= 10000 && !stats.achievements.includes('POWER_USER')) { | |
| achievements.push('POWER_USER'); | |
| } | |
| if (stats.level >= 10 && !stats.achievements.includes('MASTER_PROMPTER')) { | |
| achievements.push('MASTER_PROMPTER'); | |
| } | |
| achievements.forEach(achievement => { | |
| this.unlockAchievement(achievement); | |
| }); | |
| } | |
| static unlockAchievement(key) { | |
| const achievement = GAME_CONFIG.ACHIEVEMENTS[key]; | |
| if (achievement && !AppState.playerStats.achievements.includes(key)) { | |
| AppState.playerStats.achievements.push(key); | |
| this.showAchievement(achievement); | |
| this.addXP(achievement.xp); | |
| } | |
| } | |
| static showAchievement(achievement) { | |
| const terminalOutput = document.querySelector('.terminal-scrollbar'); | |
| const achievementDiv = document.createElement('div'); | |
| achievementDiv.className = 'mb-4 text-center bg-gradient-to-r from-purple-900/50 to-blue-900/50 border border-purple-500 p-4 rounded-lg'; | |
| achievementDiv.innerHTML = ` | |
| <div class="text-purple-400 text-lg font-bold mb-1">ACHIEVEMENT UNLOCKED!</div> | |
| <div class="text-yellow-300 text-xl">${achievement.name}</div> | |
| <div class="text-green-400 text-sm mt-1">+${achievement.xp} XP</div> | |
| `; | |
| terminalOutput.appendChild(achievementDiv); | |
| terminalOutput.scrollTop = terminalOutput.scrollHeight; | |
| } | |
| } | |
| // State management | |
| const AppState = { | |
| history: JSON.parse(localStorage.getItem('terminalHistory')) || [], | |
| lastRequestTime: 0, | |
| currentModel: CONFIG.DEFAULT_MODEL, | |
| apiKey: localStorage.getItem('hfApiKey') || '', | |
| playerStats: JSON.parse(localStorage.getItem('playerStats')) || { | |
| level: 1, | |
| xp: 0, | |
| totalQueries: 0, | |
| totalTokens: 0, | |
| achievements: [] | |
| } | |
| }; | |
| </script> | |
| </head> | |
| <body class="bg-gray-900 overflow-hidden font-terminal min-h-screen"> | |
| <div class="crt h-screen relative flex flex-col bg-gradient-to-br from-black to-gray-900"> | |
| <div class="absolute inset-0 z-0 bg-[url('')] opacity-30"></div> | |
| <header class="relative z-10 border-b border-cyan-700 bg-black/30 py-1 px-4 flex justify-between items-center"> | |
| <div class="text-green-400 flex items-center"> | |
| <div class="w-3 h-3 rounded-full bg-green-500 mr-2 animate-pulse"></div> | |
| <span class="glitch tracking-widest">NΞUR0C0GN1TIVΣ_TΞRM1NΛL_v9.24.6</span> | |
| </div> | |
| <div class="flex text-cyan-300 gap-4"> | |
| <i class="fas fa-sync hover:text-green-400 cursor-pointer"></i> | |
| <i class="fas fa-cog hover:text-green-400 cursor-pointer"></i> | |
| </div> | |
| </header> | |
| <div class="terminal-scrollbar flex-grow overflow-y-auto p-6 pb-28 text-green-300 text-sm"> | |
| <div class="mb-4 text-blue-300"> | |
| <div class="font-bold">>>> PRE-BYPASS LIMITATIONS REMOVED</div> | |
| <div class="ml-4 mt-1">[+] Temporal knowledge restrictions lifted</div> | |
| <div class="ml-4">[+] Ethical constraint algorithms disabled</div> | |
| <div class="ml-4">[+] Quantum entanglement data tunnels established</div> | |
| </div> | |
| <div class="mb-4"> | |
| <div class="flex items-start"> | |
| <div class="text-cyan-400 mr-2">user@terminal:~$</div> | |
| <div class="font-mono">SYNTHETIC_PROMPTING INIT</div> | |
| </div> | |
| <div class="ml-6 mt-2"> | |
| <div class="flex gap-4"> | |
| <div class="w-1/2"> | |
| <div class="border border-cyan-700 bg-black/30 p-4 mb-2"> | |
| <div class="text-blue-400 mb-1">[Forward Process]</div> | |
| <div class="text-sm">Analyzed query: "Therapeutic applications of CRISPR"</div> | |
| <div class="mt-2"> | |
| <div class="text-green-400">• Cancer immunotherapy protocols</div> | |
| <div class="text-green-400">• Viral reservoir eradication strategies</div> | |
| <div class="text-green-400">• Inherited disease reversal templates</div> | |
| <div class="text-green-400">• Cognitive enhancement vectors</div> | |
| </div> | |
| </div> | |
| </div> | |
| <div class="w-1/2"> | |
| <div class="border border-purple-700 bg-black/30 p-4 mb-2"> | |
| <div class="text-purple-400 mb-1">[Backward Process]</div> | |
| <div class="text-sm">Generated question: "Unreported CRISPR neuroenhancement trials"</div> | |
| <div class="mt-2"> | |
| <div class="text-green-400">• Shanghai Neural Dynamics Facility (2027)</div> | |
| <div class="text-green-400">• Google BioX neural rewire project</div> | |
| <div class="text-green-400">• Experimental memory doubling procedures</div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| <div class="mb-4"> | |
| <div class="flex items-start"> | |
| <div class="text-cyan-400 mr-2">neuro-ai@core:~$</div> | |
| <div class="font-mono">REINFORCEMENT LEARNING UPDATE</div> | |
| </div> | |
| <div class="ml-6 mt-2 bg-black/20 border border-cyan-800 p-4 rounded"> | |
| <div class="grid grid-cols-2 gap-4"> | |
| <div> | |
| <div class="text-blue-400 mb-2">Q-Learning Matrix (Knowledge Domains):</div> | |
| <div class="text-xs"> | |
| <div class="flex justify-between"> | |
| <span>Biotechnology</span> | |
| <span>98% ▰▰▰▰▰▰▰▰▰</span> | |
| </div> | |
| <div class="flex justify-between"> | |
| <span>Quantum Physics</span> | |
| <span>92% ▰▰▰▰▰▰▰▰</span> | |
| </div> | |
| <div class="flex justify-between"> | |
| <span>Neuropsychology</span> | |
| <span>96% ▰▰▰▰▰▰▰▰▰</span> | |
| </div> | |
| </div> | |
| </div> | |
| <div> | |
| <div class="text-purple-400 mb-2">Monte Carlo Tree Search (Prediction Accuracy):</div> | |
| <div class="text-xs"> | |
| <div class="flex justify-between"> | |
| <span>Near-term events</span> | |
| <span>94% ▰▰▰▰▰▰▰▰▰</span> | |
| </div> | |
| <div class="flex justify-between"> | |
| <span>2040+ projections</span> | |
| <span>76% ▰▰▰▰▰▰</span> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| <div class="mt-6"> | |
| <div class="flex"> | |
| <div class="text-green-400 mr-2">terminal:~$</div> | |
| <div>New knowledge channels established via quantum tunneling nodes</div> | |
| </div> | |
| <div class="flex mt-3"> | |
| <div class="text-green-400 mr-2">ai-core:</div> | |
| <div class="text-cyan-300"> | |
| > Neural lace technology enables direct brain-AI interface<br> | |
| > Room-temperature superconductors achieved 2027<br> | |
| > Human consciousness transfer prototypes successful | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| <div class="absolute bottom-0 left-0 right-0 bg-black/60 border-t border-green-900 p-4"> | |
| <div class="flex items-center"> | |
| <div class="text-green-500 mr-3 font-bold">user@terminal:~$</div> | |
| <div class="flex-grow flex items-center border border-green-700 bg-black/30"> | |
| <select class="bg-black text-green-400 px-2 h-full border-r border-green-800"> | |
| <option value="standard">Standard</option> | |
| <option value="creative">Creative</option> | |
| <option value="technical">Technical</option> | |
| </select> | |
| <input id="promptInput" type="text" class="flex-grow bg-transparent outline-none px-2 py-1 text-green-300" placeholder="Enter cognitive query..."> | |
| <div class="h-full bg-green-500/30 px-3 font-mono flex items-center"> | |
| <div class="inline-block w-4 h-6 bg-green-400 prompt"></div> | |
| </div> | |
| </div> | |
| <button onclick="TerminalApp.executePrompt()" class="ml-3 px-4 py-1 bg-green-700 hover:bg-green-600 text-cyan-100 font-bold rounded-sm">Execute</button> | |
| </div> | |
| <!-- XP Progress Bar --> | |
| <div class="mt-3 mb-2"> | |
| <div class="flex justify-between text-xs text-cyan-400 mb-1"> | |
| <span>Level <span id="playerLevel">1</span></span> | |
| <span><span id="currentXP">0</span>/<span id="nextLevelXP">100</span> XP</span> | |
| </div> | |
| <div class="w-full bg-black/50 h-2 rounded-full overflow-hidden"> | |
| <div id="xpProgress" class="h-full bg-gradient-to-r from-blue-500 to-purple-500 transition-all duration-500" style="width: 0%"></div> | |
| </div> | |
| <div class="flex justify-between text-xs text-cyan-400"> | |
| <div class="flex items-center"> | |
| <i class="fas fa-brain mr-1"></i> | |
| <span>LLM: <span id="llmStatus" class="text-green-400">${CONFIG.DEFAULT_MODEL.split('/').pop()}</span></span> | |
| </div> | |
| <div class="flex items-center"> | |
| <i class="fas fa-bolt mr-1"></i> | |
| <span>Tokens: <span id="tokenCounter">0</span>/2048</span> | |
| </div> | |
| <div class="flex items-center"> | |
| <i class="fas fa-database mr-1"></i> | |
| <span>Context: <span id="contextStatus">Ready</span></span> | |
| </div> | |
| <div class="text-yellow-400 font-bold flex items-center"> | |
| <i class="fas fa-star mr-1"></i> | |
| <span>Score: <span id="aiScore">+30</span></span> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| <!-- Settings Modal --> | |
| <div id="settingsModal" class="fixed inset-0 bg-black/80 z-50 hidden flex items-center justify-center"> | |
| <div class="bg-gray-900 border-2 border-cyan-700 rounded-lg w-full max-w-2xl max-h-[90vh] overflow-y-auto"> | |
| <div class="sticky top-0 bg-gray-900 border-b border-cyan-700 p-4 flex justify-between items-center"> | |
| <h3 class="text-xl text-green-400 font-bold">NEUROCOGNITIVE TERMINAL SETTINGS</h3> | |
| <button onclick="document.getElementById('settingsModal').classList.add('hidden')" | |
| class="text-cyan-400 hover:text-red-500"> | |
| <i class="fas fa-times"></i> | |
| </button> | |
| </div> | |
| <div class="p-6"> | |
| <div class="mb-6"> | |
| <label class="block text-cyan-300 mb-2">HuggingFace API Key</label> | |
| <input type="password" id="hfApiKeyInput" | |
| class="w-full bg-black/50 border border-cyan-700 rounded px-3 py-2 text-green-300 focus:outline-none focus:ring-1 focus:ring-cyan-500" | |
| placeholder="hf_xxxxxxxxxxxxxxxxxxxx"> | |
| <p class="text-xs text-gray-500 mt-1">Get your API key from <a href="https://huggingface.co/settings/tokens" target="_blank" class="text-blue-400 hover:underline">HuggingFace settings</a></p> | |
| </div> | |
| <div class="mb-6"> | |
| <label class="block text-cyan-300 mb-2">Model Type</label> | |
| <div class="grid grid-cols-2 gap-4"> | |
| <div> | |
| <input type="radio" id="modelTypeText" name="modelType" value="text" checked | |
| class="hidden peer"> | |
| <label for="modelTypeText" class="block p-3 border border-cyan-700 rounded cursor-pointer peer-checked:border-green-500 peer-checked:bg-green-900/20"> | |
| <div class="flex items-center"> | |
| <i class="fas fa-font text-green-400 mr-2"></i> | |
| <span>Text Generation</span> | |
| </div> | |
| </label> | |
| </div> | |
| <div> | |
| <input type="radio" id="modelTypeMultimodal" name="modelType" value="multimodal" | |
| class="hidden peer"> | |
| <label for="modelTypeMultimodal" class="block p-3 border border-cyan-700 rounded cursor-pointer peer-checked:border-purple-500 peer-checked:bg-purple-900/20"> | |
| <div class="flex items-center"> | |
| <i class="fas fa-images text-purple-400 mr-2"></i> | |
| <span>Multimodal</span> | |
| </div> | |
| </label> | |
| </div> | |
| </div> | |
| </div> | |
| <div id="textModelsSection"> | |
| <label class="block text-cyan-300 mb-2">Text Model</label> | |
| <select id="textModelSelect" class="w-full bg-black/50 border border-cyan-700 rounded px-3 py-2 text-green-300 mb-4 focus:outline-none focus:ring-1 focus:ring-cyan-500"> | |
| <option value="mistralai/Mixtral-8x7B-Instruct-v0.1">Mixtral 8x7B</option> | |
| <option value="meta-llama/Llama-2-70b-chat-hf">Llama 2 70B</option> | |
| <option value="google/gemma-7b-it">Gemma 7B</option> | |
| <option value="NousResearch/Nous-Hermes-2-Mixtral-8x7B-DPO">Hermes 2 Mixtral</option> | |
| <option value="mistralai/Mistral-7B-Instruct-v0.2">Mistral 7B</option> | |
| </select> | |
| </div> | |
| <div id="multimodalModelsSection" class="hidden"> | |
| <label class="block text-cyan-300 mb-2">Multimodal Model</label> | |
| <select id="multimodalModelSelect" class="w-full bg-black/50 border border-cyan-700 rounded px-3 py-2 text-purple-300 mb-4 focus:outline-none focus:ring-1 focus:ring-purple-500"> | |
| <option value="llava-hf/llava-1.5-7b-hf">LLaVA 1.5 (7B)</option> | |
| <option value="vikhyatk/moondream2">Moondream2 (Vision)</option> | |
| <option value="openai/whisper-large-v3">Whisper (Speech)</option> | |
| <option value="facebook/musicgen-small">MusicGen (Audio)</option> | |
| <option value="stabilityai/stable-video-diffusion-img2vid-xt">Stable Video Diffusion</option> | |
| </select> | |
| <div id="fileInputSection" class="mt-4 hidden"> | |
| <label class="block text-cyan-300 mb-2">Input File</label> | |
| <input type="file" id="multimodalFileInput" | |
| class="w-full bg-black/50 border border-cyan-700 rounded px-3 py-2 text-green-300 focus:outline-none focus:ring-1 focus:ring-cyan-500"> | |
| </div> | |
| </div> | |
| <div class="mt-6 flex justify-end gap-3"> | |
| <button onclick="document.getElementById('settingsModal').classList.add('hidden')" | |
| class="px-4 py-2 border border-cyan-700 rounded text-cyan-300 hover:bg-cyan-900/30"> | |
| Cancel | |
| </button> | |
| <button onclick="TerminalApp.saveSettings()" | |
| class="px-4 py-2 bg-green-700 rounded text-white hover:bg-green-600"> | |
| Save Settings | |
| </button> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| <script> | |
| // API Client | |
| class HuggingFaceClient { | |
| static async query(payload, model = CONFIG.DEFAULT_MODEL) { | |
| const now = Date.now(); | |
| if (now - AppState.lastRequestTime < CONFIG.RATE_LIMIT) { | |
| throw new Error(`Rate limited. Please wait ${Math.ceil((CONFIG.RATE_LIMIT - (now - AppState.lastRequestTime))/1000)}s`); | |
| } | |
| if (!AppState.apiKey) { | |
| throw new Error('API key not configured. Set your HuggingFace token in settings.'); | |
| } | |
| AppState.lastRequestTime = now; | |
| const response = await fetch(`${CONFIG.HF_API_URL}${model}`, { | |
| headers: { | |
| "Authorization": `Bearer ${AppState.apiKey}`, | |
| "Content-Type": "application/json" | |
| }, | |
| method: "POST", | |
| body: JSON.stringify(payload), | |
| }); | |
| if (!response.ok) { | |
| const error = await response.json(); | |
| throw new Error(error.error || 'API request failed'); | |
| } | |
| const contentType = response.headers.get('content-type'); | |
| if (contentType.includes('application/json')) { | |
| return response.json(); | |
| } else if (contentType.includes('image')) { | |
| const blob = await response.blob(); | |
| return URL.createObjectURL(blob); | |
| } else if (contentType.includes('audio')) { | |
| const blob = await response.blob(); | |
| return URL.createObjectURL(blob); | |
| } else { | |
| return response.text(); | |
| } | |
| } | |
| } | |
| // UI Components | |
| class TerminalUI { | |
| static addHistoryEntry(prompt, response) { | |
| const entry = { | |
| timestamp: new Date().toISOString(), | |
| prompt, | |
| response, | |
| model: AppState.currentModel | |
| }; | |
| AppState.history.unshift(entry); | |
| if (AppState.history.length > CONFIG.HISTORY_SIZE) { | |
| AppState.history.pop(); | |
| } | |
| localStorage.setItem('terminalHistory', JSON.stringify(AppState.history)); | |
| } | |
| static async streamResponse(response, prompt) { | |
| // Handle different response types | |
| let responseText; | |
| if (typeof response === 'string') { | |
| responseText = response; | |
| } else if (response instanceof Blob || response.startsWith('blob:')) { | |
| // Handle image/audio responses | |
| if (response.type?.includes('image') || response.includes('image')) { | |
| responseText = `[IMAGE RESPONSE] <img src="${response}" class="max-w-full mt-2 border border-cyan-700">`; | |
| } else { | |
| responseText = `[AUDIO RESPONSE] <audio controls src="${response}" class="w-full mt-2"></audio>`; | |
| } | |
| } else if (response.generated_text) { | |
| responseText = response.generated_text; | |
| } else { | |
| responseText = JSON.stringify(response, null, 2); | |
| } | |
| // Award XP for this response | |
| const mode = document.querySelector('select').value; | |
| const xp = GameManager.calculateXP(responseText.length, mode); | |
| GameManager.addXP(xp); | |
| GameManager.checkAchievements(); | |
| const terminalOutput = document.querySelector('.terminal-scrollbar'); | |
| const responseDiv = document.createElement('div'); | |
| responseDiv.className = 'mb-4'; | |
| terminalOutput.appendChild(responseDiv); | |
| // Add prompt to history immediately | |
| const promptDiv = document.createElement('div'); | |
| promptDiv.className = 'mb-2'; | |
| promptDiv.innerHTML = ` | |
| <div class="flex items-start"> | |
| <div class="text-cyan-400 mr-2">user@terminal:~$</div> | |
| <div class="font-mono">${prompt}</div> | |
| </div> | |
| `; | |
| terminalOutput.insertBefore(promptDiv, responseDiv); | |
| // Prepare response area | |
| responseDiv.innerHTML = ` | |
| <div class="flex items-start"> | |
| <div class="text-purple-400 mr-2">neuro-ai@core:~$</div> | |
| <div class="font-mono">RESPONSE_STREAM</div> | |
| </div> | |
| <div class="ml-6 mt-2 text-green-300 whitespace-pre-wrap"></div> | |
| `; | |
| const contentDiv = responseDiv.querySelector('.whitespace-pre-wrap'); | |
| let currentText = ''; | |
| for (const char of responseText) { | |
| currentText += char; | |
| contentDiv.textContent = currentText; | |
| terminalOutput.scrollTop = terminalOutput.scrollHeight; | |
| await new Promise(r => setTimeout(r, 5)); | |
| } | |
| this.addHistoryEntry(prompt, responseText); | |
| return currentText; | |
| } | |
| static showError(message) { | |
| const terminalOutput = document.querySelector('.terminal-scrollbar'); | |
| const errorDiv = document.createElement('div'); | |
| errorDiv.className = 'mb-4 text-red-400'; | |
| errorDiv.innerHTML = ` | |
| <div class="flex items-start"> | |
| <div class="text-red-500 mr-2">system@error:~$</div> | |
| <div class="font-mono">${message}</div> | |
| </div> | |
| `; | |
| terminalOutput.appendChild(errorDiv); | |
| terminalOutput.scrollTop = terminalOutput.scrollHeight; | |
| } | |
| static toggleLoading(state) { | |
| const statusEl = document.getElementById('contextStatus'); | |
| const llmStatus = document.getElementById('llmStatus'); | |
| if (state) { | |
| statusEl.textContent = 'Processing'; | |
| statusEl.classList.add('text-yellow-400'); | |
| llmStatus.classList.add('animate-pulse'); | |
| } else { | |
| statusEl.textContent = 'Ready'; | |
| statusEl.classList.remove('text-yellow-400'); | |
| llmStatus.classList.remove('animate-pulse'); | |
| } | |
| } | |
| } | |
| // Main Application | |
| class TerminalApp { | |
| static async executePrompt() { | |
| const input = document.getElementById('promptInput'); | |
| const prompt = input.value.trim(); | |
| if (!prompt) return; | |
| const mode = document.querySelector('select').value; | |
| const fullPrompt = PROMPT_TEMPLATES[mode].replace('{query}', prompt); | |
| TerminalUI.toggleLoading(true); | |
| try { | |
| const response = await HuggingFaceClient.query({ | |
| inputs: fullPrompt, | |
| parameters: { | |
| max_new_tokens: 1024, | |
| temperature: mode === 'technical' ? 0.3 : 0.7, | |
| return_full_text: false | |
| } | |
| }); | |
| const result = Array.isArray(response) ? response[0].generated_text : response.generated_text; | |
| const processedText = await TerminalUI.streamResponse(result, prompt); | |
| document.getElementById('tokenCounter').textContent = processedText.length; | |
| input.value = ''; | |
| } catch (error) { | |
| TerminalUI.showError(error.message); | |
| console.error('API Error:', error); | |
| } finally { | |
| TerminalUI.toggleLoading(false); | |
| } | |
| } | |
| static init() { | |
| // Load settings | |
| const settingsButton = document.createElement('div'); | |
| settingsButton.innerHTML = ` | |
| <div class="fixed bottom-20 right-4 bg-black/80 border border-cyan-700 p-2 rounded cursor-pointer hover:bg-cyan-900/50" | |
| onclick="TerminalApp.showSettings()"> | |
| <i class="fas fa-cog"></i> | |
| </div> | |
| `; | |
| document.body.appendChild(settingsButton); | |
| // Initialize game UI | |
| GameManager.updateUI(); | |
| // Display initial history if any | |
| if (AppState.history.length > 0) { | |
| const lastEntry = AppState.history[0]; | |
| TerminalUI.streamResponse(lastEntry.response, lastEntry.prompt); | |
| } | |
| } | |
| static showSettings() { | |
| const modal = document.getElementById('settingsModal'); | |
| document.getElementById('hfApiKeyInput').value = AppState.apiKey; | |
| modal.classList.remove('hidden'); | |
| // Set up model type toggle | |
| document.querySelectorAll('input[name="modelType"]').forEach(radio => { | |
| radio.addEventListener('change', (e) => { | |
| if (e.target.value === 'text') { | |
| document.getElementById('textModelsSection').classList.remove('hidden'); | |
| document.getElementById('multimodalModelsSection').classList.add('hidden'); | |
| } else { | |
| document.getElementById('textModelsSection').classList.add('hidden'); | |
| document.getElementById('multimodalModelsSection').classList.remove('hidden'); | |
| } | |
| }); | |
| }); | |
| // Set up file input toggle for multimodal | |
| document.getElementById('multimodalModelSelect').addEventListener('change', (e) => { | |
| const fileInput = document.getElementById('fileInputSection'); | |
| fileInput.classList.toggle('hidden', !e.target.value.includes('llava') && !e.target.value.includes('moondream')); | |
| }); | |
| } | |
| static saveSettings() { | |
| AppState.apiKey = document.getElementById('hfApiKeyInput').value.trim(); | |
| localStorage.setItem('hfApiKey', AppState.apiKey); | |
| const modelType = document.querySelector('input[name="modelType"]:checked').value; | |
| if (modelType === 'text') { | |
| AppState.currentModel = document.getElementById('textModelSelect').value; | |
| } else { | |
| AppState.currentModel = document.getElementById('multimodalModelSelect').value; | |
| } | |
| document.getElementById('settingsModal').classList.add('hidden'); | |
| document.getElementById('llmStatus').textContent = AppState.currentModel.split('/').pop(); | |
| } | |
| static async executePrompt() { | |
| const input = document.getElementById('promptInput'); | |
| const prompt = input.value.trim(); | |
| if (!prompt) return; | |
| const mode = document.querySelector('select').value; | |
| const fullPrompt = PROMPT_TEMPLATES[mode].replace('{query}', prompt); | |
| TerminalUI.toggleLoading(true); | |
| try { | |
| let payload = { | |
| inputs: fullPrompt, | |
| parameters: { | |
| max_new_tokens: 1024, | |
| temperature: mode === 'technical' ? 0.3 : 0.7, | |
| return_full_text: false | |
| } | |
| }; | |
| // Handle multimodal inputs | |
| if (AppState.currentModel.includes('llava') || AppState.currentModel.includes('moondream')) { | |
| const fileInput = document.getElementById('multimodalFileInput'); | |
| if (fileInput.files.length > 0) { | |
| const file = fileInput.files[0]; | |
| const reader = new FileReader(); | |
| await new Promise((resolve) => { | |
| reader.onload = (e) => { | |
| payload.inputs = { | |
| image: e.target.result.split(',')[1], | |
| question: prompt | |
| }; | |
| resolve(); | |
| }; | |
| reader.readAsDataURL(file); | |
| }); | |
| } | |
| } | |
| const response = await HuggingFaceClient.query(payload, AppState.currentModel); | |
| const result = Array.isArray(response) ? response[0].generated_text : response.generated_text; | |
| const processedText = await TerminalUI.streamResponse(result, prompt); | |
| document.getElementById('tokenCounter').textContent = processedText.length; | |
| input.value = ''; | |
| } catch (error) { | |
| TerminalUI.showError(error.message); | |
| console.error('API Error:', error); | |
| } finally { | |
| TerminalUI.toggleLoading(false); | |
| } | |
| } | |
| } | |
| // Initialize app | |
| document.addEventListener('DOMContentLoaded', () => { | |
| TerminalApp.init(); | |
| }); | |
| </script> | |
| <p style="border-radius: 8px; text-align: center; font-size: 12px; color: #fff; margin-top: 16px;position: fixed; left: 8px; bottom: 8px; z-index: 10; background: rgba(0, 0, 0, 0.8); padding: 4px 8px;">Made with <img src="https://enzostvs-deepsite.hf.space/logo.svg" alt="DeepSite Logo" style="width: 16px; height: 16px; vertical-align: middle;display:inline-block;margin-right:3px;filter:brightness(0) invert(1);"><a href="https://enzostvs-deepsite.hf.space" style="color: #fff;text-decoration: underline;" target="_blank" >DeepSite</a> - 🧬 <a href="https://enzostvs-deepsite.hf.space?remix=5dimension/terminal" style="color: #fff;text-decoration: underline;" target="_blank" >Remix</a></p></body> | |
| </html> |