Anshini's picture
Update pages/GenAI.py
84fa53d verified
import streamlit as st
import os
from langchain_huggingface import HuggingFaceEndpoint, ChatHuggingFace
from langchain_core.messages import HumanMessage, SystemMessage
# Load Hugging Face token from environment
hf = os.getenv('HF_TOKEN')
os.environ['HUGGINGFACEHUB_API_TOKEN'] = hf
os.environ['HF_TOKEN'] = hf
# --- Page Config ---
st.set_page_config(page_title="GenAI Mentor", layout="wide")
# --- Custom CSS Styling ---
st.markdown("""
<style>
body {
background-color: #1e1e2f;
font-family: 'Segoe UI', sans-serif;
}
.main {
background: linear-gradient(to right, #3e32a8, #80ffe0);
padding: 2rem;
border-radius: 12px;
}
h1, h2, h3, p, label {
color: white !important;
text-align: center;
}
.stTextInput>div>div>input {
border: 1px solid #ddd;
border-radius: 10px;
padding: 0.5rem;
font-size: 16px;
width: 100%;
}
.stButton>button {
background-color: #6a00ff;
color: white;
padding: 0.6rem 1.2rem;
font-size: 16px;
border: none;
border-radius: 10px;
transition: 0.3s ease;
}
.stButton>button:hover {
background-color: #5300e8;
}
.chat-box {
background-color: #ffffff15;
border-radius: 12px;
padding: 1rem;
margin-bottom: 1rem;
color: white;
line-height: 1.6;
}
.user-msg {
color: #e0e0e0;
font-weight: 600;
}
.bot-msg {
color: #ffffff;
margin-top: 0.3rem;
}
hr {
border: 0;
height: 1px;
background: #ffffff30;
margin: 1.5rem 0;
}
</style>
""", unsafe_allow_html=True)
# --- Title ---
st.title("🤖 GenAI Mentor Chat")
st.markdown("<p style='font-size:18px;'>Empowering your AI journey—one question at a time.</p>", unsafe_allow_html=True)
# --- Sidebar ---
st.sidebar.title("Mentor Preferences")
experience_label = st.sidebar.selectbox("Choose your experience level:", ["Beginner", "Intermediate", "Expert"])
# --- Model Initialization ---
genai_skeleton = HuggingFaceEndpoint(
repo_id='google/gemma-2-9b-it',
provider='nebius',
temperature=0.7,
max_new_tokens=150,
task='conversational'
)
genai_chat = ChatHuggingFace(
llm=genai_skeleton,
repo_id='google/gemma-2-9b-it',
provider='nebius',
temperature=0.7,
max_new_tokens=150,
task='conversational'
)
# --- Session Key ---
PAGE_KEY = "genai_chat_history"
if PAGE_KEY not in st.session_state:
st.session_state[PAGE_KEY] = []
# --- Chat Form ---
with st.form(key="chat_form"):
st.markdown("#### 💬 Ask your question:")
user_input = st.text_input("", placeholder="Type your Generative AI question here...")
submit = st.form_submit_button("Send")
# --- Handle Submission ---
if submit and user_input:
system_prompt = (
f"Act as a Generative AI mentor with {experience_label} expertise. "
f"Explain concepts in a friendly tone, within 150 words. "
f"If the question is not related to Generative AI, politely say it's out of scope."
)
messages = [SystemMessage(content=system_prompt), HumanMessage(content=user_input)]
result = genai_chat.invoke(messages)
st.session_state[PAGE_KEY].append((user_input, result.content))
# --- Display Chat History ---
st.subheader("🗨️ Conversation History")
for user, bot in reversed(st.session_state[PAGE_KEY]):
st.markdown(f"""
<div class="chat-box">
<div class="user-msg">🧑‍💻 <strong>You:</strong> {user}</div>
<div class="bot-msg">🤖 <strong>Mentor:</strong> {bot}</div>
</div>
""", unsafe_allow_html=True)