rkgk/static/brush-editor.js

85 lines
2.8 KiB
JavaScript
Raw Normal View History

2024-08-10 23:13:20 +02:00
const defaultBrush = `
; This is your brush.
; Feel free to edit it to your liking!
(stroke
2024-08-19 23:56:11 +02:00
8 ; thickness
(rgba 0.0 0.0 0.0 1.0) ; color
(vec)) ; position
2024-08-10 23:13:20 +02:00
`.trim();
export class BrushEditor extends HTMLElement {
constructor() {
super();
}
connectedCallback() {
this.classList.add("rkgk-panel");
this.textArea = this.appendChild(document.createElement("textarea"));
2024-08-10 23:13:20 +02:00
this.textArea.classList.add("text-area");
this.textArea.value = localStorage.getItem("rkgk.brushEditor.code") ?? defaultBrush;
2024-08-10 23:13:20 +02:00
this.textArea.spellcheck = false;
this.textArea.rows = 1;
2024-08-10 23:13:20 +02:00
this.textArea.addEventListener("input", () => {
this.#resizeTextArea();
localStorage.setItem("rkgk.brushEditor.code", this.code);
2024-08-10 23:13:20 +02:00
this.dispatchEvent(
Object.assign(new Event(".codeChanged"), {
newCode: this.code,
2024-08-10 23:13:20 +02:00
}),
);
});
requestAnimationFrame(() => this.#resizeTextArea());
2024-08-19 23:56:11 +02:00
this.errorHeader = this.appendChild(document.createElement("h1"));
this.errorHeader.classList.add("error-header");
this.errorArea = this.appendChild(document.createElement("pre"));
this.errorArea.classList.add("errors");
2024-08-10 23:13:20 +02:00
}
#resizeTextArea() {
this.textArea.style.height = "";
this.textArea.style.height = `${this.textArea.scrollHeight}px`;
}
2024-08-10 23:13:20 +02:00
get code() {
return this.textArea.value;
2024-08-10 23:13:20 +02:00
}
2024-08-19 23:56:11 +02:00
resetErrors() {
this.errorHeader.textContent = "";
this.errorArea.textContent = "";
}
renderHakuResult(phase, result) {
this.resetErrors();
if (result.status != "error") return;
this.errorHeader.textContent = `${phase} failed`;
if (result.errorKind == "diagnostics") {
// This is kind of wooden; I'd prefer if the error spans were rendered inline in text,
// but I haven't integrated anything for syntax highlighting yet that would let me
// do that.
this.errorArea.textContent = result.diagnostics
.map(
(diagnostic) => `${diagnostic.start}..${diagnostic.end}: ${diagnostic.message}`,
)
.join("\n");
} else if (result.errorKind == "plain") {
this.errorHeader.textContent = result.message;
} else if (result.errorKind == "exception") {
// TODO: This should show a stack trace.
this.errorArea.textContent = `an exception occurred: ${result.message}`;
} else {
console.warn(`unknown error kind: ${result.errorKind}`);
this.errorHeader.textContent = "(unknown error kind)";
}
}
2024-08-10 23:13:20 +02:00
}
customElements.define("rkgk-brush-editor", BrushEditor);