Move token counters to separate JS file, fix names
This commit is contained in:
parent
8faac8b963
commit
5ed970b949
@ -84,5 +84,7 @@ module.exports = {
|
|||||||
// imageviewer.js
|
// imageviewer.js
|
||||||
modalPrevImage: "readonly",
|
modalPrevImage: "readonly",
|
||||||
modalNextImage: "readonly",
|
modalNextImage: "readonly",
|
||||||
|
// token-counters.js
|
||||||
|
setupTokenCounters: "readonly",
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
75
javascript/token-counters.js
Normal file
75
javascript/token-counters.js
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
let promptTokenCountDebounceTime = 800;
|
||||||
|
let promptTokenCountTimeouts = {};
|
||||||
|
var promptTokenCountUpdateFunctions = {};
|
||||||
|
|
||||||
|
function update_txt2img_tokens(...args) {
|
||||||
|
// Called from Gradio
|
||||||
|
update_token_counter("txt2img_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");
|
||||||
|
if (args.length == 2) {
|
||||||
|
return args[0];
|
||||||
|
}
|
||||||
|
return args;
|
||||||
|
}
|
||||||
|
|
||||||
|
function update_token_counter(button_id) {
|
||||||
|
if (promptTokenCountTimeouts[button_id]) {
|
||||||
|
clearTimeout(promptTokenCountTimeouts[button_id]);
|
||||||
|
}
|
||||||
|
promptTokenCountTimeouts[button_id] = setTimeout(
|
||||||
|
() => gradioApp().getElementById(button_id)?.click(),
|
||||||
|
promptTokenCountDebounceTime,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
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";
|
||||||
|
|
||||||
|
promptTokenCountUpdateFunctions[id] = function() {
|
||||||
|
update_token_counter(id_button);
|
||||||
|
};
|
||||||
|
textarea.addEventListener("input", promptTokenCountUpdateFunctions[id]);
|
||||||
|
}
|
||||||
|
|
||||||
|
function setupTokenCounters() {
|
||||||
|
setupTokenCounting('txt2img_prompt', 'txt2img_token_counter', 'txt2img_token_button');
|
||||||
|
setupTokenCounting('txt2img_neg_prompt', 'txt2img_negative_token_counter', 'txt2img_negative_token_button');
|
||||||
|
setupTokenCounting('img2img_prompt', 'img2img_token_counter', 'img2img_token_button');
|
||||||
|
setupTokenCounting('img2img_neg_prompt', 'img2img_negative_token_counter', 'img2img_negative_token_button');
|
||||||
|
}
|
@ -248,27 +248,6 @@ function confirm_clear_prompt(prompt, negative_prompt) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
var promptTokecountUpdateFuncs = {};
|
|
||||||
|
|
||||||
function recalculatePromptTokens(name) {
|
|
||||||
if (promptTokecountUpdateFuncs[name]) {
|
|
||||||
promptTokecountUpdateFuncs[name]();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function recalculate_prompts_txt2img() {
|
|
||||||
recalculatePromptTokens('txt2img_prompt');
|
|
||||||
recalculatePromptTokens('txt2img_neg_prompt');
|
|
||||||
return Array.from(arguments);
|
|
||||||
}
|
|
||||||
|
|
||||||
function recalculate_prompts_img2img() {
|
|
||||||
recalculatePromptTokens('img2img_prompt');
|
|
||||||
recalculatePromptTokens('img2img_neg_prompt');
|
|
||||||
return Array.from(arguments);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var opts = {};
|
var opts = {};
|
||||||
onUiUpdate(function() {
|
onUiUpdate(function() {
|
||||||
if (Object.keys(opts).length != 0) return;
|
if (Object.keys(opts).length != 0) return;
|
||||||
@ -302,28 +281,7 @@ onUiUpdate(function() {
|
|||||||
|
|
||||||
json_elem.parentElement.style.display = "none";
|
json_elem.parentElement.style.display = "none";
|
||||||
|
|
||||||
function registerTextarea(id, id_counter, id_button) {
|
setupTokenCounters();
|
||||||
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";
|
|
||||||
|
|
||||||
promptTokecountUpdateFuncs[id] = function() {
|
|
||||||
update_token_counter(id_button);
|
|
||||||
};
|
|
||||||
textarea.addEventListener("input", promptTokecountUpdateFuncs[id]);
|
|
||||||
}
|
|
||||||
|
|
||||||
registerTextarea('txt2img_prompt', 'txt2img_token_counter', 'txt2img_token_button');
|
|
||||||
registerTextarea('txt2img_neg_prompt', 'txt2img_negative_token_counter', 'txt2img_negative_token_button');
|
|
||||||
registerTextarea('img2img_prompt', 'img2img_token_counter', 'img2img_token_button');
|
|
||||||
registerTextarea('img2img_neg_prompt', 'img2img_negative_token_counter', 'img2img_negative_token_button');
|
|
||||||
|
|
||||||
var show_all_pages = gradioApp().getElementById('settings_show_all_pages');
|
var show_all_pages = gradioApp().getElementById('settings_show_all_pages');
|
||||||
var settings_tabs = gradioApp().querySelector('#settings div');
|
var settings_tabs = gradioApp().querySelector('#settings div');
|
||||||
@ -354,33 +312,6 @@ onOptionsChanged(function() {
|
|||||||
});
|
});
|
||||||
|
|
||||||
let txt2img_textarea, img2img_textarea = undefined;
|
let txt2img_textarea, img2img_textarea = undefined;
|
||||||
let wait_time = 800;
|
|
||||||
let token_timeouts = {};
|
|
||||||
|
|
||||||
function update_txt2img_tokens(...args) {
|
|
||||||
update_token_counter("txt2img_token_button");
|
|
||||||
if (args.length == 2) {
|
|
||||||
return args[0];
|
|
||||||
}
|
|
||||||
return args;
|
|
||||||
}
|
|
||||||
|
|
||||||
function update_img2img_tokens(...args) {
|
|
||||||
update_token_counter(
|
|
||||||
"img2img_token_button"
|
|
||||||
);
|
|
||||||
if (args.length == 2) {
|
|
||||||
return args[0];
|
|
||||||
}
|
|
||||||
return args;
|
|
||||||
}
|
|
||||||
|
|
||||||
function update_token_counter(button_id) {
|
|
||||||
if (token_timeouts[button_id]) {
|
|
||||||
clearTimeout(token_timeouts[button_id]);
|
|
||||||
}
|
|
||||||
token_timeouts[button_id] = setTimeout(() => gradioApp().getElementById(button_id)?.click(), wait_time);
|
|
||||||
}
|
|
||||||
|
|
||||||
function restart_reload() {
|
function restart_reload() {
|
||||||
document.body.innerHTML = '<h1 style="font-family:monospace;margin-top:20%;color:lightgray;text-align:center;">Reloading...</h1>';
|
document.body.innerHTML = '<h1 style="font-family:monospace;margin-top:20%;color:lightgray;text-align:center;">Reloading...</h1>';
|
||||||
|
Loading…
Reference in New Issue
Block a user