-
Notifications
You must be signed in to change notification settings - Fork 1
/
prompt_stash_saver_node.py
134 lines (116 loc) · 5.43 KB
/
prompt_stash_saver_node.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
import os
import json
import folder_paths
from server import PromptServer
from .data_utils import init_data_file
class PromptStashSaver:
def __init__(self):
self.base_dir = os.path.dirname(os.path.realpath(__file__))
self.data_file = init_data_file(self.base_dir)
self.data = self.load_data()
@classmethod
def INPUT_TYPES(s):
return {
"required": {
},
"optional": {
"use_input_text": ("BOOLEAN", {"default": False, "label_on": "Use Input", "label_off": "Use Prompt"}),
"text": ("STRING", {"default": "", "defaultInput": True, "tooltip": "Optional input text", "lazy": True}),
"prompt_text": ("STRING", {"multiline": True, "default": "", "placeholder": "Enter prompt text"}),
"save_as_key": ("STRING", {"default": "", "placeholder": "Enter key to save as"}),
"load_saved": ("STRING", {"default": "None"}), # Will be populated with actual prompts
"prompt_lists": ("STRING", {"default": "default"}), # Will be populated with actual lists
},
"hidden": {
"unique_id": "UNIQUE_ID",
"extra_pnginfo": "EXTRA_PNGINFO",
}
}
RETURN_TYPES = ("STRING",)
RETURN_NAMES = ("text",)
FUNCTION = "process"
CATEGORY = "utils"
def check_lazy_status(self, use_input_text=False, text="", prompt_text="", save_as_key="", load_saved="None", prompt_lists="default", unique_id=None, extra_pnginfo=None):
# Only need the text input if use_input_text is True
needed = []
if use_input_text:
needed.append("text")
return needed
def load_data(self):
if os.path.exists(self.data_file):
try:
with open(self.data_file, 'r', encoding='utf-8') as f:
data = json.load(f)
# Broadcast initial data to all nodes
PromptServer.instance.send_sync("prompt-stash-update-all", {
"lists": data.get("lists", {"default": {}})
})
return data
except Exception as e:
print(f"Error loading prompts: {e}")
return {"lists": {"default": {}}}
def save_data(self):
try:
os.makedirs(os.path.dirname(self.data_file), exist_ok=True)
with open(self.data_file, 'w', encoding='utf-8') as f:
json.dump(self.data, f, indent=2)
return True
except Exception as e:
print(f"Error saving data: {e}")
return False
def save_prompt(self, save_as_key, prompt, list_name, unique_id):
save_as_key = save_as_key.strip()
if not save_as_key or not prompt:
return False
if list_name not in self.data["lists"]:
list_name = "default"
self.data["lists"][list_name][save_as_key] = prompt
success = self.save_data()
if success:
# Notify all nodes of the update
PromptServer.instance.send_sync("prompt-stash-update-all", {
"lists": self.data["lists"]
})
return success
def delete_prompt(self, save_as_key, list_name, unique_id):
if list_name not in self.data["lists"]:
return False
if save_as_key in self.data["lists"][list_name]:
del self.data["lists"][list_name][save_as_key]
success = self.save_data()
if success:
# Notify all nodes of the update
PromptServer.instance.send_sync("prompt-stash-update-all", {
"lists": self.data["lists"]
})
return success
return False
def process(self, use_input_text=False, text="", prompt_text="", save_as_key="", load_saved="None", prompt_lists="default", unique_id=None, extra_pnginfo=None):
# Update the prompt text based on use_input_text toggle
output_text = prompt_text
if use_input_text and text is not None:
output_text = text
# Send update to frontend to update prompt widget
PromptServer.instance.send_sync("prompt-stash-update-prompt", {
"node_id": unique_id,
"prompt": text
})
# Handle both list and dict formats of extra_pnginfo
workflow = None
if isinstance(extra_pnginfo, list) and len(extra_pnginfo) > 0:
workflow = extra_pnginfo[0].get("workflow")
elif isinstance(extra_pnginfo, dict):
workflow = extra_pnginfo.get("workflow")
if workflow:
node = next(
(x for x in workflow["nodes"] if str(x["id"]) == str(unique_id)),
None
)
if node and "widgets_values" in node:
# Set use_input_text to False in metadata (index 0 based on INPUT_TYPES order)
use_input_text_index = 0 # First widget in optional inputs
prompt_text_index = 2 # Third widget in optional inputs
# Update the values in metadata
node["widgets_values"][use_input_text_index] = False # Force use_input_text to False in metadata
node["widgets_values"][prompt_text_index] = output_text # Update the prompt text
return (output_text,)