Spaces:
Sleeping
Sleeping
import os | |
import gradio as gr | |
from huggingface_hub import login | |
from transformers import AutoModelForSeq2SeqLM, T5Tokenizer | |
from peft import PeftModel, PeftConfig | |
# Hugging Face login | |
token = os.environ.get("token") | |
login(token) | |
print("login is succesful") | |
max_length=512 | |
# Model and tokenizer setup | |
MODEL_NAME = "google/flan-t5-base" | |
tokenizer = T5Tokenizer.from_pretrained(MODEL_NAME, use_auth_token=token) | |
config = PeftConfig.from_pretrained("Komal-patra/results") | |
base_model = AutoModelForSeq2SeqLM.from_pretrained(MODEL_NAME) | |
model = PeftModel.from_pretrained(base_model, "Komal-patra/results") | |
# Text generation function | |
def generate_text(prompt, max_length=512): | |
inputs = tokenizer(prompt, return_tensors="pt") | |
outputs = model.generate( | |
input_ids=inputs["input_ids"], | |
max_length=max_length, | |
num_beams=1, | |
repetition_penalty=2.2 | |
) | |
generated_text = tokenizer.decode(outputs[0], skip_special_tokens=True) | |
return generated_text | |
# Custom CSS for the UI | |
background_image_path = 'https://www.shlegal-technology.com/sites/default/files/insight/ExploringTheLegislativeBackgroundBANNER.jpg' | |
custom_css = f""" | |
.message.pending {{ | |
background: #A8C4D6; | |
}} | |
/* Response message */ | |
.message.bot.svelte-1s78gfg.message-bubble-border {{ | |
border-color: #266B99; | |
}} | |
/* User message */ | |
.message.user.svelte-1s78gfg.message-bubble-border {{ | |
background: #9DDDF9; | |
border-color: #9DDDF9; | |
}} | |
/* For both user and response message as per the document */ | |
span.md.svelte-8tpqd2.chatbot.prose p {{ | |
color: #266B99; | |
}} | |
/* Chatbot container */ | |
.gradio-container {{ | |
background: #1c1c1c; /* Dark background */ | |
color: white; /* Light text color */ | |
background-image: url('{background_image_path}'); /* Add background image */ | |
background-size: cover; /* Cover the entire container */ | |
background-position: center; /* Center the image */ | |
background-repeat: no-repeat; /* Do not repeat the image */ | |
}} | |
/* RED (Hex: #DB1616) for action buttons and links only */ | |
.clear-btn {{ | |
background: #DB1616; | |
color: white; | |
}} | |
/* Primary colors are set to be used for all sorts */ | |
.submit-btn {{ | |
background: #266B99; | |
color: white; | |
}} | |
/* Add icons to messages */ | |
.message.user.svelte-1s78gfg {{ | |
display: flex; | |
align-items: center; | |
}} | |
.message.user.svelte-1s78gfg:before {{ | |
content: url('file=Komal-patra/EU_AI_ACT/user icon.jpeg'); | |
margin-right: 8px; | |
}} | |
.message.bot.svelte-1s78gfg {{ | |
display: flex; | |
align-items: center; | |
}} | |
.message.bot.svelte-1s78gfg:before {{ | |
content: url('file=Komal-patra/EU_AI_ACT/orcawise image.png'); | |
margin-right: 8px; | |
}} | |
/* Enable scrolling for the chatbot messages */ | |
.chatbot.messages {{ | |
max-height: 500px; /* Adjust as needed */ | |
overflow-y: auto; | |
}} | |
/* Add transparency to chatbox */ | |
.chatbot {{ | |
background-color: rgba(255, 255, 255, 0.5); /* 50% transparent white background */ | |
border: none; | |
box-shadow: none; | |
}} | |
""" | |
# Gradio interface setup | |
with gr.Blocks(css=custom_css) as demo: | |
gr.Markdown("<h1>Ask a question about the EU AI Act</h1>") | |
chatbot = gr.Chatbot() | |
msg = gr.Textbox(placeholder="Ask your question...", show_label=False) # Add placeholder text | |
submit_button = gr.Button("Submit", elem_classes="submit-btn") | |
clear = gr.Button("Clear", elem_classes="clear-btn") | |
# Function to handle user input | |
def user(user_message, history): | |
response = generate_text(user_message) | |
return [user_message, response] | |
# Event listener for submit button | |
submit_button.click(fn=user, inputs=[msg, chatbot], outputs=[chatbot, msg]) | |
# Event listener for clear button | |
clear.click(fn=lambda: "", inputs=None, outputs=msg) | |
demo.launch() |