Created
March 11, 2025 23:48
-
-
Save CodaBool/c48f9ce922943c4f94a09118d176a210 to your computer and use it in GitHub Desktop.
V12+ DialogV2 change background
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
const backgrounds = [ | |
"/full/path/to/file.webp", | |
"https://or.even.urls" | |
// ... list of images here | |
] | |
// Generate the dialog content | |
let content = '<form><div class="form-group" style="display: flex">' | |
backgrounds.forEach((bg, index) => { | |
content += ` | |
<div style="flex:none"> | |
<input type="radio" name="background" value="${index}" id="bg-${index}"> | |
<img src="${bg}" width="300" height="200" style="margin: 1px;"> | |
</div>` | |
}) | |
content += '</div></form>' | |
foundry.applications.api.DialogV2.wait({ | |
window: { title: "Change Background" }, | |
position: { width: window.innerWidth * .8, height: window.innerHeight * .8 }, | |
content, | |
id: "select-background-dialog", | |
buttons: [{ | |
action: "1", | |
label: `Change Background`, | |
icon: "fas fa-check", | |
callback: () => { | |
const selected = document.querySelector('#select-background-dialog input[name="background"]:checked')?.value | |
if (!selected) return | |
// Get the selected background image | |
const background = backgrounds[selected] | |
// Update the scene's background | |
canvas.scene.update({ "background.src": background }) | |
} | |
}], | |
}) | |
// add a scrollbar | |
setTimeout(() => { | |
document.querySelector("#select-background-dialog section").style.overflow = "auto" | |
}, 200) |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment