2022-12-12 21:25:32 +00:00
|
|
|
/**
|
|
|
|
* This file is for processing prompt/negative prompt and prompt style data
|
|
|
|
*/
|
|
|
|
|
|
|
|
// Prompt Style Element
|
|
|
|
const styleSelectElement = createAutoComplete(
|
|
|
|
"Style",
|
|
|
|
document.getElementById("style-ac-mselect"),
|
|
|
|
{multiple: true}
|
|
|
|
);
|
|
|
|
|
|
|
|
// Function to get styles from AUTOMATIC1111 webui
|
|
|
|
async function getStyles() {
|
|
|
|
var url = document.getElementById("host").value + "/sdapi/v1/prompt-styles";
|
|
|
|
try {
|
|
|
|
const response = await fetch(url);
|
|
|
|
/** @type {{name: string, prompt: string, negative_prompt: string}[]} */
|
|
|
|
const data = await response.json();
|
|
|
|
|
|
|
|
/** @type {string[]} */
|
|
|
|
let stored = null;
|
|
|
|
try {
|
|
|
|
stored = JSON.parse(localStorage.getItem("promptStyle"));
|
|
|
|
// doesn't seem to throw a syntaxerror if the localstorage item simply doesn't exist?
|
|
|
|
if (stored == null) stored = [];
|
|
|
|
} catch (e) {
|
|
|
|
stored = [];
|
|
|
|
}
|
|
|
|
|
|
|
|
styleSelectElement.options = data.map((style) => ({
|
|
|
|
name: style.name,
|
|
|
|
value: style.name,
|
|
|
|
title: `prompt: ${style.prompt}\nnegative: ${style.negative_prompt}`,
|
|
|
|
}));
|
|
|
|
styleSelectElement.onchange.on(({value}) => {
|
|
|
|
let selected = [];
|
|
|
|
if (value.find((v) => v === "None")) {
|
|
|
|
styleSelectElement.value = [];
|
|
|
|
} else {
|
|
|
|
selected = value;
|
|
|
|
}
|
|
|
|
stableDiffusionData.styles = selected;
|
|
|
|
localStorage.setItem("promptStyle", JSON.stringify(selected));
|
|
|
|
});
|
|
|
|
|
|
|
|
styleSelectElement.value = stored;
|
|
|
|
localStorage.setItem("promptStyle", JSON.stringify(stored));
|
|
|
|
} catch (e) {
|
|
|
|
console.warn("[index] Failed to fetch prompt styles");
|
|
|
|
console.warn(e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
(async () => {
|
|
|
|
// Default configurations
|
|
|
|
const defaultPrompt =
|
|
|
|
"ocean floor scientific expedition, underwater wildlife";
|
|
|
|
const defaultNegativePrompt =
|
|
|
|
"people, person, humans, human, divers, diver, glitch, error, text, watermark, bad quality, blurry";
|
|
|
|
|
|
|
|
// Prompt Elements
|
|
|
|
const promptEl = document.getElementById("prompt");
|
|
|
|
const negativePromptEl = document.getElementById("negPrompt");
|
|
|
|
|
|
|
|
// Add prompt change handlers
|
|
|
|
promptEl.oninput = () => {
|
|
|
|
stableDiffusionData.prompt = promptEl.value;
|
|
|
|
promptEl.title = promptEl.value;
|
|
|
|
localStorage.setItem("prompt", stableDiffusionData.prompt);
|
|
|
|
};
|
|
|
|
|
|
|
|
negativePromptEl.oninput = () => {
|
|
|
|
stableDiffusionData.negative_prompt = negativePromptEl.value;
|
|
|
|
negativePromptEl.title = negativePromptEl.value;
|
|
|
|
localStorage.setItem("neg_prompt", stableDiffusionData.negative_prompt);
|
|
|
|
};
|
|
|
|
|
|
|
|
// Load from local storage if set
|
2022-12-13 20:04:16 +00:00
|
|
|
const storedPrompt = localStorage.getItem("prompt");
|
|
|
|
const storedNeg = localStorage.getItem("neg_prompt");
|
|
|
|
const promptDefaultValue =
|
|
|
|
storedPrompt === null ? defaultPrompt : storedPrompt;
|
2022-12-12 21:25:32 +00:00
|
|
|
const negativePromptDefaultValue =
|
2022-12-13 20:04:16 +00:00
|
|
|
storedNeg === null ? defaultNegativePrompt : storedNeg;
|
2022-12-12 21:25:32 +00:00
|
|
|
|
|
|
|
promptEl.value = promptEl.title = promptDefaultValue;
|
|
|
|
negativePromptEl.value = negativePromptEl.title = negativePromptDefaultValue;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Prompt History
|
|
|
|
*/
|
|
|
|
|
|
|
|
// Get history-related elements
|
|
|
|
const promptHistoryEl = document.getElementById("prompt-history");
|
|
|
|
|
|
|
|
// History
|
|
|
|
const history = [];
|
|
|
|
|
|
|
|
function syncPromptHistory() {
|
|
|
|
const historyCopy = Array.from(history);
|
|
|
|
historyCopy.reverse();
|
|
|
|
|
|
|
|
for (let i = 0; i < historyCopy.length; i++) {
|
|
|
|
const historyItem = historyCopy[i];
|
|
|
|
|
|
|
|
const id = `prompt-history-${historyItem.id}`;
|
|
|
|
if (promptHistoryEl.querySelector(`#${id}`)) break;
|
|
|
|
|
|
|
|
const historyEntry = document.createElement("div");
|
|
|
|
historyEntry.classList.add("entry");
|
|
|
|
historyEntry.id = id;
|
|
|
|
historyEntry.title = `prompt: ${historyItem.prompt}\nnegative: ${
|
|
|
|
historyItem.negative
|
|
|
|
}\nstyles: ${historyItem.styles.join(", ")}`;
|
|
|
|
|
|
|
|
// Compare with previous
|
|
|
|
const samePrompt =
|
|
|
|
i !== historyCopy.length - 1 &&
|
|
|
|
historyItem.prompt === historyCopy[i + 1].prompt;
|
|
|
|
const sameNegativePrompt =
|
|
|
|
i !== historyCopy.length - 1 &&
|
|
|
|
historyItem.negative === historyCopy[i + 1].negative;
|
|
|
|
const sameStyles =
|
|
|
|
i !== historyCopy.length - 1 &&
|
|
|
|
historyItem.styles.length === historyCopy[i + 1].styles.length &&
|
|
|
|
!historyItem.styles.some(
|
|
|
|
(v, index) => v !== historyCopy[i + 1].styles[index]
|
|
|
|
);
|
|
|
|
|
|
|
|
const prompt = historyItem.prompt;
|
|
|
|
const negative = historyItem.negative;
|
|
|
|
const styles = historyItem.styles;
|
|
|
|
|
|
|
|
const promptBtn = document.createElement("button");
|
|
|
|
promptBtn.classList.add("prompt");
|
|
|
|
promptBtn.addEventListener("click", () => {
|
|
|
|
stableDiffusionData.prompt = prompt;
|
|
|
|
promptEl.title = prompt;
|
|
|
|
promptEl.value = prompt;
|
|
|
|
localStorage.setItem("prompt", prompt);
|
|
|
|
});
|
|
|
|
promptBtn.textContent = (samePrompt ? "= " : "") + prompt;
|
|
|
|
|
|
|
|
const negativeBtn = document.createElement("button");
|
|
|
|
negativeBtn.classList.add("negative");
|
|
|
|
negativeBtn.addEventListener("click", () => {
|
|
|
|
stableDiffusionData.negative_prompt = negative;
|
|
|
|
negativePromptEl.title = negative;
|
|
|
|
negativePromptEl.value = negative;
|
|
|
|
localStorage.setItem("neg_prompt", negative);
|
|
|
|
});
|
|
|
|
negativeBtn.textContent = (sameNegativePrompt ? "= " : "") + negative;
|
|
|
|
|
|
|
|
const stylesBtn = document.createElement("button");
|
|
|
|
stylesBtn.classList.add("styles");
|
|
|
|
stylesBtn.textContent = (sameStyles ? "= " : "") + styles.join(", ");
|
|
|
|
stylesBtn.addEventListener("click", () => {
|
|
|
|
styleSelectElement.value = styles;
|
|
|
|
});
|
|
|
|
|
|
|
|
historyEntry.appendChild(promptBtn);
|
|
|
|
historyEntry.appendChild(negativeBtn);
|
|
|
|
historyEntry.appendChild(stylesBtn);
|
|
|
|
|
|
|
|
promptHistoryEl.insertBefore(historyEntry, promptHistoryEl.firstChild);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Listen for dreaming to add to history
|
|
|
|
events.tool.dream.on((message) => {
|
|
|
|
const {event} = message;
|
|
|
|
if (event === "generate") {
|
|
|
|
const {prompt, negative_prompt, styles} = message.request;
|
|
|
|
const hash = hashCode(
|
|
|
|
`p: ${prompt}, n: ${negative_prompt}, s: ${JSON.stringify(styles)}`
|
|
|
|
);
|
|
|
|
if (
|
|
|
|
!history[history.length - 1] ||
|
|
|
|
history[history.length - 1].hash !== hash
|
|
|
|
)
|
|
|
|
history.push({
|
|
|
|
id: guid(),
|
|
|
|
hash,
|
|
|
|
prompt,
|
|
|
|
negative: negative_prompt,
|
|
|
|
styles,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
syncPromptHistory();
|
|
|
|
});
|
|
|
|
})();
|