Gaia_Mistral / app.py
Clément Simon
Merge branch 'main' into clément
c593df6
raw
history blame
4.17 kB
import os
import sys
from datetime import datetime
from pathlib import Path
import gradio as gr
import plotly.graph_objects as go
import uvicorn
from dotenv import load_dotenv
from fastapi import FastAPI
from fastapi.staticfiles import StaticFiles
from mistralai.client import ChatMessage, MistralClient
# create a FastAPI app
app = FastAPI()
# create a static directory to store the static files
static_dir = Path('./static')
static_dir.mkdir(parents=True, exist_ok=True)
# mount FastAPI StaticFiles server
app.mount("/static", StaticFiles(directory=static_dir), name="static")
# Gradio stuff
# def predict(text_input):
# file_name = f"{datetime.utcnow().strftime('%s')}.html"
# file_path = static_dir / file_name
# print(file_path)
# with open(file_path, "w") as f:
# f.write(f"""
# <script src="https://cdn.tailwindcss.com"></script>
# <body class="bg-gray-200 dark:text-white dark:bg-gray-900">
# <h1 class="text-3xl font-bold">
# Hello <i>{text_input}</i> From Gradio Iframe
# </h1>
# <h3>Filename: {file_name}</h3>
# """)
# iframe = f"""<iframe src="/static/{file_name}" width="100%" height="500px"></iframe>"""
# link = f'<a href="/static/{file_name}" target="_blank">{file_name}</a>'
# return link, iframe
# with gr.Blocks() as block:
# gr.Markdown("""
# ## Gradio + FastAPI + Static Server
# This is a demo of how to use Gradio with FastAPI and a static server.
# The Gradio app generates dynamic HTML files and stores them in a static directory. FastAPI serves the static files.
# """)
# with gr.Row():
# with gr.Column():
# text_input = gr.Textbox(label="Name")
# markdown = gr.Markdown(label="Output Box")
# new_btn = gr.Button("New")
# with gr.Column():
# html = gr.HTML(label="HTML preview", show_label=True)
# new_btn.click(fn=predict, inputs=[text_input], outputs=[markdown, html])
# Load environment variables
load_dotenv()
api_key = os.getenv('API_KEY')
client = MistralClient(api_key=api_key)
model = 'mistral-small'
title = "Gaia Mistral Chat Demo"
description = "Example of simple chatbot with Gradio and Mistral AI via its API"
placeholder = "Posez moi une question sur l'agriculture"
examples = ["Comment fait on pour produire du maïs ?", "Rédige moi une lettre pour faire un stage dans une exploitation agricole", "Comment reprendre une exploitation agricole ?"]
def chat_with_mistral(user_input):
messages = [ChatMessage(role="user", content=user_input)]
chat_response = client.chat(model=model, messages=messages)
return chat_response.choices[0].message.content
def create_world_map(
lat=45.5017,
lon=-73.5673,
):
fig = go.Figure(go.Scattermapbox
(
lat=[lat],
lon=[lon],
mode='markers',
marker=go.scattermapbox.Marker(size=14),
text=['Montreal'],
))
fig.update_layout(
mapbox_style="open-street-map",
hovermode='closest',
mapbox=dict(
bearing=0,
center=go.layout.mapbox.Center(
lat=lat,
lon=lon,
),
pitch=0,
zoom=5
),
)
return fig
with gr.Blocks() as demo:
with gr.Column():
with gr.Row():
user_input = gr.Textbox(lines=2, placeholder=placeholder)
send_chat_btn = gr.Button(value="Send")
lat = gr.Number(value=45.5017, label="Latitude")
lon = gr.Number(value=-73.5673, label="Longitude")
update_map_btn = gr.Button(value="Update Map")
chat_output = gr.Textbox(lines=2, placeholder="Réponse")
# map:
map = gr.Plot()
demo.load(chat_with_mistral, user_input, chat_output)
send_chat_btn.click(chat_with_mistral, user_input, chat_output)
# map:
demo.load(create_world_map, [lat, lon], map)
update_map_btn.click(create_world_map, [lat, lon], map)
# mount Gradio app to FastAPI app
app = gr.mount_gradio_app(app, demo, path="/")
# serve the app
if __name__ == "__main__":
uvicorn.run(app, host="0.0.0.0", port=7860)