hmb's picture
hmb HF staff
Update app.py
d075fe5 verified
import gradio as gr
import os
# Multimodal Chatbot demo that shows support for examples (example messages shown within the chatbot).
def print_like_dislike(x: gr.LikeData):
print(x.index, x.value, x.liked)
def add_message(history, message):
for x in message["files"]:
history.append(((x,), None))
if message["text"] is not None:
history.append((message["text"], None))
return history, gr.MultimodalTextbox(value=None, interactive=False)
def append_example_message(x: gr.SelectData, history):
if x.value["text"] is not None:
history.append((x.value["text"], None))
if "files" in x.value:
if isinstance(x.value["files"], list):
for file in x.value["files"]:
history.append((file, None))
else:
history.append((x.value["files"], None))
return history
def respond(history):
history[-1][1] = "Cool!"
return history
with gr.Blocks(fill_height=True) as demo:
chatbot = gr.Chatbot(
elem_id="chatbot",
bubble_full_width=False,
scale=1,
placeholder='<h1 style="font-weight: bold; color: #FFFFFF; text-align: center; font-size: 48px; font-family: Arial, sans-serif;">Welcome to Gradio!</h1>',
examples=[
{"icon": "https://images.pexels.com/photos/1108099/pexels-photo-1108099.jpeg",
"display_text": "Display Text Here!",
"text": "Try this example with this audio.",
"files": [os.path.join(os.path.dirname(__file__), "files/cantina.wav"), os.path.join(os.path.dirname(__file__), "files/cantina.wav"), os.path.join(os.path.dirname(__file__), "files/cantina.wav"), os.path.join(os.path.dirname(__file__), "files/cantina.wav"), os.path.join(os.path.dirname(__file__), "files/cantina.wav"), os.path.join(os.path.dirname(__file__), "files/cantina.wav")]},
{"text": "Try this example with this image.",
"files": ["https://images.pexels.com/photos/1108099/pexels-photo-1108099.jpeg", "https://images.pexels.com/photos/1108099/pexels-photo-1108099.jpeg", "https://images.pexels.com/photos/1108099/pexels-photo-1108099.jpeg", "https://images.pexels.com/photos/1108099/pexels-photo-1108099.jpeg", "https://images.pexels.com/photos/1108099/pexels-photo-1108099.jpeg", "https://images.pexels.com/photos/1108099/pexels-photo-1108099.jpeg"]},
{"text": "This is just text, no files!"},
{"text": "Try this example with this image.",
"files": ["https://images.pexels.com/photos/1108099/pexels-photo-1108099.jpeg"]}
]
)
chat_input = gr.MultimodalTextbox(interactive=True,
file_count="multiple",
placeholder="Enter message or upload file...", show_label=False)
chat_msg = chat_input.submit(add_message, [chatbot, chat_input], [chatbot, chat_input])
bot_msg = chat_msg.then(respond, chatbot, chatbot, api_name="bot_response")
bot_msg.then(lambda: gr.MultimodalTextbox(interactive=True), None, [chat_input])
chatbot.like(print_like_dislike, None, None)
chatbot.example_select(append_example_message, [chatbot], [chatbot]).then(respond, chatbot, chatbot, api_name="respond")
if __name__ == "__main__":
demo.launch()