File size: 3,299 Bytes
4f48282
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
# gradio_interface.py
import gradio as gr
from config.config import prompts, models  # Indirect import
from src.img_gen_diffusers import generate_image

print("Hello from gradio_interface_head!")

# Modal remote function synchronously
def generate(prompt_dropdown, team_dropdown, model_dropdown, custom_prompt_input):
    # Debug: Print a message instead of generating an image
    debug_message = f"Debug: Button clicked! Inputs - Prompt: {prompt_dropdown}, Team: {team_dropdown}, Model: {model_dropdown}, Custom Prompt: {custom_prompt_input}"
    print(debug_message)  # Print to console for debugging
    try:
        # Import the remote function
        image_path, message = generate_image(prompt_dropdown, team_dropdown, model_dropdown, custom_prompt_input)
        return image_path, message
    except Exception as e:
        return None, f"An error occurred: {e}"
    
def generate_gpu(prompt_dropdown, team_dropdown, model_dropdown, custom_prompt_input):
    # Debug: Print a message instead of generating an image
    debug_message = f"Debug: Button clicked! Inputs - Prompt: {prompt_dropdown}, Team: {team_dropdown}, Model: {model_dropdown}, Custom Prompt: {custom_prompt_input}"
    print(debug_message)  # Print to console for debugging
    try:
        # Import the remote function
        f = modal.Function.from_name("img-gen-modal-gpu", "generate_image")
        image_path, message = f.remote(prompt_dropdown, team_dropdown, model_dropdown, custom_prompt_input)
        return image_path, message
    except Exception as e:
        return None, f"An error occurred: {e}"
   

def gradio_interface_diffusers():
    from config.config import prompts, models  # Indirect import
    # Gradio Interface
    with gr.Blocks() as demo:
        gr.Markdown("# CtB AI Image Generator")
        with gr.Row():
            # Set default values for dropdowns
            prompt_dropdown = gr.Dropdown(choices=[p["alias"] for p in prompts], label="Select Prompt", value=prompts[0]["alias"])
            team_dropdown = gr.Dropdown(choices=["Red", "Blue"], label="Select Team", value="Red")
            model_dropdown = gr.Dropdown(choices=[m["alias"] for m in models], label="Select Model", value=models[0]["alias"])
        with gr.Row():
            # Add a text box for custom user input (max 200 characters)
            custom_prompt_input = gr.Textbox(label="Custom Prompt (Optional)", placeholder="Enter additional details (max 200 chars)...", max_lines=1, max_length=200)
        with gr.Row():
            generate_button = gr.Button("Generate Image")
        with gr.Row():
            output_image = gr.Image(label="Generated Image")
        with gr.Row():
            status_text = gr.Textbox(label="Status", placeholder="Waiting for input...", interactive=False)
        print("Building cudasdasrer...")

        ##Connect the button to the call_generate function 
        ##had do do it to handle gradio/modal interaction)
        generate_button.click(
        generate,
        inputs=[prompt_dropdown, team_dropdown, model_dropdown, custom_prompt_input],
        outputs=[output_image, status_text],
        )
    return demo

# Create the demo instance
demo = gradio_interface_diffusers()

# Only launch if running directly
if __name__ == "__main__":
    demo.queue().launch()