Update app.py
Browse files
app.py
CHANGED
@@ -1,6 +1,7 @@
|
|
1 |
import streamlit as st
|
2 |
import importlib
|
3 |
from io import BytesIO
|
|
|
4 |
|
5 |
st.set_page_config(page_title="Multilingual Translator", page_icon="🌐", layout="centered")
|
6 |
|
@@ -21,6 +22,7 @@ def main():
|
|
21 |
user_text = doc_file.read().decode("utf-8").strip() if doc_file else ""
|
22 |
|
23 |
if user_text:
|
|
|
24 |
detected_options = lang_detect.detect_language(user_text) if len(user_text) >= 10 else [("English", 1.0, "English")]
|
25 |
source_lang = detected_options[0][0] if detected_options else "English"
|
26 |
|
@@ -39,17 +41,20 @@ def main():
|
|
39 |
target_lang = next((k for k, v in native_lang_map.items() if v == target_lang_display), "Hindi")
|
40 |
|
41 |
if st.button("Translate", key="translate_btn"):
|
42 |
-
|
43 |
-
|
44 |
-
|
45 |
-
|
46 |
-
|
47 |
-
|
|
|
|
|
|
|
48 |
|
49 |
with col2:
|
50 |
if "translated_text" in st.session_state and st.session_state.translated_text:
|
51 |
-
st.
|
52 |
-
st.write(st.session_state.
|
53 |
output_option = st.radio("Output", ["Text", "Audio"], horizontal=True, key="output_option")
|
54 |
if output_option == "Audio":
|
55 |
audio = audio_processor.text_to_speech(st.session_state.translated_text, target_lang)
|
@@ -57,7 +62,13 @@ def main():
|
|
57 |
st.audio(audio, format="audio/mp3")
|
58 |
st.success("Audio playing.")
|
59 |
else:
|
60 |
-
st.error("Audio generation failed.
|
|
|
|
|
|
|
|
|
|
|
|
|
61 |
|
62 |
st.markdown("""
|
63 |
<p style='font-size: small; color: grey; text-align: center; margin-top: 20px;'>
|
|
|
1 |
import streamlit as st
|
2 |
import importlib
|
3 |
from io import BytesIO
|
4 |
+
import time
|
5 |
|
6 |
st.set_page_config(page_title="Multilingual Translator", page_icon="🌐", layout="centered")
|
7 |
|
|
|
22 |
user_text = doc_file.read().decode("utf-8").strip() if doc_file else ""
|
23 |
|
24 |
if user_text:
|
25 |
+
start_time = time.time()
|
26 |
detected_options = lang_detect.detect_language(user_text) if len(user_text) >= 10 else [("English", 1.0, "English")]
|
27 |
source_lang = detected_options[0][0] if detected_options else "English"
|
28 |
|
|
|
41 |
target_lang = next((k for k, v in native_lang_map.items() if v == target_lang_display), "Hindi")
|
42 |
|
43 |
if st.button("Translate", key="translate_btn"):
|
44 |
+
with st.spinner("Translating..."):
|
45 |
+
try:
|
46 |
+
translated_text = translation.translate(user_text, source_lang, target_lang)
|
47 |
+
st.session_state.translated_text = translated_text
|
48 |
+
st.session_state.translation_time = time.time() - start_time
|
49 |
+
except Exception as e:
|
50 |
+
st.error(f"Translation failed: {str(e)}. Using input as fallback.")
|
51 |
+
st.session_state.translated_text = user_text
|
52 |
+
st.session_state.translation_time = time.time() - start_time
|
53 |
|
54 |
with col2:
|
55 |
if "translated_text" in st.session_state and st.session_state.translated_text:
|
56 |
+
st.text_area("Translation:", value=st.session_state.translated_text, height=len(st.session_state.translated_text.splitlines()) * 20 + 50, key="output_area")
|
57 |
+
st.write(f"Translation time: {st.session_state.translation_time:.2f} seconds")
|
58 |
output_option = st.radio("Output", ["Text", "Audio"], horizontal=True, key="output_option")
|
59 |
if output_option == "Audio":
|
60 |
audio = audio_processor.text_to_speech(st.session_state.translated_text, target_lang)
|
|
|
62 |
st.audio(audio, format="audio/mp3")
|
63 |
st.success("Audio playing.")
|
64 |
else:
|
65 |
+
st.error("Audio generation failed. Retrying with English...")
|
66 |
+
audio_fallback = audio_processor.text_to_speech(st.session_state.translated_text, "English")
|
67 |
+
if audio_fallback and audio_fallback.getbuffer().nbytes > 0:
|
68 |
+
st.audio(audio_fallback, format="audio/mp3")
|
69 |
+
st.success("Fallback audio in English playing.")
|
70 |
+
else:
|
71 |
+
st.error("Audio generation failed. Try again later or use English/French.")
|
72 |
|
73 |
st.markdown("""
|
74 |
<p style='font-size: small; color: grey; text-align: center; margin-top: 20px;'>
|