File size: 3,185 Bytes
33473a0
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
console.log("Whisper STT script loaded");

let mediaRecorder;
let audioChunks = [];
let isRecording = false;

window.startStopRecording = function() {
  if (!navigator.mediaDevices || !navigator.mediaDevices.getUserMedia) {
    console.error("getUserMedia not supported on your browser!");
    return;
  }

  if (isRecording == false) {
    //console.log("Start recording function called");
    navigator.mediaDevices.getUserMedia({ audio: true })
      .then(stream => {
        //console.log("Got audio stream");
        mediaRecorder = new MediaRecorder(stream);
        audioChunks = []; // Reset audio chunks
        mediaRecorder.start();
        //console.log("MediaRecorder started");
        recButton.icon;
        recordButton.innerHTML = recButton.innerHTML = "Stop";
        isRecording = true;

        mediaRecorder.addEventListener("dataavailable", event => {
          //console.log("Data available event, data size: ", event.data.size);
          audioChunks.push(event.data);
        });
                
        mediaRecorder.addEventListener("stop", () => {
          //console.log("MediaRecorder stopped");
          if (audioChunks.length > 0) {
            const audioBlob = new Blob(audioChunks, { type: "audio/webm" });
            //console.log("Audio blob created, size: ", audioBlob.size);
            const reader = new FileReader();
            reader.readAsDataURL(audioBlob);
            reader.onloadend = function() {
              const base64data = reader.result;
              //console.log("Audio converted to base64, length: ", base64data.length);
                            
              const audioBase64Input = document.querySelector("#audio-base64 textarea");
              if (audioBase64Input) {
                audioBase64Input.value = base64data;
                audioBase64Input.dispatchEvent(new Event("input", { bubbles: true }));
                audioBase64Input.dispatchEvent(new Event("change", { bubbles: true }));
                //console.log("Updated textarea with base64 data");
              } else {
                console.error("Could not find audio-base64 textarea");
              }
            };
          } else {
            console.error("No audio data recorded for Whisper");
          }
        });
      });
  } else {
    //console.log("Stopping MediaRecorder");
    recordButton.innerHTML = recButton.innerHTML = "Rec.";
    isRecording = false;
    mediaRecorder.stop();
  }
};

const recordButton = gradioApp().querySelector("#record-button");
recordButton.addEventListener("click", window.startStopRecording);


function gradioApp() {
  const elems = document.getElementsByTagName("gradio-app");
  const gradioShadowRoot = elems.length == 0 ? null : elems[0].shadowRoot;
  return gradioShadowRoot ? gradioShadowRoot : document;
}


// extra rec button next to generate button
var recButton = recordButton.cloneNode(true);
var generate_button = document.getElementById("Generate");
generate_button.insertAdjacentElement("afterend", recButton);

recButton.style.setProperty("margin-left", "-10px");
recButton.innerHTML = "Rec.";

recButton.addEventListener("click", function() {
  recordButton.click();
});