| <!DOCTYPE html> |
| <html lang="en"> |
| <head> |
| <meta charset="UTF-8"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>BitCheck Audio Verification Test</title> |
| <style> |
| body { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif; max-width: 800px; margin: 40px auto; padding: 0 20px; line-height: 1.6; color: #333; } |
| .container { background: #f9f9f9; padding: 25px; border-radius: 8px; border: 1px solid #ddd; box-shadow: 0 2px 4px rgba(0,0,0,0.05); } |
| .form-group { margin-bottom: 20px; } |
| label { display: block; margin-bottom: 8px; font-weight: bold; } |
| input[type="file"] { width: 100%; padding: 10px; background: white; border: 1px solid #ccc; border-radius: 4px; } |
| button { background: #2563eb; color: white; border: none; padding: 12px 24px; border-radius: 4px; cursor: pointer; font-size: 16px; font-weight: bold; transition: background 0.2s; } |
| button:hover { background: #1d4ed8; } |
| button:disabled { background: #9ca3af; cursor: not-allowed; } |
| #result { margin-top: 25px; background: #1f2937; color: #f8fafc; padding: 20px; border-radius: 6px; white-space: pre-wrap; font-family: "JetBrains Mono", Consolas, monospace; font-size: 14px; overflow-x: auto; display: none; } |
| .loading { display: none; margin-top: 15px; color: #4b5563; font-weight: 500; } |
| .header { margin-bottom: 30px; } |
| </style> |
| </head> |
| <body> |
| <div class="header"> |
| <h1>BitCheck Audio API Tester</h1> |
| <p>Upload an audio or video file to test the AI verification model hosted on Hugging Face.</p> |
| </div> |
|
|
| <div class="container"> |
| <form id="uploadForm"> |
| <div class="form-group"> |
| <label for="audioFile">Select Audio/Video File:</label> |
| <input type="file" id="audioFile" name="file" accept="audio/*,video/*" required> |
| </div> |
| |
| <div class="form-group"> |
| <label style="font-weight: normal; cursor: pointer;"> |
| <input type="checkbox" id="returnFeatures" name="return_features" value="true"> |
| Include extracted raw features in response |
| </label> |
| </div> |
|
|
| <button type="submit" id="submitBtn">Verify Audio</button> |
| <div class="loading" id="loadingIndicator">⏳ Uploading and verifying... This may take a moment.</div> |
| </form> |
|
|
| <div id="result"></div> |
| </div> |
|
|
| <script> |
| document.getElementById('uploadForm').addEventListener('submit', async (e) => { |
| e.preventDefault(); |
| |
| const fileInput = document.getElementById('audioFile'); |
| const returnFeatures = document.getElementById('returnFeatures').checked; |
| const submitBtn = document.getElementById('submitBtn'); |
| const loading = document.getElementById('loadingIndicator'); |
| const resultDiv = document.getElementById('result'); |
| |
| if (!fileInput.files.length) { |
| alert('Please select a file first.'); |
| return; |
| } |
| |
| const formData = new FormData(); |
| formData.append('file', fileInput.files[0]); |
| formData.append('return_features', returnFeatures ? 'true' : 'false'); |
| |
| |
| submitBtn.disabled = true; |
| loading.style.display = 'block'; |
| resultDiv.style.display = 'none'; |
| resultDiv.textContent = ''; |
| |
| try { |
| |
| const apiUrl = 'https://jaykay73-bitcheck-audio.hf.space/verify/audio'; |
| |
| const response = await fetch(apiUrl, { |
| method: 'POST', |
| body: formData, |
| headers: { |
| 'Accept': 'application/json' |
| } |
| }); |
| |
| const contentType = response.headers.get("content-type"); |
| if (contentType && contentType.indexOf("application/json") !== -1) { |
| const data = await response.json(); |
| resultDiv.textContent = JSON.stringify(data, null, 2); |
| } else { |
| const textData = await response.text(); |
| resultDiv.textContent = `Error: The server returned an HTML/Text page instead of JSON. This usually means the Space is not found, is still building, or is asleep.\n\nStatus: ${response.status}\n\nResponse preview:\n${textData.substring(0, 500)}`; |
| } |
| |
| resultDiv.style.display = 'block'; |
| |
| } catch (error) { |
| resultDiv.textContent = 'Error: ' + error.message; |
| resultDiv.style.display = 'block'; |
| } finally { |
| submitBtn.disabled = false; |
| loading.style.display = 'none'; |
| } |
| }); |
| </script> |
| </body> |
| </html> |
|
|