import streamlit as st
import datetime
import os
import base64
# Initialize session state variables
if 'transcript_history' not in st.session_state:
st.session_state.transcript_history = []
# Function to create a download link for a string
def get_download_link(text, filename):
b64 = base64.b64encode(text.encode()).decode()
return f'Download Transcript'
# Create the main layout
st.title("Speech Recognition with Transcript History")
col1, col2 = st.columns([2, 1])
with col1:
html = """
Continuous Speech Demo
Ready
"""
# Display the HTML component
component = st.components.v1.html(html, height=400)
with col2:
# Display transcript history
st.subheader("Transcript History")
# Function to save transcript
def save_transcript(text):
if not os.path.exists('transcripts'):
os.makedirs('transcripts')
timestamp = datetime.datetime.now().strftime('%Y%m%d_%H%M%S')
filename = f"transcripts/transcript_{timestamp}.md"
with open(filename, 'w', encoding='utf-8') as f:
f.write(text)
return filename
# Display transcript
if st.session_state.transcript_history:
full_transcript = "\n".join(st.session_state.transcript_history)
st.text_area("Full Transcript", value=full_transcript, height=300)
# Save transcript to file
timestamp = datetime.datetime.now().strftime('%Y%m%d_%H%M%S')
filename = f"transcript_{timestamp}.md"
# Create download link
st.markdown(get_download_link(full_transcript, filename), unsafe_allow_html=True)
# Save to file system
if st.button("Save to File"):
saved_file = save_transcript(full_transcript)
st.success(f"Saved to {saved_file}")
# Handle transcript updates from JavaScript
if component:
try:
data = component
if isinstance(data, dict) and data.get('type') == 'transcript':
st.session_state.transcript_history.append(data['text'])
st.experimental_rerun()
elif isinstance(data, dict) and data.get('type') == 'clear':
st.session_state.transcript_history = []
st.experimental_rerun()
except Exception as e:
st.error(f"Error processing transcript: {e}")