import os import time from typing import List, Tuple, Optional import google.generativeai as genai import gradio as gr from PIL import Image print("google-generativeai:", genai.__version__) GOOGLE_API_KEY = os.environ.get("GOOGLE_API_KEY") TITLE = """

👗 Gemini Personal Stylist Chatbot 🛍️

""" SUBTITLE = """

💅 Get ready with your personal stylist

""" DUPLICATE = """
Duplicate Space Duplicate the Space and run securely with your GOOGLE API KEY.
""" IMAGE_WIDTH = 512 def preprocess_image(image: Image.Image) -> Image.Image: image_height = int(image.height * IMAGE_WIDTH / image.width) return image.resize((IMAGE_WIDTH, image_height)) def user(text_prompt: str, chatbot: List[Tuple[str, str]]): return "", chatbot + [[text_prompt, None]] def bot( google_key: str, image_prompt: Optional[Image.Image], text_prompt: str, chatbot: List[Tuple[str, str]] ): google_key = google_key or GOOGLE_API_KEY if not google_key: raise ValueError("GOOGLE_API_KEY is not set. Please set it up.") genai.configure(api_key=google_key) instructions = "You are an expert stylist. You suggest and evaluate any style-related question to make anyone, regardless of gender, race, or any other demographic diversity, look stylish." model_name = 'gemini-pro-vision' if image_prompt else 'gemini-flash-latest' if image_prompt: images_with_prompt = [text_prompt, instructions, preprocess_image(image_prompt)] model = genai.GenerativeModel(model_name) response = model.generate_content(images_with_prompt, stream=True) else: text_with_prompt = [text_prompt, instructions] model = genai.GenerativeModel(model_name) response = model.generate_content(text_with_prompt, stream=True) response.resolve() chatbot[-1][1] = "" for chunk in response: for i in range(0, len(chunk.text), 10): chatbot[-1][1] += chunk.text[i:i + 10] time.sleep(0.01) yield chatbot google_key_component = gr.Textbox( label="GOOGLE API KEY", type="password", placeholder="Enter your Google API Key", visible=GOOGLE_API_KEY is None ) image_prompt_component = gr.Image(type="pil", label="Upload Image", width=200) text_prompt_component = gr.Textbox( placeholder="Describe your style needs", label="Enter your prompt", width=300 ) run_button_component = gr.Button("Ask Stylist") with gr.Blocks() as demo: gr.HTML(TITLE) gr.HTML(SUBTITLE) gr.HTML(DUPLICATE) with gr.Row(): google_key_component.render() with gr.Row(): text_prompt_component.render() image_prompt_component.render() chatbot_component = gr.Chatbot(label='Gemini Personal Stylist') chatbot_component.render() run_button_component.render() run_button_component.click( inputs=[text_prompt_component, image_prompt_component, chatbot_component], outputs=chatbot_component, fn=bot ) demo.launch()