Fix showing slice of output not working.

Fix output status message not being reset.
Hide magic button when baking.
This commit is contained in:
j433866 2019-05-08 10:10:14 +01:00
parent 8190c7aac7
commit 28182713bf
4 changed files with 61 additions and 9 deletions

View file

@ -196,7 +196,7 @@ class Manager {
this.addMultiEventListener("#output-html", "mousedown dblclick select", this.highlighter.outputHtmlMousedown, this.highlighter); this.addMultiEventListener("#output-html", "mousedown dblclick select", this.highlighter.outputHtmlMousedown, this.highlighter);
this.addDynamicListener("#output-file-download", "click", this.output.downloadFile, this.output); this.addDynamicListener("#output-file-download", "click", this.output.downloadFile, this.output);
this.addDynamicListener("#output-file-slice i", "click", this.output.displayFileSlice, this.output); this.addDynamicListener("#output-file-slice i", "click", this.output.displayFileSlice, this.output);
// document.getElementById("show-file-overlay").addEventListener("click", this.output.showFileOverlayClick.bind(this.output)); document.getElementById("show-file-overlay").addEventListener("click", this.output.showFileOverlayClick.bind(this.output));
// this.addDynamicListener(".extract-file,.extract-file i", "click", this.output.extractFileClick, this.output); // this.addDynamicListener(".extract-file,.extract-file i", "click", this.output.extractFileClick, this.output);
this.addDynamicListener("#output-tabs-wrapper #output-tabs li .output-tab-content", "click", this.output.changeTabClick, this.output); this.addDynamicListener("#output-tabs-wrapper #output-tabs li .output-tab-content", "click", this.output.changeTabClick, this.output);
document.getElementById("btn-previous-output-tab").addEventListener("click", this.output.changeTabLeft.bind(this.output)); document.getElementById("btn-previous-output-tab").addEventListener("click", this.output.changeTabLeft.bind(this.output));

View file

@ -158,9 +158,6 @@ class OutputWaiter {
this.outputs[inputNum].error = error; this.outputs[inputNum].error = error;
this.outputs[inputNum].progress = progress; this.outputs[inputNum].progress = progress;
this.updateOutputStatus("error", inputNum); this.updateOutputStatus("error", inputNum);
// call handle error here
// or make the error handling part of set()
} }
/** /**
@ -245,6 +242,8 @@ class OutputWaiter {
this.manager.recipe.updateBreakpointIndicator(false); this.manager.recipe.updateBreakpointIndicator(false);
document.getElementById("show-file-overlay").style.display = "none";
if (output.status === "pending" || output.status === "baking") { if (output.status === "pending" || output.status === "baking") {
// show the loader and the status message if it's being shown // show the loader and the status message if it's being shown
// otherwise don't do anything // otherwise don't do anything
@ -256,6 +255,7 @@ class OutputWaiter {
// run app.handleError() // run app.handleError()
this.toggleLoader(false); this.toggleLoader(false);
outputText.style.display = "block"; outputText.style.display = "block";
outputText.classList.remove("blur");
outputHtml.style.display = "none"; outputHtml.style.display = "none";
outputFile.style.display = "none"; outputFile.style.display = "none";
outputHighlighter.display = "none"; outputHighlighter.display = "none";
@ -439,7 +439,10 @@ class OutputWaiter {
* Handler for file download events. * Handler for file download events.
*/ */
async downloadFile() { async downloadFile() {
const fileName = window.prompt("Please enter a filename: ", "download.dat"); let fileName = window.prompt("Please enter a filename: ", "download.dat");
if (fileName === null) fileName = "download.dat";
const file = new File([this.getActive(true)], fileName); const file = new File([this.getActive(true)], fileName);
FileSaver.saveAs(file, fileName, false); FileSaver.saveAs(file, fileName, false);
} }
@ -608,6 +611,7 @@ class OutputWaiter {
document.getElementById("output-highlighter").style.height = "calc(100% - var(--tab-height) - var(--title-height))"; document.getElementById("output-highlighter").style.height = "calc(100% - var(--tab-height) - var(--title-height))";
document.getElementById("output-file").style.height = "calc(100% - var(--tab-height) - var(--title-height))"; document.getElementById("output-file").style.height = "calc(100% - var(--tab-height) - var(--title-height))";
document.getElementById("output-loader").style.height = "calc(100% - var(--tab-height) - var(--title-height))"; document.getElementById("output-loader").style.height = "calc(100% - var(--tab-height) - var(--title-height))";
document.getElementById("show-file-overlay").style.top = "calc(var(--tab-height) + var(--title-height) + 10px)";
document.getElementById("save-all-to-file").style.display = "inline-block"; document.getElementById("save-all-to-file").style.display = "inline-block";
} else { } else {
@ -617,6 +621,7 @@ class OutputWaiter {
document.getElementById("output-highlighter").style.height = "calc(100% - var(--title-height))"; document.getElementById("output-highlighter").style.height = "calc(100% - var(--title-height))";
document.getElementById("output-file").style.height = "calc(100% - var(--title-height))"; document.getElementById("output-file").style.height = "calc(100% - var(--title-height))";
document.getElementById("output-loader").style.height = "calc(100% - var(--title-height))"; document.getElementById("output-loader").style.height = "calc(100% - var(--title-height))";
document.getElementById("show-file-overlay").style.top = "calc(var(--title-height) + 10px)";
document.getElementById("save-all-to-file").style.display = "none"; document.getElementById("save-all-to-file").style.display = "none";
} }
@ -882,6 +887,7 @@ class OutputWaiter {
document.getElementById("output-highlighter").style.height = "calc(100% - var(--tab-height) - var(--title-height))"; document.getElementById("output-highlighter").style.height = "calc(100% - var(--tab-height) - var(--title-height))";
document.getElementById("output-file").style.height = "calc(100% - var(--tab-height) - var(--title-height))"; document.getElementById("output-file").style.height = "calc(100% - var(--tab-height) - var(--title-height))";
document.getElementById("output-loader").style.height = "calc(100% - var(--tab-height) - var(--title-height))"; document.getElementById("output-loader").style.height = "calc(100% - var(--tab-height) - var(--title-height))";
document.getElementById("show-file-overlay").style.top = "calc(var(--tab-height) + var(--title-height) + 10px)";
document.getElementById("save-all-to-file").style.display = "inline-block"; document.getElementById("save-all-to-file").style.display = "inline-block";
@ -892,6 +898,7 @@ class OutputWaiter {
document.getElementById("output-highlighter").style.height = "calc(100% - var(--title-height))"; document.getElementById("output-highlighter").style.height = "calc(100% - var(--title-height))";
document.getElementById("output-file").style.height = "calc(100% - var(--title-height))"; document.getElementById("output-file").style.height = "calc(100% - var(--title-height))";
document.getElementById("output-loader").style.height = "calc(100% - var(--title-height))"; document.getElementById("output-loader").style.height = "calc(100% - var(--title-height))";
document.getElementById("show-file-overlay").style.top = "calc(var(--title-height) + 10px)";
document.getElementById("save-all-to-file").style.display = "none"; document.getElementById("save-all-to-file").style.display = "none";
} }
@ -1059,7 +1066,11 @@ class OutputWaiter {
* Handler for file slice display events. * Handler for file slice display events.
*/ */
displayFileSlice() { displayFileSlice() {
const startTime = new Date().getTime(), const outputText = document.getElementById("output-text"),
outputHtml = document.getElementById("output-html"),
outputFile = document.getElementById("output-file"),
outputHighlighter = document.getElementById("output-highlighter"),
inputHighlighter = document.getElementById("input-highlighter"),
showFileOverlay = document.getElementById("show-file-overlay"), showFileOverlay = document.getElementById("show-file-overlay"),
sliceFromEl = document.getElementById("output-file-slice-from"), sliceFromEl = document.getElementById("output-file-slice-from"),
sliceToEl = document.getElementById("output-file-slice-to"), sliceToEl = document.getElementById("output-file-slice-to"),
@ -1067,11 +1078,50 @@ class OutputWaiter {
sliceTo = parseInt(sliceToEl.value, 10), sliceTo = parseInt(sliceToEl.value, 10),
str = Utils.arrayBufferToStr(this.getActive(true).slice(sliceFrom, sliceTo)); str = Utils.arrayBufferToStr(this.getActive(true).slice(sliceFrom, sliceTo));
document.getElementById("output-text").classList.remove("blur"); outputText.classList.remove("blur");
showFileOverlay.style.display = "block"; showFileOverlay.style.display = "block";
outputText.value = str;
outputText.style.display = "block";
outputHtml.style.display = "none";
outputFile.style.display = "none";
outputHighlighter.display = "block";
inputHighlighter.display = "block";
} }
/**
* Handler for show file overlay events
*
* @param {Event} e
*/
showFileOverlayClick(e) {
const showFileOverlay = e.target;
document.getElementById("output-text").classList.add("blur");
showFileOverlay.style.display = "none";
this.set(this.getActiveTab());
}
/**
* Handler for extract file events.
*
* @param {Event} e
*/
async extractFileClick(e) {
e.preventDefault();
e.stopPropagation();
const el = e.target.nodeName === "I" ? e.target.parentNode : e.target;
const blobURL = el.getAttribute("blob-url");
const fileName = el.getAttribute("file-name");
const blob = await fetch(blobURL).then(r => r.blob());
this.manager.input.loadUIFiles([new File([blob], fileName, {type: blob.type})]);
}
/** /**
* Handler for copy click events. * Handler for copy click events.

View file

@ -205,6 +205,8 @@ class WorkerWaiter {
setBakingStatus(bakingStatus) { setBakingStatus(bakingStatus) {
this.app.baking = bakingStatus; this.app.baking = bakingStatus;
this.manager.controls.toggleBakeButtonFunction(bakingStatus); this.manager.controls.toggleBakeButtonFunction(bakingStatus);
if (bakingStatus) this.manager.output.hideMagicButton();
} }
/** /**
@ -403,7 +405,7 @@ class WorkerWaiter {
} }
} }
this.manager.output.updateOutputStatus("pending", inputData.inputNum); this.manager.output.updateOutputStatus("pending", inputData.inputNum);
this.manager.output.updateOutputMessage(`Input ${inputData.inputNum} has not been baked yet.`); this.manager.output.updateOutputMessage(`Input ${inputData.inputNum} has not been baked yet.`, inputData.inputNum);
if (inputData.override) { if (inputData.override) {

View file

@ -233,7 +233,7 @@
#show-file-overlay { #show-file-overlay {
position: absolute; position: absolute;
right: 15px; right: 15px;
top: 15px; top: calc(var(--title-height) + 10px);
cursor: pointer; cursor: pointer;
display: none; display: none;
} }