fix for setting values for gradio sliders when users has bad data in ui-config.json

This commit is contained in:
AUTOMATIC 2022-09-05 19:11:29 +03:00
parent 595c907c29
commit 5bb69bd915
1 changed files with 3 additions and 3 deletions

View File

@ -553,13 +553,13 @@ def create_ui(txt2img, img2img, run_extras, run_pnginfo):
print(traceback.format_exc(), file=sys.stderr) print(traceback.format_exc(), file=sys.stderr)
def loadsave(path, x): def loadsave(path, x):
def apply_field(obj, field): def apply_field(obj, field, condition=None):
key = path + "/" + field key = path + "/" + field
saved_value = ui_settings.get(key, None) saved_value = ui_settings.get(key, None)
if saved_value is None: if saved_value is None:
ui_settings[key] = getattr(obj, field) ui_settings[key] = getattr(obj, field)
else: elif condition is None or condition(saved_value):
setattr(obj, field, saved_value) setattr(obj, field, saved_value)
if type(x) == gr.Slider: if type(x) == gr.Slider:
@ -569,7 +569,7 @@ def create_ui(txt2img, img2img, run_extras, run_pnginfo):
apply_field(x, 'step') apply_field(x, 'step')
if type(x) == gr.Radio: if type(x) == gr.Radio:
apply_field(x, 'value') apply_field(x, 'value', lambda val: val in x.choices)
visit(txt2img_interface, loadsave, "txt2img") visit(txt2img_interface, loadsave, "txt2img")
visit(img2img_interface, loadsave, "img2img") visit(img2img_interface, loadsave, "img2img")