diff --git a/app/index.html b/app/index.html index 5ac1aa1..8d3c9e5 100644 --- a/app/index.html +++ b/app/index.html @@ -24,6 +24,9 @@ import '@shoelace-style/shoelace/dist/components/option/option.js'; import '@shoelace-style/shoelace/dist/components/select/select.js'; import '@shoelace-style/shoelace/dist/components/progress-bar/progress-bar.js'; + import '@shoelace-style/shoelace/dist/components/tooltip/tooltip.js'; + import '@shoelace-style/shoelace/dist/components/format-bytes/format-bytes.js'; + import '@shoelace-style/shoelace/dist/components/details/details.js'; import { setBasePath } from '@shoelace-style/shoelace/dist/utilities/base-path'; setBasePath('/'); @@ -60,11 +63,11 @@

ITK IO Scanco

Convert Scanco .AIM or .ISQ volumes to an open standard file format.

- - +
+

- + MetaImage NIfTI NRRD @@ -73,7 +76,7 @@

ITK IO Scanco


-
Load sample +
Load sample Convert

@@ -82,8 +85,8 @@

ITK IO Scanco

- - Download + + Download

diff --git a/app/src/conversion-controller.ts b/app/src/conversion-controller.ts index 4bb983c..658e196 100644 --- a/app/src/conversion-controller.ts +++ b/app/src/conversion-controller.ts @@ -47,9 +47,8 @@ class ConversionController { files[0].arrayBuffer().then((arrayBuffer) => { model.inputVolume = new Uint8Array(arrayBuffer) - const inputVolumeElement = document.querySelector("#conversionInputs sl-input[name=input-volume]") - inputVolumeElement.value = model.inputVolume.subarray(0, 50).toString() + ' ...' - inputVolumeElement.helpText = `Input volume size: ${model.inputVolume.length.toString()} bytes` + const inputVolumeDescription = document.getElementById("input-volume-description") + inputVolumeDescription.innerHTML = `${files[0].name}, ()` }) }) @@ -108,7 +107,6 @@ class ConversionController { outputOutputDownload.variant = "success" outputOutputDownload.disabled = false - const outputOutput = document.querySelector('#conversionOutputs sl-textarea[name=output-file]') function replacer (key, value) { if (!!value && value.byteLength !== undefined) { return String(value.slice(0, 6)) + '...' @@ -117,7 +115,9 @@ class ConversionController { } image.direction = direction image.data = "[...]" - outputOutput.value = JSON.stringify(image, replacer, 2) + const outputOutput = document.getElementById('output-image-details') + outputOutput.innerHTML = `
${globalThis.escapeHtml(JSON.stringify(image, replacer, 2))}
` + outputOutput.disabled = false } catch (error) { notify("Error while running pipeline", error.toString(), "danger", "exclamation-octagon") throw error diff --git a/app/src/conversion-load-sample-inputs.ts b/app/src/conversion-load-sample-inputs.ts index f91389e..2fbcc9c 100644 --- a/app/src/conversion-load-sample-inputs.ts +++ b/app/src/conversion-load-sample-inputs.ts @@ -3,12 +3,12 @@ export default async function conversionLoadSampleInputs (model) { progressBar.value = 0 progressBar.setAttribute('style', 'display: block;') - const inputVolumeElement = document.querySelector("#conversionInputs sl-input[name=input-volume]") + const inputVolumeDescription = document.getElementById("input-volume-description") const url = import.meta.env.DEV ? '/sample-data/AIMIOTestImage.AIM' : 'https://itk.mypinata.cloud/ipfs/QmPaZBXqb99fsKQi28tCuGpW1LgiVrBYKRimY28nA9mYgE' const response = await fetch(url) const contentLength = parseInt(response.headers.get('Content-Length')) - inputVolumeElement.helpText = 'Input volume size: ' + contentLength + ' bytes' + inputVolumeDescription.innerHTML = `Sample AIM volume size: ` const reader = response.body.getReader() @@ -37,7 +37,6 @@ export default async function conversionLoadSampleInputs (model) { model.inputVolume = inputVolume model.inputFileName = 'ITKIOScancoSampleVolume.aim' - inputVolumeElement.value = inputVolume.subarray(0, 50).toString() + ' ...' progressBar.setAttribute('style', 'display: none;') progressBar.textContent = '' progressBar.max = 100 diff --git a/app/src/utilities.ts b/app/src/utilities.ts index 9ef324d..5fea7e2 100644 --- a/app/src/utilities.ts +++ b/app/src/utilities.ts @@ -22,6 +22,7 @@ function escapeHtml(html) { div.remove() return escaped } +globalThis.escapeHtml = escapeHtml export function notify(title, message, variant = 'primary', icon = 'info-circle', duration = 3000) { const slAlert = Object.assign(document.createElement('sl-alert'), {