diff options
author | AUTOMATIC1111 <16777216c@gmail.com> | 2023-08-25 13:24:45 +0000 |
---|---|---|
committer | AUTOMATIC1111 <16777216c@gmail.com> | 2023-08-25 13:24:45 +0000 |
commit | 4c6788644a367704d5dcb684a6c74a4ad1d1b078 (patch) | |
tree | 46b057d2491ff25123dcb1a591a407aa1d4221c8 | |
parent | a6cedafb27aa5fa50a06d2c7889b99eb274e2246 (diff) | |
parent | e004384e460ad4568736dfff459c1ea809f05794 (diff) | |
download | stable-diffusion-webui-gfx803-4c6788644a367704d5dcb684a6c74a4ad1d1b078.tar.gz stable-diffusion-webui-gfx803-4c6788644a367704d5dcb684a6c74a4ad1d1b078.tar.bz2 stable-diffusion-webui-gfx803-4c6788644a367704d5dcb684a6c74a4ad1d1b078.zip |
Merge branch 'release_candidate' into dev
-rw-r--r-- | modules/ui_loadsave.py | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/modules/ui_loadsave.py b/modules/ui_loadsave.py index 9a40cf4f..ec8fa8e8 100644 --- a/modules/ui_loadsave.py +++ b/modules/ui_loadsave.py @@ -7,6 +7,10 @@ from modules import errors from modules.ui_components import ToolButton
+def radio_choices(comp): # gradio 3.41 changes choices from list of values to list of pairs
+ return [x[0] if isinstance(x, tuple) else x for x in getattr(comp, 'choices', [])]
+
+
class UiLoadsave:
"""allows saving and restoring default values for gradio components"""
@@ -28,6 +32,8 @@ class UiLoadsave: self.error_loading = True
errors.display(e, "loading settings")
+
+
def add_component(self, path, x):
"""adds component to the registry of tracked components"""
@@ -73,7 +79,7 @@ class UiLoadsave: apply_field(x, 'step')
if type(x) == gr.Radio:
- apply_field(x, 'value', lambda val: val in x.choices)
+ apply_field(x, 'value', lambda val: val in radio_choices(x))
if type(x) == gr.Checkbox:
apply_field(x, 'value')
@@ -86,10 +92,11 @@ class UiLoadsave: if type(x) == gr.Dropdown:
def check_dropdown(val):
+ choices = radio_choices(x)
if getattr(x, 'multiselect', False):
- return all(value in x.choices for value in val)
+ return all(value in choices for value in val)
else:
- return val in x.choices
+ return val in choices
apply_field(x, 'value', check_dropdown, getattr(x, 'init_field', None))
@@ -146,12 +153,14 @@ class UiLoadsave: for (path, component), new_value in zip(self.component_mapping.items(), values):
old_value = current_ui_settings.get(path)
- choices = getattr(component, 'choices', None)
+ choices = radio_choices(component)
if isinstance(new_value, int) and choices:
if new_value >= len(choices):
continue
new_value = choices[new_value]
+ if isinstance(new_value, tuple):
+ new_value = new_value[0]
if new_value == old_value:
continue
|