mirror of
https://github.com/AUTOMATIC1111/stable-diffusion-webui.git
synced 2025-01-18 20:30:13 +08:00
083dc3c76a
create HTML for extra network pages only on demand allow directories starting with . to still list their models for lora, checkpoints, etc keep "search" filter for extra networks when user refreshes the page
197 lines
6.2 KiB
JavaScript
197 lines
6.2 KiB
JavaScript
function setupExtraNetworksForTab(tabname){
|
|
gradioApp().querySelector('#'+tabname+'_extra_tabs').classList.add('extra-networks')
|
|
|
|
var tabs = gradioApp().querySelector('#'+tabname+'_extra_tabs > div')
|
|
var search = gradioApp().querySelector('#'+tabname+'_extra_search textarea')
|
|
var refresh = gradioApp().getElementById(tabname+'_extra_refresh')
|
|
|
|
search.classList.add('search')
|
|
tabs.appendChild(search)
|
|
tabs.appendChild(refresh)
|
|
|
|
var applyFilter = function(){
|
|
var searchTerm = search.value.toLowerCase()
|
|
|
|
gradioApp().querySelectorAll('#'+tabname+'_extra_tabs div.card').forEach(function(elem){
|
|
var searchOnly = elem.querySelector('.search_only')
|
|
var text = elem.querySelector('.name').textContent.toLowerCase() + " " + elem.querySelector('.search_term').textContent.toLowerCase()
|
|
|
|
var visible = text.indexOf(searchTerm) != -1
|
|
|
|
if(searchOnly && searchTerm.length < 4){
|
|
visible = false
|
|
}
|
|
|
|
elem.style.display = visible ? "" : "none"
|
|
})
|
|
}
|
|
|
|
search.addEventListener("input", applyFilter);
|
|
applyFilter();
|
|
|
|
extraNetworksApplyFilter[tabname] = applyFilter;
|
|
}
|
|
|
|
function applyExtraNetworkFilter(tabname){
|
|
setTimeout(extraNetworksApplyFilter[tabname], 1);
|
|
}
|
|
|
|
var extraNetworksApplyFilter = {}
|
|
var activePromptTextarea = {};
|
|
|
|
function setupExtraNetworks(){
|
|
setupExtraNetworksForTab('txt2img')
|
|
setupExtraNetworksForTab('img2img')
|
|
|
|
function registerPrompt(tabname, id){
|
|
var textarea = gradioApp().querySelector("#" + id + " > label > textarea");
|
|
|
|
if (! activePromptTextarea[tabname]){
|
|
activePromptTextarea[tabname] = textarea
|
|
}
|
|
|
|
textarea.addEventListener("focus", function(){
|
|
activePromptTextarea[tabname] = textarea;
|
|
});
|
|
}
|
|
|
|
registerPrompt('txt2img', 'txt2img_prompt')
|
|
registerPrompt('txt2img', 'txt2img_neg_prompt')
|
|
registerPrompt('img2img', 'img2img_prompt')
|
|
registerPrompt('img2img', 'img2img_neg_prompt')
|
|
}
|
|
|
|
onUiLoaded(setupExtraNetworks)
|
|
|
|
var re_extranet = /<([^:]+:[^:]+):[\d\.]+>/;
|
|
var re_extranet_g = /\s+<([^:]+:[^:]+):[\d\.]+>/g;
|
|
|
|
function tryToRemoveExtraNetworkFromPrompt(textarea, text){
|
|
var m = text.match(re_extranet)
|
|
if(! m) return false
|
|
|
|
var partToSearch = m[1]
|
|
var replaced = false
|
|
var newTextareaText = textarea.value.replaceAll(re_extranet_g, function(found){
|
|
m = found.match(re_extranet);
|
|
if(m[1] == partToSearch){
|
|
replaced = true;
|
|
return ""
|
|
}
|
|
return found;
|
|
})
|
|
|
|
if(replaced){
|
|
textarea.value = newTextareaText
|
|
return true;
|
|
}
|
|
|
|
return false
|
|
}
|
|
|
|
function cardClicked(tabname, textToAdd, allowNegativePrompt){
|
|
var textarea = allowNegativePrompt ? activePromptTextarea[tabname] : gradioApp().querySelector("#" + tabname + "_prompt > label > textarea")
|
|
|
|
if(! tryToRemoveExtraNetworkFromPrompt(textarea, textToAdd)){
|
|
textarea.value = textarea.value + opts.extra_networks_add_text_separator + textToAdd
|
|
}
|
|
|
|
updateInput(textarea)
|
|
}
|
|
|
|
function saveCardPreview(event, tabname, filename){
|
|
var textarea = gradioApp().querySelector("#" + tabname + '_preview_filename > label > textarea')
|
|
var button = gradioApp().getElementById(tabname + '_save_preview')
|
|
|
|
textarea.value = filename
|
|
updateInput(textarea)
|
|
|
|
button.click()
|
|
|
|
event.stopPropagation()
|
|
event.preventDefault()
|
|
}
|
|
|
|
function extraNetworksSearchButton(tabs_id, event){
|
|
var searchTextarea = gradioApp().querySelector("#" + tabs_id + ' > div > textarea')
|
|
var button = event.target
|
|
var text = button.classList.contains("search-all") ? "" : button.textContent.trim()
|
|
|
|
searchTextarea.value = text
|
|
updateInput(searchTextarea)
|
|
}
|
|
|
|
var globalPopup = null;
|
|
var globalPopupInner = null;
|
|
function popup(contents){
|
|
if(! globalPopup){
|
|
globalPopup = document.createElement('div')
|
|
globalPopup.onclick = function(){ globalPopup.style.display = "none"; };
|
|
globalPopup.classList.add('global-popup');
|
|
|
|
var close = document.createElement('div')
|
|
close.classList.add('global-popup-close');
|
|
close.onclick = function(){ globalPopup.style.display = "none"; };
|
|
close.title = "Close";
|
|
globalPopup.appendChild(close)
|
|
|
|
globalPopupInner = document.createElement('div')
|
|
globalPopupInner.onclick = function(event){ event.stopPropagation(); return false; };
|
|
globalPopupInner.classList.add('global-popup-inner');
|
|
globalPopup.appendChild(globalPopupInner)
|
|
|
|
gradioApp().appendChild(globalPopup);
|
|
}
|
|
|
|
globalPopupInner.innerHTML = '';
|
|
globalPopupInner.appendChild(contents);
|
|
|
|
globalPopup.style.display = "flex";
|
|
}
|
|
|
|
function extraNetworksShowMetadata(text){
|
|
var elem = document.createElement('pre')
|
|
elem.classList.add('popup-metadata');
|
|
elem.textContent = text;
|
|
|
|
popup(elem);
|
|
}
|
|
|
|
function requestGet(url, data, handler, errorHandler){
|
|
var xhr = new XMLHttpRequest();
|
|
var args = Object.keys(data).map(function(k){ return encodeURIComponent(k) + '=' + encodeURIComponent(data[k]) }).join('&')
|
|
xhr.open("GET", url + "?" + args, true);
|
|
|
|
xhr.onreadystatechange = function () {
|
|
if (xhr.readyState === 4) {
|
|
if (xhr.status === 200) {
|
|
try {
|
|
var js = JSON.parse(xhr.responseText);
|
|
handler(js)
|
|
} catch (error) {
|
|
console.error(error);
|
|
errorHandler()
|
|
}
|
|
} else{
|
|
errorHandler()
|
|
}
|
|
}
|
|
};
|
|
var js = JSON.stringify(data);
|
|
xhr.send(js);
|
|
}
|
|
|
|
function extraNetworksRequestMetadata(event, extraPage, cardName){
|
|
var showError = function(){ extraNetworksShowMetadata("there was an error getting metadata"); }
|
|
|
|
requestGet("./sd_extra_networks/metadata", {"page": extraPage, "item": cardName}, function(data){
|
|
if(data && data.metadata){
|
|
extraNetworksShowMetadata(data.metadata)
|
|
} else{
|
|
showError()
|
|
}
|
|
}, showError)
|
|
|
|
event.stopPropagation()
|
|
}
|