Skip to content

Commit

Permalink
Fix multiple trigger bug when function has js (#9188)
Browse files Browse the repository at this point in the history
* add code

* add changeset

* lint

---------

Co-authored-by: gradio-pr-bot <[email protected]>
  • Loading branch information
freddyaboulton and gradio-pr-bot authored Sep 10, 2024
1 parent ac2c015 commit 8f8e1c6
Show file tree
Hide file tree
Showing 4 changed files with 44 additions and 33 deletions.
7 changes: 7 additions & 0 deletions .changeset/blue-rooms-run.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
---
"@gradio/audio": patch
"@gradio/core": patch
"gradio": patch
---

fix:Fix multiple trigger bug when function has js
1 change: 0 additions & 1 deletion js/audio/interactive/InteractiveAudio.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -97,7 +97,6 @@
Boolean
) as FileData[]
)[0];
dispatch(event, value);
};
Expand Down
45 changes: 23 additions & 22 deletions js/audio/recorder/AudioRecorder.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -62,17 +62,17 @@
edit: undefined;
}>();
$: record?.on("record-start", () => {
function record_start_callback(): void {
start_interval();
timing = true;
dispatch("start_recording");
if (waveform_options.show_recording_waveform) {
let waveformCanvas = microphoneContainer;
if (waveformCanvas) waveformCanvas.style.display = "block";
}
});
}
$: record?.on("record-end", async (blob) => {
async function record_end_callback(blob: Blob): Promise<void> {
seconds = 0;
timing = false;
clearInterval(interval);
Expand All @@ -91,12 +91,7 @@
} catch (e) {
console.error(e);
}
});
$: record?.on("record-pause", () => {
dispatch("pause_recording");
clearInterval(interval);
});
}
$: record?.on("record-resume", () => {
start_interval();
Expand Down Expand Up @@ -140,6 +135,25 @@
record = micWaveform.registerPlugin(RecordPlugin.create());
record.startMic();
record?.on("record-end", record_end_callback);
record?.on("record-start", record_start_callback);
record?.on("record-pause", () => {
dispatch("pause_recording");
clearInterval(interval);
});
record?.on("record-end", (blob) => {
recordedAudio = URL.createObjectURL(blob);
const microphone = microphoneContainer;
const recording = recordingContainer;
if (microphone) microphone.style.display = "none";
if (recording && recordedAudio) {
recording.innerHTML = "";
create_recording_waveform();
}
});
};
const create_recording_waveform = (): void => {
Expand All @@ -152,19 +166,6 @@
});
};
$: record?.on("record-end", (blob) => {
recordedAudio = URL.createObjectURL(blob);
const microphone = microphoneContainer;
const recording = recordingContainer;
if (microphone) microphone.style.display = "none";
if (recording && recordedAudio) {
recording.innerHTML = "";
create_recording_waveform();
}
});
const handle_trim_audio = async (
start: number,
end: number
Expand Down
24 changes: 14 additions & 10 deletions js/core/src/Blocks.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -238,7 +238,7 @@
.then((v: unknown[]) => {
if (dep.backend_fn) {
payload.data = v;
make_prediction(payload);
trigger_prediction(dep, payload);
} else {
handle_update(v, dep_index);
}
Expand All @@ -253,16 +253,20 @@
);
} else {
if (dep.backend_fn) {
if (dep.trigger_mode === "once") {
if (!dep.pending_request) make_prediction(payload);
} else if (dep.trigger_mode === "multiple") {
trigger_prediction(dep, payload);
}
}
function trigger_prediction(dep: Dependency, payload: Payload): void {
if (dep.trigger_mode === "once") {
if (!dep.pending_request) make_prediction(payload);
} else if (dep.trigger_mode === "multiple") {
make_prediction(payload);
} else if (dep.trigger_mode === "always_last") {
if (!dep.pending_request) {
make_prediction(payload);
} else if (dep.trigger_mode === "always_last") {
if (!dep.pending_request) {
make_prediction(payload);
} else {
dep.final_event = payload;
}
} else {
dep.final_event = payload;
}
}
}
Expand Down

0 comments on commit 8f8e1c6

Please sign in to comment.