// Saving settings let saveSettingsConfigTable = document.getElementById("save-settings-config-table") let saveSettingsConfigOverlay = document.getElementById("save-settings-config") let resetImageSettingsButton = document.getElementById("reset-image-settings") const SETTINGS_KEY = "user_settings_v2" const SETTINGS = {} // key=id. dict initialized in initSettings. { element, default, value, ignore } const SETTINGS_IDS_LIST = [ "prompt", "seed", "random_seed", "num_outputs_total", "num_outputs_parallel", "stable_diffusion_model", "vae_model", "hypernetwork_model", "lora_model", "sampler_name", "width", "height", "num_inference_steps", "guidance_scale", "prompt_strength", "hypernetwork_strength", "lora_alpha", "output_format", "output_quality", "negative_prompt", "stream_image_progress", "use_face_correction", "gfpgan_model", "use_upscale", "upscale_amount", "block_nsfw", "show_only_filtered_image", "upscale_model", "preview-image", "modifier-card-size-slider", "theme", "save_to_disk", "diskPath", "sound_toggle", "vram_usage_level", "confirm_dangerous_actions", "metadata_output_format", "auto_save_settings", "apply_color_correction", "process_order_toggle", "thumbnail_size", "auto_scroll", "zip_toggle", "tree_toggle", "json_toggle" ] const IGNORE_BY_DEFAULT = [ "prompt" ] const SETTINGS_SECTIONS = [ // gets the "keys" property filled in with an ordered list of settings in this section via initSettings { id: "editor-inputs", name: "Prompt" }, { id: "editor-settings", name: "Image Settings" }, { id: "system-settings", name: "System Settings" }, { id: "container", name: "Other" } ] async function initSettings() { SETTINGS_IDS_LIST.forEach(id => { var element = document.getElementById(id) if (!element) { console.error(`Missing settings element ${id}`) } if (id in SETTINGS) { // don't create it again return } SETTINGS[id] = { key: id, element: element, label: getSettingLabel(element), default: getSetting(element), value: getSetting(element), ignore: IGNORE_BY_DEFAULT.includes(id) } element.addEventListener("input", settingChangeHandler) element.addEventListener("change", settingChangeHandler) }) var unsorted_settings_ids = [...SETTINGS_IDS_LIST] SETTINGS_SECTIONS.forEach(section => { var name = section.name var element = document.getElementById(section.id) var unsorted_ids = unsorted_settings_ids.map(id => `#${id}`).join(",") var children = unsorted_ids == "" ? [] : Array.from(element.querySelectorAll(unsorted_ids)); section.keys = [] children.forEach(e => { section.keys.push(e.id) }) unsorted_settings_ids = unsorted_settings_ids.filter(id => children.find(e => e.id == id) == undefined) }) loadSettings() } function getSetting(element) { if (element.dataset && 'path' in element.dataset) { return element.dataset.path } if (typeof element === "string" || element instanceof String) { element = SETTINGS[element].element } if (element.type == "checkbox") { return element.checked } return element.value } function setSetting(element, value) { if (element.dataset && 'path' in element.dataset) { element.dataset.path = value return // no need to dispatch any event here because the models are not loaded yet } if (typeof element === "string" || element instanceof String) { element = SETTINGS[element].element } SETTINGS[element.id].value = value if (getSetting(element) == value) { return // no setting necessary } if (element.type == "checkbox") { element.checked = value } else { element.value = value } element.dispatchEvent(new Event("input")) element.dispatchEvent(new Event("change")) } function saveSettings() { var saved_settings = Object.values(SETTINGS).map(setting => { return { key: setting.key, value: setting.value, ignore: setting.ignore } }) localStorage.setItem(SETTINGS_KEY, JSON.stringify(saved_settings)) } var CURRENTLY_LOADING_SETTINGS = false function loadSettings() { var saved_settings_text = localStorage.getItem(SETTINGS_KEY) if (saved_settings_text) { var saved_settings = JSON.parse(saved_settings_text) if (saved_settings.find(s => s.key == "auto_save_settings")?.value == false) { setSetting("auto_save_settings", false) return } CURRENTLY_LOADING_SETTINGS = true saved_settings.forEach(saved_setting => { var setting = SETTINGS[saved_setting.key] if (!setting) { console.warn(`Attempted to load setting ${saved_setting.key}, but no setting found`); return null; } setting.ignore = saved_setting.ignore if (!setting.ignore) { setting.value = saved_setting.value setSetting(setting.element, setting.value) } }) CURRENTLY_LOADING_SETTINGS = false } else { CURRENTLY_LOADING_SETTINGS = true tryLoadOldSettings(); CURRENTLY_LOADING_SETTINGS = false saveSettings() } } function loadDefaultSettingsSection(section_id) { CURRENTLY_LOADING_SETTINGS = true var section = SETTINGS_SECTIONS.find(s => s.id == section_id); section.keys.forEach(key => { var setting = SETTINGS[key]; setting.value = setting.default setSetting(setting.element, setting.value) }) CURRENTLY_LOADING_SETTINGS = false saveSettings() } function settingChangeHandler(event) { if (!CURRENTLY_LOADING_SETTINGS) { var element = event.target var value = getSetting(element) if (value != SETTINGS[element.id].value) { SETTINGS[element.id].value = value saveSettings() } } } function getSettingLabel(element) { var labelElement = document.querySelector(`label[for='${element.id}']`) var label = labelElement?.innerText || element.id var truncate_length = 30 if (label.includes(" (")) { label = label.substring(0, label.indexOf(" (")) } if (label.length > truncate_length) { label = label.substring(0, truncate_length - 3) + "..." } label = label.replace("➕", "") label = label.replace("➖", "") return label } function fillSaveSettingsConfigTable() { saveSettingsConfigTable.textContent = "" SETTINGS_SECTIONS.forEach(section => { var section_row = `