Spaces:
Running
Running
<html> | |
<head> | |
<title>Fast TTS</title> | |
<meta charset="UTF-8"> | |
<meta name="viewport" content="width=device-width, initial-scale=1.0"> | |
<link rel="stylesheet" href="/static/styles.css"> <!-- Link to your external CSS file --> | |
<!-- Add any CSS links or styles here --> | |
</head> | |
<body> | |
<form method="post" action="/" onsubmit="showLoadingMessage()"> | |
<div> | |
<label for="text_input">Text to synthesize:</label> | |
<textarea id="text_input" name="text_input" rows="5" cols="50">{{ text_input }}</textarea> | |
</div> | |
<div> | |
<label for="selection">Select speaker:</label> | |
<select id="speaker" name="speaker"> | |
{% for option in data.speaker_options %} | |
<option {% if option == data.default_speaker %}selected{% endif %}>{{ option }}</option> | |
{% endfor %} | |
</select> | |
</div> | |
<!-- Select a model --> | |
<div> | |
<label for="selected_model">Select a model:</label> | |
<select id="selected_model" name="selected_model"> | |
{% for model_name in onnx_models %} | |
<option value="{{ model_name }}">{{ model_name }}</option> | |
{% endfor %} | |
</select> | |
</div> | |
<!-- Display speaker options --> | |
<div> | |
<label for="selected_speaker_id">Select a speaker:</label> | |
<select id="selected_speaker_id" name="selected_speaker_id"> | |
{% for speaker_id, speaker_name in speaker_id_map.items() %} | |
<option value="{{ speaker_id }}">{{ speaker_name }}</option> | |
{% endfor %} | |
</select> | |
</div> | |
<div id="speaker_selection" style="display: none;"> | |
<!-- Dropdown for speaker selection --> | |
</div> | |
<div> | |
<label for="speed_slider">Rate scale:</label> | |
<input type="range" id="speed_slider" name="speed_slider" min="0.25" max="2" step="0.1" value="1"> | |
</div> | |
<div> | |
<label for="noise_scale_slider">Phoneme noise scale:</label> | |
<input type="range" id="noise_scale_slider" name="noise_scale_slider" min="0.25" max="1" step="0.1" value="0.667"> | |
</div> | |
<div> | |
<label for="noise_scale_w_slider">Phoneme stressing scale:</label> | |
<input type="range" id="noise_scale_w_slider" name="noise_scale_w_slider" min="0.25" max="1" step="0.1" value="1"> | |
</div> | |
<!-- Add a div with the "loading-message" ID for the loading message --> | |
<div id="loading-message"></div> | |
<!-- Include the dynamic content from response_html --> | |
{{ response_html|safe }} | |
<div> | |
<button type="submit" id="synthesize_button">Synthesize</button> | |
</div> | |
{% if file_url %} | |
<h2>Generated Audio</h2> | |
<audio controls id="audio-player"> | |
<source src="{{ file_url }}" type="audio/mpeg"> | |
Your browser does not support the audio element. | |
</audio> | |
<a href="{{ file_url }}" download>Download Audio</a> | |
{% endif %} | |
<script> | |
function showLoadingMessage() { | |
// Display the loading message | |
document.getElementById("loading-message").innerText = "Generating your audio, please wait..."; | |
// Optionally, you can disable the form elements to prevent further interactions while waiting | |
document.getElementById("synthesize_button").disabled = true; | |
} | |
</script> | |
</form> | |
<script> | |
const selectedModelDropdown = document.getElementById("selected_model"); | |
const speakerDropdown = document.getElementById("selected_speaker_id"); | |
selectedModelDropdown.addEventListener("change", () => { | |
const selectedModel = selectedModelDropdown.value; | |
// Fetch speaker options for the selected model | |
fetch(`/get_speaker_id_map?selected_model=${selectedModel}`) | |
.then(response => response.json()) | |
.then(data => { | |
const speakerIdMap = data.speaker_id_map; | |
speakerDropdown.innerHTML = ""; // Clear existing options | |
for (const [speakerId, speakerName] of Object.entries(speakerIdMap)) { | |
const option = document.createElement("option"); | |
option.value = speakerId; | |
option.textContent = speakerName; | |
speakerDropdown.appendChild(option); | |
} | |
}) | |
.catch(error => console.error("Error fetching speaker options:", error)); | |
}); | |
</script> | |
<!-- Move the JavaScript code outside the conditional block --> | |
</body> | |
</html> | |