Spaces:
Running
Running
import streamlit as st | |
import os | |
from langchain_huggingface import HuggingFaceEndpoint, ChatHuggingFace | |
from langchain_core.messages import HumanMessage, SystemMessage | |
# Set environment variables | |
hf = os.getenv('HF_TOKEN') | |
os.environ['HUGGINGFACEHUB_API_KEY'] = hf | |
os.environ['HF_TOKEN'] = hf | |
# Initialize DeepSeek model (you can replace this with your own model if needed) | |
def load_deepseek_model(): | |
deep_seek_model = HuggingFaceEndpoint( | |
repo_id="deepseek-ai/DeepSeek-R1", | |
provider="nebius", | |
temperature=0.7, | |
max_new_tokens=150, | |
task="conversational" | |
) | |
return ChatHuggingFace(llm=deep_seek_model) | |
sql_mentor = load_deepseek_model() | |
# Streamlit page setup | |
st.set_page_config(page_title="SQL Mentor Chat", layout="centered") | |
# Improved custom CSS | |
st.markdown(""" | |
<style> | |
.main { | |
background: linear-gradient(to right, #1f4037, #99f2c8); | |
padding: 2rem; | |
font-family: 'Segoe UI', sans-serif; | |
} | |
.stButton>button { | |
background-color: #ffffff10; | |
color: white; | |
font-weight: 600; | |
border-radius: 10px; | |
padding: 0.6rem 1rem; | |
transition: all 0.3s ease; | |
border: 1px solid white; | |
} | |
.stButton>button:hover { | |
background-color: #ffffff30; | |
color: white; | |
border-color: #fff; | |
} | |
h1, h3, p, label { | |
color: white; | |
text-align: center; | |
} | |
.chat-bubble-user { | |
background-color: #ffffff25; | |
padding: 0.75rem 1rem; | |
border-radius: 1rem; | |
margin-bottom: 0.5rem; | |
color: #fff; | |
font-weight: 500; | |
text-align: left; | |
width: fit-content; | |
max-width: 90%; | |
align-self: flex-end; | |
} | |
.chat-bubble-bot { | |
background-color: #ffffff15; | |
padding: 0.75rem 1rem; | |
border-radius: 1rem; | |
margin-bottom: 0.5rem; | |
color: #fff; | |
text-align: left; | |
width: fit-content; | |
max-width: 90%; | |
align-self: flex-start; | |
} | |
.chat-container { | |
display: flex; | |
flex-direction: column; | |
gap: 0.5rem; | |
margin-top: 2rem; | |
} | |
</style> | |
""", unsafe_allow_html=True) | |
# Page title | |
st.markdown("<h1 style='margin-bottom: 0;'>ποΈ SQL Mentor Chat</h1>", unsafe_allow_html=True) | |
st.markdown("<p style='margin-top: 0.2rem;'>Learn SQL interactively from your AI mentor!</p>", unsafe_allow_html=True) | |
# Sidebar for user preference | |
st.sidebar.title("Mentor Preferences") | |
exp = st.sidebar.selectbox("Choose your experience level:", ["Beginner", "Intermediate", "Expert"]) | |
# Session state key | |
PAGE_KEY = "chat_history" | |
# Initialize session state | |
if PAGE_KEY not in st.session_state: | |
st.session_state[PAGE_KEY] = [] | |
# Chat input box | |
st.markdown("<hr>", unsafe_allow_html=True) | |
with st.form(key="chat_form"): | |
user_input = st.text_input("π¬ Ask me anything about SQL:") | |
submit = st.form_submit_button("Send") | |
# Chat logic | |
if submit and user_input: | |
system_prompt = ( | |
f"Act as a SQL mentor with {exp.lower()} expertise. " | |
f"Answer in a friendly tone and within 150 words. " | |
f"If the question is not SQL-related, politely say it's out of scope." | |
) | |
messages = [SystemMessage(content=system_prompt), HumanMessage(content=user_input)] | |
result = sql_mentor.invoke(messages) | |
st.session_state[PAGE_KEY].append((user_input, result.content)) | |
# Show conversation as chat bubbles | |
if st.session_state[PAGE_KEY]: | |
st.markdown('<div class="chat-container">', unsafe_allow_html=True) | |
for user, bot in st.session_state[PAGE_KEY]: | |
st.markdown(f'<div class="chat-bubble-user">π€ <strong>You:</strong> {user}</div>', unsafe_allow_html=True) | |
st.markdown(f'<div class="chat-bubble-bot">π§βπ« <strong>Mentor:</strong> {bot}</div>', unsafe_allow_html=True) | |
st.markdown('</div>', unsafe_allow_html=True) | |