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}")