mirror of
https://github.com/gchq/CyberChef
synced 2025-01-23 09:45:02 +00:00
Fix showing slice of output not working.
Fix output status message not being reset. Hide magic button when baking.
This commit is contained in:
parent
8190c7aac7
commit
28182713bf
4 changed files with 61 additions and 9 deletions
|
@ -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));
|
||||||
|
|
|
@ -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.
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue