Almaatla commited on
Commit
a394cbb
·
verified ·
1 Parent(s): cf6009e

Update index.html

Browse files
Files changed (1) hide show
  1. index.html +36 -13
index.html CHANGED
@@ -55,9 +55,9 @@
55
  <div id="container">
56
  <h1>Whisper WAV Transcription</h1>
57
 
58
- <div id="apiKey" style="display:none"></div>
59
- <div id="apiBaseUrl">Hi</div>
60
-
61
  <label for="audioFile">Select WAV File:</label>
62
  <input type="file" id="audioFile" accept=".wav">
63
 
@@ -65,17 +65,41 @@
65
 
66
  <div id="transcription"></div>
67
  <button id="copyButton" onclick="copyToClipboard()" style="display: none;">Copy to Clipboard</button>
68
-
69
  </div>
70
 
71
  <script>
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
72
  async function transcribeAudio() {
73
- const apiKey = document.getElementById('apiKey').textContent;
74
- const apiBaseUrl = document.getElementById('apiBaseUrl').textContent;
75
-
76
  const audioFile = document.getElementById('audioFile').files[0];
77
  const transcriptionDiv = document.getElementById('transcription');
78
-
79
  if (!apiKey || !audioFile) {
80
  console.log(apiKey);
81
  alert('Please provide both API key and a WAV file.');
@@ -115,7 +139,7 @@
115
  }
116
 
117
  transcriptionDiv.innerHTML = fullTranscription;
118
- document.getElementById('copyButton').style.display = 'block'; // Show copy button
119
 
120
  } catch (error) {
121
  console.error('Error during transcription:', error);
@@ -216,9 +240,8 @@
216
  view.setUint8(offset + i, string.charCodeAt(i));
217
  }
218
  }
219
-
220
-
221
- function copyToClipboard() {
222
  const transcriptionText = document.getElementById('transcription').innerText;
223
  navigator.clipboard.writeText(transcriptionText)
224
  .then(() => {
@@ -230,4 +253,4 @@
230
  }
231
  </script>
232
  </body>
233
- </html>
 
55
  <div id="container">
56
  <h1>Whisper WAV Transcription</h1>
57
 
58
+ <input type="hidden" id="apiKey"> <!-- Hidden input for API key -->
59
+ <input type="hidden" id="apiBaseUrl"> <!-- Hidden input for API base URL -->
60
+
61
  <label for="audioFile">Select WAV File:</label>
62
  <input type="file" id="audioFile" accept=".wav">
63
 
 
65
 
66
  <div id="transcription"></div>
67
  <button id="copyButton" onclick="copyToClipboard()" style="display: none;">Copy to Clipboard</button>
 
68
  </div>
69
 
70
  <script>
71
+ // Function to extract parameters from URL hash
72
+ function getHashParams() {
73
+ const hash = window.location.hash.substring(1);
74
+ const params = {};
75
+
76
+ hash.split('&').forEach(part => {
77
+ const [key, value] = part.split('=');
78
+ if (key && value) {
79
+ params[key] = decodeURIComponent(value);
80
+ }
81
+ });
82
+
83
+ return params;
84
+ }
85
+
86
+ // Set apiKey and apiBaseUrl from URL hash
87
+ window.onload = () => {
88
+ const params = getHashParams();
89
+ document.getElementById('apiKey').value = params.apiKey || '';
90
+ document.getElementById('apiBaseUrl').value = params.apiBaseUrl || '';
91
+
92
+ if (!params.apiKey || !params.apiBaseUrl) {
93
+ alert('Please provide both apiKey and apiBaseUrl in the URL hash.');
94
+ }
95
+ };
96
+
97
  async function transcribeAudio() {
98
+ const apiKey = document.getElementById('apiKey').value;
99
+ const apiBaseUrl = document.getElementById('apiBaseUrl').value;
 
100
  const audioFile = document.getElementById('audioFile').files[0];
101
  const transcriptionDiv = document.getElementById('transcription');
102
+
103
  if (!apiKey || !audioFile) {
104
  console.log(apiKey);
105
  alert('Please provide both API key and a WAV file.');
 
139
  }
140
 
141
  transcriptionDiv.innerHTML = fullTranscription;
142
+ document.getElementById('copyButton').style.display = 'block'; // Show copy button
143
 
144
  } catch (error) {
145
  console.error('Error during transcription:', error);
 
240
  view.setUint8(offset + i, string.charCodeAt(i));
241
  }
242
  }
243
+
244
+ function copyToClipboard() {
 
245
  const transcriptionText = document.getElementById('transcription').innerText;
246
  navigator.clipboard.writeText(transcriptionText)
247
  .then(() => {
 
253
  }
254
  </script>
255
  </body>
256
+ </html>