2023-07-08 15:49:56 +00:00
/ * *
* Extensions helper thing or class or whatever
* /
const extensions = {
// alwaysOnScriptsData: {},
alwaysOnScripts : false ,
2024-02-21 20:40:02 +00:00
// softInpaintingEnabled: false, //???
2023-07-08 15:49:56 +00:00
controlNetEnabled : false ,
controlNetActive : false ,
2023-07-15 17:10:45 +00:00
controlNetReferenceActive : false ,
controlNetReferenceFidelity : 0.5 ,
2023-07-08 20:21:58 +00:00
selectedControlNetModel : null ,
selectedControlNetModule : null ,
2023-07-15 17:10:45 +00:00
selectedCNReferenceModule : null ,
controlNetModelCount : 0 ,
2023-07-08 15:49:56 +00:00
dynamicPromptsEnabled : false ,
dynamicPromptsActive : false ,
dynamicPromptsAlwaysonScriptName : null , //GRUMBLE GRUMBLE
enabledExtensions : [ ] ,
controlNetModels : null ,
controlNetModules : null ,
2023-07-08 17:54:17 +00:00
async getExtensions (
controlNetModelAutoComplete ,
2023-07-15 17:10:45 +00:00
controlNetModuleAutoComplete ,
controlNetReferenceModuleAutoComplete
2023-07-08 17:54:17 +00:00
) {
2023-07-08 15:49:56 +00:00
const allowedExtensions = [
"controlnet" ,
// "none",
// "adetailer", // no API, can't verify available models
"dynamic prompts" , //seriously >:( why put version in the name, now i have to fuzzy match it - just simply enabled or not? no API but so so good
//"segment anything", // ... API lets me get model but not processor?!?!?!
//"self attention guidance", // no API but useful, just enabled button, scale and threshold sliders?
] ;
// check http://127.0.0.1:7860/sdapi/v1/scripts for extensions
// if any of the allowed extensions are found, add them to the list
var url = document . getElementById ( "host" ) . value + "/sdapi/v1/scripts" ;
try {
const response = await fetch ( url ) ;
const data = await response . json ( ) ;
// enable checkboxes for extensions based on existence in data
data . img2img
. filter ( ( extension ) => {
return allowedExtensions . some ( ( allowedExtension ) => {
return extension . toLowerCase ( ) . includes ( allowedExtension ) ;
} ) ;
} )
. forEach ( ( extension ) => {
this . enabledExtensions . push ( extension ) ;
} ) ;
} catch ( e ) {
console . warn ( "[index] Failed to fetch extensions" ) ;
console . warn ( e ) ;
}
2024-02-21 14:18:28 +00:00
this . checkForSoftInpainting ( ) ;
2023-07-08 15:49:56 +00:00
this . checkForDynamicPrompts ( ) ;
2023-07-08 17:54:17 +00:00
this . checkForControlNet (
controlNetModelAutoComplete ,
2023-07-15 17:10:45 +00:00
controlNetModuleAutoComplete ,
controlNetReferenceModuleAutoComplete
2023-07-08 17:54:17 +00:00
) ;
2023-07-08 15:49:56 +00:00
//checkForSAM(); //or inpaintAnything or something i dunno
//checkForADetailer(); //? this one seems iffy
//checkForSAG(); //??
} ,
2024-02-21 14:18:28 +00:00
async checkForSoftInpainting ( ) {
this . alwaysOnScripts = true ;
//TODO implement, inpaint/img2img only
} ,
2023-07-08 15:49:56 +00:00
async checkForDynamicPrompts ( ) {
2023-07-08 17:54:17 +00:00
if (
this . enabledExtensions . filter ( ( e ) => e . includes ( "dynamic prompts" ) )
. length > 0
) {
// Dynamic Prompts found, enable checkbox
this . alwaysOnScripts = true ;
this . dynamicPromptsAlwaysonScriptName =
this . enabledExtensions [
this . enabledExtensions . findIndex ( ( e ) => e . includes ( "dynamic prompts" ) )
] ;
// this.alwaysOnScriptsData[this.dynamicPromptsAlwaysonScriptName] = {};
this . dynamicPromptsEnabled = true ;
document . getElementById ( "cbxDynPrompts" ) . disabled = false ;
}
2023-07-08 15:49:56 +00:00
// basically param 0 is true for on, false for off, that's it
} ,
2023-07-08 17:54:17 +00:00
async checkForControlNet (
controlNetModelAutoComplete ,
2023-07-15 17:10:45 +00:00
controlNetModuleAutoComplete ,
controlNetReferenceModuleAutoComplete
2023-07-08 17:54:17 +00:00
) {
2023-07-08 15:49:56 +00:00
var url = document . getElementById ( "host" ) . value + "/controlnet/version" ;
2023-07-22 14:48:43 +00:00
if (
this . enabledExtensions . filter ( ( e ) => e . includes ( "controlnet" ) ) . length > 0
) {
2023-07-15 17:10:45 +00:00
try {
2023-07-22 14:48:43 +00:00
const response = await fetch ( url ) ;
const data = await response . json ( ) ;
if ( data . version > 0 ) {
// ControlNet found
this . alwaysOnScripts = true ;
this . controlNetEnabled = true ;
document . getElementById ( "cbxControlNet" ) . disabled = false ;
// ok cool so now we can get the models and modules
this . getModels ( controlNetModelAutoComplete ) ;
this . getModules (
controlNetModuleAutoComplete ,
controlNetReferenceModuleAutoComplete
2023-07-15 17:10:45 +00:00
) ;
}
2023-07-22 14:48:43 +00:00
url = document . getElementById ( "host" ) . value + "/controlnet/settings" ;
try {
const response2 = await fetch ( url ) ;
const data2 = await response2 . json ( ) ;
if ( data2 . control _net _max _models _num < 2 ) {
document . getElementById ( "cbxControlNetReferenceLayer" ) . disabled =
"disabled" ;
console . warn (
"[extensions] ControlNet reference layer disabled due to insufficient units enabled in settings - cannot be enabled via API, please increase to at least 2 units manually"
) ;
}
} catch ( ex ) { }
} catch ( e ) {
// ??
global . controlnetAPI = false ;
}
} else {
2023-07-08 15:49:56 +00:00
global . controlnetAPI = false ;
}
} ,
2023-07-08 17:54:17 +00:00
async getModels ( controlNetModelAutoComplete ) {
2023-07-08 15:49:56 +00:00
// only worry about inpaint models for now
var url = document . getElementById ( "host" ) . value + "/controlnet/model_list" ;
try {
const response = await fetch ( url ) ;
const data = await response . json ( ) ;
this . controlNetModels = data . model _list ;
} catch ( e ) {
console . warn ( "[extensions] Failed to fetch controlnet models" ) ;
console . warn ( e ) ;
}
2023-07-08 17:54:17 +00:00
let opt = null ;
opt = this . controlNetModels
. filter ( ( m ) => m . includes ( "inpaint" ) )
. map ( ( option ) => ( {
name : option ,
value : option ,
} ) ) ;
controlNetModelAutoComplete . options = opt ;
2023-07-08 15:49:56 +00:00
} ,
2023-07-15 17:10:45 +00:00
async getModules (
controlNetModuleAutoComplete ,
controlNetReferenceModuleAutoComplete
) {
2023-07-08 15:49:56 +00:00
const allowedModules = [ "reference" , "inpaint" ] ;
var url = document . getElementById ( "host" ) . value + "/controlnet/module_list" ;
try {
const response = await fetch ( url ) ;
const data = await response . json ( ) ;
this . controlNetModules = data ;
} catch ( e ) {
console . warn ( "[extensions] Failed to fetch controlnet modules" ) ;
console . warn ( e ) ;
}
2023-07-08 17:54:17 +00:00
let opt = null ;
opt = this . controlNetModules . module _list
2023-07-08 22:45:47 +00:00
. filter ( ( m ) => m . includes ( "inpaint" ) ) // why is there just "inpaint" in the modules if it's not in the ui
2023-07-08 17:54:17 +00:00
. map ( ( option ) => ( {
name : option ,
value : option ,
} ) ) ;
opt . push ( {
name : "inpaint_global_harmonious" ,
2023-07-08 22:45:47 +00:00
value : "inpaint_global_harmonious" , // WTF WHY IS THIS ONE NOT LISTED IN MODULES BUT DISTINCT IN THE API CALL?!?!?!??!??! it is slightly different from "inpaint" from what i can tell
2023-07-08 17:54:17 +00:00
} ) ;
controlNetModuleAutoComplete . options = opt ;
2023-07-15 17:10:45 +00:00
opt = this . controlNetModules . module _list
. filter ( ( m ) => m . includes ( "reference" ) )
. map ( ( option ) => ( {
name : option ,
value : option ,
} ) ) ;
controlNetReferenceModuleAutoComplete . options = opt ;
2023-07-08 15:49:56 +00:00
} ,
} ;