tykiww's picture
Update app.py
7f2009a verified
raw
history blame
2.29 kB
import gradio as gr
from utilities.setup import get_files
# import spaces
#@spaces.GPU
def process_meeting(audio_input, num_speakers, speaker_names):
if 1 < num_speakers < 6:
answer = "Completed Loading Data", "fl"
else:
answer = "Number of speakers out of range", "fl"
return answer
def main(conf):
with gr.Blocks(theme=gr.themes.Soft(text_size="lg")) as demo:
with gr.TabItem(conf["layout"]["page_names"][0]):
gr.Markdown("# 🎀 Non-Video Meeting Transcription and Speaker Diarization")
gr.Markdown("![](file/microphone_pen_and_paper.png)")
gr.Markdown(get_files.load_markdown_file(conf["layout"]["about"]))
with gr.TabItem(conf["layout"]["page_names"][1]):
gr.Markdown("# πŸ”Š Upload or record your meeting")
audio_input = gr.Audio(type="filepath", label="Upload Audio File")
num_speakers = gr.Dropdown(list(range(conf["session"]["min_speakers"],
conf["session"]["max_speakers"])),
label="Number of Speakers",
value=conf["session"]["min_speakers"])
speaker_names = gr.Dataframe(
label="Type your names and details. Your actual entries will be limited to the speakers you selected above.",
headers=["Name", "Supporting Details"],
datatype=["str", "str"],
row_count=(5,"fixed"),
col_count=(2, "fixed"),
)
process_button = gr.Button("Process")
with gr.TabItem(conf["layout"]["page_names"][2]):
gr.Markdown("# πŸ”Š View and download your meeting transcript")
diarization_output = gr.Textbox(label="Diarization Output")
label_file_link = gr.File(label="Download DAW Labels")
# Process
process_button.click(
fn=process_meeting,
inputs=[audio_input, num_speakers, speaker_names],
outputs=[diarization_output, label_file_link]
)
demo.launch(server_name="0.0.0.0", allowed_paths=["/"])
if __name__ == "__main__":
conf = get_files.json_cfg()
main(conf)