| | import streamlit as st |
| | import google.generativeai as genai |
| | from PIL import Image |
| | import os |
| |
|
| | genai.configure(api_key = os.getenv('GOOGLE_API_KEY')) |
| |
|
| | model=genai.GenerativeModel('gemini-1.5-pro-latest') |
| | input_prompt = """ |
| | As an HTML and CSS expert, your task is to create complete HTML and CSS code based on the provided screenshot, ensuring clear and functional markup. Provide a main.html file with inline CSS that replicates the exact color and style as shown in the given screenshot. |
| | Output structure: |
| | Start and end with (```) |
| | """ |
| |
|
| | def generate_response(input_prompt,image): |
| | response = model.generate_content([input_prompt,image[0]]) |
| | |
| | return response.text |
| |
|
| | def input_image_setup(uploaded_file): |
| | |
| | if uploaded_file is not None: |
| | |
| | bytes_data = uploaded_file.getvalue() |
| |
|
| | image_parts = [ |
| | { |
| | "mime_type": uploaded_file.type, |
| | "data": bytes_data |
| | } |
| | ] |
| | return image_parts |
| | else: |
| | raise FileNotFoundError("No file uploaded") |
| | |
| | st.title("Screenshot -> HTML") |
| | st.text("Upload Image Here:") |
| |
|
| | upload_file = st.file_uploader('',type=['jpg','jpeg','png']) |
| | if upload_file is not None: |
| | image = Image.open(upload_file) |
| | st.image(image, caption="Uploaded Image", use_column_width=True) |
| | |
| | submit = st.button('Create a webpage') |
| | if submit: |
| | image_data = input_image_setup(uploaded_file=upload_file) |
| | with st.spinner("Building the Webpage..."): |
| | response = generate_response(input_prompt, image_data) |
| | st.subheader("CODE:") |
| | st.markdown(response) |