ChenyuRabbitLove's picture
feat/add g-drive coontection
c88c1d9
raw
history blame
3.95 kB
import gradio as gr
from utils.chatbot import Chatbot, VideoChatbot
from utils.utils import *
# start of gradio interface
with gr.Blocks() as demo:
user_chatbot = gr.State(Chatbot())
test_video_chabot = gr.State(VideoChatbot())
with gr.Row():
gr.HTML("Junyi Academy Chatbot")
with gr.Row(equal_height=True):
with gr.Column(scale=5):
with gr.Row():
chatbot = gr.Chatbot()
with gr.Row():
with gr.Column(scale=12):
user_input = gr.Textbox(
show_label=False,
placeholder="Enter text",
container=False,
)
with gr.Column(min_width=70, scale=1):
clear_btn = gr.Button("清除")
with gr.Column(min_width=70, scale=1):
submit_btn = gr.Button("傳送")
with gr.Row():
index_file = gr.File(
file_count="multiple", file_types=["pdf"], label="Upload PDF file", scale=3
)
upload_to_db = gr.CheckboxGroup(
["Upload to Database"],
label="是否上傳至資料庫", info="將資料上傳至資料庫時,資料庫會自動建立索引,下次使用時可以直接檢索,預設為僅作這次使用", scale=1
)
with gr.Row():
instruction = gr.Markdown(
"""
## 使用說明
1. 上傳一個或多個 PDF 檔案,系統將自動進行摘要、翻譯等處理後建立知識庫
2. 在上方輸入欄輸入問題,系統將自動回覆
3. 可以根據下方的摘要內容來提問
4. 每次對話會根據第一個問題的內容來檢索所有文件,並挑選最能回答問題的文件來回覆
5. 要切換檢索的文件,請點選「清除」按鈕後再重新提問
""",
)
with gr.Row():
describe = gr.Markdown("", visible=True)
with gr.Row():
video_text_input = gr.Textbox("", visible=False)
video_text_output = gr.Textbox("", visible=False)
# end of gradio interface
# start of workflow controller
# defining workflow of user bot interaction
bot_args = dict(
fn=bot,
inputs=user_chatbot,
outputs=chatbot,
)
user_args = dict(
fn=user,
inputs=[user_chatbot, user_input],
outputs=[user_input, chatbot],
queue=False,
)
response = user_input.submit(**user_args).then(**bot_args)
response.then(lambda: gr.update(interactive=True), None, [user_input], queue=False)
submit_btn.click(
**user_args,
).then(
**bot_args
).then(lambda: gr.update(interactive=True), None, [user_input], queue=False)
# defining workflow of clear state
clear_state_args = dict(
fn=clear_state,
inputs=user_chatbot,
outputs=None,
)
clear_btn.click(**clear_state_args)
# defining workflow of building knowledge base
send_system_nofification_args = dict(
fn=send_system_nofification,
inputs=user_chatbot,
outputs=chatbot,
)
bulid_knowledge_base_args = dict(
fn=build_knowledge_base,
inputs=[user_chatbot, index_file, upload_to_db],
outputs=None,
)
change_md_args = dict(
fn=change_md,
inputs=[user_chatbot],
outputs=[describe],
)
index_file.upload(**send_system_nofification_args).then(
lambda: gr.update(interactive=True), None, None, queue=False
).then(**bulid_knowledge_base_args).then(**send_system_nofification_args).then(
lambda: gr.update(interactive=True), None, None, queue=False
).then(
**change_md_args
)
video_text_input.submit(video_bot, [test_video_chabot, video_text_input], video_text_output, api_name="video_bot")
if __name__ == "__main__":
demo.launch()