mirror of
https://github.com/invoke-ai/InvokeAI
synced 2024-08-30 20:32:17 +00:00
Add techedi code to avoid rendering prompt/seed with null
- Added techjedi github and real names
This commit is contained in:
parent
8469d3e95a
commit
a846d82fa1
@ -1,12 +1,12 @@
|
|||||||
# Copyright (c) 2023 - The InvokeAI Team
|
# Copyright (c) 2023 - The InvokeAI Team
|
||||||
# Author: techjedi
|
# Primary Author: David Lovell (github @f412design, discord @techedi)
|
||||||
|
# co-author, minor tweaks - Lincoln Stein
|
||||||
|
|
||||||
# pylint: disable=line-too-long
|
# pylint: disable=line-too-long
|
||||||
# pylint: disable=broad-exception-caught
|
# pylint: disable=broad-exception-caught
|
||||||
"""Script to import images into the new database system for 3.0.0"""
|
"""Script to import images into the new database system for 3.0.0"""
|
||||||
|
|
||||||
import os
|
import os
|
||||||
import platform
|
|
||||||
import datetime
|
import datetime
|
||||||
import shutil
|
import shutil
|
||||||
import locale
|
import locale
|
||||||
@ -24,12 +24,19 @@ from pathlib import Path
|
|||||||
from prompt_toolkit import prompt
|
from prompt_toolkit import prompt
|
||||||
from prompt_toolkit.shortcuts import message_dialog
|
from prompt_toolkit.shortcuts import message_dialog
|
||||||
from prompt_toolkit.completion import PathCompleter
|
from prompt_toolkit.completion import PathCompleter
|
||||||
|
from prompt_toolkit.key_binding import KeyBindings
|
||||||
|
|
||||||
from invokeai.app.services.config import InvokeAIAppConfig
|
from invokeai.app.services.config import InvokeAIAppConfig
|
||||||
|
|
||||||
app_config = InvokeAIAppConfig.get_config()
|
app_config = InvokeAIAppConfig.get_config()
|
||||||
path_delimiter = "\\" if platform.uname().system == "Windows" else "/"
|
|
||||||
print(path_delimiter)
|
bindings = KeyBindings()
|
||||||
|
|
||||||
|
|
||||||
|
@bindings.add("c-c")
|
||||||
|
def _(event):
|
||||||
|
raise KeyboardInterrupt
|
||||||
|
|
||||||
|
|
||||||
# release notes
|
# release notes
|
||||||
# "Use All" with size dimensions not selectable in the UI will not load dimensions
|
# "Use All" with size dimensions not selectable in the UI will not load dimensions
|
||||||
@ -116,11 +123,7 @@ class Config:
|
|||||||
)
|
)
|
||||||
if database_path.endswith(".db") and os.path.isabs(database_path) and os.path.exists(database_path):
|
if database_path.endswith(".db") and os.path.isabs(database_path) and os.path.exists(database_path):
|
||||||
break
|
break
|
||||||
default = (
|
default = database_path + "/" if Path(database_path).is_dir() else database_path
|
||||||
database_path + path_delimiter
|
|
||||||
if Path(database_path).is_dir() and not database_path.endswith(("\\", "/"))
|
|
||||||
else database_path
|
|
||||||
)
|
|
||||||
|
|
||||||
default = ""
|
default = ""
|
||||||
while True:
|
while True:
|
||||||
@ -134,11 +137,7 @@ class Config:
|
|||||||
|
|
||||||
if outputs_path.endswith("images") and os.path.isabs(outputs_path) and os.path.exists(outputs_path):
|
if outputs_path.endswith("images") and os.path.isabs(outputs_path) and os.path.exists(outputs_path):
|
||||||
break
|
break
|
||||||
default = (
|
default = outputs_path + "/" if Path(outputs_path).is_dir() else outputs_path
|
||||||
outputs_path + path_delimiter
|
|
||||||
if Path(outputs_path).is_dir() and not database_path.endswith(("\\", "/"))
|
|
||||||
else outputs_path
|
|
||||||
)
|
|
||||||
|
|
||||||
self.database_path = database_path
|
self.database_path = database_path
|
||||||
self.outputs_path = outputs_path
|
self.outputs_path = outputs_path
|
||||||
@ -217,11 +216,17 @@ class InvokeAIMetadata:
|
|||||||
"""Convert the active instance to json format."""
|
"""Convert the active instance to json format."""
|
||||||
prop_dict = {}
|
prop_dict = {}
|
||||||
prop_dict["generation_mode"] = self.generation_mode
|
prop_dict["generation_mode"] = self.generation_mode
|
||||||
prop_dict["positive_prompt"] = self.positive_prompt
|
# dont render prompt nodes if neither are set to avoid the ui thinking it can set them
|
||||||
prop_dict["negative_prompt"] = self.negative_prompt
|
# if at least one exists, render them both, but use empty string instead of None if one of them is empty
|
||||||
|
# this allows the field that is empty to actually be cleared byt he UI instead of leaving the previous value
|
||||||
|
if self.positive_prompt or self.negative_prompt:
|
||||||
|
prop_dict["positive_prompt"] = "" if self.positive_prompt is None else self.positive_prompt
|
||||||
|
prop_dict["negative_prompt"] = "" if self.negative_prompt is None else self.negative_prompt
|
||||||
prop_dict["width"] = self.width
|
prop_dict["width"] = self.width
|
||||||
prop_dict["height"] = self.height
|
prop_dict["height"] = self.height
|
||||||
prop_dict["seed"] = self.seed
|
# only render seed if it has a value to avoid ui thinking it can set this and then error
|
||||||
|
if self.seed:
|
||||||
|
prop_dict["seed"] = self.seed
|
||||||
prop_dict["rand_device"] = self.rand_device
|
prop_dict["rand_device"] = self.rand_device
|
||||||
prop_dict["cfg_scale"] = self.cfg_scale
|
prop_dict["cfg_scale"] = self.cfg_scale
|
||||||
prop_dict["steps"] = self.steps
|
prop_dict["steps"] = self.steps
|
||||||
|
Loading…
Reference in New Issue
Block a user