2022-11-03 00:05:00 +08:00
// various functions for interaction with ui.py not large enough to warrant putting them in separate files
2022-09-03 04:25:29 +08:00
2023-05-17 20:46:58 +08:00
function set _theme ( theme ) {
var gradioURL = window . location . href ;
2022-10-18 00:24:24 +08:00
if ( ! gradioURL . includes ( '?__theme=' ) ) {
2023-05-17 20:46:58 +08:00
window . location . replace ( gradioURL + '?__theme=' + theme ) ;
2022-10-17 17:05:05 +08:00
}
}
2023-03-26 02:52:47 +08:00
function all _gallery _buttons ( ) {
var allGalleryButtons = gradioApp ( ) . querySelectorAll ( '[style="display: block;"].tabitem div[id$=_gallery].gradio-gallery .thumbnails > .thumbnail-item.thumbnail-small' ) ;
var visibleGalleryButtons = [ ] ;
allGalleryButtons . forEach ( function ( elem ) {
if ( elem . parentElement . offsetParent ) {
visibleGalleryButtons . push ( elem ) ;
}
2023-05-17 20:46:58 +08:00
} ) ;
2023-03-26 02:52:47 +08:00
return visibleGalleryButtons ;
}
function selected _gallery _button ( ) {
var allCurrentButtons = gradioApp ( ) . querySelectorAll ( '[style="display: block;"].tabitem div[id$=_gallery].gradio-gallery .thumbnail-item.thumbnail-small.selected' ) ;
var visibleCurrentButton = null ;
allCurrentButtons . forEach ( function ( elem ) {
if ( elem . parentElement . offsetParent ) {
visibleCurrentButton = elem ;
}
2023-05-17 20:46:58 +08:00
} ) ;
2023-03-26 02:52:47 +08:00
return visibleCurrentButton ;
}
2023-05-17 20:46:58 +08:00
function selected _gallery _index ( ) {
2023-03-26 02:52:47 +08:00
var buttons = all _gallery _buttons ( ) ;
var button = selected _gallery _button ( ) ;
2022-09-03 04:25:29 +08:00
2023-05-17 20:46:58 +08:00
var result = - 1 ;
buttons . forEach ( function ( v , i ) {
if ( v == button ) {
result = i ;
}
} ) ;
2022-09-03 04:25:29 +08:00
2023-05-17 20:46:58 +08:00
return result ;
2022-09-03 04:25:29 +08:00
}
2023-05-17 20:46:58 +08:00
function extract _image _from _gallery ( gallery ) {
if ( gallery . length == 0 ) {
2023-03-26 02:52:47 +08:00
return [ null ] ;
}
2023-05-17 20:46:58 +08:00
if ( gallery . length == 1 ) {
2023-03-26 02:52:47 +08:00
return [ gallery [ 0 ] ] ;
2022-09-03 04:25:29 +08:00
}
2023-05-17 20:46:58 +08:00
var index = selected _gallery _index ( ) ;
2022-09-03 04:25:29 +08:00
2023-05-17 20:46:58 +08:00
if ( index < 0 || index >= gallery . length ) {
2023-03-26 02:52:47 +08:00
// Use the first image in the gallery as the default
index = 0 ;
2022-09-03 04:25:29 +08:00
}
2023-01-03 03:44:46 +08:00
return [ gallery [ index ] ] ;
2022-09-11 05:17:34 +08:00
}
2023-05-17 20:46:58 +08:00
function args _to _array ( args ) {
var res = [ ] ;
for ( var i = 0 ; i < args . length ; i ++ ) {
res . push ( args [ i ] ) ;
2022-09-24 03:49:21 +08:00
}
2023-05-17 20:46:58 +08:00
return res ;
2022-09-24 03:49:21 +08:00
}
2023-05-17 20:46:58 +08:00
function switch _to _txt2img ( ) {
2022-10-14 01:42:27 +08:00
gradioApp ( ) . querySelector ( '#tabs' ) . querySelectorAll ( 'button' ) [ 0 ] . click ( ) ;
2022-09-24 03:49:21 +08:00
return args _to _array ( arguments ) ;
}
2023-05-17 20:46:58 +08:00
function switch _to _img2img _tab ( no ) {
2022-10-14 01:42:27 +08:00
gradioApp ( ) . querySelector ( '#tabs' ) . querySelectorAll ( 'button' ) [ 1 ] . click ( ) ;
2023-01-15 03:43:01 +08:00
gradioApp ( ) . getElementById ( 'mode_img2img' ) . querySelectorAll ( 'button' ) [ no ] . click ( ) ;
}
2023-05-17 20:46:58 +08:00
function switch _to _img2img ( ) {
2023-01-15 03:43:01 +08:00
switch _to _img2img _tab ( 0 ) ;
return args _to _array ( arguments ) ;
}
2023-05-17 20:46:58 +08:00
function switch _to _sketch ( ) {
2023-01-15 03:43:01 +08:00
switch _to _img2img _tab ( 1 ) ;
return args _to _array ( arguments ) ;
}
2023-05-17 20:46:58 +08:00
function switch _to _inpaint ( ) {
2023-01-15 03:43:01 +08:00
switch _to _img2img _tab ( 2 ) ;
return args _to _array ( arguments ) ;
}
2022-09-24 03:49:21 +08:00
2023-05-17 20:46:58 +08:00
function switch _to _inpaint _sketch ( ) {
2023-01-15 03:43:01 +08:00
switch _to _img2img _tab ( 3 ) ;
2022-09-24 03:49:21 +08:00
return args _to _array ( arguments ) ;
}
2023-05-17 20:46:58 +08:00
function switch _to _inpaint ( ) {
2022-10-14 01:42:27 +08:00
gradioApp ( ) . querySelector ( '#tabs' ) . querySelectorAll ( 'button' ) [ 1 ] . click ( ) ;
2023-01-13 00:47:33 +08:00
gradioApp ( ) . getElementById ( 'mode_img2img' ) . querySelectorAll ( 'button' ) [ 2 ] . click ( ) ;
2022-09-24 03:49:21 +08:00
return args _to _array ( arguments ) ;
}
2023-05-17 20:46:58 +08:00
function switch _to _extras ( ) {
2022-10-14 01:42:27 +08:00
gradioApp ( ) . querySelector ( '#tabs' ) . querySelectorAll ( 'button' ) [ 2 ] . click ( ) ;
2022-09-24 03:49:21 +08:00
return args _to _array ( arguments ) ;
}
2023-05-17 20:46:58 +08:00
function get _tab _index ( tabId ) {
var res = 0 ;
2022-09-22 17:11:48 +08:00
2023-05-17 20:46:58 +08:00
gradioApp ( ) . getElementById ( tabId ) . querySelector ( 'div' ) . querySelectorAll ( 'button' ) . forEach ( function ( button , i ) {
if ( button . className . indexOf ( 'selected' ) != - 1 ) {
res = i ;
}
} ) ;
2022-09-22 17:11:48 +08:00
2023-05-17 20:46:58 +08:00
return res ;
2022-09-22 17:11:48 +08:00
}
2023-05-17 20:46:58 +08:00
function create _tab _index _args ( tabId , args ) {
var res = [ ] ;
for ( var i = 0 ; i < args . length ; i ++ ) {
res . push ( args [ i ] ) ;
2022-09-22 17:11:48 +08:00
}
2022-09-06 07:09:01 +08:00
2023-05-17 20:46:58 +08:00
res [ 0 ] = get _tab _index ( tabId ) ;
2022-09-22 17:11:48 +08:00
2023-05-17 20:46:58 +08:00
return res ;
2022-09-22 17:11:48 +08:00
}
2023-01-19 01:16:52 +08:00
function get _img2img _tab _index ( ) {
2023-05-17 20:46:58 +08:00
let res = args _to _array ( arguments ) ;
res . splice ( - 2 ) ;
res [ 0 ] = get _tab _index ( 'mode_img2img' ) ;
return res ;
2023-01-19 01:16:52 +08:00
}
2023-05-17 20:46:58 +08:00
function create _submit _args ( args ) {
var res = [ ] ;
for ( var i = 0 ; i < args . length ; i ++ ) {
res . push ( args [ i ] ) ;
2022-09-06 07:09:01 +08:00
}
2022-09-17 13:03:47 +08:00
// 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.
2022-12-15 10:01:32 +08:00
// 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.
2022-09-17 13:03:47 +08:00
// If gradio at some point stops sending outputs, this may break something
2023-05-17 20:46:58 +08:00
if ( Array . isArray ( res [ res . length - 3 ] ) ) {
res [ res . length - 3 ] = null ;
2022-09-17 13:03:47 +08:00
}
2023-05-17 20:46:58 +08:00
return res ;
2022-09-08 02:26:19 +08:00
}
2022-09-08 03:58:11 +08:00
2023-05-17 20:46:58 +08:00
function showSubmitButtons ( tabname , show ) {
gradioApp ( ) . getElementById ( tabname + '_interrupt' ) . style . display = show ? "none" : "block" ;
gradioApp ( ) . getElementById ( tabname + '_skip' ) . style . display = show ? "none" : "block" ;
2023-01-15 23:50:56 +08:00
}
2023-05-17 20:46:58 +08:00
function showRestoreProgressButton ( tabname , show ) {
var button = gradioApp ( ) . getElementById ( tabname + "_restore_progress" ) ;
if ( ! button ) return ;
2023-04-30 03:16:54 +08:00
2023-05-17 20:46:58 +08:00
button . style . display = show ? "flex" : "none" ;
2023-04-30 03:16:54 +08:00
}
2023-05-17 20:46:58 +08:00
function submit ( ) {
rememberGallerySelection ( 'txt2img_gallery' ) ;
showSubmitButtons ( 'txt2img' , false ) ;
2023-01-15 23:50:56 +08:00
2023-05-17 20:46:58 +08:00
var id = randomId ( ) ;
2023-04-30 03:16:54 +08:00
localStorage . setItem ( "txt2img_task_id" , id ) ;
2023-05-17 20:46:58 +08:00
requestProgress ( id , gradioApp ( ) . getElementById ( 'txt2img_gallery_container' ) , gradioApp ( ) . getElementById ( 'txt2img_gallery' ) , function ( ) {
showSubmitButtons ( 'txt2img' , true ) ;
localStorage . removeItem ( "txt2img_task_id" ) ;
showRestoreProgressButton ( 'txt2img' , false ) ;
} ) ;
2022-09-22 17:11:48 +08:00
2023-05-17 20:46:58 +08:00
var res = create _submit _args ( arguments ) ;
2023-01-15 23:50:56 +08:00
2023-05-17 20:46:58 +08:00
res [ 0 ] = id ;
2023-01-15 23:50:56 +08:00
2023-05-17 20:46:58 +08:00
return res ;
2022-09-22 17:11:48 +08:00
}
2023-05-17 20:46:58 +08:00
function submit _img2img ( ) {
rememberGallerySelection ( 'img2img_gallery' ) ;
showSubmitButtons ( 'img2img' , false ) ;
2023-01-15 23:50:56 +08:00
2023-05-17 20:46:58 +08:00
var id = randomId ( ) ;
2023-04-30 03:16:54 +08:00
localStorage . setItem ( "img2img_task_id" , id ) ;
2023-05-17 20:46:58 +08:00
requestProgress ( id , gradioApp ( ) . getElementById ( 'img2img_gallery_container' ) , gradioApp ( ) . getElementById ( 'img2img_gallery' ) , function ( ) {
showSubmitButtons ( 'img2img' , true ) ;
localStorage . removeItem ( "img2img_task_id" ) ;
showRestoreProgressButton ( 'img2img' , false ) ;
} ) ;
2022-09-22 17:11:48 +08:00
2023-05-17 20:46:58 +08:00
var res = create _submit _args ( arguments ) ;
2022-09-22 17:11:48 +08:00
2023-05-17 20:46:58 +08:00
res [ 0 ] = id ;
res [ 1 ] = get _tab _index ( 'mode_img2img' ) ;
2022-09-22 17:11:48 +08:00
2023-05-17 20:46:58 +08:00
return res ;
2022-09-22 17:11:48 +08:00
}
2023-05-17 20:46:58 +08:00
function restoreProgressTxt2img ( ) {
showRestoreProgressButton ( "txt2img" , false ) ;
var id = localStorage . getItem ( "txt2img_task_id" ) ;
2023-04-30 03:16:54 +08:00
2023-05-17 20:46:58 +08:00
id = localStorage . getItem ( "txt2img_task_id" ) ;
2023-04-30 03:16:54 +08:00
2023-05-17 20:46:58 +08:00
if ( id ) {
requestProgress ( id , gradioApp ( ) . getElementById ( 'txt2img_gallery_container' ) , gradioApp ( ) . getElementById ( 'txt2img_gallery' ) , function ( ) {
showSubmitButtons ( 'txt2img' , true ) ;
} , null , 0 ) ;
2023-04-30 03:16:54 +08:00
}
2023-05-17 20:46:58 +08:00
return id ;
2023-04-30 03:16:54 +08:00
}
2023-05-01 18:58:10 +08:00
2023-05-17 20:46:58 +08:00
function restoreProgressImg2img ( ) {
showRestoreProgressButton ( "img2img" , false ) ;
var id = localStorage . getItem ( "img2img_task_id" ) ;
2023-04-30 03:16:54 +08:00
2023-05-17 20:46:58 +08:00
if ( id ) {
requestProgress ( id , gradioApp ( ) . getElementById ( 'img2img_gallery_container' ) , gradioApp ( ) . getElementById ( 'img2img_gallery' ) , function ( ) {
showSubmitButtons ( 'img2img' , true ) ;
} , null , 0 ) ;
2023-04-30 03:16:54 +08:00
}
2023-05-17 20:46:58 +08:00
return id ;
2023-04-30 03:16:54 +08:00
}
2023-05-17 20:46:58 +08:00
onUiLoaded ( function ( ) {
showRestoreProgressButton ( 'txt2img' , localStorage . getItem ( "txt2img_task_id" ) ) ;
showRestoreProgressButton ( 'img2img' , localStorage . getItem ( "img2img_task_id" ) ) ;
2023-04-30 03:16:54 +08:00
} ) ;
2023-05-17 20:46:58 +08:00
function modelmerger ( ) {
var id = randomId ( ) ;
requestProgress ( id , gradioApp ( ) . getElementById ( 'modelmerger_results_panel' ) , null , function ( ) { } ) ;
2023-01-19 14:25:37 +08:00
2023-05-17 20:46:58 +08:00
var res = create _submit _args ( arguments ) ;
res [ 0 ] = id ;
return res ;
2023-01-19 14:25:37 +08:00
}
2022-09-22 17:11:48 +08:00
2022-09-11 22:35:12 +08:00
function ask _for _style _name ( _ , prompt _text , negative _prompt _text ) {
2023-05-17 20:46:58 +08:00
var name _ = prompt ( 'Style name:' ) ;
return [ name _ , prompt _text , negative _prompt _text ] ;
2022-09-10 04:16:02 +08:00
}
2022-09-19 03:25:18 +08:00
2022-12-10 18:46:18 +08:00
function confirm _clear _prompt ( prompt , negative _prompt ) {
2023-05-17 20:46:58 +08:00
if ( confirm ( "Delete prompt?" ) ) {
prompt = "" ;
negative _prompt = "" ;
2022-10-20 14:08:24 +08:00
}
2022-10-21 06:03:25 +08:00
2023-05-17 20:46:58 +08:00
return [ prompt , negative _prompt ] ;
2022-10-20 14:08:24 +08:00
}
2023-01-30 06:03:31 +08:00
2023-05-17 20:46:58 +08:00
promptTokecountUpdateFuncs = { } ;
2023-01-30 06:03:31 +08:00
2023-05-17 20:46:58 +08:00
function recalculatePromptTokens ( name ) {
if ( promptTokecountUpdateFuncs [ name ] ) {
promptTokecountUpdateFuncs [ name ] ( ) ;
2023-01-30 06:03:31 +08:00
}
}
2023-05-17 20:46:58 +08:00
function recalculate _prompts _txt2img ( ) {
recalculatePromptTokens ( 'txt2img_prompt' ) ;
recalculatePromptTokens ( 'txt2img_neg_prompt' ) ;
2023-01-30 06:03:31 +08:00
return args _to _array ( arguments ) ;
}
2023-05-17 20:46:58 +08:00
function recalculate _prompts _img2img ( ) {
recalculatePromptTokens ( 'img2img_prompt' ) ;
recalculatePromptTokens ( 'img2img_neg_prompt' ) ;
2023-01-30 06:03:31 +08:00
return args _to _array ( arguments ) ;
}
2023-05-17 20:46:58 +08:00
var opts = { } ;
onUiUpdate ( function ( ) {
if ( Object . keys ( opts ) . length != 0 ) return ;
2022-09-19 03:25:18 +08:00
2023-05-17 20:46:58 +08:00
var json _elem = gradioApp ( ) . getElementById ( 'settings_json' ) ;
if ( json _elem == null ) return ;
2022-09-19 03:25:18 +08:00
2023-05-17 20:46:58 +08:00
var textarea = json _elem . querySelector ( 'textarea' ) ;
var jsdata = textarea . value ;
opts = JSON . parse ( jsdata ) ;
2023-01-14 20:55:40 +08:00
executeCallbacks ( optionsChangedCallbacks ) ;
2022-09-19 03:25:18 +08:00
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 ) {
2023-05-17 20:46:58 +08:00
opts = JSON . parse ( textarea . value ) ;
2022-09-19 03:25:18 +08:00
}
2023-01-14 20:55:40 +08:00
executeCallbacks ( optionsChangedCallbacks ) ;
2022-09-19 03:25:18 +08:00
} ,
get : function ( ) {
var valueProp = Object . getOwnPropertyDescriptor ( HTMLTextAreaElement . prototype , 'value' ) ;
return valueProp . get . call ( textarea ) ;
}
} ) ;
2023-05-17 20:46:58 +08:00
json _elem . parentElement . style . display = "none" ;
2022-09-28 21:43:54 +08:00
2023-05-17 20:46:58 +08:00
function registerTextarea ( id , id _counter , id _button ) {
var prompt = gradioApp ( ) . getElementById ( id ) ;
var counter = gradioApp ( ) . getElementById ( id _counter ) ;
2023-01-20 15:18:41 +08:00
var textarea = gradioApp ( ) . querySelector ( "#" + id + " > label > textarea" ) ;
2023-05-17 20:46:58 +08:00
if ( counter . parentElement == prompt . parentElement ) {
return ;
2023-01-20 15:18:41 +08:00
}
2023-05-17 20:46:58 +08:00
prompt . parentElement . insertBefore ( counter , prompt ) ;
prompt . parentElement . style . position = "relative" ;
2023-01-20 15:18:41 +08:00
2023-05-17 20:46:58 +08:00
promptTokecountUpdateFuncs [ id ] = function ( ) {
update _token _counter ( id _button ) ;
} ;
textarea . addEventListener ( "input" , promptTokecountUpdateFuncs [ id ] ) ;
2023-01-20 15:18:41 +08:00
}
2023-05-17 20:46:58 +08:00
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 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 ) {
if ( elem . id == "settings_tab_licenses" ) {
2023-05-08 20:30:32 +08:00
return ;
2023-05-17 20:46:58 +08:00
}
2023-05-08 20:30:32 +08:00
2023-01-03 15:01:06 +08:00
elem . style . display = "block" ;
2023-05-17 20:46:58 +08:00
} ) ;
} ;
2023-01-03 15:01:06 +08:00
}
2023-05-17 20:46:58 +08:00
} ) ;
2022-09-28 03:56:18 +08:00
2023-05-17 20:46:58 +08:00
onOptionsChanged ( function ( ) {
var elem = gradioApp ( ) . getElementById ( 'sd_checkpoint_hash' ) ;
var sd _checkpoint _hash = opts . sd _checkpoint _hash || "" ;
var shorthash = sd _checkpoint _hash . substring ( 0 , 10 ) ;
2023-01-14 20:55:40 +08:00
2023-05-17 20:46:58 +08:00
if ( elem && elem . textContent != shorthash ) {
elem . textContent = shorthash ;
elem . title = sd _checkpoint _hash ;
elem . href = "https://google.com/search?q=" + sd _checkpoint _hash ;
}
} ) ;
2023-01-14 20:55:40 +08:00
2022-09-28 21:43:54 +08:00
let txt2img _textarea , img2img _textarea = undefined ;
2023-05-17 20:46:58 +08:00
let wait _time = 800 ;
2023-01-30 06:03:31 +08:00
let token _timeouts = { } ;
2022-09-28 03:56:18 +08:00
2022-10-01 00:12:44 +08:00
function update _txt2img _tokens ( ... args ) {
2023-05-17 20:46:58 +08:00
update _token _counter ( "txt2img_token_button" ) ;
if ( args . length == 2 ) {
return args [ 0 ] ;
}
return args ;
2022-09-30 02:40:47 +08:00
}
2022-10-01 00:12:44 +08:00
function update _img2img _tokens ( ... args ) {
2023-05-17 20:46:58 +08:00
update _token _counter ( "img2img_token_button" ) ;
if ( args . length == 2 ) {
return args [ 0 ] ;
}
return args ;
2022-10-01 04:31:00 +08:00
}
2022-09-28 21:43:54 +08:00
function update _token _counter ( button _id ) {
2023-05-17 20:46:58 +08:00
if ( token _timeouts [ button _id ] ) {
clearTimeout ( token _timeouts [ button _id ] ) ;
}
token _timeouts [ button _id ] = setTimeout ( ( ) => gradioApp ( ) . getElementById ( button _id ) ? . click ( ) , wait _time ) ;
2022-09-28 07:29:53 +08:00
}
2022-10-02 07:12:49 +08:00
2023-05-17 20:46:58 +08:00
function restart _reload ( ) {
document . body . innerHTML = '<h1 style="font-family:monospace;margin-top:20%;color:lightgray;text-align:center;">Reloading...</h1>' ;
2023-05-09 16:42:47 +08:00
2023-05-17 20:46:58 +08:00
var requestPing = function ( ) {
requestGet ( "./internal/ping" , { } , function ( data ) {
2023-05-09 16:42:47 +08:00
location . reload ( ) ;
2023-05-17 20:46:58 +08:00
} , function ( ) {
2023-05-09 16:42:47 +08:00
setTimeout ( requestPing , 500 ) ;
2023-05-17 20:46:58 +08:00
} ) ;
} ;
2023-05-09 16:42:47 +08:00
setTimeout ( requestPing , 2000 ) ;
2022-11-06 14:02:25 +08:00
2023-05-17 20:46:58 +08:00
return [ ] ;
2022-10-02 07:12:49 +08:00
}
2023-01-17 19:15:47 +08:00
// 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.
2023-05-17 20:46:58 +08:00
function updateInput ( target ) {
let e = new Event ( "input" , { bubbles : true } ) ;
Object . defineProperty ( e , "target" , { value : target } ) ;
target . dispatchEvent ( e ) ;
2023-01-17 19:15:47 +08:00
}
2023-01-29 03:52:27 +08:00
var desiredCheckpointName = null ;
2023-05-17 20:46:58 +08:00
function selectCheckpoint ( name ) {
2023-01-29 03:52:27 +08:00
desiredCheckpointName = name ;
2023-05-17 20:46:58 +08:00
gradioApp ( ) . getElementById ( 'change_checkpoint' ) . click ( ) ;
2023-01-29 03:52:27 +08:00
}
2023-02-06 03:55:31 +08:00
2023-05-17 20:46:58 +08:00
function currentImg2imgSourceResolution ( _ , _ , scaleBy ) {
var img = gradioApp ( ) . querySelector ( '#mode_img2img > div[style="display: block;"] img' ) ;
return img ? [ img . naturalWidth , img . naturalHeight , scaleBy ] : [ 0 , 0 , scaleBy ] ;
2023-03-29 03:23:40 +08:00
}
2023-04-30 00:39:22 +08:00
2023-05-17 20:46:58 +08:00
function updateImg2imgResizeToTextAfterChangingImage ( ) {
2023-04-30 00:39:22 +08:00
// At the time this is called from gradio, the image has no yet been replaced.
// There may be a better solution, but this is simple and straightforward so I'm going with it.
setTimeout ( function ( ) {
2023-05-17 20:46:58 +08:00
gradioApp ( ) . getElementById ( 'img2img_update_resize_to' ) . click ( ) ;
2023-04-30 00:39:22 +08:00
} , 500 ) ;
2023-05-17 20:46:58 +08:00
return [ ] ;
2023-04-30 00:39:22 +08:00
}