Untitled
2 months ago in Plain Text
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Jarvis Style Voice Bot</title>
<link href="https://cdn.jsdelivr.net/npm/[email protected]/dist/tailwind.min.css" rel="stylesheet">
<style>
.spinner {
border: 4px solid rgba(190, 183, 164, 0.3);
border-top: 4px solid #3b82f6;
border-radius: 50%;
width: 24px;
height: 24px;
animation: spin 1s linear infinite;
}
@keyframes spin {
0% { transform: rotate(0deg); }
100% { transform: rotate(360deg); }
}
.holographic-face {
width: 150px;
height: 150px;
background: radial-gradient(circle, rgba(0, 204, 255, 0.4), rgba(0, 204, 255, 0.1));
border-radius: 50%;
border: 2px solid rgba(0, 204, 255, 0.8);
box-shadow: 0 0 15px 5px rgba(0, 204, 255, 0.5), inset 0 0 15px rgba(0, 204, 255, 0.5);
margin: 0 auto;
position: relative;
}
.holographic-face::before {
content: '';
position: absolute;
top: 50%;
left: 50%;
width: 100px;
height: 100px;
border-radius: 50%;
background: radial-gradient(circle, rgba(255, 255, 255, 0.2) 20%, rgba(0, 204, 255, 0.1));
transform: translate(-50%, -50%);
animation: pulse 3s infinite alternate;
}
@keyframes pulse {
0% { transform: translate(-50%, -50%) scale(1); }
100% { transform: translate(-50%, -50%) scale(1.2); }
}
</style>
</head>
<body class="bg-black text-white flex items-center justify-center h-screen">
<div class="text-center p-8 rounded-lg shadow-lg">
<h1 class="text-4xl font-bold mb-4">Jarvis Voice Bot</h1>
<div class="holographic-face mb-4"></div>
<button id="start-btn" class="px-4 py-2 bg-blue-500 hover:bg-blue-600 rounded">🎙 Start Listening</button>
<p id="status" class="mt-3 text-gray-400"></p>
<p id="transcript" class="mt-4 p-2 text-blue-300"></p>
<p id="response" class="mt-4 p-2 text-green-300"></p>
<div id="spinner" class="mt-4 hidden spinner"></div>
</div>
<script>
const startBtn = document.getElementById('start-btn');
const transcriptDiv = document.getElementById('transcript');
const responseDiv = document.getElementById('response');
const spinner = document.getElementById('spinner');
const statusDiv = document.getElementById('status');
let recognition;
if ('webkitSpeechRecognition' in window) {
recognition = new webkitSpeechRecognition();
recognition.lang = 'en-US';
recognition.continuous = false;
recognition.interimResults = false;
recognition.onstart = function() {
statusDiv.innerText = "🎧 Listening...";
};
recognition.onresult = function(event) {
const transcript = event.results[0][0].transcript;
transcriptDiv.innerText = 'You said: ' + transcript;
statusDiv.innerText = "";
processCommand(transcript);
};
recognition.onerror = function(event) {
statusDiv.innerText = '⚠ Error: ' + event.error;
};
recognition.onend = function() {
statusDiv.innerText = "";
};
} else {
statusDiv.innerText = 'Speech recognition not supported in this browser. Use Chrome.';
}
startBtn.addEventListener('click', () => {
if (recognition) {
recognition.start();
}
});
function processCommand(transcript) {
responseDiv.innerText = '';
spinner.classList.remove('hidden');
fetch("https://api.openai.com/v1/chat/completions", {
method: 'POST',
headers: {
'Content-Type': 'application/json',
'Authorization': 'Bearer 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
'
},
body: JSON.stringify({
model: "gpt-3.5-turbo",
messages: [{ role: "user", content: transcript }]
})
})
.then(response => response.json())
.then(data => {
spinner.classList.add('hidden');
if (data.choices && data.choices.length > 0) {
let reply = data.choices[0].message.content;
responseDiv.innerText = 'Jarvis: ' + reply;
speak(reply);
} else {
responseDiv.innerText = '❌ API error or empty response';
}
})
.catch(error => {
spinner.classList.add('hidden');
responseDiv.innerText = '❌ Network error';
});
}
function speak(text) {
const synth = window.speechSynthesis;
const utterThis = new SpeechSynthesisUtterance(text);
utterThis.pitch = 1.2;
utterThis.rate = 1;
utterThis.voice = synth.getVoices().find(voice => voice.name.includes('Google US English')) || null;
synth.speak(utterThis);
}
</script>
</body>
</html>