johann-foerster commited on
Commit
41b1d8d
1 Parent(s): 35f1465

more responsive UX

Browse files
Files changed (1) hide show
  1. webui.py +24 -19
webui.py CHANGED
@@ -19,10 +19,8 @@ EXAMPLE_GREETINGS = [
19
  ]
20
 
21
  def generate(*args):
22
- yield gr.update(interactive=False), \
23
- gr.update(value=modules.html.make_progress_html(1, "0/30")), \
24
- gr.update(visible=True), \
25
- gr.update(visible=False)
26
 
27
  while worker.is_working:
28
  time.sleep(0.1)
@@ -37,16 +35,12 @@ def generate(*args):
37
  flag, product = worker.outputs.pop(0)
38
  if flag == 'preview':
39
  percentage, title, image = product
40
- yield gr.update(), \
41
- gr.update(value=modules.html.make_progress_html(percentage, title)), \
42
- gr.update(value=image) if image is not None else gr.update(), \
43
- gr.update()
44
  if flag == 'results':
45
  image = product[0]
46
- yield gr.update(interactive=True), \
47
- gr.update(value=""), \
48
- gr.update(visible=False, value=image), \
49
- gr.update(visible=True, value=image)
50
  finished = True
51
  return
52
 
@@ -56,6 +50,15 @@ def translate_promt_example(prompt_de):
56
  def toggle_greet_visibility(is_visible):
57
  return gr.update(visible=is_visible)
58
 
 
 
 
 
 
 
 
 
 
59
  def debounce():
60
  time.sleep(0.5)
61
  return gr.update()
@@ -116,7 +119,7 @@ with shared.gradio_root:
116
  style_selection = gr.Dropdown(choices=style_keys, value='Kinofilm', container=False, elem_id="style-selection")
117
  with gr.Column(scale=1, min_width="80px"):
118
  progress_html = gr.HTML(visible=True, elem_id='progress-bar', elem_classes='progress-bar')
119
- run_button = gr.Button(value="Weihnachtskarte\nerstellen", variant='primary', elem_id='generate-button')
120
  with gr.Row():
121
  promt_example_de = gr.Textbox(visible=False)
122
  gr.Examples(elem_id="prompt-examples", examples=PROMPT_EXAMPLES, inputs=[promt_example_de], cache_examples=False)
@@ -137,12 +140,14 @@ with shared.gradio_root:
137
  value=pil_image_with_overlay(Image.open("resources/init.png"), toggle_greet.value, greet.value))
138
 
139
  promt_example_de.change(fn=translate_promt_example, inputs=[promt_example_de], outputs=[prompt], queue=False)
140
- toggle_greet.change(fn=toggle_greet_visibility, inputs=[toggle_greet], outputs=[greeting_row], queue=False)\
141
- .then(fn=make_overlay, inputs=[generated_image_raw, toggle_greet, greet], outputs=[generated_image_overlayed], queue=False)
142
- greet.change(fn=debounce, outputs=[generated_image_overlayed], queue=False)\
143
- .then(fn=make_overlay, inputs=[generated_image_raw, toggle_greet, greet], outputs=[generated_image_overlayed], queue=False)
144
- run_button.click(fn=generate, inputs=[prompt, style_selection], outputs=[run_button, progress_html, generated_image_raw, generated_image_overlayed], show_progress=False)\
145
- .then(fn=make_overlay, inputs=[generated_image_raw, toggle_greet, greet], outputs=[generated_image_overlayed], queue=False)
 
 
146
 
147
  shared.gradio_root.queue(concurrency_count=1, api_open=False)
148
  shared.gradio_root.launch(server_name="0.0.0.0", show_api=False)
 
19
  ]
20
 
21
  def generate(*args):
22
+ yield gr.update(value=modules.html.make_progress_html(1, "0/30")), \
23
+ gr.update()
 
 
24
 
25
  while worker.is_working:
26
  time.sleep(0.1)
 
35
  flag, product = worker.outputs.pop(0)
36
  if flag == 'preview':
37
  percentage, title, image = product
38
+ yield gr.update(value=modules.html.make_progress_html(percentage, title)), \
39
+ gr.update(value=image) if image is not None else gr.update()
 
 
40
  if flag == 'results':
41
  image = product[0]
42
+ yield gr.update(value=""), \
43
+ gr.update(value=image)
 
 
44
  finished = True
45
  return
46
 
 
50
  def toggle_greet_visibility(is_visible):
51
  return gr.update(visible=is_visible)
52
 
53
+ def __toggle_generate_state(is_preview):
54
+ return gr.update(visible=is_preview), gr.update(visible=not is_preview), gr.update(interactive=not is_preview)
55
+
56
+ def prepare_generate():
57
+ return __toggle_generate_state(True)
58
+
59
+ def finish_generate():
60
+ return __toggle_generate_state(False)
61
+
62
  def debounce():
63
  time.sleep(0.5)
64
  return gr.update()
 
119
  style_selection = gr.Dropdown(choices=style_keys, value='Kinofilm', container=False, elem_id="style-selection")
120
  with gr.Column(scale=1, min_width="80px"):
121
  progress_html = gr.HTML(visible=True, elem_id='progress-bar', elem_classes='progress-bar')
122
+ run_button = gr.Button(value="Weihnachtskarte\nerstellen", variant='primary', elem_id='generate-button', )
123
  with gr.Row():
124
  promt_example_de = gr.Textbox(visible=False)
125
  gr.Examples(elem_id="prompt-examples", examples=PROMPT_EXAMPLES, inputs=[promt_example_de], cache_examples=False)
 
140
  value=pil_image_with_overlay(Image.open("resources/init.png"), toggle_greet.value, greet.value))
141
 
142
  promt_example_de.change(fn=translate_promt_example, inputs=[promt_example_de], outputs=[prompt], queue=False)
143
+ toggle_greet.change(fn=toggle_greet_visibility, inputs=[toggle_greet], outputs=[greeting_row], queue=False, show_progress=False)\
144
+ .then(fn=make_overlay, inputs=[generated_image_raw, toggle_greet, greet], outputs=[generated_image_overlayed], show_progress=False, queue=False)
145
+ greet.change(fn=debounce, outputs=[generated_image_overlayed], queue=False, show_progress=False)\
146
+ .then(fn=make_overlay, inputs=[generated_image_raw, toggle_greet, greet], outputs=[generated_image_overlayed], queue=False, show_progress=False)
147
+ run_button.click(fn=prepare_generate, outputs=[generated_image_raw, generated_image_overlayed, run_button], queue=False)\
148
+ .then(fn=generate, inputs=[prompt, style_selection], outputs=[progress_html, generated_image_raw], queue=True)\
149
+ .then(fn=make_overlay, inputs=[generated_image_raw, toggle_greet, greet], outputs=[generated_image_overlayed], queue=False)\
150
+ .then(fn=finish_generate, outputs=[generated_image_raw, generated_image_overlayed, run_button], queue=False)
151
 
152
  shared.gradio_root.queue(concurrency_count=1, api_open=False)
153
  shared.gradio_root.launch(server_name="0.0.0.0", show_api=False)