123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316 |
- // various functions for interaction with ui.py not large enough to warrant putting them in separate files
- function set_theme(theme){
- gradioURL = window.location.href
- if (!gradioURL.includes('?__theme=')) {
- window.location.replace(gradioURL + '?__theme=' + theme);
- }
- }
- function selected_gallery_index(){
- var buttons = gradioApp().querySelectorAll('[style="display: block;"].tabitem div[id$=_gallery] .gallery-item')
- var button = gradioApp().querySelector('[style="display: block;"].tabitem div[id$=_gallery] .gallery-item.\\!ring-2')
- var result = -1
- buttons.forEach(function(v, i){ if(v==button) { result = i } })
- return result
- }
- function extract_image_from_gallery(gallery){
- if(gallery.length == 1){
- return [gallery[0]]
- }
- index = selected_gallery_index()
- if (index < 0 || index >= gallery.length){
- return [null]
- }
- return [gallery[index]];
- }
- function args_to_array(args){
- res = []
- for(var i=0;i<args.length;i++){
- res.push(args[i])
- }
- return res
- }
- function switch_to_txt2img(){
- gradioApp().querySelector('#tabs').querySelectorAll('button')[0].click();
- return args_to_array(arguments);
- }
- function switch_to_img2img_tab(no){
- gradioApp().querySelector('#tabs').querySelectorAll('button')[1].click();
- gradioApp().getElementById('mode_img2img').querySelectorAll('button')[no].click();
- }
- function switch_to_img2img(){
- switch_to_img2img_tab(0);
- return args_to_array(arguments);
- }
- function switch_to_sketch(){
- switch_to_img2img_tab(1);
- return args_to_array(arguments);
- }
- function switch_to_inpaint(){
- switch_to_img2img_tab(2);
- return args_to_array(arguments);
- }
- function switch_to_inpaint_sketch(){
- switch_to_img2img_tab(3);
- return args_to_array(arguments);
- }
- function switch_to_inpaint(){
- gradioApp().querySelector('#tabs').querySelectorAll('button')[1].click();
- gradioApp().getElementById('mode_img2img').querySelectorAll('button')[2].click();
- return args_to_array(arguments);
- }
- function switch_to_extras(){
- gradioApp().querySelector('#tabs').querySelectorAll('button')[2].click();
- return args_to_array(arguments);
- }
- function get_tab_index(tabId){
- var res = 0
- gradioApp().getElementById(tabId).querySelector('div').querySelectorAll('button').forEach(function(button, i){
- if(button.className.indexOf('bg-white') != -1)
- res = i
- })
- return res
- }
- function create_tab_index_args(tabId, args){
- var res = []
- for(var i=0; i<args.length; i++){
- res.push(args[i])
- }
- res[0] = get_tab_index(tabId)
- return res
- }
- function get_extras_tab_index(){
- const [,,...args] = [...arguments]
- return [get_tab_index('mode_extras'), get_tab_index('extras_resize_mode'), ...args]
- }
- function get_img2img_tab_index() {
- let res = args_to_array(arguments)
- res.splice(-2)
- res[0] = get_tab_index('mode_img2img')
- return res
- }
- function create_submit_args(args){
- res = []
- for(var i=0;i<args.length;i++){
- res.push(args[i])
- }
- // As it is currently, txt2img and img2img send back the previous output args (txt2img_gallery, generation_info, html_info) whenever you generate a new image.
- // This can lead to uploading a huge gallery of previously generated images, which leads to an unnecessary delay between submitting and beginning to generate.
- // I don't know why gradio is sending outputs along with inputs, but we can prevent sending the image gallery here, which seems to be an issue for some.
- // If gradio at some point stops sending outputs, this may break something
- if(Array.isArray(res[res.length - 3])){
- res[res.length - 3] = null
- }
- return res
- }
- function showSubmitButtons(tabname, show){
- gradioApp().getElementById(tabname+'_interrupt').style.display = show ? "none" : "block"
- gradioApp().getElementById(tabname+'_skip').style.display = show ? "none" : "block"
- }
- function submit(){
- rememberGallerySelection('txt2img_gallery')
- showSubmitButtons('txt2img', false)
- var id = randomId()
- requestProgress(id, gradioApp().getElementById('txt2img_gallery_container'), gradioApp().getElementById('txt2img_gallery'), function(){
- showSubmitButtons('txt2img', true)
- })
- var res = create_submit_args(arguments)
- res[0] = id
- return res
- }
- function submit_img2img(){
- rememberGallerySelection('img2img_gallery')
- showSubmitButtons('img2img', false)
- var id = randomId()
- requestProgress(id, gradioApp().getElementById('img2img_gallery_container'), gradioApp().getElementById('img2img_gallery'), function(){
- showSubmitButtons('img2img', true)
- })
- var res = create_submit_args(arguments)
- res[0] = id
- res[1] = get_tab_index('mode_img2img')
- return res
- }
- function modelmerger(){
- var id = randomId()
- requestProgress(id, gradioApp().getElementById('modelmerger_results_panel'), null, function(){})
- var res = create_submit_args(arguments)
- res[0] = id
- return res
- }
- function ask_for_style_name(_, prompt_text, negative_prompt_text) {
- name_ = prompt('Style name:')
- return [name_, prompt_text, negative_prompt_text]
- }
- function confirm_clear_prompt(prompt, negative_prompt) {
- if(confirm("Delete prompt?")) {
- prompt = ""
- negative_prompt = ""
- }
- return [prompt, negative_prompt]
- }
- opts = {}
- onUiUpdate(function(){
- if(Object.keys(opts).length != 0) return;
- json_elem = gradioApp().getElementById('settings_json')
- if(json_elem == null) return;
- textarea = json_elem.querySelector('textarea')
- jsdata = textarea.value
- opts = JSON.parse(jsdata)
- executeCallbacks(optionsChangedCallbacks);
- Object.defineProperty(textarea, 'value', {
- set: function(newValue) {
- var valueProp = Object.getOwnPropertyDescriptor(HTMLTextAreaElement.prototype, 'value');
- var oldValue = valueProp.get.call(textarea);
- valueProp.set.call(textarea, newValue);
- if (oldValue != newValue) {
- opts = JSON.parse(textarea.value)
- }
- executeCallbacks(optionsChangedCallbacks);
- },
- get: function() {
- var valueProp = Object.getOwnPropertyDescriptor(HTMLTextAreaElement.prototype, 'value');
- return valueProp.get.call(textarea);
- }
- });
- json_elem.parentElement.style.display="none"
- function registerTextarea(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)
- counter.classList.add("token-counter")
- prompt.parentElement.style.position = "relative"
- textarea.addEventListener("input", function(){
- update_token_counter(id_button);
- });
- }
- 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')
- show_all_pages = gradioApp().getElementById('settings_show_all_pages')
- settings_tabs = gradioApp().querySelector('#settings div')
- if(show_all_pages && settings_tabs){
- settings_tabs.appendChild(show_all_pages)
- show_all_pages.onclick = function(){
- gradioApp().querySelectorAll('#settings > div').forEach(function(elem){
- elem.style.display = "block";
- })
- }
- }
- })
- onOptionsChanged(function(){
- elem = gradioApp().getElementById('sd_checkpoint_hash')
- sd_checkpoint_hash = opts.sd_checkpoint_hash || ""
- shorthash = sd_checkpoint_hash.substr(0,10)
- if(elem && elem.textContent != shorthash){
- elem.textContent = shorthash
- elem.title = sd_checkpoint_hash
- elem.href = "https://google.com/search?q=" + sd_checkpoint_hash
- }
- })
- let txt2img_textarea, img2img_textarea = undefined;
- let wait_time = 800
- let token_timeout;
- 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_timeout)
- clearTimeout(token_timeout);
- token_timeout = setTimeout(() => gradioApp().getElementById(button_id)?.click(), wait_time);
- }
- function restart_reload(){
- document.body.innerHTML='<h1 style="font-family:monospace;margin-top:20%;color:lightgray;text-align:center;">Reloading...</h1>';
- setTimeout(function(){location.reload()},2000)
- return []
- }
- // Simulate an `input` DOM event for Gradio Textbox component. Needed after you edit its contents in javascript, otherwise your edits
- // will only visible on web page and not sent to python.
- function updateInput(target){
- let e = new Event("input", { bubbles: true })
- Object.defineProperty(e, "target", {value: target})
- target.dispatchEvent(e);
- }
|