Spaces:
Running
Running
import os | |
from dotenv import load_dotenv | |
import gradio as gr | |
from langchain_huggingface import HuggingFaceEndpoint | |
from datetime import datetime | |
# Load environment variables | |
load_dotenv() | |
HF_TOKEN = os.getenv("HF_TOKEN") | |
# Initialize the HuggingFace inference endpoint | |
llm = HuggingFaceEndpoint( | |
repo_id="mistralai/Mistral-7B-Instruct-v0.3", | |
huggingfacehub_api_token=HF_TOKEN.strip(), | |
temperature=0.7, | |
) | |
# Input validation function | |
def validate_ingredients(ingredients): | |
prompt = ( | |
f"Review the provided list of items: {ingredients}. " | |
f"Determine if all items are valid food ingredients. " | |
f"Respond only with 'Valid' if all are valid food items or 'Invalid' if any are not." | |
) | |
response = llm(prompt) | |
return response.strip() | |
# Recipe generation function | |
def generate_recipe(ingredients): | |
prompt = ( | |
f"You are an expert chef. Using the ingredients: {ingredients}, " | |
f"suggest two recipes. Provide a title, preparation time, and step-by-step instructions. " | |
f"It is not mandatory to include all ingredients, pick the ingredients required for each recipe. " | |
f"Do not include the ingredient list explicitly in the response." | |
) | |
response = llm(prompt) | |
return response.strip() | |
# Combined function for Gradio | |
def suggest_recipes(ingredients): | |
validation_result = validate_ingredients(ingredients) | |
if validation_result == "Valid": | |
return generate_recipe(ingredients) | |
else: | |
return "I'm sorry, but I can't process this request due to invalid ingredients. Please provide valid ingredients for cooking!" | |
# Feedback function | |
def save_feedback(feedback): | |
if feedback.strip(): | |
with open("feedback.txt", "a") as file: | |
file.write(f"{datetime.now()}: {feedback}\n") | |
return "Thank you for your feedback!" | |
return "Please enter feedback before submitting." | |
# Gradio interface with professional color theme | |
with gr.Blocks(theme=gr.themes.Monochrome(primary_hue="blue")) as app: | |
# Header section with professional background and white text | |
with gr.Row(): | |
gr.HTML( | |
""" | |
<div style="text-align: center; margin: auto;"> | |
<h1 style="color: #1155ff; font-size: 3.5em; font-weight: bold; font-family: 'Arial', sans-serif; margin-bottom: 0.5em;">🍳 Recipe Generator !</h1> | |
<p style="font-size: 1.5em; color: #555555; font-weight: lighter; font-family: 'Verdana', sans-serif;"> | |
Enter the ingredients you have, and we'll validate them and suggest delightful recipes! | |
</p> | |
</div> | |
""" | |
) | |
# Banner Image | |
with gr.Row(): | |
gr.Image("./recipe-generator-banner.png", show_label=False, elem_id="banner-image", width="100%") | |
# Ingredient input and output with borders and padding for more contrast | |
with gr.Row(): | |
with gr.Column(): | |
ingredients_input = gr.Textbox( | |
label="Enter Ingredients (comma-separated):", | |
placeholder="e.g., eggs, milk, flour", | |
elem_id="input-box", | |
show_label=True, | |
interactive=True, | |
lines=2, | |
max_lines=5 | |
) | |
with gr.Column(): | |
recipe_output = gr.Textbox( | |
label="Suggested Recipes or Validation Result:", | |
lines=15, | |
interactive=False, | |
elem_id="output-box" | |
) | |
# Buttons with professional color design and hover effect | |
with gr.Row(): | |
generate_button = gr.Button("Get Recipes", elem_id="generate-btn", size="lg") | |
reset_button = gr.Button("Reset", elem_id="reset-btn", size="lg") | |
generate_button.click(suggest_recipes, inputs=ingredients_input, outputs=recipe_output) | |
reset_button.click(lambda: "", inputs=None, outputs=ingredients_input) | |
# Feedback Section with professional styled input fields | |
with gr.Row(): | |
feedback_input = gr.Textbox( | |
label="Feedback:", | |
placeholder="Let us know how we can improve!", | |
elem_id="feedback-input", | |
lines=1 | |
) | |
feedback_button = gr.Button("Submit", elem_id="feedback-btn", size="lg") | |
feedback_output = gr.Textbox( | |
label="Feedback Response:", | |
lines=1, | |
interactive=False, | |
elem_id="feedback-output" | |
) | |
feedback_button.click(save_feedback, inputs=feedback_input, outputs=feedback_output) | |
# Footer with contact link | |
with gr.Row(): | |
gr.Markdown( | |
""" | |
<div style="text-align: center; margin-top: 2em;"> | |
<p style="font-size: 1em; color:#333333; font-family: 'Arial', sans-serif;"> | |
Developed by CloudYuga! Your feedback is valuable. Have questions? | |
<a href="mailto:[email protected]" style="color: #0000FF; font-weight: bold; text-decoration: underline;">Contact us!</a> | |
</p> | |
</div> | |
""" | |
) | |
# Apply custom professional theme styling | |
app.css = """ | |
body { | |
background-color: #f4f4f9; /* Soft background */ | |
color: #333333; | |
font-family: 'Arial', sans-serif; | |
} | |
#input-box, #output-box, #feedback-input { | |
background-color: #ffffff; | |
border: 2px solid #cccccc; | |
border-radius: 8px; | |
padding: 12px; | |
color: #333333; | |
font-size: 1.1em; | |
} | |
#generate-btn, #reset-btn, #feedback-btn { | |
border-radius: 8px; | |
padding: 15px 30px; | |
font-size: 1.2em; | |
transition: background-color 0.3s ease; | |
} | |
#generate-btn { | |
background-color: #4caf50; /* Green for recipe button */ | |
color: #fff; | |
} | |
#generate-btn:hover { | |
background-color: #45a049; | |
} | |
#reset-btn { | |
background-color: #ff9800; /* Orange for reset button */ | |
color: #fff; | |
} | |
#reset-btn:hover { | |
background-color: #fb8c00; | |
} | |
#feedback-btn { | |
background-color: #2196f3; /* Blue for feedback button */ | |
color: #fff; | |
} | |
#feedback-btn:hover { | |
background-color: #1e88e5; | |
} | |
#banner-image { | |
width: 100%; | |
height: auto; | |
border-radius: 10px; | |
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); | |
} | |
""" | |
# Launch the app | |
app.launch() | |