88 lines
2.7 KiB
JavaScript
88 lines
2.7 KiB
JavaScript
let promptTokenCountUpdateFunctions = {};
|
|
|
|
function update_txt2img_tokens(...args) {
|
|
// Called from Gradio
|
|
update_token_counter("txt2img_token_button");
|
|
update_token_counter("txt2img_negative_token_button");
|
|
if (args.length == 2) {
|
|
return args[0];
|
|
}
|
|
return args;
|
|
}
|
|
|
|
function update_img2img_tokens(...args) {
|
|
// Called from Gradio
|
|
update_token_counter("img2img_token_button");
|
|
update_token_counter("img2img_negative_token_button");
|
|
if (args.length == 2) {
|
|
return args[0];
|
|
}
|
|
return args;
|
|
}
|
|
|
|
function update_token_counter(button_id) {
|
|
promptTokenCountUpdateFunctions[button_id]?.();
|
|
}
|
|
|
|
|
|
function recalculatePromptTokens(name) {
|
|
promptTokenCountUpdateFunctions[name]?.();
|
|
}
|
|
|
|
function recalculate_prompts_txt2img() {
|
|
// Called from Gradio
|
|
recalculatePromptTokens('txt2img_prompt');
|
|
recalculatePromptTokens('txt2img_neg_prompt');
|
|
return Array.from(arguments);
|
|
}
|
|
|
|
function recalculate_prompts_img2img() {
|
|
// Called from Gradio
|
|
recalculatePromptTokens('img2img_prompt');
|
|
recalculatePromptTokens('img2img_neg_prompt');
|
|
return Array.from(arguments);
|
|
}
|
|
|
|
function setupTokenCounting(id, id_counter, id_button) {
|
|
var prompt = gradioApp().getElementById(id);
|
|
var counter = gradioApp().getElementById(id_counter);
|
|
var textarea = gradioApp().querySelector(`#${id} > label > textarea`);
|
|
|
|
if (counter.parentElement == prompt.parentElement) {
|
|
return;
|
|
}
|
|
|
|
prompt.parentElement.insertBefore(counter, prompt);
|
|
prompt.parentElement.style.position = "relative";
|
|
|
|
var func = onEdit(id, textarea, 800, function() {
|
|
if (counter.classList.contains("token-counter-visible")) {
|
|
gradioApp().getElementById(id_button)?.click();
|
|
}
|
|
});
|
|
promptTokenCountUpdateFunctions[id] = func;
|
|
promptTokenCountUpdateFunctions[id_button] = func;
|
|
}
|
|
|
|
function toggleTokenCountingVisibility(id, id_counter, id_button) {
|
|
var counter = gradioApp().getElementById(id_counter);
|
|
|
|
counter.style.display = opts.disable_token_counters ? "none" : "block";
|
|
counter.classList.toggle("token-counter-visible", !opts.disable_token_counters);
|
|
}
|
|
|
|
function runCodeForTokenCounters(fun) {
|
|
fun('txt2img_prompt', 'txt2img_token_counter', 'txt2img_token_button');
|
|
fun('txt2img_neg_prompt', 'txt2img_negative_token_counter', 'txt2img_negative_token_button');
|
|
fun('img2img_prompt', 'img2img_token_counter', 'img2img_token_button');
|
|
fun('img2img_neg_prompt', 'img2img_negative_token_counter', 'img2img_negative_token_button');
|
|
}
|
|
|
|
onUiLoaded(function() {
|
|
runCodeForTokenCounters(setupTokenCounting);
|
|
});
|
|
|
|
onOptionsChanged(function() {
|
|
runCodeForTokenCounters(toggleTokenCountingVisibility);
|
|
});
|