waloneai commited on
Commit
2717910
·
verified ·
1 Parent(s): f6084c1

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +23 -27
app.py CHANGED
@@ -16,15 +16,12 @@ headers = {"Authorization": f"Bearer {API_TOKEN}"}
16
  timeout = 100
17
 
18
  # Function to query the API and return the generated image
19
- def query(prompt, is_negative=False, steps=35, cfg_scale=7, sampler="DPM++ 2M Karras", seed=-1, strength=0.7, width=1024, height=1024):
20
- if prompt == "" or prompt is None:
21
- return None
22
 
23
  key = random.randint(0, 999)
24
-
25
- API_TOKEN = random.choice([os.getenv("HF_READ_TOKEN")])
26
- headers = {"Authorization": f"Bearer {API_TOKEN}"}
27
-
28
  # Translate the prompt from Russian to English if necessary
29
  prompt = GoogleTranslator(source='my', target='en').translate(prompt)
30
  print(f'\033[1mGeneration {key} translation:\033[0m {prompt}')
@@ -32,30 +29,30 @@ def query(prompt, is_negative=False, steps=35, cfg_scale=7, sampler="DPM++ 2M Ka
32
  # Add some extra flair to the prompt
33
  prompt = f"{prompt} | ultra detail, ultra elaboration, ultra quality, perfect."
34
  print(f'\033[1mGeneration {key}:\033[0m {prompt}')
35
-
36
  # Prepare the payload for the API call, including width and height
37
  payload = {
38
  "inputs": prompt,
39
- "is_negative": is_negative,
40
- "steps": steps,
41
- "cfg_scale": cfg_scale,
42
- "seed": seed if seed != -1 else random.randint(1, 1000000000),
43
- "strength": strength,
44
  "parameters": {
45
- "width": width, # Pass the width to the API
46
- "height": height # Pass the height to the API
 
 
 
 
 
 
47
  }
48
  }
49
 
50
  # Send the request to the API and handle the response
51
  response = requests.post(API_URL, headers=headers, json=payload, timeout=timeout)
52
  if response.status_code != 200:
53
- print(f"Error: Failed to get image. Response status: {response.status_code}")
54
- print(f"Response content: {response.text}")
55
  if response.status_code == 503:
56
- raise gr.Error(f"{response.status_code} : The model is being loaded")
57
- raise gr.Error(f"{response.status_code}")
58
-
59
  try:
60
  # Convert the response content into an image
61
  image_bytes = response.content
@@ -63,8 +60,7 @@ def query(prompt, is_negative=False, steps=35, cfg_scale=7, sampler="DPM++ 2M Ka
63
  print(f'\033[1mGeneration {key} completed!\033[0m ({prompt})')
64
  return image
65
  except Exception as e:
66
- print(f"Error when trying to open the image: {e}")
67
- return None
68
 
69
  # CSS to style the app
70
  css = """
@@ -79,7 +75,7 @@ css = """
79
  with gr.Blocks(theme='Nymbo/Nymbo_Theme', css=css) as app:
80
  # Add a title to the app
81
  gr.HTML("<center><h1>Walone AI Image Pro Large</h1></center>")
82
-
83
  # Container for all the UI elements
84
  with gr.Column(elem_id="app-container"):
85
  # Add a text input for the main prompt
@@ -87,7 +83,7 @@ with gr.Blocks(theme='Nymbo/Nymbo_Theme', css=css) as app:
87
  with gr.Column(elem_id="prompt-container"):
88
  with gr.Row():
89
  text_prompt = gr.Textbox(label="Prompt", placeholder="Prompt စာသားရေးပါ", lines=2, elem_id="prompt-text-input")
90
-
91
  # Accordion for advanced settings
92
  with gr.Row():
93
  with gr.Accordion("Advanced Settings", open=False):
@@ -104,13 +100,13 @@ with gr.Blocks(theme='Nymbo/Nymbo_Theme', css=css) as app:
104
  # Add a button to trigger the image generation
105
  with gr.Row():
106
  text_button = gr.Button("Run", variant='primary', elem_id="gen-button")
107
-
108
  # Image output area to display the generated image
109
  with gr.Row():
110
  image_output = gr.Image(type="pil", label="Image Output", elem_id="gallery")
111
-
112
  # Bind the button to the query function with the added width and height inputs
113
  text_button.click(query, inputs=[text_prompt, negative_prompt, steps, cfg, method, seed, strength, width, height], outputs=image_output)
114
 
115
  # Launch the Gradio app
116
- app.launch(show_api=False, share=False)
 
16
  timeout = 100
17
 
18
  # Function to query the API and return the generated image
19
+ def query(prompt, negative_prompt, steps=35, cfg_scale=7, sampler="DPM++ 2M Karras", seed=-1, strength=0.7, width=1024, height=1024):
20
+ if not prompt:
21
+ raise gr.Error("Prompt cannot be empty.")
22
 
23
  key = random.randint(0, 999)
24
+
 
 
 
25
  # Translate the prompt from Russian to English if necessary
26
  prompt = GoogleTranslator(source='my', target='en').translate(prompt)
27
  print(f'\033[1mGeneration {key} translation:\033[0m {prompt}')
 
29
  # Add some extra flair to the prompt
30
  prompt = f"{prompt} | ultra detail, ultra elaboration, ultra quality, perfect."
31
  print(f'\033[1mGeneration {key}:\033[0m {prompt}')
32
+
33
  # Prepare the payload for the API call, including width and height
34
  payload = {
35
  "inputs": prompt,
 
 
 
 
 
36
  "parameters": {
37
+ "negative_prompt": negative_prompt,
38
+ "steps": steps,
39
+ "cfg_scale": cfg_scale,
40
+ "sampler": sampler,
41
+ "seed": seed if seed != -1 else random.randint(1, 1000000000),
42
+ "strength": strength,
43
+ "width": width,
44
+ "height": height
45
  }
46
  }
47
 
48
  # Send the request to the API and handle the response
49
  response = requests.post(API_URL, headers=headers, json=payload, timeout=timeout)
50
  if response.status_code != 200:
51
+ error_message = f"Error: Failed to get image. Response status: {response.status_code}"
 
52
  if response.status_code == 503:
53
+ error_message += " - The model is being loaded"
54
+ raise gr.Error(error_message)
55
+
56
  try:
57
  # Convert the response content into an image
58
  image_bytes = response.content
 
60
  print(f'\033[1mGeneration {key} completed!\033[0m ({prompt})')
61
  return image
62
  except Exception as e:
63
+ raise gr.Error(f"Error when trying to open the image: {e}")
 
64
 
65
  # CSS to style the app
66
  css = """
 
75
  with gr.Blocks(theme='Nymbo/Nymbo_Theme', css=css) as app:
76
  # Add a title to the app
77
  gr.HTML("<center><h1>Walone AI Image Pro Large</h1></center>")
78
+
79
  # Container for all the UI elements
80
  with gr.Column(elem_id="app-container"):
81
  # Add a text input for the main prompt
 
83
  with gr.Column(elem_id="prompt-container"):
84
  with gr.Row():
85
  text_prompt = gr.Textbox(label="Prompt", placeholder="Prompt စာသားရေးပါ", lines=2, elem_id="prompt-text-input")
86
+
87
  # Accordion for advanced settings
88
  with gr.Row():
89
  with gr.Accordion("Advanced Settings", open=False):
 
100
  # Add a button to trigger the image generation
101
  with gr.Row():
102
  text_button = gr.Button("Run", variant='primary', elem_id="gen-button")
103
+
104
  # Image output area to display the generated image
105
  with gr.Row():
106
  image_output = gr.Image(type="pil", label="Image Output", elem_id="gallery")
107
+
108
  # Bind the button to the query function with the added width and height inputs
109
  text_button.click(query, inputs=[text_prompt, negative_prompt, steps, cfg, method, seed, strength, width, height], outputs=image_output)
110
 
111
  # Launch the Gradio app
112
+ app.launch(show_api=False, share=False)