@cornerstonejs/dicom-image-loader 2.0.0-beta.12 → 2.0.0-beta.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (38) hide show
  1. package/dist/920.bundle.min.js +3 -0
  2. package/dist/920.bundle.min.js.map +1 -0
  3. package/dist/cornerstoneDICOMImageLoader.bundle.min.js +1 -1
  4. package/dist/cornerstoneDICOMImageLoader.bundle.min.js.map +1 -1
  5. package/dist/dynamic-import/918.min.js +2 -0
  6. package/dist/dynamic-import/918.min.js.map +1 -0
  7. package/dist/dynamic-import/cornerstoneDICOMImageLoader.min.js +1 -1
  8. package/dist/dynamic-import/cornerstoneDICOMImageLoader.min.js.map +1 -1
  9. package/dist/esm/src/{shared/decodeImageFrame.js → decodeImageFrameWorker.js} +16 -18
  10. package/dist/esm/src/decodeImageFrameWorker.js.map +1 -0
  11. package/dist/esm/src/externalModules.js +1 -1
  12. package/dist/esm/src/externalModules.js.map +1 -1
  13. package/dist/esm/src/imageLoader/decodeImageFrame.js +0 -2
  14. package/dist/esm/src/imageLoader/decodeImageFrame.js.map +1 -1
  15. package/dist/esm/src/shared/decoders/decodeHTJ2K.js +1 -1
  16. package/dist/esm/src/shared/decoders/decodeHTJ2K.js.map +1 -1
  17. package/dist/esm/src/shared/decoders/decodeJPEG2000.js +1 -1
  18. package/dist/esm/src/shared/decoders/decodeJPEG2000.js.map +1 -1
  19. package/dist/esm/src/shared/decoders/decodeJPEGBaseline8Bit.js +1 -1
  20. package/dist/esm/src/shared/decoders/decodeJPEGBaseline8Bit.js.map +1 -1
  21. package/dist/esm/src/shared/decoders/decodeJPEGLS.js +1 -1
  22. package/dist/esm/src/shared/decoders/decodeJPEGLS.js.map +1 -1
  23. package/dist/types/src/decodeImageFrameWorker.d.ts +2 -0
  24. package/dist/types/src/decodeImageFrameWorker.d.ts.map +1 -0
  25. package/dist/types/src/imageLoader/decodeImageFrame.d.ts.map +1 -1
  26. package/dist/types/src/shared/decoders/decodeHTJ2K.d.ts.map +1 -1
  27. package/dist/types/src/shared/decoders/decodeJPEG2000.d.ts.map +1 -1
  28. package/dist/types/src/shared/decoders/decodeJPEGBaseline8Bit.d.ts.map +1 -1
  29. package/dist/types/src/shared/decoders/decodeJPEGLS.d.ts.map +1 -1
  30. package/package.json +2 -2
  31. package/dist/744.bundle.min.js +0 -3
  32. package/dist/744.bundle.min.js.map +0 -1
  33. package/dist/dynamic-import/595.min.js +0 -2
  34. package/dist/dynamic-import/595.min.js.map +0 -1
  35. package/dist/esm/src/shared/decodeImageFrame.js.map +0 -1
  36. package/dist/types/src/shared/decodeImageFrame.d.ts +0 -2
  37. package/dist/types/src/shared/decodeImageFrame.d.ts.map +0 -1
  38. /package/dist/{744.bundle.min.js.LICENSE.txt → 920.bundle.min.js.LICENSE.txt} +0 -0
@@ -0,0 +1,2 @@
1
+ !function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define("918",[],t):"object"==typeof exports?exports[918]=t():e[918]=t()}(this,(()=>(()=>{var e,t,r,n,o={760:(e,t,r)=>{"use strict";var n=r(635);const o=async function(e,t){let r=t.buffer,n=t.byteOffset;const o=t.length;return 16===e.bitsAllocated?(n%2&&(r=r.slice(n),n=0),0===e.pixelRepresentation?e.pixelData=new Uint16Array(r,n,o/2):e.pixelData=new Int16Array(r,n,o/2)):8===e.bitsAllocated||1===e.bitsAllocated?e.pixelData=t:32===e.bitsAllocated&&(n%2&&(r=r.slice(n),n=0),e.pixelData=new Float32Array(r,n,o/4)),e};const i=async function(e,t){if(16===e.bitsAllocated){let n=t.buffer,o=t.byteOffset;const i=t.length;o%2&&(n=n.slice(o),o=0),0===e.pixelRepresentation?e.pixelData=new Uint16Array(n,o,i/2):e.pixelData=new Int16Array(n,o,i/2);for(let t=0;t<e.pixelData.length;t++)e.pixelData[t]=(255&(r=e.pixelData[t]))<<8|r>>8&255}else 8===e.bitsAllocated&&(e.pixelData=t);var r;return e};const s=async function(e,t){if(8===e.bitsAllocated)return e.planarConfiguration?function(e,t){const r=t,n=e.rows*e.columns,o=new ArrayBuffer(n*e.samplesPerPixel),i=new DataView(r.buffer,r.byteOffset),s=new Int8Array(r.buffer,r.byteOffset),a=new Int8Array(o);let c=0;const l=i.getInt32(0,!0);for(let e=0;e<l;++e){c=e*n;let t=i.getInt32(4*(e+1),!0),o=i.getInt32(4*(e+2),!0);0===o&&(o=r.length);const f=n*l;for(;t<o;){const e=s[t++];if(e>=0&&e<=127)for(let r=0;r<e+1&&c<f;++r)a[c]=s[t++],c++;else if(e<=-1&&e>=-127){const r=s[t++];for(let t=0;t<1-e&&c<f;++t)a[c]=r,c++}}}return e.pixelData=new Uint8Array(o),e}(e,t):function(e,t){const r=t,n=e.rows*e.columns,o=new ArrayBuffer(n*e.samplesPerPixel),i=new DataView(r.buffer,r.byteOffset),s=new Int8Array(r.buffer,r.byteOffset),a=new Int8Array(o);let c=0;const l=i.getInt32(0,!0);for(let t=0;t<l;++t){c=t;let o=i.getInt32(4*(t+1),!0),f=i.getInt32(4*(t+2),!0);0===f&&(f=r.length);const d=n*l;for(;o<f;){const t=s[o++];if(t>=0&&t<=127)for(let r=0;r<t+1&&c<d;++r)a[c]=s[o++],c+=e.samplesPerPixel;else if(t<=-1&&t>=-127){const r=s[o++];for(let n=0;n<1-t&&c<d;++n)a[c]=r,c+=e.samplesPerPixel}}}return e.pixelData=new Uint8Array(o),e}(e,t);if(16===e.bitsAllocated)return function(e,t){const r=t,n=e.rows*e.columns,o=new ArrayBuffer(n*e.samplesPerPixel*2),i=new DataView(r.buffer,r.byteOffset),s=new Int8Array(r.buffer,r.byteOffset),a=new Int8Array(o),c=i.getInt32(0,!0);for(let e=0;e<c;++e){let t=0;const o=0===e?1:0;let c=i.getInt32(4*(e+1),!0),l=i.getInt32(4*(e+2),!0);for(0===l&&(l=r.length);c<l;){const e=s[c++];if(e>=0&&e<=127)for(let r=0;r<e+1&&t<n;++r)a[2*t+o]=s[c++],t++;else if(e<=-1&&e>=-127){const r=s[c++];for(let i=0;i<1-e&&t<n;++i)a[2*t+o]=r,t++}}}0===e.pixelRepresentation?e.pixelData=new Uint16Array(o):e.pixelData=new Int16Array(o);return e}(e,t);throw new Error("unsupported pixel format for RLE")};var a=r(851),c=r.n(a);const l=new URL(r(427),r.b),f={codec:void 0,decoder:void 0};const d=async function(e,t){await function(){if(f.codec)return Promise.resolve();const e=c()({locateFile:e=>e.endsWith(".wasm")?l.toString():e});return new Promise(((t,r)=>{e.then((e=>{f.codec=e,f.decoder=new e.JPEGDecoder,t()}),r)}))}();const r=f.decoder;r.getEncodedBuffer(e.length).set(e),r.decode();const n=r.getFrameInfo(),o=r.getDecodedBuffer(),i={columns:n.width,rows:n.height,bitsPerPixel:n.bitsPerSample,signed:t.signed,bytesPerPixel:t.bytesPerPixel,componentsPerPixel:n.componentCount},s=function(e,t){if(e.isSigned)return new Int8Array(t.buffer,t.byteOffset,t.byteLength);return new Uint8Array(t.buffer,t.byteOffset,t.byteLength)}(n,o),a={frameInfo:n};return{...t,pixelData:s,imageInfo:i,encodeOptions:a,...a,...i}},u={JpegImage:void 0,decodeConfig:{}};const g=async function(e,t){var n;if(await(u.decodeConfig=n,u.JpegImage?Promise.resolve():new Promise(((e,t)=>{r.e(584).then(r.t.bind(r,584,23)).then((({JpegImage:t})=>{u.JpegImage=t,e()}),t)}))),void 0===u.JpegImage)throw new Error("No JPEG Baseline decoder loaded");const o=new u.JpegImage;return o.parse(t),o.colorTransform=!1,8===e.bitsAllocated?(e.pixelData=o.getData(e.columns,e.rows),e):16===e.bitsAllocated?(e.pixelData=o.getData16(e.columns,e.rows),e):void 0},p={jpeg:void 0,decodeConfig:{}};const b=async function(e,t){var n;if(await(p.decodeConfig=n,p.jpeg?Promise.resolve():new Promise(((e,t)=>{r.e(610).then(r.t.bind(r,610,23)).then((t=>{p.jpeg=t,e()}),t)}))),void 0===p.jpeg||void 0===p.jpeg.lossless||void 0===p.jpeg.lossless.Decoder)throw new Error("No JPEG Lossless decoder loaded");const o=e.bitsAllocated<=8?1:2,i=t.buffer,s=(new p.jpeg.lossless.Decoder).decode(i,t.byteOffset,t.length,o);return 0===e.pixelRepresentation?16===e.bitsAllocated?(e.pixelData=new Uint16Array(s.buffer),e):(e.pixelData=new Uint8Array(s.buffer),e):(e.pixelData=new Int16Array(s.buffer),e)};var y=r(37),m=r.n(y);const h=new URL(r(69),r.b),w={codec:void 0,decoder:void 0,decodeConfig:{}};const x=async function(e,t){try{await function(e){if(w.decodeConfig=e,w.codec)return Promise.resolve();const t=m()({locateFile:e=>e.endsWith(".wasm")?h.toString():e});return new Promise(((e,r)=>{t.then((t=>{w.codec=t,w.decoder=new t.JpegLSDecoder,e()}),r)}))}();const r=w.decoder;r.getEncodedBuffer(e.length).set(e),r.decode();const n=r.getFrameInfo(),o=r.getInterleaveMode(),i=r.getNearLossless(),s=r.getDecodedBuffer(),a={columns:n.width,rows:n.height,bitsPerPixel:n.bitsPerSample,signed:t.signed,bytesPerPixel:t.bytesPerPixel,componentsPerPixel:n.componentCount},c=function(e,t,r){if(e.bitsPerSample>8)return r?new Int16Array(t.buffer,t.byteOffset,t.byteLength/2):new Uint16Array(t.buffer,t.byteOffset,t.byteLength/2);if(r)return new Int8Array(t.buffer,t.byteOffset,t.byteLength);return new Uint8Array(t.buffer,t.byteOffset,t.byteLength)}(n,s,t.signed),l={nearLossless:i,interleaveMode:o,frameInfo:n};return{...t,pixelData:c,imageInfo:a,encodeOptions:l,...l,...a}}catch(e){throw"number"==typeof(r=e)?w.codec.getExceptionMessage(r):r}var r};var P=r(272),v=r.n(P);const A=new URL(r(699),r.b),I={codec:void 0,decoder:void 0,decodeConfig:{}};const D=async function(e,t){await function(e){if(I.decodeConfig=e,I.codec)return Promise.resolve();const t=v()({locateFile:e=>e.endsWith(".wasm")?A.toString():e});return new Promise(((e,r)=>{t.then((t=>{I.codec=t,I.decoder=new t.J2KDecoder,e()}),r)}))}();const r=I.decoder,n=r.getEncodedBuffer(e.length);n.set(e),r.decode();const o=r.getFrameInfo(),i=r.getDecodedBuffer();new Uint8Array(i.length).set(i);const s=`x: ${r.getImageOffset().x}, y: ${r.getImageOffset().y}`,a=r.getNumDecompositions(),c=r.getNumLayers(),l=["unknown","LRCP","RLCP","RPCL","PCRL","CPRL"][r.getProgressionOrder()+1],f=r.getIsReversible(),d=`${r.getBlockDimensions().width} x ${r.getBlockDimensions().height}`,u=`${r.getTileSize().width} x ${r.getTileSize().height}`,g=`${r.getTileOffset().x}, ${r.getTileOffset().y}`,p=r.getColorSpace(),b=`${i.length.toLocaleString()} bytes`,y=`${(i.length/n.length).toFixed(2)}:1`,m={columns:o.width,rows:o.height,bitsPerPixel:o.bitsPerSample,signed:o.isSigned,bytesPerPixel:t.bytesPerPixel,componentsPerPixel:o.componentCount},h=function(e,t){if(e.bitsPerSample>8)return e.isSigned?new Int16Array(t.buffer,t.byteOffset,t.byteLength/2):new Uint16Array(t.buffer,t.byteOffset,t.byteLength/2);if(e.isSigned)return new Int8Array(t.buffer,t.byteOffset,t.byteLength);return new Uint8Array(t.buffer,t.byteOffset,t.byteLength)}(o,i),w={imageOffset:s,numDecompositions:a,numLayers:c,progessionOrder:l,reversible:f,blockDimensions:d,tileSize:u,tileOffset:g,colorTransform:p,decodedSize:b,compressionRatio:y};return{...t,pixelData:h,imageInfo:m,encodeOptions:w,...w,...m}};var O=r(430),S=r.n(O);const L=new URL(r(813),r.b),R={codec:void 0,decoder:void 0,decodeConfig:{}};const B=async function(e,t){await function(e){if(R.decodeConfig=e,R.codec)return Promise.resolve();const t=S()({locateFile:e=>e.endsWith(".wasm")?L:e});return new Promise(((e,r)=>{t.then((t=>{R.codec=t,R.decoder=new t.HTJ2KDecoder,e()}),r)}))}();const r=new R.codec.HTJ2KDecoder,n=r.getEncodedBuffer(e.length);n.set(e);const o=t.decodeLevel||0;r.decodeSubResolution(o);const i=r.getFrameInfo();if(t.decodeLevel>0){const{width:e,height:r}=function(e,t,r){const n={width:t,height:r};for(;e>0;)n.width=Math.ceil(n.width/2),n.height=Math.ceil(n.height/2),e--;return n}(t.decodeLevel,i.width,i.height);i.width=e,i.height=r}const s=r.getDecodedBuffer();new Uint8Array(s.length).set(s);const a=`x: ${r.getImageOffset().x}, y: ${r.getImageOffset().y}`,c=r.getNumDecompositions(),l=r.getNumLayers(),f=["unknown","LRCP","RLCP","RPCL","PCRL","CPRL"][r.getProgressionOrder()+1],d=r.getIsReversible(),u=`${r.getBlockDimensions().width} x ${r.getBlockDimensions().height}`,g=`${r.getTileSize().width} x ${r.getTileSize().height}`,p=`${r.getTileOffset().x}, ${r.getTileOffset().y}`,b=`${s.length.toLocaleString()} bytes`,y=`${(s.length/n.length).toFixed(2)}:1`,m={columns:i.width,rows:i.height,bitsPerPixel:i.bitsPerSample,signed:i.isSigned,bytesPerPixel:t.bytesPerPixel,componentsPerPixel:i.componentCount};let h=function(e,t){if(e.bitsPerSample>8)return e.isSigned?new Int16Array(t.buffer,t.byteOffset,t.byteLength/2):new Uint16Array(t.buffer,t.byteOffset,t.byteLength/2);if(e.isSigned)return new Int8Array(t.buffer,t.byteOffset,t.byteLength);return new Uint8Array(t.buffer,t.byteOffset,t.byteLength)}(i,s);const{buffer:w,byteOffset:x,byteLength:P}=h,v=w.slice(x,x+P);h=new h.constructor(v);const A={imageOffset:a,numDecompositions:c,numLayers:l,progessionOrder:f,reversible:d,blockDimensions:u,tileSize:g,tileOffset:p,decodedSize:b,compressionRatio:y};return{...t,pixelData:h,imageInfo:m,encodeOptions:A,...A,...m}};const C=function(e){let t,r=e[0],n=e[0];const o=e.length;for(let i=1;i<o;i++)t=e[i],r=Math.min(r,t),n=Math.max(n,t);return{min:r,max:n}};const T={bilinear:function(e,t){const{rows:r,columns:n,data:o}=e,{rows:i,columns:s,data:a}=t,c=[],l=[],f=[];for(let e=0;e<s;e++){const t=e*(n-1)/(s-1);c[e]=Math.floor(t),l[e]=Math.min(c[e]+1,n-1),f[e]=t-c[e]}for(let e=0;e<i;e++){const t=e*(r-1)/(i-1),d=Math.floor(t)*n,u=Math.min(d+n,(r-1)*n),g=t-Math.floor(t),p=1-g,b=e*s;for(let e=0;e<s;e++){const t=o[d+c[e]],r=o[d+l[e]],n=o[u+c[e]],i=o[u+l[e]],s=1-f[e];a[b+e]=(t*s+r*f[e])*p+(n*s+i*f[e])*g}}return a},replicate:function(e,t){const{rows:r,columns:n,pixelData:o,samplesPerPixel:i=1}=e,{rows:s,columns:a,pixelData:c}=t,l=[];for(let e=0;e<a;e++){const t=e*(n-1)/(a-1);l[e]=Math.floor(t)*i}for(let e=0;e<s;e++){const t=e*(r-1)/(s-1),f=Math.floor(t)*n*i,d=e*a;for(let e=0;e<a;e++)for(let t=0;t<i;t++)c[d+e+t]=o[f+l[e]+t]}return c}};async function U(e,t,r,n,a,c){const l=(new Date).getTime();let f,u=null;switch(t){case"1.2.840.10008.1.2":case"1.2.840.10008.1.2.1":case"1.2.840.10008.1.2.1.99":u=o(e,r);break;case"1.2.840.10008.1.2.2":u=i(e,r);break;case"1.2.840.10008.1.2.5":u=s(e,r);break;case"1.2.840.10008.1.2.4.50":f={...e},u=d(r,f);break;case"1.2.840.10008.1.2.4.51":u=g(e,r);break;case"1.2.840.10008.1.2.4.57":case"1.2.840.10008.1.2.4.70":u=b(e,r);break;case"1.2.840.10008.1.2.4.80":case"1.2.840.10008.1.2.4.81":f={signed:1===e.pixelRepresentation,bytesPerPixel:e.bitsAllocated<=8?1:2,...e},u=x(r,f);break;case"1.2.840.10008.1.2.4.90":case"1.2.840.10008.1.2.4.91":f={...e},u=D(r,f);break;case"3.2.840.10008.1.2.4.96":case"1.2.840.10008.1.2.4.201":case"1.2.840.10008.1.2.4.202":case"1.2.840.10008.1.2.4.203":f={...e},u=B(r,f);break;default:throw new Error(`no decoder for transfer syntax ${t}`)}if(!u)throw new Error("decodePromise not defined");const p=function(e,t,r,n){const{use16BitDataType:o}=n||{},i=void 0!==e.pixelRepresentation&&1===e.pixelRepresentation,s=i&&void 0!==e.bitsStored?32-e.bitsStored:void 0;if(i&&void 0!==s)for(let t=0;t<e.pixelData.length;t++)e.pixelData[t]=e.pixelData[t]<<s>>s;let a=e.pixelData;e.pixelDataLength=e.pixelData.length;const{min:c,max:l}=C(e.pixelData),f={Uint8Array,Uint16Array:o?Uint16Array:void 0,Int16Array:o?Int16Array:void 0,Float32Array},d=t.targetBuffer?.type,u=void 0===t.allowFloatRendering||t.allowFloatRendering,g=!(m=e.photometricInterpretation,"RGB"!==m&&"PALETTE COLOR"!==m&&"YBR_FULL"!==m&&"YBR_FULL_422"!==m&&"YBR_PARTIAL_422"!==m&&"YBR_PARTIAL_420"!==m&&"YBR_RCT"!==m&&"YBR_ICT"!==m||void 0!==t.targetBuffer?.offset),p=t.preScale?.enabled,b=p&&Object.values(t.preScale.scalingParameters).some((e=>"number"==typeof e&&!Number.isInteger(e))),y=!t.preScale.enabled||!u&&b;var m;a=d&&!g?function(e,t,r,n){const{arrayBuffer:o,type:i,offset:s=0,length:a,rows:c}=e.targetBuffer,l=r[i];if(!l)throw new Error(`target array ${i} is not supported, you need to set use16BitDataType to true if you want to use Uint16Array or Int16Array.`);c&&c!=t.rows&&function(e,t,r){const n=function(e,t,r){const{samplesPerPixel:n}=e,{rows:o,columns:i}=t,s=o*i*n,a=new r(s),c=a.byteLength/s;return{pixelData:a,rows:o,columns:i,frameInfo:{...e.frameInfo,rows:o,columns:i},imageInfo:{...e.imageInfo,rows:o,columns:i,bytesPerPixel:c}}}(e,t,r),{scalingType:o="replicate"}=t;T[o](e,n),Object.assign(e,n)}(t,e.targetBuffer,l);const f=t.pixelDataLength,d=s,u=null!=a?a:f-d,g=t.pixelData;if(u!==g.length)throw new Error(`target array for image does not have the same length (${u}) as the decoded image length (${g.length}).`);const p=o?new l(o,d,u):new l(u);return p.set(g,0),n=p,n}(t,e,f,a):t.preScale.enabled&&!y?function(e,t,r,n){const o=e.preScale.scalingParameters;$(o);const{rescaleSlope:i,rescaleIntercept:s}=o;let a=t,c=r;"number"==typeof i&&"number"==typeof s&&(a=i*t+s,c=i*r+s);return j(a,c,n)}(t,c,l,e):j(c,l,e);let h=c,w=l;if(t.preScale.enabled&&!y){const r=t.preScale.scalingParameters;$(r);const{rescaleSlope:n,rescaleIntercept:o}=r;if("number"==typeof n&&"number"==typeof o){!function(e,t){const r=e.length,{rescaleSlope:n,rescaleIntercept:o,suvbw:i}=t;if("PT"===t.modality&&"number"==typeof i)for(let t=0;t<r;t++)e[t]=i*(e[t]*n+o);else for(let t=0;t<r;t++)e[t]=e[t]*n+o}(a,r),e.preScale={...t.preScale,scaled:!0};const{rescaleIntercept:n,rescaleSlope:o,suvbw:i}=r;h=o*c+n,w=o*l+n,i&&(h*=i,w*=i)}}else y&&(e.preScale={enabled:!0,scaled:!1},h=c,w=l);const x=void 0!==t.targetBuffer;x&&t.isSharedArrayBuffer||(e.pixelData=a);e.minAfterScale=h,e.maxAfterScale=w;const P=(new Date).getTime();return e.decodeTimeInMS=P-r,e}(await u,a,l,n);return c?.(p),p}function j(e,t,r){const n=function(e,t){let r;return Number.isInteger(e)&&Number.isInteger(t)&&(e>=0?t<=255?r=Uint8Array:t<=65535&&(r=Uint16Array):e>=-128&&t<=127?r=Int8Array:e>=-32768&&t<=32767&&(r=Int16Array)),r||Float32Array}(e,t),o=new n(r.pixelData.length);return o.set(r.pixelData,0),o}function $(e){if(!e)throw new Error("options.preScale.scalingParameters must be defined if preScale.enabled is true, and scalingParameters cannot be derived from the metadata providers.")}const k={decodeTask:({imageFrame:e,transferSyntax:t,decodeConfig:r,options:n,pixelData:o,callbackFn:i})=>U(e,t,o,r,n,i)};(0,n.Jj)(k)},716:()=>{},401:()=>{},491:()=>{},33:()=>{},261:()=>{},926:()=>{},280:()=>{},103:()=>{}},i={};function s(e){var t=i[e];if(void 0!==t)return t.exports;var r=i[e]={exports:{}};return o[e].call(r.exports,r,r.exports,s),r.exports}return s.m=o,s.x=()=>{var e=s.O(void 0,[958],(()=>s(760)));return e=s.O(e)},e=[],s.O=(t,r,n,o)=>{if(!r){var i=1/0;for(f=0;f<e.length;f++){for(var[r,n,o]=e[f],a=!0,c=0;c<r.length;c++)(!1&o||i>=o)&&Object.keys(s.O).every((e=>s.O[e](r[c])))?r.splice(c--,1):(a=!1,o<i&&(i=o));if(a){e.splice(f--,1);var l=n();void 0!==l&&(t=l)}}return t}o=o||0;for(var f=e.length;f>0&&e[f-1][2]>o;f--)e[f]=e[f-1];e[f]=[r,n,o]},s.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return s.d(t,{a:t}),t},r=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__,s.t=function(e,n){if(1&n&&(e=this(e)),8&n)return e;if("object"==typeof e&&e){if(4&n&&e.__esModule)return e;if(16&n&&"function"==typeof e.then)return e}var o=Object.create(null);s.r(o);var i={};t=t||[null,r({}),r([]),r(r)];for(var a=2&n&&e;"object"==typeof a&&!~t.indexOf(a);a=r(a))Object.getOwnPropertyNames(a).forEach((t=>i[t]=()=>e[t]));return i.default=()=>e,s.d(o,i),o},s.d=(e,t)=>{for(var r in t)s.o(t,r)&&!s.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},s.f={},s.e=e=>Promise.all(Object.keys(s.f).reduce(((t,r)=>(s.f[r](e,t),t)),[])),s.u=e=>e+".min.js",s.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),s.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),s.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},(()=>{var e;s.g.importScripts&&(e=s.g.location+"");var t=s.g.document;if(!e&&t&&(t.currentScript&&(e=t.currentScript.src),!e)){var r=t.getElementsByTagName("script");if(r.length)for(var n=r.length-1;n>-1&&!e;)e=r[n--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),s.p=e})(),(()=>{s.b=self.location+"";var e={918:1};s.f.i=(t,r)=>{e[t]||importScripts(s.p+s.u(t))};var t=this.webpackChunk=this.webpackChunk||[],r=t.push.bind(t);t.push=t=>{var[n,o,i]=t;for(var a in o)s.o(o,a)&&(s.m[a]=o[a]);for(i&&i(s);n.length;)e[n.pop()]=1;r(t)}})(),n=s.x,s.x=()=>s.e(958).then(n),s.x()})()));
2
+ //# sourceMappingURL=918.min.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"918.min.js","mappings":"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","sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/runtime/chunk loaded","webpack:///webpack/runtime/create fake namespace object","webpack:///webpack/runtime/startup chunk dependencies","webpack:///./shared/decoders/decodeLittleEndian.ts","webpack:///./shared/decoders/decodeBigEndian.ts","webpack:///./shared/decoders/decodeRLE.ts","webpack:///./shared/decoders/decodeJPEGBaseline8Bit.ts","webpack:///./shared/decoders/decodeJPEGBaseline12Bit-js.ts","webpack:///./shared/decoders/decodeJPEGLossless.ts","webpack:///./shared/decoders/decodeJPEGLS.ts","webpack:///./shared/decoders/decodeJPEG2000.ts","webpack:///./shared/decoders/decodeHTJ2K.ts","webpack:///./shared/getMinMax.ts","webpack:///./decodeImageFrameWorker.js","webpack:///./shared/scaling/bilinear.ts","webpack:///./shared/scaling/replicate.ts","webpack:///./shared/isColorImage.ts","webpack:///./shared/scaling/scaleArray.ts","webpack:///./shared/getPixelDataTypeFromMinMax.ts","webpack:///webpack/bootstrap","webpack:///webpack/runtime/compat get default export","webpack:///webpack/runtime/define property getters","webpack:///webpack/runtime/ensure chunk","webpack:///webpack/runtime/get javascript chunk filename","webpack:///webpack/runtime/global","webpack:///webpack/runtime/hasOwnProperty shorthand","webpack:///webpack/runtime/make namespace object","webpack:///webpack/runtime/publicPath","webpack:///webpack/runtime/importScripts chunk loading","webpack:///webpack/startup"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"918\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"918\"] = factory();\n\telse\n\t\troot[\"918\"] = factory();\n})(this, () => {\nreturn ","var deferred = [];\n__webpack_require__.O = (result, chunkIds, fn, priority) => {\n\tif(chunkIds) {\n\t\tpriority = priority || 0;\n\t\tfor(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];\n\t\tdeferred[i] = [chunkIds, fn, priority];\n\t\treturn;\n\t}\n\tvar notFulfilled = Infinity;\n\tfor (var i = 0; i < deferred.length; i++) {\n\t\tvar [chunkIds, fn, priority] = deferred[i];\n\t\tvar fulfilled = true;\n\t\tfor (var j = 0; j < chunkIds.length; j++) {\n\t\t\tif ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every((key) => (__webpack_require__.O[key](chunkIds[j])))) {\n\t\t\t\tchunkIds.splice(j--, 1);\n\t\t\t} else {\n\t\t\t\tfulfilled = false;\n\t\t\t\tif(priority < notFulfilled) notFulfilled = priority;\n\t\t\t}\n\t\t}\n\t\tif(fulfilled) {\n\t\t\tdeferred.splice(i--, 1)\n\t\t\tvar r = fn();\n\t\t\tif (r !== undefined) result = r;\n\t\t}\n\t}\n\treturn result;\n};","var getProto = Object.getPrototypeOf ? (obj) => (Object.getPrototypeOf(obj)) : (obj) => (obj.__proto__);\nvar leafPrototypes;\n// create a fake namespace object\n// mode & 1: value is a module id, require it\n// mode & 2: merge all properties of value into the ns\n// mode & 4: return value when already ns object\n// mode & 16: return value when it's Promise-like\n// mode & 8|1: behave like require\n__webpack_require__.t = function(value, mode) {\n\tif(mode & 1) value = this(value);\n\tif(mode & 8) return value;\n\tif(typeof value === 'object' && value) {\n\t\tif((mode & 4) && value.__esModule) return value;\n\t\tif((mode & 16) && typeof value.then === 'function') return value;\n\t}\n\tvar ns = Object.create(null);\n\t__webpack_require__.r(ns);\n\tvar def = {};\n\tleafPrototypes = leafPrototypes || [null, getProto({}), getProto([]), getProto(getProto)];\n\tfor(var current = mode & 2 && value; typeof current == 'object' && !~leafPrototypes.indexOf(current); current = getProto(current)) {\n\t\tObject.getOwnPropertyNames(current).forEach((key) => (def[key] = () => (value[key])));\n\t}\n\tdef['default'] = () => (value);\n\t__webpack_require__.d(ns, def);\n\treturn ns;\n};","var next = __webpack_require__.x;\n__webpack_require__.x = () => {\n\treturn __webpack_require__.e(958).then(next);\n};","import { ByteArray } from 'dicom-parser';\nimport { ImageFrame } from '../../types';\n\nasync function decodeLittleEndian(\n imageFrame: ImageFrame,\n pixelData: ByteArray\n): Promise<ImageFrame> {\n let arrayBuffer = pixelData.buffer;\n\n let offset = pixelData.byteOffset;\n const length = pixelData.length;\n\n if (imageFrame.bitsAllocated === 16) {\n // if pixel data is not aligned on even boundary, shift it so we can create the 16 bit array\n // buffers on it\n if (offset % 2) {\n arrayBuffer = arrayBuffer.slice(offset);\n offset = 0;\n }\n\n if (imageFrame.pixelRepresentation === 0) {\n imageFrame.pixelData = new Uint16Array(arrayBuffer, offset, length / 2);\n } else {\n imageFrame.pixelData = new Int16Array(arrayBuffer, offset, length / 2);\n }\n } else if (imageFrame.bitsAllocated === 8 || imageFrame.bitsAllocated === 1) {\n imageFrame.pixelData = pixelData;\n } else if (imageFrame.bitsAllocated === 32) {\n // if pixel data is not aligned on even boundary, shift it\n if (offset % 2) {\n arrayBuffer = arrayBuffer.slice(offset);\n offset = 0;\n }\n\n imageFrame.pixelData = new Float32Array(arrayBuffer, offset, length / 4);\n }\n\n return imageFrame;\n}\n\nexport default decodeLittleEndian;\n","import { ByteArray } from 'dicom-parser';\nimport { ImageFrame } from '../../types';\n\n/* eslint no-bitwise: 0 */\nfunction swap16(val) {\n return ((val & 0xff) << 8) | ((val >> 8) & 0xff);\n}\n\nasync function decodeBigEndian(\n imageFrame: ImageFrame,\n pixelData: ByteArray\n): Promise<ImageFrame> {\n if (imageFrame.bitsAllocated === 16) {\n let arrayBuffer = pixelData.buffer;\n\n let offset = pixelData.byteOffset;\n const length = pixelData.length;\n // if pixel data is not aligned on even boundary, shift it so we can create the 16 bit array\n // buffers on it\n\n if (offset % 2) {\n arrayBuffer = arrayBuffer.slice(offset);\n offset = 0;\n }\n\n if (imageFrame.pixelRepresentation === 0) {\n imageFrame.pixelData = new Uint16Array(arrayBuffer, offset, length / 2);\n } else {\n imageFrame.pixelData = new Int16Array(arrayBuffer, offset, length / 2);\n }\n // Do the byte swap\n for (let i = 0; i < imageFrame.pixelData.length; i++) {\n imageFrame.pixelData[i] = swap16(imageFrame.pixelData[i]);\n }\n } else if (imageFrame.bitsAllocated === 8) {\n imageFrame.pixelData = pixelData;\n }\n\n return imageFrame;\n}\n\nexport default decodeBigEndian;\n","import { ByteArray } from 'dicom-parser';\nimport { ImageFrame } from '../../types';\n\nasync function decodeRLE(\n imageFrame: ImageFrame,\n pixelData: ByteArray\n): Promise<ImageFrame> {\n if (imageFrame.bitsAllocated === 8) {\n if (imageFrame.planarConfiguration) {\n return decode8Planar(imageFrame, pixelData);\n }\n\n return decode8(imageFrame, pixelData);\n } else if (imageFrame.bitsAllocated === 16) {\n return decode16(imageFrame, pixelData);\n }\n\n throw new Error('unsupported pixel format for RLE');\n}\n\nfunction decode8(imageFrame: ImageFrame, pixelData: ByteArray) {\n const frameData = pixelData;\n const frameSize = imageFrame.rows * imageFrame.columns;\n const outFrame = new ArrayBuffer(frameSize * imageFrame.samplesPerPixel);\n const header = new DataView(frameData.buffer, frameData.byteOffset);\n const data = new Int8Array(frameData.buffer, frameData.byteOffset);\n const out = new Int8Array(outFrame);\n\n let outIndex = 0;\n const numSegments = header.getInt32(0, true);\n\n for (let s = 0; s < numSegments; ++s) {\n outIndex = s;\n\n let inIndex = header.getInt32((s + 1) * 4, true);\n\n let maxIndex = header.getInt32((s + 2) * 4, true);\n\n if (maxIndex === 0) {\n maxIndex = frameData.length;\n }\n\n const endOfSegment = frameSize * numSegments;\n\n while (inIndex < maxIndex) {\n const n = data[inIndex++];\n\n if (n >= 0 && n <= 127) {\n // copy n bytes\n for (let i = 0; i < n + 1 && outIndex < endOfSegment; ++i) {\n out[outIndex] = data[inIndex++];\n outIndex += imageFrame.samplesPerPixel;\n }\n } else if (n <= -1 && n >= -127) {\n const value = data[inIndex++];\n // run of n bytes\n\n for (let j = 0; j < -n + 1 && outIndex < endOfSegment; ++j) {\n out[outIndex] = value;\n outIndex += imageFrame.samplesPerPixel;\n }\n } /* else if (n === -128) {\n\n } // do nothing */\n }\n }\n imageFrame.pixelData = new Uint8Array(outFrame);\n\n return imageFrame;\n}\n\nfunction decode8Planar(imageFrame: ImageFrame, pixelData: ByteArray) {\n const frameData = pixelData;\n const frameSize = imageFrame.rows * imageFrame.columns;\n const outFrame = new ArrayBuffer(frameSize * imageFrame.samplesPerPixel);\n const header = new DataView(frameData.buffer, frameData.byteOffset);\n const data = new Int8Array(frameData.buffer, frameData.byteOffset);\n const out = new Int8Array(outFrame);\n\n let outIndex = 0;\n const numSegments = header.getInt32(0, true);\n\n for (let s = 0; s < numSegments; ++s) {\n outIndex = s * frameSize;\n\n let inIndex = header.getInt32((s + 1) * 4, true);\n\n let maxIndex = header.getInt32((s + 2) * 4, true);\n\n if (maxIndex === 0) {\n maxIndex = frameData.length;\n }\n\n const endOfSegment = frameSize * numSegments;\n\n while (inIndex < maxIndex) {\n const n = data[inIndex++];\n\n if (n >= 0 && n <= 127) {\n // copy n bytes\n for (let i = 0; i < n + 1 && outIndex < endOfSegment; ++i) {\n out[outIndex] = data[inIndex++];\n outIndex++;\n }\n } else if (n <= -1 && n >= -127) {\n const value = data[inIndex++];\n // run of n bytes\n\n for (let j = 0; j < -n + 1 && outIndex < endOfSegment; ++j) {\n out[outIndex] = value;\n outIndex++;\n }\n } /* else if (n === -128) {\n\n } // do nothing */\n }\n }\n imageFrame.pixelData = new Uint8Array(outFrame);\n\n return imageFrame;\n}\n\nfunction decode16(imageFrame: ImageFrame, pixelData: ByteArray) {\n const frameData = pixelData;\n const frameSize = imageFrame.rows * imageFrame.columns;\n const outFrame = new ArrayBuffer(frameSize * imageFrame.samplesPerPixel * 2);\n\n const header = new DataView(frameData.buffer, frameData.byteOffset);\n const data = new Int8Array(frameData.buffer, frameData.byteOffset);\n const out = new Int8Array(outFrame);\n\n const numSegments = header.getInt32(0, true);\n\n for (let s = 0; s < numSegments; ++s) {\n let outIndex = 0;\n const highByte = s === 0 ? 1 : 0;\n\n let inIndex = header.getInt32((s + 1) * 4, true);\n\n let maxIndex = header.getInt32((s + 2) * 4, true);\n\n if (maxIndex === 0) {\n maxIndex = frameData.length;\n }\n\n while (inIndex < maxIndex) {\n const n = data[inIndex++];\n\n if (n >= 0 && n <= 127) {\n for (let i = 0; i < n + 1 && outIndex < frameSize; ++i) {\n out[outIndex * 2 + highByte] = data[inIndex++];\n outIndex++;\n }\n } else if (n <= -1 && n >= -127) {\n const value = data[inIndex++];\n\n for (let j = 0; j < -n + 1 && outIndex < frameSize; ++j) {\n out[outIndex * 2 + highByte] = value;\n outIndex++;\n }\n } /* else if (n === -128) {\n\n } // do nothing */\n }\n }\n if (imageFrame.pixelRepresentation === 0) {\n imageFrame.pixelData = new Uint16Array(outFrame);\n } else {\n imageFrame.pixelData = new Int16Array(outFrame);\n }\n\n return imageFrame;\n}\n\nexport default decodeRLE;\n","import type {\n LibJpegTurbo8Bit,\n OpenJpegModule,\n} from '@cornerstonejs/codec-libjpeg-turbo-8bit/dist/libjpegturbowasm_decode';\nimport { ByteArray } from 'dicom-parser';\n// @ts-ignore\nimport libjpegTurboFactory from '@cornerstonejs/codec-libjpeg-turbo-8bit/decodewasmjs';\n\n// @ts-ignore\n// import libjpegTurboWasm from '@cornerstonejs/codec-libjpeg-turbo-8bit/decodewasm';\nconst libjpegTurboWasm = new URL(\n '@cornerstonejs/codec-libjpeg-turbo-8bit/decodewasm',\n import.meta.url\n);\nimport { ImageFrame } from '../../types';\n\nconst local: {\n codec: OpenJpegModule;\n decoder: LibJpegTurbo8Bit;\n} = {\n codec: undefined,\n decoder: undefined,\n};\n\nfunction initLibjpegTurbo(): Promise<void> {\n if (local.codec) {\n return Promise.resolve();\n }\n\n const libjpegTurboModule = libjpegTurboFactory({\n locateFile: (f) => {\n if (f.endsWith('.wasm')) {\n return libjpegTurboWasm.toString();\n }\n\n return f;\n },\n });\n\n return new Promise((resolve, reject) => {\n libjpegTurboModule.then((instance) => {\n local.codec = instance;\n local.decoder = new instance.JPEGDecoder();\n resolve();\n }, reject);\n });\n}\n\n// imageFrame.pixelRepresentation === 1 <-- Signed\n/**\n *\n * @param {*} compressedImageFrame\n * @param {object} imageInfo\n * @param {boolean} imageInfo.signed -\n */\nasync function decodeAsync(\n compressedImageFrame,\n imageInfo\n): Promise<ImageFrame> {\n await initLibjpegTurbo();\n const decoder = local.decoder;\n\n // get pointer to the source/encoded bit stream buffer in WASM memory\n // that can hold the encoded bitstream\n const encodedBufferInWASM = decoder.getEncodedBuffer(\n compressedImageFrame.length\n );\n\n // copy the encoded bitstream into WASM memory buffer\n encodedBufferInWASM.set(compressedImageFrame);\n\n // decode it\n decoder.decode();\n\n // get information about the decoded image\n const frameInfo = decoder.getFrameInfo();\n\n // get the decoded pixels\n const decodedPixelsInWASM = decoder.getDecodedBuffer();\n\n const encodedImageInfo = {\n columns: frameInfo.width,\n rows: frameInfo.height,\n bitsPerPixel: frameInfo.bitsPerSample,\n signed: imageInfo.signed,\n bytesPerPixel: imageInfo.bytesPerPixel,\n componentsPerPixel: frameInfo.componentCount,\n };\n\n const pixelData = getPixelData(frameInfo, decodedPixelsInWASM);\n\n const encodeOptions = {\n frameInfo,\n };\n\n return {\n ...imageInfo,\n pixelData,\n imageInfo: encodedImageInfo,\n encodeOptions,\n ...encodeOptions,\n ...encodedImageInfo,\n };\n}\n\nfunction getPixelData(frameInfo, decodedBuffer: ByteArray) {\n if (frameInfo.isSigned) {\n return new Int8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n }\n\n return new Uint8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n}\n\nexport default decodeAsync;\n","import { ByteArray } from 'dicom-parser';\nimport { ImageFrame, WebWorkerDecodeConfig } from '../../types';\n\nconst local = {\n JpegImage: undefined,\n decodeConfig: {} as WebWorkerDecodeConfig,\n};\n\nexport function initialize(\n decodeConfig?: WebWorkerDecodeConfig\n): Promise<void> {\n local.decodeConfig = decodeConfig;\n\n if (local.JpegImage) {\n return Promise.resolve();\n }\n\n return new Promise((resolve, reject) => {\n // @ts-ignore\n import('../../../codecs/jpeg').then(({ JpegImage }) => {\n local.JpegImage = JpegImage;\n resolve();\n }, reject);\n });\n}\n\nasync function decodeJPEGBaseline12BitAsync(\n imageFrame: ImageFrame,\n pixelData: ByteArray\n): Promise<ImageFrame> {\n // check to make sure codec is loaded\n await initialize();\n if (typeof local.JpegImage === 'undefined') {\n throw new Error('No JPEG Baseline decoder loaded');\n }\n const jpeg = new local.JpegImage();\n\n jpeg.parse(pixelData);\n\n // Do not use the internal jpeg.js color transformation,\n // since we will handle this afterwards\n jpeg.colorTransform = false;\n\n if (imageFrame.bitsAllocated === 8) {\n imageFrame.pixelData = jpeg.getData(imageFrame.columns, imageFrame.rows);\n\n return imageFrame;\n } else if (imageFrame.bitsAllocated === 16) {\n imageFrame.pixelData = jpeg.getData16(imageFrame.columns, imageFrame.rows);\n\n return imageFrame;\n }\n}\n\nexport default decodeJPEGBaseline12BitAsync;\n","import { ByteArray } from 'dicom-parser';\nimport { ImageFrame, WebWorkerDecodeConfig } from '../../types';\n\nconst local = {\n jpeg: undefined,\n decodeConfig: {} as WebWorkerDecodeConfig,\n};\n\nexport function initialize(\n decodeConfig?: WebWorkerDecodeConfig\n): Promise<void> {\n local.decodeConfig = decodeConfig;\n\n if (local.jpeg) {\n return Promise.resolve();\n }\n\n return new Promise((resolve, reject) => {\n import('../../../codecs/jpegLossless').then((jpeg) => {\n local.jpeg = jpeg;\n resolve();\n }, reject);\n });\n}\n\nasync function decodeJPEGLossless(\n imageFrame: ImageFrame,\n pixelData: ByteArray\n): Promise<ImageFrame> {\n await initialize();\n\n // check to make sure codec is loaded\n if (\n typeof local.jpeg === 'undefined' ||\n typeof local.jpeg.lossless === 'undefined' ||\n typeof local.jpeg.lossless.Decoder === 'undefined'\n ) {\n throw new Error('No JPEG Lossless decoder loaded');\n }\n\n const byteOutput = imageFrame.bitsAllocated <= 8 ? 1 : 2;\n // console.time('jpeglossless');\n const buffer = pixelData.buffer;\n const decoder = new local.jpeg.lossless.Decoder();\n const decompressedData = decoder.decode(\n buffer,\n pixelData.byteOffset,\n pixelData.length,\n byteOutput\n );\n // console.timeEnd('jpeglossless');\n\n if (imageFrame.pixelRepresentation === 0) {\n if (imageFrame.bitsAllocated === 16) {\n imageFrame.pixelData = new Uint16Array(decompressedData.buffer);\n\n return imageFrame;\n }\n // untested!\n imageFrame.pixelData = new Uint8Array(decompressedData.buffer);\n\n return imageFrame;\n }\n imageFrame.pixelData = new Int16Array(decompressedData.buffer);\n\n return imageFrame;\n}\n\nexport default decodeJPEGLossless;\n","import type {\n CharlsModule,\n JpegLSDecoder,\n} from '@cornerstonejs/codec-charls/dist/charlswasm_decode';\n// @ts-ignore\nimport charlsFactory from '@cornerstonejs/codec-charls/decodewasmjs';\n// @ts-ignore\n// import charlsWasm from '@cornerstonejs/codec-charls/decodewasm';\nconst charlsWasm = new URL(\n '@cornerstonejs/codec-charls/decodewasm',\n import.meta.url\n);\nimport { ByteArray } from 'dicom-parser';\nimport { ImageFrame, WebWorkerDecodeConfig } from '../../types';\n\nconst local: {\n codec: CharlsModule;\n decoder: JpegLSDecoder;\n decodeConfig: WebWorkerDecodeConfig;\n} = {\n codec: undefined,\n decoder: undefined,\n decodeConfig: {} as WebWorkerDecodeConfig,\n};\n\nfunction getExceptionMessage(exception) {\n return typeof exception === 'number'\n ? local.codec.getExceptionMessage(exception)\n : exception;\n}\n\nexport function initialize(\n decodeConfig?: WebWorkerDecodeConfig\n): Promise<void> {\n local.decodeConfig = decodeConfig;\n\n if (local.codec) {\n return Promise.resolve();\n }\n\n const charlsModule = charlsFactory({\n locateFile: (f) => {\n if (f.endsWith('.wasm')) {\n return charlsWasm.toString();\n }\n\n return f;\n },\n });\n\n return new Promise((resolve, reject) => {\n charlsModule.then((instance) => {\n local.codec = instance;\n local.decoder = new instance.JpegLSDecoder();\n resolve();\n }, reject);\n });\n}\n\n/**\n *\n * @param {*} compressedImageFrame\n * @param {object} imageInfo\n * @param {boolean} imageInfo.signed - (pixelRepresentation === 1)\n */\nasync function decodeAsync(\n compressedImageFrame,\n imageInfo\n): Promise<ImageFrame> {\n try {\n await initialize();\n const decoder = local.decoder;\n\n // get pointer to the source/encoded bit stream buffer in WASM memory\n // that can hold the encoded bitstream\n const encodedBufferInWASM = decoder.getEncodedBuffer(\n compressedImageFrame.length\n );\n\n // copy the encoded bitstream into WASM memory buffer\n encodedBufferInWASM.set(compressedImageFrame);\n\n // decode it\n decoder.decode();\n\n // get information about the decoded image\n const frameInfo = decoder.getFrameInfo();\n const interleaveMode = decoder.getInterleaveMode();\n const nearLossless = decoder.getNearLossless();\n\n // get the decoded pixels\n const decodedPixelsInWASM = decoder.getDecodedBuffer();\n\n const encodedImageInfo = {\n columns: frameInfo.width,\n rows: frameInfo.height,\n bitsPerPixel: frameInfo.bitsPerSample,\n signed: imageInfo.signed,\n bytesPerPixel: imageInfo.bytesPerPixel,\n componentsPerPixel: frameInfo.componentCount,\n };\n\n const pixelData = getPixelData(\n frameInfo,\n decodedPixelsInWASM,\n imageInfo.signed\n );\n\n const encodeOptions = {\n nearLossless,\n interleaveMode,\n frameInfo,\n };\n\n // local.codec.doLeakCheck();\n\n return {\n ...imageInfo,\n pixelData,\n imageInfo: encodedImageInfo,\n encodeOptions,\n ...encodeOptions,\n ...encodedImageInfo,\n };\n } catch (error) {\n // Handle cases where WASM throws an error internally, and it only gives JS a number\n // See https://emscripten.org/docs/porting/Debugging.html#handling-c-exceptions-from-javascript\n // TODO: Copy to other codecs as well\n throw getExceptionMessage(error);\n }\n}\n\nfunction getPixelData(frameInfo, decodedBuffer: ByteArray, signed: boolean) {\n if (frameInfo.bitsPerSample > 8) {\n if (signed) {\n return new Int16Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength / 2\n );\n }\n\n return new Uint16Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength / 2\n );\n }\n\n if (signed) {\n return new Int8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n }\n\n return new Uint8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n}\n\nexport default decodeAsync;\n","// https://emscripten.org/docs/api_reference/module.html\nimport type {\n J2KDecoder,\n OpenJpegModule,\n} from '@cornerstonejs/codec-openjpeg/dist/openjpegwasm_decode';\n// @ts-ignore\nimport openJpegFactory from '@cornerstonejs/codec-openjpeg/decodewasmjs';\n\n// Webpack asset/resource copies this to our output folder\n\n// TODO: At some point maybe we can use this instead.\n// This is closer to what Webpack 5 wants but it doesn't seem to work now\n// const wasm = new URL('./blah.wasm', import.meta.url)\n// @ts-ignore\n// import openjpegWasm from '@cornerstonejs/codec-openjpeg/decodewasm';\nconst openjpegWasm = new URL(\n '@cornerstonejs/codec-openjpeg/decodewasm',\n import.meta.url\n);\n\nimport { ImageFrame, WebWorkerDecodeConfig } from '../../types';\n\nconst local: {\n codec: OpenJpegModule;\n decoder: J2KDecoder;\n decodeConfig: WebWorkerDecodeConfig;\n} = {\n codec: undefined,\n decoder: undefined,\n decodeConfig: {} as WebWorkerDecodeConfig,\n};\n\nexport function initialize(\n decodeConfig?: WebWorkerDecodeConfig\n): Promise<void> {\n local.decodeConfig = decodeConfig;\n\n if (local.codec) {\n return Promise.resolve();\n }\n\n const openJpegModule = openJpegFactory({\n locateFile: (f) => {\n if (f.endsWith('.wasm')) {\n return openjpegWasm.toString();\n }\n\n return f;\n },\n });\n\n return new Promise((resolve, reject) => {\n openJpegModule.then((instance) => {\n local.codec = instance;\n local.decoder = new instance.J2KDecoder();\n resolve();\n }, reject);\n });\n}\n\n// https://github.com/chafey/openjpegjs/blob/master/test/browser/index.html\nasync function decodeAsync(\n compressedImageFrame,\n imageInfo\n): Promise<ImageFrame> {\n await initialize();\n const decoder = local.decoder;\n\n // get pointer to the source/encoded bit stream buffer in WASM memory\n // that can hold the encoded bitstream\n const encodedBufferInWASM = decoder.getEncodedBuffer(\n compressedImageFrame.length\n );\n\n // copy the encoded bitstream into WASM memory buffer\n encodedBufferInWASM.set(compressedImageFrame);\n\n // decode it\n decoder.decode();\n // decoder.decodeSubResolution(decodeLevel, decodeLayer);\n // const resolutionAtLevel = decoder.calculateSizeAtDecompositionLevel(decodeLevel);\n\n // get information about the decoded image\n const frameInfo = decoder.getFrameInfo();\n // get the decoded pixels\n const decodedBufferInWASM = decoder.getDecodedBuffer();\n const imageFrame = new Uint8Array(decodedBufferInWASM.length);\n\n imageFrame.set(decodedBufferInWASM);\n\n const imageOffset = `x: ${decoder.getImageOffset().x}, y: ${\n decoder.getImageOffset().y\n }`;\n const numDecompositions = decoder.getNumDecompositions();\n const numLayers = decoder.getNumLayers();\n const progessionOrder = ['unknown', 'LRCP', 'RLCP', 'RPCL', 'PCRL', 'CPRL'][\n decoder.getProgressionOrder() + 1\n ];\n const reversible = decoder.getIsReversible();\n const blockDimensions = `${decoder.getBlockDimensions().width} x ${\n decoder.getBlockDimensions().height\n }`;\n const tileSize = `${decoder.getTileSize().width} x ${\n decoder.getTileSize().height\n }`;\n const tileOffset = `${decoder.getTileOffset().x}, ${\n decoder.getTileOffset().y\n }`;\n const colorTransform = decoder.getColorSpace();\n\n const decodedSize = `${decodedBufferInWASM.length.toLocaleString()} bytes`;\n const compressionRatio = `${(\n decodedBufferInWASM.length / encodedBufferInWASM.length\n ).toFixed(2)}:1`;\n\n const encodedImageInfo = {\n columns: frameInfo.width,\n rows: frameInfo.height,\n bitsPerPixel: frameInfo.bitsPerSample,\n signed: frameInfo.isSigned,\n bytesPerPixel: imageInfo.bytesPerPixel,\n componentsPerPixel: frameInfo.componentCount,\n };\n const pixelData = getPixelData(frameInfo, decodedBufferInWASM);\n\n const encodeOptions = {\n imageOffset,\n numDecompositions,\n numLayers,\n progessionOrder,\n reversible,\n blockDimensions,\n tileSize,\n tileOffset,\n colorTransform,\n decodedSize,\n compressionRatio,\n };\n\n return {\n ...imageInfo,\n pixelData,\n imageInfo: encodedImageInfo,\n encodeOptions,\n ...encodeOptions,\n ...encodedImageInfo,\n };\n}\n\nfunction getPixelData(frameInfo, decodedBuffer) {\n if (frameInfo.bitsPerSample > 8) {\n if (frameInfo.isSigned) {\n return new Int16Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength / 2\n );\n }\n\n return new Uint16Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength / 2\n );\n }\n\n if (frameInfo.isSigned) {\n return new Int8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n }\n\n return new Uint8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n}\n\nexport default decodeAsync;\n","import { ByteArray } from 'dicom-parser';\n// @ts-ignore\nimport openJphFactory from '@cornerstonejs/codec-openjph/wasmjs';\n// @ts-ignore\n// import openjphWasm from '@cornerstonejs/codec-openjph/wasm';\nconst openjphWasm = new URL(\n '@cornerstonejs/codec-openjph/wasm',\n import.meta.url\n);\n\nimport { LoaderDecodeOptions } from '../../types';\n\nconst local: {\n codec: any;\n decoder: any;\n decodeConfig: LoaderDecodeOptions;\n} = {\n codec: undefined,\n decoder: undefined,\n decodeConfig: {},\n};\n\nfunction calculateSizeAtDecompositionLevel(\n decompositionLevel: number,\n frameWidth: number,\n frameHeight: number\n) {\n const result = { width: frameWidth, height: frameHeight };\n while (decompositionLevel > 0) {\n result.width = Math.ceil(result.width / 2);\n result.height = Math.ceil(result.height / 2);\n decompositionLevel--;\n }\n return result;\n}\n\nexport function initialize(decodeConfig?: LoaderDecodeOptions): Promise<void> {\n local.decodeConfig = decodeConfig;\n\n if (local.codec) {\n return Promise.resolve();\n }\n\n const openJphModule = openJphFactory({\n locateFile: (f) => {\n if (f.endsWith('.wasm')) {\n return openjphWasm;\n }\n\n return f;\n },\n });\n\n return new Promise<void>((resolve, reject) => {\n openJphModule.then((instance) => {\n local.codec = instance;\n local.decoder = new instance.HTJ2KDecoder();\n resolve();\n }, reject);\n });\n}\n\n// https://github.com/chafey/openjpegjs/blob/master/test/browser/index.html\nasync function decodeAsync(compressedImageFrame: ByteArray, imageInfo) {\n await initialize();\n // const decoder = local.decoder; // This is much slower for some reason\n const decoder = new local.codec.HTJ2KDecoder();\n\n // get pointer to the source/encoded bit stream buffer in WASM memory\n // that can hold the encoded bitstream\n const encodedBufferInWASM = decoder.getEncodedBuffer(\n compressedImageFrame.length\n );\n\n // copy the encoded bitstream into WASM memory buffer\n encodedBufferInWASM.set(compressedImageFrame);\n\n // decode it\n // decoder.decode();\n const decodeLevel = imageInfo.decodeLevel || 0;\n decoder.decodeSubResolution(decodeLevel);\n // decoder.decodeSubResolution(decodeLevel, decodeLayer);\n // const resolutionAtLevel = decoder.calculateSizeAtDecompositionLevel(decodeLevel);\n\n // get information about the decoded image\n const frameInfo = decoder.getFrameInfo();\n // Overwrite width/height if subresolution\n if (imageInfo.decodeLevel > 0) {\n const { width, height } = calculateSizeAtDecompositionLevel(\n imageInfo.decodeLevel,\n frameInfo.width,\n frameInfo.height\n );\n frameInfo.width = width;\n frameInfo.height = height;\n // console.log(`Decoded sub-resolution of size: ${width} x ${height}`);\n }\n // get the decoded pixels\n const decodedBufferInWASM = decoder.getDecodedBuffer();\n const imageFrame = new Uint8Array(decodedBufferInWASM.length);\n\n imageFrame.set(decodedBufferInWASM);\n\n const imageOffset = `x: ${decoder.getImageOffset().x}, y: ${\n decoder.getImageOffset().y\n }`;\n const numDecompositions = decoder.getNumDecompositions();\n const numLayers = decoder.getNumLayers();\n const progessionOrder = ['unknown', 'LRCP', 'RLCP', 'RPCL', 'PCRL', 'CPRL'][\n decoder.getProgressionOrder() + 1\n ];\n const reversible = decoder.getIsReversible();\n const blockDimensions = `${decoder.getBlockDimensions().width} x ${\n decoder.getBlockDimensions().height\n }`;\n const tileSize = `${decoder.getTileSize().width} x ${\n decoder.getTileSize().height\n }`;\n const tileOffset = `${decoder.getTileOffset().x}, ${\n decoder.getTileOffset().y\n }`;\n // const colorTransform = decoder.getColorSpace();\n\n const decodedSize = `${decodedBufferInWASM.length.toLocaleString()} bytes`;\n const compressionRatio = `${(\n decodedBufferInWASM.length / encodedBufferInWASM.length\n ).toFixed(2)}:1`;\n\n const encodedImageInfo = {\n columns: frameInfo.width,\n rows: frameInfo.height,\n bitsPerPixel: frameInfo.bitsPerSample,\n signed: frameInfo.isSigned,\n bytesPerPixel: imageInfo.bytesPerPixel,\n componentsPerPixel: frameInfo.componentCount,\n };\n // const pixelData = getPixelData(frameInfo, decodedBufferInWASM);\n\n /**\n * Have to truncate the arraybuffer here to the length of the typed array. Not\n * sure why the arraybuffer is so huge, maybe this is allocated by the WASM\n * module? In any case, I think it's too big to postMessage in it's entirety.\n */\n let pixelData = getPixelData(frameInfo, decodedBufferInWASM);\n const { buffer: b, byteOffset, byteLength } = pixelData;\n const pixelDataArrayBuffer = b.slice(byteOffset, byteOffset + byteLength);\n\n // @ts-ignore\n pixelData = new pixelData.constructor(pixelDataArrayBuffer);\n\n const encodeOptions = {\n imageOffset,\n numDecompositions,\n numLayers,\n progessionOrder,\n reversible,\n blockDimensions,\n tileSize,\n tileOffset,\n // colorTransform,\n decodedSize,\n compressionRatio,\n };\n\n return {\n ...imageInfo,\n pixelData,\n imageInfo: encodedImageInfo,\n encodeOptions,\n ...encodeOptions,\n ...encodedImageInfo,\n };\n}\n\nfunction getPixelData(frameInfo, decodedBuffer) {\n if (frameInfo.bitsPerSample > 8) {\n if (frameInfo.isSigned) {\n return new Int16Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength / 2\n );\n }\n\n return new Uint16Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength / 2\n );\n }\n\n if (frameInfo.isSigned) {\n return new Int8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n }\n\n return new Uint8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n}\n\nexport default decodeAsync;\n","import { PixelDataTypedArray } from '../types';\n\n/**\n * Calculate the minimum and maximum values in an Array\n *\n * @param {Number[]} storedPixelData\n * @return {{min: Number, max: Number}}\n */\nfunction getMinMax(storedPixelData: PixelDataTypedArray): {\n min: number;\n max: number;\n} {\n // we always calculate the min max values since they are not always\n // present in DICOM and we don't want to trust them anyway as cornerstone\n // depends on us providing reliable values for these\n let min = storedPixelData[0];\n\n let max = storedPixelData[0];\n\n let storedPixel;\n const numPixels = storedPixelData.length;\n\n for (let index = 1; index < numPixels; index++) {\n storedPixel = storedPixelData[index];\n min = Math.min(min, storedPixel);\n max = Math.max(max, storedPixel);\n }\n\n return {\n min,\n max,\n };\n}\n\nexport default getMinMax;\n","/* eslint-disable complexity */\nimport bilinear from './shared/scaling/bilinear';\nimport replicate from './shared/scaling/replicate';\nimport { expose } from 'comlink';\n\nimport decodeLittleEndian from './shared/decoders/decodeLittleEndian';\nimport decodeBigEndian from './shared/decoders/decodeBigEndian';\nimport decodeRLE from './shared/decoders/decodeRLE';\nimport decodeJPEGBaseline8Bit from './shared/decoders/decodeJPEGBaseline8Bit';\n// import decodeJPEGBaseline12Bit from './shared/decoders/decodeJPEGBaseline12Bit';\nimport decodeJPEGBaseline12Bit from './shared/decoders/decodeJPEGBaseline12Bit-js';\nimport decodeJPEGLossless from './shared/decoders/decodeJPEGLossless';\nimport decodeJPEGLS from './shared/decoders/decodeJPEGLS';\nimport decodeJPEG2000 from './shared/decoders/decodeJPEG2000';\nimport decodeHTJ2K from './shared/decoders/decodeHTJ2K';\n// Note that the scaling is pixel value scaling, which is applying a modality LUT\nimport applyModalityLUT from './shared/scaling/scaleArray';\nimport getMinMax from './shared/getMinMax';\nimport getPixelDataTypeFromMinMax from './shared/getPixelDataTypeFromMinMax';\nimport isColorImage from './shared/isColorImage';\n\nconst imageUtils = {\n bilinear,\n replicate,\n};\n\n/**\n * Decodes the provided image frame.\n * This is an async function return the result, or you can provide an optional\n * callbackFn that is called with the results.\n */\nasync function decodeImageFrame(\n imageFrame,\n transferSyntax,\n pixelData,\n decodeConfig,\n options,\n callbackFn\n) {\n const start = new Date().getTime();\n\n let decodePromise = null;\n\n let opts;\n\n switch (transferSyntax) {\n case '1.2.840.10008.1.2':\n case '1.2.840.10008.1.2.1':\n // Implicit or Explicit VR Little Endian\n decodePromise = decodeLittleEndian(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.2':\n // Explicit VR Big Endian (retired)\n decodePromise = decodeBigEndian(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.1.99':\n // Deflate transfer syntax (deflated by dicomParser)\n decodePromise = decodeLittleEndian(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.5':\n // RLE Lossless\n decodePromise = decodeRLE(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.4.50':\n // JPEG Baseline lossy process 1 (8 bit)\n opts = {\n ...imageFrame,\n };\n\n decodePromise = decodeJPEGBaseline8Bit(pixelData, opts);\n break;\n case '1.2.840.10008.1.2.4.51':\n // JPEG Baseline lossy process 2 & 4 (12 bit)\n // opts = {\n // ...imageFrame,\n // };\n // decodePromise = decodeJPEGBaseline12Bit(pixelData, opts);\n //throw new Error('Currently unsupported: 1.2.840.10008.1.2.4.51');\n decodePromise = decodeJPEGBaseline12Bit(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.4.57':\n // JPEG Lossless, Nonhierarchical (Processes 14)\n decodePromise = decodeJPEGLossless(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.4.70':\n // JPEG Lossless, Nonhierarchical (Processes 14 [Selection 1])\n decodePromise = decodeJPEGLossless(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.4.80':\n // JPEG-LS Lossless Image Compression\n opts = {\n signed: imageFrame.pixelRepresentation === 1, // imageFrame.signed,\n // shouldn't need...\n bytesPerPixel: imageFrame.bitsAllocated <= 8 ? 1 : 2,\n ...imageFrame,\n };\n\n decodePromise = decodeJPEGLS(pixelData, opts);\n break;\n case '1.2.840.10008.1.2.4.81':\n // JPEG-LS Lossy (Near-Lossless) Image Compression\n opts = {\n signed: imageFrame.pixelRepresentation === 1, // imageFrame.signed,\n // shouldn't need...\n bytesPerPixel: imageFrame.bitsAllocated <= 8 ? 1 : 2,\n ...imageFrame,\n };\n\n decodePromise = decodeJPEGLS(pixelData, opts);\n break;\n case '1.2.840.10008.1.2.4.90':\n opts = {\n ...imageFrame,\n };\n\n // JPEG 2000 Lossless\n // imageFrame, pixelData, decodeConfig, options\n decodePromise = decodeJPEG2000(pixelData, opts);\n break;\n case '1.2.840.10008.1.2.4.91':\n // JPEG 2000 Lossy\n opts = {\n ...imageFrame,\n };\n\n // JPEG 2000 Lossy\n // imageFrame, pixelData, decodeConfig, options\n decodePromise = decodeJPEG2000(pixelData, opts);\n break;\n case '3.2.840.10008.1.2.4.96':\n case '1.2.840.10008.1.2.4.201':\n case '1.2.840.10008.1.2.4.202':\n case '1.2.840.10008.1.2.4.203':\n // HTJ2K\n opts = {\n ...imageFrame,\n };\n\n decodePromise = decodeHTJ2K(pixelData, opts);\n break;\n default:\n throw new Error(`no decoder for transfer syntax ${transferSyntax}`);\n }\n\n /* Don't know if these work...\n // JPEG 2000 Part 2 Multicomponent Image Compression (Lossless Only)\n else if(transferSyntax === \"1.2.840.10008.1.2.4.92\")\n {\n return decodeJPEG2000(dataSet, frame);\n }\n // JPEG 2000 Part 2 Multicomponent Image Compression\n else if(transferSyntax === \"1.2.840.10008.1.2.4.93\")\n {\n return decodeJPEG2000(dataSet, frame);\n }\n */\n\n if (!decodePromise) {\n throw new Error('decodePromise not defined');\n }\n\n const decodedFrame = await decodePromise;\n\n const postProcessed = postProcessDecodedPixels(\n decodedFrame,\n options,\n start,\n decodeConfig\n );\n\n // Call the callbackFn to agree with older arguments\n callbackFn?.(postProcessed);\n\n return postProcessed;\n}\n\nfunction postProcessDecodedPixels(imageFrame, options, start, decodeConfig) {\n const { use16BitDataType } = decodeConfig || {};\n\n const shouldShift =\n imageFrame.pixelRepresentation !== undefined &&\n imageFrame.pixelRepresentation === 1;\n const shift =\n shouldShift && imageFrame.bitsStored !== undefined\n ? 32 - imageFrame.bitsStored\n : undefined;\n\n if (shouldShift && shift !== undefined) {\n for (let i = 0; i < imageFrame.pixelData.length; i++) {\n // eslint-disable-next-line no-bitwise\n imageFrame.pixelData[i] = (imageFrame.pixelData[i] << shift) >> shift;\n }\n }\n\n // Cache the pixelData reference quickly incase we want to set a targetBuffer _and_ scale.\n let pixelDataArray = imageFrame.pixelData;\n imageFrame.pixelDataLength = imageFrame.pixelData.length;\n const { min: minBeforeScale, max: maxBeforeScale } = getMinMax(\n imageFrame.pixelData\n );\n\n const typedArrayConstructors = {\n Uint8Array,\n Uint16Array: use16BitDataType ? Uint16Array : undefined,\n Int16Array: use16BitDataType ? Int16Array : undefined,\n Float32Array,\n };\n\n const type = options.targetBuffer?.type;\n\n const canRenderFloat =\n typeof options.allowFloatRendering !== 'undefined'\n ? options.allowFloatRendering\n : true;\n\n // Sometimes the type is specified before the DICOM header data has been\n // read. This is fine except for color data, where the wrong type gets\n // specified. Don't use the target buffer in that case.\n const invalidType =\n isColorImage(imageFrame.photometricInterpretation) &&\n options.targetBuffer?.offset === undefined;\n\n const willScale = options.preScale?.enabled;\n\n const hasFloatRescale =\n willScale &&\n Object.values(options.preScale.scalingParameters).some(\n (v) => typeof v === 'number' && !Number.isInteger(v)\n );\n const disableScale =\n !options.preScale.enabled || (!canRenderFloat && hasFloatRescale);\n\n if (type && !invalidType) {\n pixelDataArray = _handleTargetBuffer(\n options,\n imageFrame,\n typedArrayConstructors,\n pixelDataArray\n );\n } else if (options.preScale.enabled && !disableScale) {\n pixelDataArray = _handlePreScaleSetup(\n options,\n minBeforeScale,\n maxBeforeScale,\n imageFrame\n );\n } else {\n pixelDataArray = _getDefaultPixelDataArray(\n minBeforeScale,\n maxBeforeScale,\n imageFrame\n );\n }\n\n let minAfterScale = minBeforeScale;\n let maxAfterScale = maxBeforeScale;\n\n if (options.preScale.enabled && !disableScale) {\n const scalingParameters = options.preScale.scalingParameters;\n _validateScalingParameters(scalingParameters);\n\n const { rescaleSlope, rescaleIntercept } = scalingParameters;\n const isSlopeAndInterceptNumbers =\n typeof rescaleSlope === 'number' && typeof rescaleIntercept === 'number';\n\n if (isSlopeAndInterceptNumbers) {\n applyModalityLUT(pixelDataArray, scalingParameters);\n imageFrame.preScale = {\n ...options.preScale,\n scaled: true,\n };\n\n // calculate the min and max after scaling\n const { rescaleIntercept, rescaleSlope, suvbw } = scalingParameters;\n minAfterScale = rescaleSlope * minBeforeScale + rescaleIntercept;\n maxAfterScale = rescaleSlope * maxBeforeScale + rescaleIntercept;\n\n if (suvbw) {\n minAfterScale = minAfterScale * suvbw;\n maxAfterScale = maxAfterScale * suvbw;\n }\n }\n } else if (disableScale) {\n imageFrame.preScale = {\n enabled: true,\n scaled: false,\n };\n\n minAfterScale = minBeforeScale;\n maxAfterScale = maxBeforeScale;\n }\n\n // assign the array buffer to the pixelData only if it is not a SharedArrayBuffer\n // since we can't transfer ownership of a SharedArrayBuffer to another thread\n // in the workers\n const hasTargetBuffer = options.targetBuffer !== undefined;\n\n if (!hasTargetBuffer || !options.isSharedArrayBuffer) {\n imageFrame.pixelData = pixelDataArray;\n }\n\n imageFrame.minAfterScale = minAfterScale;\n imageFrame.maxAfterScale = maxAfterScale;\n\n const end = new Date().getTime();\n imageFrame.decodeTimeInMS = end - start;\n\n return imageFrame;\n}\n\nfunction _handleTargetBuffer(\n options,\n imageFrame,\n typedArrayConstructors,\n pixelDataArray\n) {\n const {\n arrayBuffer,\n type,\n offset: rawOffset = 0,\n length: rawLength,\n rows,\n } = options.targetBuffer;\n\n const TypedArrayConstructor = typedArrayConstructors[type];\n\n if (!TypedArrayConstructor) {\n throw new Error(\n `target array ${type} is not supported, you need to set use16BitDataType to true if you want to use Uint16Array or Int16Array.`\n );\n }\n\n if (rows && rows != imageFrame.rows) {\n scaleImageFrame(imageFrame, options.targetBuffer, TypedArrayConstructor);\n }\n const imageFrameLength = imageFrame.pixelDataLength;\n\n const offset = rawOffset;\n const length =\n rawLength !== null && rawLength !== undefined\n ? rawLength\n : imageFrameLength - offset;\n\n const imageFramePixelData = imageFrame.pixelData;\n\n if (length !== imageFramePixelData.length) {\n throw new Error(\n `target array for image does not have the same length (${length}) as the decoded image length (${imageFramePixelData.length}).`\n );\n }\n\n // TypedArray.Set is api level and ~50x faster than copying elements even for\n // Arrays of different types, which aren't simply memcpy ops.\n const typedArray = arrayBuffer\n ? new TypedArrayConstructor(arrayBuffer, offset, length)\n : new TypedArrayConstructor(length);\n\n typedArray.set(imageFramePixelData, 0);\n\n // If need to scale, need to scale correct array.\n pixelDataArray = typedArray;\n return pixelDataArray;\n}\n\nfunction _handlePreScaleSetup(\n options,\n minBeforeScale,\n maxBeforeScale,\n imageFrame\n) {\n const scalingParameters = options.preScale.scalingParameters;\n _validateScalingParameters(scalingParameters);\n\n const { rescaleSlope, rescaleIntercept } = scalingParameters;\n const areSlopeAndInterceptNumbers =\n typeof rescaleSlope === 'number' && typeof rescaleIntercept === 'number';\n\n let scaledMin = minBeforeScale;\n let scaledMax = maxBeforeScale;\n\n if (areSlopeAndInterceptNumbers) {\n scaledMin = rescaleSlope * minBeforeScale + rescaleIntercept;\n scaledMax = rescaleSlope * maxBeforeScale + rescaleIntercept;\n }\n\n return _getDefaultPixelDataArray(scaledMin, scaledMax, imageFrame);\n}\n\nfunction _getDefaultPixelDataArray(min, max, imageFrame) {\n const TypedArrayConstructor = getPixelDataTypeFromMinMax(min, max);\n // @ts-ignore\n const typedArray = new TypedArrayConstructor(imageFrame.pixelData.length);\n typedArray.set(imageFrame.pixelData, 0);\n\n return typedArray;\n}\n\nfunction _validateScalingParameters(scalingParameters) {\n if (!scalingParameters) {\n throw new Error(\n 'options.preScale.scalingParameters must be defined if preScale.enabled is true, and scalingParameters cannot be derived from the metadata providers.'\n );\n }\n}\n\nfunction createDestinationImage(\n imageFrame,\n targetBuffer,\n TypedArrayConstructor\n) {\n const { samplesPerPixel } = imageFrame;\n const { rows, columns } = targetBuffer;\n const typedLength = rows * columns * samplesPerPixel;\n const pixelData = new TypedArrayConstructor(typedLength);\n const bytesPerPixel = pixelData.byteLength / typedLength;\n return {\n pixelData,\n rows,\n columns,\n frameInfo: {\n ...imageFrame.frameInfo,\n rows,\n columns,\n },\n imageInfo: {\n ...imageFrame.imageInfo,\n rows,\n columns,\n bytesPerPixel,\n },\n };\n}\n\n/** Scales the image frame, updating the frame in place with a new scaled\n * version of it (in place modification)\n */\nfunction scaleImageFrame(imageFrame, targetBuffer, TypedArrayConstructor) {\n const dest = createDestinationImage(\n imageFrame,\n targetBuffer,\n TypedArrayConstructor\n );\n const { scalingType = 'replicate' } = targetBuffer;\n imageUtils[scalingType](imageFrame, dest);\n Object.assign(imageFrame, dest);\n return imageFrame;\n}\n\nconst obj = {\n decodeTask({\n imageFrame,\n transferSyntax,\n decodeConfig,\n options,\n pixelData,\n callbackFn,\n }) {\n return decodeImageFrame(\n imageFrame,\n transferSyntax,\n pixelData,\n decodeConfig,\n options,\n callbackFn\n );\n },\n};\n\nexpose(obj);\n","/**\n * Performs a bilinear scaling, both scaling up and scaling down.\n * Only supports 1 channel per pixel (grayscale)\n * @param src - src image frame to get map from\n * @param dest - dest image frame to write to\n * @returns destination data buffer\n */\nexport default function bilinear(src, dest) {\n const { rows: srcRows, columns: srcColumns, data: srcData } = src;\n const { rows, columns, data } = dest;\n\n const xSrc1Off = [];\n const xSrc2Off = [];\n const xFrac = [];\n\n // Precompute offsets\n for (let x = 0; x < columns; x++) {\n const xSrc = (x * (srcColumns - 1)) / (columns - 1);\n xSrc1Off[x] = Math.floor(xSrc);\n xSrc2Off[x] = Math.min(xSrc1Off[x] + 1, srcColumns - 1);\n xFrac[x] = xSrc - xSrc1Off[x];\n // console.log(\"x src info\", x, xSrc, xFrac[x]);\n }\n\n for (let y = 0; y < rows; y++) {\n const ySrc = (y * (srcRows - 1)) / (rows - 1);\n const ySrc1Off = Math.floor(ySrc) * srcColumns;\n // Get the second offset, but duplicate the last row so the lookup works\n const ySrc2Off = Math.min(\n ySrc1Off + srcColumns,\n (srcRows - 1) * srcColumns\n );\n const yFrac = ySrc - Math.floor(ySrc);\n const yFracInv = 1 - yFrac;\n const yOff = y * columns;\n\n for (let x = 0; x < columns; x++) {\n // TODO - put the pXY into the data calculation\n const p00 = srcData[ySrc1Off + xSrc1Off[x]];\n const p10 = srcData[ySrc1Off + xSrc2Off[x]];\n const p01 = srcData[ySrc2Off + xSrc1Off[x]];\n const p11 = srcData[ySrc2Off + xSrc2Off[x]];\n const xFracInv = 1 - xFrac[x];\n\n // console.log(\"bilinear for\", x,y, \"from\", ySrc1Off + xSrc1Off[x], ySrc1Off + xSrc2Off[x], ySrc2Off + xSrc1Off[x], ySrc2Off + xSrc2Off[x]);\n // console.log(\"values\", p00, p10, p01, p11);\n // console.log(\"fractions\", xFracInv, xFrac[x], yFracInv, yFrac);\n\n data[yOff + x] =\n (p00 * xFracInv + p10 * xFrac[x]) * yFracInv +\n (p01 * xFracInv + p11 * xFrac[x]) * yFrac;\n }\n }\n return data;\n}\n","/** Handle replicate scaling. Use this function for samplesPerPixel>1 */\n\nexport default function replicate(src, dest) {\n const {\n rows: srcRows,\n columns: srcColumns,\n pixelData: srcData,\n samplesPerPixel = 1,\n } = src;\n const { rows, columns, pixelData } = dest;\n\n const xSrc1Off = [];\n\n // Precompute offsets\n for (let x = 0; x < columns; x++) {\n const xSrc = (x * (srcColumns - 1)) / (columns - 1);\n xSrc1Off[x] = Math.floor(xSrc) * samplesPerPixel;\n // console.log(\"x src info\", x, xSrc, xFrac[x]);\n }\n\n for (let y = 0; y < rows; y++) {\n const ySrc = (y * (srcRows - 1)) / (rows - 1);\n const ySrc1Off = Math.floor(ySrc) * srcColumns * samplesPerPixel;\n const yOff = y * columns;\n\n for (let x = 0; x < columns; x++) {\n for (let sample = 0; sample < samplesPerPixel; sample++) {\n pixelData[yOff + x + sample] = srcData[ySrc1Off + xSrc1Off[x] + sample];\n }\n }\n }\n return pixelData;\n}\n","export default function (photoMetricInterpretation: string): boolean {\n return (\n photoMetricInterpretation === 'RGB' ||\n photoMetricInterpretation === 'PALETTE COLOR' ||\n photoMetricInterpretation === 'YBR_FULL' ||\n photoMetricInterpretation === 'YBR_FULL_422' ||\n photoMetricInterpretation === 'YBR_PARTIAL_422' ||\n photoMetricInterpretation === 'YBR_PARTIAL_420' ||\n photoMetricInterpretation === 'YBR_RCT' ||\n photoMetricInterpretation === 'YBR_ICT'\n );\n}\n","import { PixelDataTypedArray } from '../../types';\n\nexport default function scaleArray(\n array: PixelDataTypedArray,\n scalingParameters\n): boolean {\n const arrayLength = array.length;\n const { rescaleSlope, rescaleIntercept, suvbw } = scalingParameters;\n\n if (scalingParameters.modality === 'PT' && typeof suvbw === 'number') {\n for (let i = 0; i < arrayLength; i++) {\n array[i] = suvbw * (array[i] * rescaleSlope + rescaleIntercept);\n }\n } else {\n for (let i = 0; i < arrayLength; i++) {\n array[i] = array[i] * rescaleSlope + rescaleIntercept;\n }\n }\n\n return true;\n}\n","import { PixelDataTypedArray } from '../types';\n\nexport default function getPixelDataTypeFromMinMax(\n min: number,\n max: number\n): PixelDataTypedArray {\n let pixelDataType;\n if (Number.isInteger(min) && Number.isInteger(max)) {\n if (min >= 0) {\n if (max <= 255) {\n pixelDataType = Uint8Array;\n } else if (max <= 65535) {\n pixelDataType = Uint16Array;\n }\n } else {\n if (min >= -128 && max <= 127) {\n pixelDataType = Int8Array;\n } else if (min >= -32768 && max <= 32767) {\n pixelDataType = Int16Array;\n }\n }\n }\n\n return pixelDataType || Float32Array;\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n// the startup function\n__webpack_require__.x = () => {\n\t// Load entry module and return exports\n\t// This entry module depends on other loaded chunks and execution need to be delayed\n\tvar __webpack_exports__ = __webpack_require__.O(undefined, [958], () => (__webpack_require__(760)))\n\t__webpack_exports__ = __webpack_require__.O(__webpack_exports__);\n\treturn __webpack_exports__;\n};\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = (chunkId) => {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce((promises, key) => {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks and sibling chunks for the entrypoint\n__webpack_require__.u = (chunkId) => {\n\t// return url for filenames based on template\n\treturn \"\" + chunkId + \".min.js\";\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","var scriptUrl;\nif (__webpack_require__.g.importScripts) scriptUrl = __webpack_require__.g.location + \"\";\nvar document = __webpack_require__.g.document;\nif (!scriptUrl && document) {\n\tif (document.currentScript)\n\t\tscriptUrl = document.currentScript.src;\n\tif (!scriptUrl) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tif(scripts.length) {\n\t\t\tvar i = scripts.length - 1;\n\t\t\twhile (i > -1 && !scriptUrl) scriptUrl = scripts[i--].src;\n\t\t}\n\t}\n}\n// When supporting browsers where an automatic publicPath is not supported you must specify an output.publicPath manually via configuration\n// or pass an empty string (\"\") and set the __webpack_public_path__ variable from your code to use your own logic.\nif (!scriptUrl) throw new Error(\"Automatic publicPath is not supported in this browser\");\nscriptUrl = scriptUrl.replace(/#.*$/, \"\").replace(/\\?.*$/, \"\").replace(/\\/[^\\/]+$/, \"/\");\n__webpack_require__.p = scriptUrl;","__webpack_require__.b = self.location + \"\";\n\n// object to store loaded chunks\n// \"1\" means \"already loaded\"\nvar installedChunks = {\n\t918: 1\n};\n\n// importScripts chunk loading\nvar installChunk = (data) => {\n\tvar [chunkIds, moreModules, runtime] = data;\n\tfor(var moduleId in moreModules) {\n\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t}\n\t}\n\tif(runtime) runtime(__webpack_require__);\n\twhile(chunkIds.length)\n\t\tinstalledChunks[chunkIds.pop()] = 1;\n\tparentChunkLoadingFunction(data);\n};\n__webpack_require__.f.i = (chunkId, promises) => {\n\t// \"1\" is the signal for \"already loaded\"\n\tif(!installedChunks[chunkId]) {\n\t\tif(true) { // all chunks have JS\n\t\t\timportScripts(__webpack_require__.p + __webpack_require__.u(chunkId));\n\t\t}\n\t}\n};\n\nvar chunkLoadingGlobal = this[\"webpackChunk\"] = this[\"webpackChunk\"] || [];\nvar parentChunkLoadingFunction = chunkLoadingGlobal.push.bind(chunkLoadingGlobal);\nchunkLoadingGlobal.push = installChunk;\n\n// no HMR\n\n// no HMR manifest","// run startup\nvar __webpack_exports__ = __webpack_require__.x();\n"],"names":["root","factory","exports","module","define","amd","this","deferred","leafPrototypes","getProto","next","async","imageFrame","pixelData","arrayBuffer","buffer","offset","byteOffset","length","bitsAllocated","slice","pixelRepresentation","Uint16Array","Int16Array","Float32Array","i","val","planarConfiguration","frameData","frameSize","rows","columns","outFrame","ArrayBuffer","samplesPerPixel","header","DataView","data","Int8Array","out","outIndex","numSegments","getInt32","s","inIndex","maxIndex","endOfSegment","n","value","j","Uint8Array","decode8Planar","decode8","highByte","decode16","Error","libjpegTurboWasm","URL","local","codec","undefined","decoder","compressedImageFrame","imageInfo","Promise","resolve","libjpegTurboModule","libjpegTurboFactory","locateFile","f","endsWith","toString","reject","then","instance","JPEGDecoder","initLibjpegTurbo","getEncodedBuffer","set","decode","frameInfo","getFrameInfo","decodedPixelsInWASM","getDecodedBuffer","encodedImageInfo","width","height","bitsPerPixel","bitsPerSample","signed","bytesPerPixel","componentsPerPixel","componentCount","decodedBuffer","isSigned","byteLength","getPixelData","encodeOptions","JpegImage","decodeConfig","jpeg","parse","colorTransform","getData","getData16","lossless","Decoder","byteOutput","decompressedData","charlsWasm","charlsModule","charlsFactory","JpegLSDecoder","initialize","interleaveMode","getInterleaveMode","nearLossless","getNearLossless","error","exception","getExceptionMessage","openjpegWasm","openJpegModule","openJpegFactory","J2KDecoder","encodedBufferInWASM","decodedBufferInWASM","imageOffset","getImageOffset","x","y","numDecompositions","getNumDecompositions","numLayers","getNumLayers","progessionOrder","getProgressionOrder","reversible","getIsReversible","blockDimensions","getBlockDimensions","tileSize","getTileSize","tileOffset","getTileOffset","getColorSpace","decodedSize","toLocaleString","compressionRatio","toFixed","openjphWasm","openJphModule","openJphFactory","HTJ2KDecoder","decodeLevel","decodeSubResolution","decompositionLevel","frameWidth","frameHeight","result","Math","ceil","calculateSizeAtDecompositionLevel","b","pixelDataArrayBuffer","constructor","storedPixelData","storedPixel","min","max","numPixels","index","imageUtils","bilinear","src","dest","srcRows","srcColumns","srcData","xSrc1Off","xSrc2Off","xFrac","xSrc","floor","ySrc","ySrc1Off","ySrc2Off","yFrac","yFracInv","yOff","p00","p10","p01","p11","xFracInv","replicate","sample","decodeImageFrame","transferSyntax","options","callbackFn","start","Date","getTime","opts","decodePromise","decodeLittleEndian","decodeBigEndian","decodeRLE","decodeJPEGBaseline8Bit","decodeJPEGBaseline12Bit","decodeJPEGLossless","decodeJPEGLS","decodeJPEG2000","decodeHTJ2K","postProcessed","use16BitDataType","shouldShift","shift","bitsStored","pixelDataArray","pixelDataLength","minBeforeScale","maxBeforeScale","getMinMax","typedArrayConstructors","type","targetBuffer","canRenderFloat","allowFloatRendering","invalidType","photoMetricInterpretation","photometricInterpretation","willScale","preScale","enabled","hasFloatRescale","Object","values","scalingParameters","some","v","Number","isInteger","disableScale","rawOffset","rawLength","TypedArrayConstructor","typedLength","createDestinationImage","scalingType","assign","scaleImageFrame","imageFrameLength","imageFramePixelData","typedArray","_handleTargetBuffer","_validateScalingParameters","rescaleSlope","rescaleIntercept","scaledMin","scaledMax","_getDefaultPixelDataArray","_handlePreScaleSetup","minAfterScale","maxAfterScale","array","arrayLength","suvbw","modality","applyModalityLUT","scaled","hasTargetBuffer","isSharedArrayBuffer","end","decodeTimeInMS","postProcessDecodedPixels","pixelDataType","getPixelDataTypeFromMinMax","obj","decodeTask","expose","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","call","m","__webpack_exports__","O","chunkIds","fn","priority","notFulfilled","Infinity","fulfilled","keys","every","key","splice","r","getter","__esModule","d","a","getPrototypeOf","t","mode","ns","create","def","current","indexOf","getOwnPropertyNames","forEach","definition","o","defineProperty","enumerable","get","e","chunkId","all","reduce","promises","u","g","globalThis","Function","window","prop","prototype","hasOwnProperty","Symbol","toStringTag","scriptUrl","importScripts","location","document","currentScript","scripts","getElementsByTagName","replace","p","self","installedChunks","chunkLoadingGlobal","parentChunkLoadingFunction","push","bind","moreModules","runtime","pop"],"sourceRoot":""}
@@ -1,2 +1,2 @@
1
- !function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("@cornerstonejs/core"),require("dicom-parser")):"function"==typeof define&&define.amd?define("cornerstoneDICOMImageLoader",["@cornerstonejs/core","dicom-parser"],t):"object"==typeof exports?exports.cornerstoneDICOMImageLoader=t(require("@cornerstonejs/core"),require("dicom-parser")):e.cornerstoneDICOMImageLoader=t(e["@cornerstonejs/core"],e.dicomParser)}(this,((e,t)=>(()=>{"use strict";var r={578:(e,t,r)=>{const n=r(823),a=r(187),o=r(592),i=r(604),s=r(249),l=r(968),c=Object.prototype.toString,{Z_NO_FLUSH:u,Z_FINISH:f,Z_OK:d,Z_STREAM_END:m,Z_NEED_DICT:g,Z_STREAM_ERROR:h,Z_DATA_ERROR:p,Z_MEM_ERROR:x}=r(684);function b(e){this.options=a.assign({chunkSize:65536,windowBits:15,to:""},e||{});const t=this.options;t.raw&&t.windowBits>=0&&t.windowBits<16&&(t.windowBits=-t.windowBits,0===t.windowBits&&(t.windowBits=-15)),!(t.windowBits>=0&&t.windowBits<16)||e&&e.windowBits||(t.windowBits+=32),t.windowBits>15&&t.windowBits<48&&(15&t.windowBits||(t.windowBits|=15)),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new s,this.strm.avail_out=0;let r=n.inflateInit2(this.strm,t.windowBits);if(r!==d)throw new Error(i[r]);if(this.header=new l,n.inflateGetHeader(this.strm,this.header),t.dictionary&&("string"==typeof t.dictionary?t.dictionary=o.string2buf(t.dictionary):"[object ArrayBuffer]"===c.call(t.dictionary)&&(t.dictionary=new Uint8Array(t.dictionary)),t.raw&&(r=n.inflateSetDictionary(this.strm,t.dictionary),r!==d)))throw new Error(i[r])}function w(e,t){const r=new b(t);if(r.push(e),r.err)throw r.msg||i[r.err];return r.result}b.prototype.push=function(e,t){const r=this.strm,a=this.options.chunkSize,i=this.options.dictionary;let s,l,b;if(this.ended)return!1;for(l=t===~~t?t:!0===t?f:u,"[object ArrayBuffer]"===c.call(e)?r.input=new Uint8Array(e):r.input=e,r.next_in=0,r.avail_in=r.input.length;;){for(0===r.avail_out&&(r.output=new Uint8Array(a),r.next_out=0,r.avail_out=a),s=n.inflate(r,l),s===g&&i&&(s=n.inflateSetDictionary(r,i),s===d?s=n.inflate(r,l):s===p&&(s=g));r.avail_in>0&&s===m&&r.state.wrap>0&&0!==e[r.next_in];)n.inflateReset(r),s=n.inflate(r,l);switch(s){case h:case p:case g:case x:return this.onEnd(s),this.ended=!0,!1}if(b=r.avail_out,r.next_out&&(0===r.avail_out||s===m))if("string"===this.options.to){let e=o.utf8border(r.output,r.next_out),t=r.next_out-e,n=o.buf2string(r.output,e);r.next_out=t,r.avail_out=a-t,t&&r.output.set(r.output.subarray(e,e+t),0),this.onData(n)}else this.onData(r.output.length===r.next_out?r.output:r.output.subarray(0,r.next_out));if(s!==d||0!==b){if(s===m)return s=n.inflateEnd(this.strm),this.onEnd(s),this.ended=!0,!0;if(0===r.avail_in)break}}return!0},b.prototype.onData=function(e){this.chunks.push(e)},b.prototype.onEnd=function(e){e===d&&("string"===this.options.to?this.result=this.chunks.join(""):this.result=a.flattenChunks(this.chunks)),this.chunks=[],this.err=e,this.msg=this.strm.msg},e.exports.Hq=function(e,t){return(t=t||{}).raw=!0,w(e,t)},r(684)},187:e=>{const t=(e,t)=>Object.prototype.hasOwnProperty.call(e,t);e.exports.assign=function(e){const r=Array.prototype.slice.call(arguments,1);for(;r.length;){const n=r.shift();if(n){if("object"!=typeof n)throw new TypeError(n+"must be non-object");for(const r in n)t(n,r)&&(e[r]=n[r])}}return e},e.exports.flattenChunks=e=>{let t=0;for(let r=0,n=e.length;r<n;r++)t+=e[r].length;const r=new Uint8Array(t);for(let t=0,n=0,a=e.length;t<a;t++){let a=e[t];r.set(a,n),n+=a.length}return r}},592:e=>{let t=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch(e){t=!1}const r=new Uint8Array(256);for(let e=0;e<256;e++)r[e]=e>=252?6:e>=248?5:e>=240?4:e>=224?3:e>=192?2:1;r[254]=r[254]=1,e.exports.string2buf=e=>{if("function"==typeof TextEncoder&&TextEncoder.prototype.encode)return(new TextEncoder).encode(e);let t,r,n,a,o,i=e.length,s=0;for(a=0;a<i;a++)r=e.charCodeAt(a),55296==(64512&r)&&a+1<i&&(n=e.charCodeAt(a+1),56320==(64512&n)&&(r=65536+(r-55296<<10)+(n-56320),a++)),s+=r<128?1:r<2048?2:r<65536?3:4;for(t=new Uint8Array(s),o=0,a=0;o<s;a++)r=e.charCodeAt(a),55296==(64512&r)&&a+1<i&&(n=e.charCodeAt(a+1),56320==(64512&n)&&(r=65536+(r-55296<<10)+(n-56320),a++)),r<128?t[o++]=r:r<2048?(t[o++]=192|r>>>6,t[o++]=128|63&r):r<65536?(t[o++]=224|r>>>12,t[o++]=128|r>>>6&63,t[o++]=128|63&r):(t[o++]=240|r>>>18,t[o++]=128|r>>>12&63,t[o++]=128|r>>>6&63,t[o++]=128|63&r);return t};e.exports.buf2string=(e,n)=>{const a=n||e.length;if("function"==typeof TextDecoder&&TextDecoder.prototype.decode)return(new TextDecoder).decode(e.subarray(0,n));let o,i;const s=new Array(2*a);for(i=0,o=0;o<a;){let t=e[o++];if(t<128){s[i++]=t;continue}let n=r[t];if(n>4)s[i++]=65533,o+=n-1;else{for(t&=2===n?31:3===n?15:7;n>1&&o<a;)t=t<<6|63&e[o++],n--;n>1?s[i++]=65533:t<65536?s[i++]=t:(t-=65536,s[i++]=55296|t>>10&1023,s[i++]=56320|1023&t)}}return((e,r)=>{if(r<65534&&e.subarray&&t)return String.fromCharCode.apply(null,e.length===r?e:e.subarray(0,r));let n="";for(let t=0;t<r;t++)n+=String.fromCharCode(e[t]);return n})(s,i)},e.exports.utf8border=(e,t)=>{(t=t||e.length)>e.length&&(t=e.length);let n=t-1;for(;n>=0&&128==(192&e[n]);)n--;return n<0||0===n?t:n+r[e[n]]>t?n:t}},693:e=>{e.exports=(e,t,r,n)=>{let a=65535&e,o=e>>>16&65535,i=0;for(;0!==r;){i=r>2e3?2e3:r,r-=i;do{a=a+t[n++]|0,o=o+a|0}while(--i);a%=65521,o%=65521}return a|o<<16}},684:e=>{e.exports={Z_NO_FLUSH:0,Z_PARTIAL_FLUSH:1,Z_SYNC_FLUSH:2,Z_FULL_FLUSH:3,Z_FINISH:4,Z_BLOCK:5,Z_TREES:6,Z_OK:0,Z_STREAM_END:1,Z_NEED_DICT:2,Z_ERRNO:-1,Z_STREAM_ERROR:-2,Z_DATA_ERROR:-3,Z_MEM_ERROR:-4,Z_BUF_ERROR:-5,Z_NO_COMPRESSION:0,Z_BEST_SPEED:1,Z_BEST_COMPRESSION:9,Z_DEFAULT_COMPRESSION:-1,Z_FILTERED:1,Z_HUFFMAN_ONLY:2,Z_RLE:3,Z_FIXED:4,Z_DEFAULT_STRATEGY:0,Z_BINARY:0,Z_TEXT:1,Z_UNKNOWN:2,Z_DEFLATED:8}},863:e=>{const t=new Uint32Array((()=>{let e,t=[];for(var r=0;r<256;r++){e=r;for(var n=0;n<8;n++)e=1&e?3988292384^e>>>1:e>>>1;t[r]=e}return t})());e.exports=(e,r,n,a)=>{const o=t,i=a+n;e^=-1;for(let t=a;t<i;t++)e=e>>>8^o[255&(e^r[t])];return~e}},968:e=>{e.exports=function(){this.text=0,this.time=0,this.xflags=0,this.os=0,this.extra=null,this.extra_len=0,this.name="",this.comment="",this.hcrc=0,this.done=!1}},365:e=>{const t=16209;e.exports=function(e,r){let n,a,o,i,s,l,c,u,f,d,m,g,h,p,x,b,w,y,S,D,P,T,v,I;const k=e.state;n=e.next_in,v=e.input,a=n+(e.avail_in-5),o=e.next_out,I=e.output,i=o-(r-e.avail_out),s=o+(e.avail_out-257),l=k.dmax,c=k.wsize,u=k.whave,f=k.wnext,d=k.window,m=k.hold,g=k.bits,h=k.lencode,p=k.distcode,x=(1<<k.lenbits)-1,b=(1<<k.distbits)-1;e:do{g<15&&(m+=v[n++]<<g,g+=8,m+=v[n++]<<g,g+=8),w=h[m&x];t:for(;;){if(y=w>>>24,m>>>=y,g-=y,y=w>>>16&255,0===y)I[o++]=65535&w;else{if(!(16&y)){if(64&y){if(32&y){k.mode=16191;break e}e.msg="invalid literal/length code",k.mode=t;break e}w=h[(65535&w)+(m&(1<<y)-1)];continue t}for(S=65535&w,y&=15,y&&(g<y&&(m+=v[n++]<<g,g+=8),S+=m&(1<<y)-1,m>>>=y,g-=y),g<15&&(m+=v[n++]<<g,g+=8,m+=v[n++]<<g,g+=8),w=p[m&b];;){if(y=w>>>24,m>>>=y,g-=y,y=w>>>16&255,16&y){if(D=65535&w,y&=15,g<y&&(m+=v[n++]<<g,g+=8,g<y&&(m+=v[n++]<<g,g+=8)),D+=m&(1<<y)-1,D>l){e.msg="invalid distance too far back",k.mode=t;break e}if(m>>>=y,g-=y,y=o-i,D>y){if(y=D-y,y>u&&k.sane){e.msg="invalid distance too far back",k.mode=t;break e}if(P=0,T=d,0===f){if(P+=c-y,y<S){S-=y;do{I[o++]=d[P++]}while(--y);P=o-D,T=I}}else if(f<y){if(P+=c+f-y,y-=f,y<S){S-=y;do{I[o++]=d[P++]}while(--y);if(P=0,f<S){y=f,S-=y;do{I[o++]=d[P++]}while(--y);P=o-D,T=I}}}else if(P+=f-y,y<S){S-=y;do{I[o++]=d[P++]}while(--y);P=o-D,T=I}for(;S>2;)I[o++]=T[P++],I[o++]=T[P++],I[o++]=T[P++],S-=3;S&&(I[o++]=T[P++],S>1&&(I[o++]=T[P++]))}else{P=o-D;do{I[o++]=I[P++],I[o++]=I[P++],I[o++]=I[P++],S-=3}while(S>2);S&&(I[o++]=I[P++],S>1&&(I[o++]=I[P++]))}break}if(64&y){e.msg="invalid distance code",k.mode=t;break e}w=p[(65535&w)+(m&(1<<y)-1)]}}break}}while(n<a&&o<s);S=g>>3,n-=S,g-=S<<3,m&=(1<<g)-1,e.next_in=n,e.next_out=o,e.avail_in=n<a?a-n+5:5-(n-a),e.avail_out=o<s?s-o+257:257-(o-s),k.hold=m,k.bits=g}},823:(e,t,r)=>{const n=r(693),a=r(863),o=r(365),i=r(446),{Z_FINISH:s,Z_BLOCK:l,Z_TREES:c,Z_OK:u,Z_STREAM_END:f,Z_NEED_DICT:d,Z_STREAM_ERROR:m,Z_DATA_ERROR:g,Z_MEM_ERROR:h,Z_BUF_ERROR:p,Z_DEFLATED:x}=r(684),b=16180,w=16190,y=16191,S=16192,D=16194,P=16199,T=16200,v=16206,I=16209,k=16210,E=e=>(e>>>24&255)+(e>>>8&65280)+((65280&e)<<8)+((255&e)<<24);function A(){this.strm=null,this.mode=0,this.last=!1,this.wrap=0,this.havedict=!1,this.flags=0,this.dmax=0,this.check=0,this.total=0,this.head=null,this.wbits=0,this.wsize=0,this.whave=0,this.wnext=0,this.window=null,this.hold=0,this.bits=0,this.length=0,this.offset=0,this.extra=0,this.lencode=null,this.distcode=null,this.lenbits=0,this.distbits=0,this.ncode=0,this.nlen=0,this.ndist=0,this.have=0,this.next=null,this.lens=new Uint16Array(320),this.work=new Uint16Array(288),this.lendyn=null,this.distdyn=null,this.sane=0,this.back=0,this.was=0}const _=e=>{if(!e)return 1;const t=e.state;return!t||t.strm!==e||t.mode<b||t.mode>16211?1:0},L=e=>{if(_(e))return m;const t=e.state;return e.total_in=e.total_out=t.total=0,e.msg="",t.wrap&&(e.adler=1&t.wrap),t.mode=b,t.last=0,t.havedict=0,t.flags=-1,t.dmax=32768,t.head=null,t.hold=0,t.bits=0,t.lencode=t.lendyn=new Int32Array(852),t.distcode=t.distdyn=new Int32Array(592),t.sane=1,t.back=-1,u},C=e=>{if(_(e))return m;const t=e.state;return t.wsize=0,t.whave=0,t.wnext=0,L(e)},O=(e,t)=>{let r;if(_(e))return m;const n=e.state;return t<0?(r=0,t=-t):(r=5+(t>>4),t<48&&(t&=15)),t&&(t<8||t>15)?m:(null!==n.window&&n.wbits!==t&&(n.window=null),n.wrap=r,n.wbits=t,C(e))},R=(e,t)=>{if(!e)return m;const r=new A;e.state=r,r.strm=e,r.window=null,r.mode=b;const n=O(e,t);return n!==u&&(e.state=null),n};let M,F,B=!0;const U=e=>{if(B){M=new Int32Array(512),F=new Int32Array(32);let t=0;for(;t<144;)e.lens[t++]=8;for(;t<256;)e.lens[t++]=9;for(;t<280;)e.lens[t++]=7;for(;t<288;)e.lens[t++]=8;for(i(1,e.lens,0,288,M,0,e.work,{bits:9}),t=0;t<32;)e.lens[t++]=5;i(2,e.lens,0,32,F,0,e.work,{bits:5}),B=!1}e.lencode=M,e.lenbits=9,e.distcode=F,e.distbits=5},N=(e,t,r,n)=>{let a;const o=e.state;return null===o.window&&(o.wsize=1<<o.wbits,o.wnext=0,o.whave=0,o.window=new Uint8Array(o.wsize)),n>=o.wsize?(o.window.set(t.subarray(r-o.wsize,r),0),o.wnext=0,o.whave=o.wsize):(a=o.wsize-o.wnext,a>n&&(a=n),o.window.set(t.subarray(r-n,r-n+a),o.wnext),(n-=a)?(o.window.set(t.subarray(r-n,r),0),o.wnext=n,o.whave=o.wsize):(o.wnext+=a,o.wnext===o.wsize&&(o.wnext=0),o.whave<o.wsize&&(o.whave+=a))),0};e.exports.inflateReset=C,e.exports.inflateReset2=O,e.exports.inflateResetKeep=L,e.exports.inflateInit=e=>R(e,15),e.exports.inflateInit2=R,e.exports.inflate=(e,t)=>{let r,A,L,C,O,R,M,F,B,j,$,G,V,q,Z,Y,z,H,W,X,Q,K,J=0;const ee=new Uint8Array(4);let te,re;const ne=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]);if(_(e)||!e.output||!e.input&&0!==e.avail_in)return m;r=e.state,r.mode===y&&(r.mode=S),O=e.next_out,L=e.output,M=e.avail_out,C=e.next_in,A=e.input,R=e.avail_in,F=r.hold,B=r.bits,j=R,$=M,K=u;e:for(;;)switch(r.mode){case b:if(0===r.wrap){r.mode=S;break}for(;B<16;){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}if(2&r.wrap&&35615===F){0===r.wbits&&(r.wbits=15),r.check=0,ee[0]=255&F,ee[1]=F>>>8&255,r.check=a(r.check,ee,2,0),F=0,B=0,r.mode=16181;break}if(r.head&&(r.head.done=!1),!(1&r.wrap)||(((255&F)<<8)+(F>>8))%31){e.msg="incorrect header check",r.mode=I;break}if((15&F)!==x){e.msg="unknown compression method",r.mode=I;break}if(F>>>=4,B-=4,Q=8+(15&F),0===r.wbits&&(r.wbits=Q),Q>15||Q>r.wbits){e.msg="invalid window size",r.mode=I;break}r.dmax=1<<r.wbits,r.flags=0,e.adler=r.check=1,r.mode=512&F?16189:y,F=0,B=0;break;case 16181:for(;B<16;){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}if(r.flags=F,(255&r.flags)!==x){e.msg="unknown compression method",r.mode=I;break}if(57344&r.flags){e.msg="unknown header flags set",r.mode=I;break}r.head&&(r.head.text=F>>8&1),512&r.flags&&4&r.wrap&&(ee[0]=255&F,ee[1]=F>>>8&255,r.check=a(r.check,ee,2,0)),F=0,B=0,r.mode=16182;case 16182:for(;B<32;){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}r.head&&(r.head.time=F),512&r.flags&&4&r.wrap&&(ee[0]=255&F,ee[1]=F>>>8&255,ee[2]=F>>>16&255,ee[3]=F>>>24&255,r.check=a(r.check,ee,4,0)),F=0,B=0,r.mode=16183;case 16183:for(;B<16;){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}r.head&&(r.head.xflags=255&F,r.head.os=F>>8),512&r.flags&&4&r.wrap&&(ee[0]=255&F,ee[1]=F>>>8&255,r.check=a(r.check,ee,2,0)),F=0,B=0,r.mode=16184;case 16184:if(1024&r.flags){for(;B<16;){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}r.length=F,r.head&&(r.head.extra_len=F),512&r.flags&&4&r.wrap&&(ee[0]=255&F,ee[1]=F>>>8&255,r.check=a(r.check,ee,2,0)),F=0,B=0}else r.head&&(r.head.extra=null);r.mode=16185;case 16185:if(1024&r.flags&&(G=r.length,G>R&&(G=R),G&&(r.head&&(Q=r.head.extra_len-r.length,r.head.extra||(r.head.extra=new Uint8Array(r.head.extra_len)),r.head.extra.set(A.subarray(C,C+G),Q)),512&r.flags&&4&r.wrap&&(r.check=a(r.check,A,G,C)),R-=G,C+=G,r.length-=G),r.length))break e;r.length=0,r.mode=16186;case 16186:if(2048&r.flags){if(0===R)break e;G=0;do{Q=A[C+G++],r.head&&Q&&r.length<65536&&(r.head.name+=String.fromCharCode(Q))}while(Q&&G<R);if(512&r.flags&&4&r.wrap&&(r.check=a(r.check,A,G,C)),R-=G,C+=G,Q)break e}else r.head&&(r.head.name=null);r.length=0,r.mode=16187;case 16187:if(4096&r.flags){if(0===R)break e;G=0;do{Q=A[C+G++],r.head&&Q&&r.length<65536&&(r.head.comment+=String.fromCharCode(Q))}while(Q&&G<R);if(512&r.flags&&4&r.wrap&&(r.check=a(r.check,A,G,C)),R-=G,C+=G,Q)break e}else r.head&&(r.head.comment=null);r.mode=16188;case 16188:if(512&r.flags){for(;B<16;){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}if(4&r.wrap&&F!==(65535&r.check)){e.msg="header crc mismatch",r.mode=I;break}F=0,B=0}r.head&&(r.head.hcrc=r.flags>>9&1,r.head.done=!0),e.adler=r.check=0,r.mode=y;break;case 16189:for(;B<32;){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}e.adler=r.check=E(F),F=0,B=0,r.mode=w;case w:if(0===r.havedict)return e.next_out=O,e.avail_out=M,e.next_in=C,e.avail_in=R,r.hold=F,r.bits=B,d;e.adler=r.check=1,r.mode=y;case y:if(t===l||t===c)break e;case S:if(r.last){F>>>=7&B,B-=7&B,r.mode=v;break}for(;B<3;){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}switch(r.last=1&F,F>>>=1,B-=1,3&F){case 0:r.mode=16193;break;case 1:if(U(r),r.mode=P,t===c){F>>>=2,B-=2;break e}break;case 2:r.mode=16196;break;case 3:e.msg="invalid block type",r.mode=I}F>>>=2,B-=2;break;case 16193:for(F>>>=7&B,B-=7&B;B<32;){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}if((65535&F)!=(F>>>16^65535)){e.msg="invalid stored block lengths",r.mode=I;break}if(r.length=65535&F,F=0,B=0,r.mode=D,t===c)break e;case D:r.mode=16195;case 16195:if(G=r.length,G){if(G>R&&(G=R),G>M&&(G=M),0===G)break e;L.set(A.subarray(C,C+G),O),R-=G,C+=G,M-=G,O+=G,r.length-=G;break}r.mode=y;break;case 16196:for(;B<14;){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}if(r.nlen=257+(31&F),F>>>=5,B-=5,r.ndist=1+(31&F),F>>>=5,B-=5,r.ncode=4+(15&F),F>>>=4,B-=4,r.nlen>286||r.ndist>30){e.msg="too many length or distance symbols",r.mode=I;break}r.have=0,r.mode=16197;case 16197:for(;r.have<r.ncode;){for(;B<3;){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}r.lens[ne[r.have++]]=7&F,F>>>=3,B-=3}for(;r.have<19;)r.lens[ne[r.have++]]=0;if(r.lencode=r.lendyn,r.lenbits=7,te={bits:r.lenbits},K=i(0,r.lens,0,19,r.lencode,0,r.work,te),r.lenbits=te.bits,K){e.msg="invalid code lengths set",r.mode=I;break}r.have=0,r.mode=16198;case 16198:for(;r.have<r.nlen+r.ndist;){for(;J=r.lencode[F&(1<<r.lenbits)-1],Z=J>>>24,Y=J>>>16&255,z=65535&J,!(Z<=B);){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}if(z<16)F>>>=Z,B-=Z,r.lens[r.have++]=z;else{if(16===z){for(re=Z+2;B<re;){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}if(F>>>=Z,B-=Z,0===r.have){e.msg="invalid bit length repeat",r.mode=I;break}Q=r.lens[r.have-1],G=3+(3&F),F>>>=2,B-=2}else if(17===z){for(re=Z+3;B<re;){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}F>>>=Z,B-=Z,Q=0,G=3+(7&F),F>>>=3,B-=3}else{for(re=Z+7;B<re;){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}F>>>=Z,B-=Z,Q=0,G=11+(127&F),F>>>=7,B-=7}if(r.have+G>r.nlen+r.ndist){e.msg="invalid bit length repeat",r.mode=I;break}for(;G--;)r.lens[r.have++]=Q}}if(r.mode===I)break;if(0===r.lens[256]){e.msg="invalid code -- missing end-of-block",r.mode=I;break}if(r.lenbits=9,te={bits:r.lenbits},K=i(1,r.lens,0,r.nlen,r.lencode,0,r.work,te),r.lenbits=te.bits,K){e.msg="invalid literal/lengths set",r.mode=I;break}if(r.distbits=6,r.distcode=r.distdyn,te={bits:r.distbits},K=i(2,r.lens,r.nlen,r.ndist,r.distcode,0,r.work,te),r.distbits=te.bits,K){e.msg="invalid distances set",r.mode=I;break}if(r.mode=P,t===c)break e;case P:r.mode=T;case T:if(R>=6&&M>=258){e.next_out=O,e.avail_out=M,e.next_in=C,e.avail_in=R,r.hold=F,r.bits=B,o(e,$),O=e.next_out,L=e.output,M=e.avail_out,C=e.next_in,A=e.input,R=e.avail_in,F=r.hold,B=r.bits,r.mode===y&&(r.back=-1);break}for(r.back=0;J=r.lencode[F&(1<<r.lenbits)-1],Z=J>>>24,Y=J>>>16&255,z=65535&J,!(Z<=B);){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}if(Y&&!(240&Y)){for(H=Z,W=Y,X=z;J=r.lencode[X+((F&(1<<H+W)-1)>>H)],Z=J>>>24,Y=J>>>16&255,z=65535&J,!(H+Z<=B);){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}F>>>=H,B-=H,r.back+=H}if(F>>>=Z,B-=Z,r.back+=Z,r.length=z,0===Y){r.mode=16205;break}if(32&Y){r.back=-1,r.mode=y;break}if(64&Y){e.msg="invalid literal/length code",r.mode=I;break}r.extra=15&Y,r.mode=16201;case 16201:if(r.extra){for(re=r.extra;B<re;){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}r.length+=F&(1<<r.extra)-1,F>>>=r.extra,B-=r.extra,r.back+=r.extra}r.was=r.length,r.mode=16202;case 16202:for(;J=r.distcode[F&(1<<r.distbits)-1],Z=J>>>24,Y=J>>>16&255,z=65535&J,!(Z<=B);){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}if(!(240&Y)){for(H=Z,W=Y,X=z;J=r.distcode[X+((F&(1<<H+W)-1)>>H)],Z=J>>>24,Y=J>>>16&255,z=65535&J,!(H+Z<=B);){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}F>>>=H,B-=H,r.back+=H}if(F>>>=Z,B-=Z,r.back+=Z,64&Y){e.msg="invalid distance code",r.mode=I;break}r.offset=z,r.extra=15&Y,r.mode=16203;case 16203:if(r.extra){for(re=r.extra;B<re;){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}r.offset+=F&(1<<r.extra)-1,F>>>=r.extra,B-=r.extra,r.back+=r.extra}if(r.offset>r.dmax){e.msg="invalid distance too far back",r.mode=I;break}r.mode=16204;case 16204:if(0===M)break e;if(G=$-M,r.offset>G){if(G=r.offset-G,G>r.whave&&r.sane){e.msg="invalid distance too far back",r.mode=I;break}G>r.wnext?(G-=r.wnext,V=r.wsize-G):V=r.wnext-G,G>r.length&&(G=r.length),q=r.window}else q=L,V=O-r.offset,G=r.length;G>M&&(G=M),M-=G,r.length-=G;do{L[O++]=q[V++]}while(--G);0===r.length&&(r.mode=T);break;case 16205:if(0===M)break e;L[O++]=r.length,M--,r.mode=T;break;case v:if(r.wrap){for(;B<32;){if(0===R)break e;R--,F|=A[C++]<<B,B+=8}if($-=M,e.total_out+=$,r.total+=$,4&r.wrap&&$&&(e.adler=r.check=r.flags?a(r.check,L,$,O-$):n(r.check,L,$,O-$)),$=M,4&r.wrap&&(r.flags?F:E(F))!==r.check){e.msg="incorrect data check",r.mode=I;break}F=0,B=0}r.mode=16207;case 16207:if(r.wrap&&r.flags){for(;B<32;){if(0===R)break e;R--,F+=A[C++]<<B,B+=8}if(4&r.wrap&&F!==(4294967295&r.total)){e.msg="incorrect length check",r.mode=I;break}F=0,B=0}r.mode=16208;case 16208:K=f;break e;case I:K=g;break e;case k:return h;default:return m}return e.next_out=O,e.avail_out=M,e.next_in=C,e.avail_in=R,r.hold=F,r.bits=B,(r.wsize||$!==e.avail_out&&r.mode<I&&(r.mode<v||t!==s))&&N(e,e.output,e.next_out,$-e.avail_out)?(r.mode=k,h):(j-=e.avail_in,$-=e.avail_out,e.total_in+=j,e.total_out+=$,r.total+=$,4&r.wrap&&$&&(e.adler=r.check=r.flags?a(r.check,L,$,e.next_out-$):n(r.check,L,$,e.next_out-$)),e.data_type=r.bits+(r.last?64:0)+(r.mode===y?128:0)+(r.mode===P||r.mode===D?256:0),(0===j&&0===$||t===s)&&K===u&&(K=p),K)},e.exports.inflateEnd=e=>{if(_(e))return m;let t=e.state;return t.window&&(t.window=null),e.state=null,u},e.exports.inflateGetHeader=(e,t)=>{if(_(e))return m;const r=e.state;return 2&r.wrap?(r.head=t,t.done=!1,u):m},e.exports.inflateSetDictionary=(e,t)=>{const r=t.length;let a,o,i;return _(e)?m:(a=e.state,0!==a.wrap&&a.mode!==w?m:a.mode===w&&(o=1,o=n(o,t,r,0),o!==a.check)?g:(i=N(e,t,r,r),i?(a.mode=k,h):(a.havedict=1,u)))},e.exports.inflateInfo="pako inflate (from Nodeca project)"},446:e=>{const t=15,r=new Uint16Array([3,4,5,6,7,8,9,10,11,13,15,17,19,23,27,31,35,43,51,59,67,83,99,115,131,163,195,227,258,0,0]),n=new Uint8Array([16,16,16,16,16,16,16,16,17,17,17,17,18,18,18,18,19,19,19,19,20,20,20,20,21,21,21,21,16,72,78]),a=new Uint16Array([1,2,3,4,5,7,9,13,17,25,33,49,65,97,129,193,257,385,513,769,1025,1537,2049,3073,4097,6145,8193,12289,16385,24577,0,0]),o=new Uint8Array([16,16,16,16,17,17,18,18,19,19,20,20,21,21,22,22,23,23,24,24,25,25,26,26,27,27,28,28,29,29,64,64]);e.exports=(e,i,s,l,c,u,f,d)=>{const m=d.bits;let g,h,p,x,b,w,y=0,S=0,D=0,P=0,T=0,v=0,I=0,k=0,E=0,A=0,_=null;const L=new Uint16Array(16),C=new Uint16Array(16);let O,R,M,F=null;for(y=0;y<=t;y++)L[y]=0;for(S=0;S<l;S++)L[i[s+S]]++;for(T=m,P=t;P>=1&&0===L[P];P--);if(T>P&&(T=P),0===P)return c[u++]=20971520,c[u++]=20971520,d.bits=1,0;for(D=1;D<P&&0===L[D];D++);for(T<D&&(T=D),k=1,y=1;y<=t;y++)if(k<<=1,k-=L[y],k<0)return-1;if(k>0&&(0===e||1!==P))return-1;for(C[1]=0,y=1;y<t;y++)C[y+1]=C[y]+L[y];for(S=0;S<l;S++)0!==i[s+S]&&(f[C[i[s+S]]++]=S);if(0===e?(_=F=f,w=20):1===e?(_=r,F=n,w=257):(_=a,F=o,w=0),A=0,S=0,y=D,b=u,v=T,I=0,p=-1,E=1<<T,x=E-1,1===e&&E>852||2===e&&E>592)return 1;for(;;){O=y-I,f[S]+1<w?(R=0,M=f[S]):f[S]>=w?(R=F[f[S]-w],M=_[f[S]-w]):(R=96,M=0),g=1<<y-I,h=1<<v,D=h;do{h-=g,c[b+(A>>I)+h]=O<<24|R<<16|M}while(0!==h);for(g=1<<y-1;A&g;)g>>=1;if(0!==g?(A&=g-1,A+=g):A=0,S++,0==--L[y]){if(y===P)break;y=i[s+f[S]]}if(y>T&&(A&x)!==p){for(0===I&&(I=T),b+=D,v=y-I,k=1<<v;v+I<P&&(k-=L[v+I],!(k<=0));)v++,k<<=1;if(E+=1<<v,1===e&&E>852||2===e&&E>592)return 1;p=A&x,c[p]=T<<24|v<<16|b-u}}return 0!==A&&(c[b+A]=y-I<<24|64<<16),d.bits=T,0}},604:e=>{e.exports={2:"need dictionary",1:"stream end",0:"","-1":"file error","-2":"stream error","-3":"data error","-4":"insufficient memory","-5":"buffer error","-6":"incompatible version"}},249:e=>{e.exports=function(){this.input=null,this.next_in=0,this.avail_in=0,this.total_in=0,this.output=null,this.next_out=0,this.avail_out=0,this.total_out=0,this.msg="",this.state=null,this.data_type=2,this.adler=0}},464:t=>{t.exports=e},713:e=>{e.exports=t}},n={};function a(e){var t=n[e];if(void 0!==t)return t.exports;var o=n[e]={exports:{}};return r[e](o,o.exports,a),o.exports}a.m=r,a.d=(e,t)=>{for(var r in t)a.o(t,r)&&!a.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},a.u=e=>e+".min.js",a.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),a.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),a.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},(()=>{var e;a.g.importScripts&&(e=a.g.location+"");var t=a.g.document;if(!e&&t&&(t.currentScript&&(e=t.currentScript.src),!e)){var r=t.getElementsByTagName("script");if(r.length)for(var n=r.length-1;n>-1&&!e;)e=r[n--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),a.p=e})(),a.b=document.baseURI||self.location.href;var o={};return(()=>{function e(e,t,r){if(void 0===e)throw new Error("decodeRGB: rgbBuffer must be defined");if(e.length%3!=0)throw new Error(`decodeRGB: rgbBuffer length ${e.length} must be divisible by 3`);const n=e.length/3;let a=0,o=0;if(r)for(let r=0;r<n;r++)t[o++]=e[a++],t[o++]=e[a++],t[o++]=e[a++],t[o++]=255;else t.set(e)}function t(e,t,r){if(void 0===e)throw new Error("decodeRGB: rgbBuffer must be defined");if(e.length%3!=0)throw new Error(`decodeRGB: rgbBuffer length ${e.length} must be divisible by 3`);const n=e.length/3;let a=0,o=0,i=n,s=2*n;if(r)for(let r=0;r<n;r++)t[a++]=e[o++],t[a++]=e[i++],t[a++]=e[s++],t[a++]=255;else for(let r=0;r<n;r++)t[a++]=e[o++],t[a++]=e[i++],t[a++]=e[s++]}function r(e,t,r){if(void 0===e)throw new Error("convertYBRFullByPixel: ybrBuffer must be defined");if(e.length%3!=0)throw new Error(`convertYBRFullByPixel: ybrBuffer length ${e.length} must be divisible by 3`);const n=e.length/3;let a=0,o=0;if(r)for(let r=0;r<n;r++){const r=e[a++],n=e[a++],i=e[a++];t[o++]=r+1.402*(i-128),t[o++]=r-.34414*(n-128)-.71414*(i-128),t[o++]=r+1.772*(n-128),t[o++]=255}else for(let r=0;r<n;r++){const r=e[a++],n=e[a++],i=e[a++];t[o++]=r+1.402*(i-128),t[o++]=r-.34414*(n-128)-.71414*(i-128),t[o++]=r+1.772*(n-128)}}function n(e,t,r){if(void 0===e)throw new Error("convertYBRFullByPlane: ybrBuffer must be defined");if(e.length%3!=0)throw new Error(`convertYBRFullByPlane: ybrBuffer length ${e.length} must be divisible by 3`);const n=e.length/3;let a=0,o=0,i=n,s=2*n;if(r)for(let r=0;r<n;r++){const r=e[o++],n=e[i++],l=e[s++];t[a++]=r+1.402*(l-128),t[a++]=r-.34414*(n-128)-.71414*(l-128),t[a++]=r+1.772*(n-128),t[a++]=255}else for(let r=0;r<n;r++){const r=e[o++],n=e[i++],l=e[s++];t[a++]=r+1.402*(l-128),t[a++]=r-.34414*(n-128)-.71414*(l-128),t[a++]=r+1.772*(n-128)}}a.r(o),a.d(o,{configure:()=>ct,convertColorSpace:()=>Q,convertPALETTECOLOR:()=>lt,convertRGBColorByPixel:()=>e,convertRGBColorByPlane:()=>t,convertYBRFullByPixel:()=>r,convertYBRFullByPlane:()=>n,createImage:()=>se,decodeJPEGBaseline8BitColor:()=>J,default:()=>ft,external:()=>ot,getImageFrame:()=>ne,getMinMax:()=>W,getPixelData:()=>H,internal:()=>u,isColorImage:()=>ae,isJPEGBaseline8BitColor:()=>ut,wadors:()=>ge,wadouri:()=>Je});let i={open(e,t){e.open("get",t,!0)},beforeSend(){},beforeProcessing:e=>Promise.resolve(e.response),imageCreated(){},strict:!1,decodeConfig:{convertFloatPixelDataToInt:!0,use16BitDataType:!1}};function s(e){i=Object.assign(i,e)}function l(){return i}const c=function(e,t,r={},n={}){const{cornerstone:a}=ot,o=l(),i=e=>{if("function"==typeof o.errorInterceptor){const t=new Error("request failed");t.request=e,t.response=e.response,t.status=e.status,o.errorInterceptor(t)}},s=new XMLHttpRequest,c=new Promise(((l,c)=>{o.open(s,e,r,n);const u=o.beforeSend(s,t,r,n);s.responseType="arraybuffer";const f=Object.assign({},r,u);Object.keys(f).forEach((function(t){null!==f[t]&&("Accept"===t&&-1!==e.indexOf("accept=")||s.setRequestHeader(t,f[t]))})),n.deferred={resolve:l,reject:c},n.url=e,n.imageId=t,s.onloadstart=function(r){o.onloadstart&&o.onloadstart(r,n);const i={url:e,imageId:t};a.triggerEvent(a.events,"cornerstoneimageloadstart",i)},s.onloadend=function(r){o.onloadend&&o.onloadend(r,n);const i={url:e,imageId:t};a.triggerEvent(a.events,"cornerstoneimageloadend",i)},s.onreadystatechange=function(e){o.onreadystatechange?o.onreadystatechange(e,n):4===s.readyState&&(200===s.status||206===s.status?o.beforeProcessing(s).then(l).catch((()=>{i(s),c(s)})):(i(s),c(s)))},s.onprogress=function(e){const t=e.loaded;let r,a;e.lengthComputable&&(r=e.total,a=Math.round(t/r*100)),o.onprogress&&o.onprogress(e,n)},s.onerror=function(){i(s),c(s)},s.onabort=function(){i(s),c(s)},s.send()}));return c.xhr=s,c},u={xhrRequest:c,setOptions:s,getOptions:l};const f=function(e,t,r){return t=t||0,e&&e.Value?e.Value.length<=t?r:e.Value[t]:r};const d=function(e,t,r){const n=f(e,t,r);if(void 0!==n)return parseFloat(n)};const m=function(e,t){const r=f(e,t);if(void 0!==r)return parseFloat(r)};const g=function(e,t){if(!e)return;if(!e.Value)return;if(!Array.isArray(e.Value))return;if(t&&e.Value.length<t)return;const r=[];for(let t=0;t<e.Value.length;t++)r.push(parseFloat(e.Value[t]));return r};function h(e){const t=e.indexOf(":");return e.substring(t+1)}function p(e,t=!0){return e&&e.Value?e.Value[0]&&t?e.Value[0]:e.Value:e}function x(e,t,r){return{shared:(t?Object.values(t[0]):[]).map((e=>e[0])).filter((e=>void 0!==e&&"object"==typeof e)),perFrame:(e?Object.values(e[r-1]):[]).map((e=>e.Value[0])).filter((e=>void 0!==e&&"object"==typeof e))}}function b(e){let{52009230:t,52009229:r,"00280008":n,...a}=e;return t=p(t,!1),r=p(r,!1),n=p(n),{PerFrameFunctionalGroupsSequence:t,SharedFunctionalGroupsSequence:r,NumberOfFrames:n,rest:a}}function w(e){const t=e.indexOf("/frames/")+8,r=e.slice(0,t),n=parseInt(e.slice(t),10);return{metadata:S[`${r}1`],frame:n}}const y={_retrieveMultiframeMetadata:w,retrieveMultiframeMetadata:function(e){return w(h(e))},isMultiframe:function(e){const t=f(e["00280008"]);return t&&t>1}};let S=[],D={};const P={add:function(e,t){const r=h(e);t.isMultiframe=y.isMultiframe(t),S[r]=t},get:function(e){const t=h(e),r=S[t];if(r&&!r?.isMultiframe)return r;const n=D[t];if(n)return n;const a=y._retrieveMultiframeMetadata(t);if(!a||!a.metadata)return;const{metadata:o,frame:i}=a;if(o){const e=function(e,t){const{PerFrameFunctionalGroupsSequence:r,SharedFunctionalGroupsSequence:n,NumberOfFrames:a,rest:o}=b(t);if(r||a>1){const{shared:i,perFrame:s}=x(r,n,e),l=Object.assign(t,{frameNumber:e});return[...i,...s].forEach((e=>{Object.entries(e).forEach((([e,t])=>{l[e]=t}))})),Object.assign(o,{"00280008":a},l)}return t}(i,o);return D[t]=e,e}},remove:function(e){const t=h(e);S[t]=void 0,D[t]=void 0},purge:function(){S=[],D={}}};function T(e){return"RECON TOMO"===e||"RECON GATED TOMO"===e}function v(e){return f(e["00080060"]).includes("NM")}function I(e,t){const r=p(e["00080008"],!1);if(r)return r[t]}function k(e){let t=g(e["00200037"],6);return!t&&v(e)&&(t=function(e){let t;const r=I(e,2);if(r&&T(r)){const r=p(e["00540022"]);r&&(t=g(r["00200037"],6))}return t}(e)),t}function E(e){let t=g(e["00200032"],3);return!t&&v(e)&&(t=function(e){let t;const r=I(e,2);if(r&&T(r)){const r=p(e["00540022"]);r&&(t=g(r["00200032"],3))}return t}(e)),t}function A(e,t,r){const n={};for(const a of r)try{const r=t(a,e);if(r){const e={};for(const t in r)if(t in r){e[_(t)]=r[t]}Object.assign(n,e)}}catch(e){console.error(`Error retrieving ${a} data:`,e)}return n}const _=e=>e.charAt(0).toUpperCase()+e.slice(1),L=["multiframeModule","generalSeriesModule","patientStudyModule","imagePlaneModule","nmMultiframeGeometryModule","imagePixelModule","modalityLutModule","voiLutModule","sopCommonModule","petIsotopeModule","overlayPlaneModule","transferSyntax","petSeriesModule","petImageModule"];function C(e,t){const r=g(e[t]);return r?r[0]:null}const O=function(e){return e?.Value?.length?Array.isArray(e.Value)?e.Value:"object"==typeof e.Value?(console.warn("Warning: Value should be an array, but an object was found. Encapsulating the object in an array."),[e.Value]):[]:[]};function R(e){const t=O(e["00186011"]);if(!t||!t.length)return null;return t.map((e=>{const t=C(e,"0018602C"),r=C(e,"0018602E"),n=C(e,"00186024"),a=C(e,"00186026");return{regionLocationMinY0:C(e,"0018601A"),regionLocationMaxY1:C(e,"0018601E"),regionLocationMinX0:C(e,"00186018"),regionLocationMaxX1:C(e,"0018601C"),referencePixelX0:C(e,"00186020"),referencePixelY0:C(e,"00186022"),physicalDeltaX:t,physicalDeltaY:r,physicalUnitsXDirection:n,physicalUnitsYDirection:a,referencePhysicalPixelValueY:C(e,"0018602A"),referencePhysicalPixelValueX:C(e,"00186028"),regionSpatialFormat:C(e,"00186012"),regionDataType:C(e,"00186014"),regionFlags:C(e,"00186016"),transducerFrequency:C(e,"00186030")}}))}function M(e,t){return{transferSyntaxUID:f(t["00020010"])||f(t["00083002"])}}const F=function e(t,r){const{MetadataModules:n}=ot.cornerstone.Enums,{dicomParser:a}=ot;if(t===n.MULTIFRAME){const{metadata:e,frame:t}=y.retrieveMultiframeMetadata(r);if(!e)return;const{PerFrameFunctionalGroupsSequence:n,SharedFunctionalGroupsSequence:a,NumberOfFrames:o}=b(e);if(n||o>1){const{shared:e,perFrame:r}=x(n,a,t);return{NumberOfFrames:o,PerFrameFunctionalInformation:r,SharedFunctionalInformation:e}}return{NumberOfFrames:o}}const o=P.get(r);if(o){if(t===n.GENERAL_STUDY)return{studyDescription:f(o["00081030"]),studyDate:a.parseDA(f(o["00080020"])),studyTime:a.parseTM(f(o["00080030"],0,"")),accessionNumber:f(o["00080050"])};if(t===n.GENERAL_SERIES)return{modality:f(o["00080060"]),seriesInstanceUID:f(o["0020000E"]),seriesNumber:m(o["00200011"]),studyInstanceUID:f(o["0020000D"]),seriesDate:a.parseDA(f(o["00080021"])),seriesTime:a.parseTM(f(o["00080031"],0,"")),acquisitionDate:a.parseDA(f(o["00080022"])),acquisitionTime:a.parseTM(f(o["00080032"],0,""))};if(t===n.GENERAL_IMAGE)return{sopInstanceUID:f(o["00080018"]),instanceNumber:m(o["00200013"]),lossyImageCompression:f(o["00282110"]),lossyImageCompressionRatio:m(o["00282112"]),lossyImageCompressionMethod:f(o["00282114"])};if(t===n.PATIENT)return{patientID:f(o["00100020"]),patientName:f(o["00100010"])};if(t===n.PATIENT_STUDY)return{patientAge:m(o["00101010"]),patientSize:m(o["00101020"]),patientSex:f(o["00100040"]),patientWeight:m(o["00101030"])};if(t===n.NM_MULTIFRAME_GEOMETRY){const e=f(o["00080060"]),t=I(o,2);return{modality:e,imageType:f(o["00080008"]),imageSubType:t,imageOrientationPatient:k(o),imagePositionPatient:E(o),sliceThickness:m(o["00180050"]),spacingBetweenSlices:m(o["00180088"]),pixelSpacing:g(o["00280030"],2),numberOfFrames:m(o["00280008"]),isNMReconstructable:T(t)&&e.includes("NM")}}if(t===n.IMAGE_PLANE){const e=k(o),t=E(o),r=g(o["00280030"],2);let n=null,a=null;r&&(a=r[0],n=r[1]);let i=null,s=null;return e&&(i=[parseFloat(e[0]),parseFloat(e[1]),parseFloat(e[2])],s=[parseFloat(e[3]),parseFloat(e[4]),parseFloat(e[5])]),{frameOfReferenceUID:f(o["00200052"]),rows:m(o["00280010"]),columns:m(o["00280011"]),imageOrientationPatient:e,rowCosines:i,columnCosines:s,imagePositionPatient:t,sliceThickness:m(o["00180050"]),sliceLocation:m(o["00201041"]),pixelSpacing:r,rowPixelSpacing:a,columnPixelSpacing:n}}if(t===n.ULTRASOUND_ENHANCED_REGION)return R(o);if(t===n.CALIBRATION){if("US"===f(o["00080060"])){return{sequenceOfUltrasoundRegions:R(o)}}}if(t===n.IMAGE_URL)return function(e,t){const{transferSyntaxUID:r}=M(e,t),n=ot.cornerstone.utilities.isVideoTransferSyntax(r),a=e.substring(7),o=a.replace("/frames/","/thumbnail/");let i=a.replace("/frames/","/rendered/");n&&(i=i.replace("/rendered/1","/rendered"));return{isVideo:n,rendered:i,thumbnail:o}}(r,o);if(t===n.CINE)return function(e,t){const r=f(t["00180040"]);return{cineRate:r,numberOfFrames:m(t["00280008"])}}(0,o);if(t===n.IMAGE_PIXEL)return{samplesPerPixel:m(o["00280002"]),photometricInterpretation:f(o["00280004"]),rows:m(o["00280010"]),columns:m(o["00280011"]),bitsAllocated:m(o["00280100"]),bitsStored:m(o["00280101"]),highBit:f(o["00280102"]),pixelRepresentation:m(o["00280103"]),planarConfiguration:m(o["00280006"]),pixelAspectRatio:f(o["00280034"]),smallestPixelValue:m(o["00280106"]),largestPixelValue:m(o["00280107"]),redPaletteColorLookupTableDescriptor:g(o["00281101"]),greenPaletteColorLookupTableDescriptor:g(o["00281102"]),bluePaletteColorLookupTableDescriptor:g(o["00281103"]),redPaletteColorLookupTableData:g(o["00281201"]),greenPaletteColorLookupTableData:g(o["00281202"]),bluePaletteColorLookupTableData:g(o["00281203"])};if(t===n.VOI_LUT)return{windowCenter:g(o["00281050"],1),windowWidth:g(o["00281051"],1)};if(t===n.MODALITY_LUT)return{rescaleIntercept:m(o["00281052"]),rescaleSlope:m(o["00281053"]),rescaleType:f(o["00281054"])};if(t===n.SOP_COMMON)return{sopClassUID:f(o["00080016"]),sopInstanceUID:f(o["00080018"])};if(t===n.PET_ISOTOPE){const e=f(o["00540016"]);if(void 0===e)return;return{radiopharmaceuticalInfo:{radiopharmaceuticalStartTime:a.parseTM(f(e["00181072"],0,"")),radiopharmaceuticalStartDateTime:f(e["00181078"],0,""),radionuclideTotalDose:m(e["00181074"]),radionuclideHalfLife:m(e["00181075"])}}}return t===n.OVERLAY_PLANE?function(e){const t=[];for(let r=0;r<=30;r+=2){let n=`x60${r.toString(16)}`;4===n.length&&(n=`x600${r.toString(16)}`);const a=f(e[`${n}3000`]);if(!a)continue;const o=[];for(let t=0;t<a.length;t++)for(let r=0;r<8;r++){const n=e.Value[a.dataOffset+t];o[8*t+r]=n>>r&1}t.push({rows:m(e[`${n}0010`]),columns:m(e[`${n}0011`]),type:f(e[`${n}0040`]),x:m(e[`${n}0050`],1)-1,y:m(e[`${n}0050`],0)-1,pixelData:o,description:f(e[`${n}0022`]),label:f(e[`${n}1500`]),roiArea:f(e[`${n}1301`]),roiMean:f(e[`${n}1302`]),roiStandardDeviation:f(e[`${n}1303`])})}return{overlays:t}}(o):"transferSyntax"===t?M(r,o):t===n.PET_SERIES?{correctedImage:f(o["00280051"]),units:f(o["00541001"]),decayCorrection:f(o["00541102"])}:t===n.PET_IMAGE?{frameReferenceTime:m(o["00541300"]),actualFrameDuration:m(o["00181242"])}:"instance"===t?A(r,e,L):void 0}};function B(e,t,r){if(r+e.length>t.length)return!1;let n=r;for(let r=0;r<e.length;r++)if(e[r]!==t[n++])return!1;return!0}const U=function(e,t,r){r=r||0;const n=function(e){const t=new Uint8Array(e.length);for(let r=0,n=e.length;r<n;r++)t[r]=e.charCodeAt(r);return t}(t);for(let t=r;t<e.length;t++)if(n[0]===e[t]&&B(n,e,t))return t;return-1};var N=a(464);const{ImageQualityStatus:j}=N.Enums;function $(e,t,r){r||={};const n=new Uint8Array(t),a=!!r?.isPartial;if(-1===e.indexOf("multipart"))return{contentType:e,imageQualityStatus:a?j.SUBRESOLUTION:j.FULL_RESOLUTION,pixelData:n};let{tokenIndex:o,responseHeaders:i,boundary:s,multipartContentType:l}=r;if(o||=U(n,"\r\n\r\n"),-1===o)throw new Error("invalid response - no multipart mime header");if(!s){const e=function(e,t,r){t=t||0,r=r||e.length-t;let n="";for(let a=t;a<t+r;a++)n+=String.fromCharCode(e[a]);return n}(n,0,o);if(i=e.split("\r\n"),s=function(e){for(let t=0;t<e.length;t++)if("--"===e[t].substr(0,2))return e[t]}(i),!s)throw new Error("invalid response - no boundary marker")}const c=o+4,u=U(n,s,c);if(-1===u&&!a)throw new Error("invalid response - terminating boundary not found");return l||=function(e){for(let t=0;t<e.length;t++)if("Content-Type:"===e[t].substr(0,13))return e[t].substr(13).trim()}(i),r.tokenIndex=o,r.boundary=s,r.responseHeaders=i,r.multipartContentType=l,r.isPartial=-1===u,{contentType:l,extractDone:!a||-1!==u,tokenIndex:o,responseHeaders:i,boundary:s,multipartContentType:l,pixelData:t.slice(c,u-2)}}const{ImageQualityStatus:G}=N.Enums;function V(e,t=!0){return t?e.imageQualityStatus??G.FULL_RESOLUTION:G.SUBRESOLUTION}const{ProgressiveIterator:q}=N.utilities;function Z(e,t,r={},n={}){const a=l(),{retrieveOptions:o={},streamingData:i={}}=n,s=o.chunkSize||131072,c=new q("streamRequest");return c.generate((async(n,l)=>{const c=Object.assign({},r);Object.keys(c).forEach((function(t){null===c[t]&&(c[t]=void 0),"Accept"===t&&-1!==e.indexOf("accept=")&&(c[t]=void 0)}));try{const a=await fetch(e,{headers:r,signal:void 0});if(200!==a.status)throw new Error(`Couldn't retrieve ${e} got status ${a.status}`);const l=a.body.getReader(),c=a.headers,u=c.get("content-type"),f=Number(c.get("Content-Length"));let d=!1,m=i.encodedData,g=i.lastSize||0;for(i.isPartial=!0;!d;){const{done:r,value:a}=await l.read();if(m=Y(m,a),!m){if(d)throw new Error(`Done but no image frame available ${t}`);continue}if(d=r||m.byteLength===f,!d&&m.length<g+s)continue;g=m.length,i.isPartial=!r;const c=$(u,m,i),h=V(o,d),p={url:e,imageId:t,...c,percentComplete:r?100:100*c.pixelData?.length/f,imageQualityStatus:h,done:d};n.add(p,d)}}catch(e){(e=>{if("function"==typeof a.errorInterceptor){const e=new Error("request failed");a.errorInterceptor(e)}})(),console.error(e),l(e)}})),c.getNextPromise()}function Y(e,t){if(!e)return t;if(!t)return e;const r=new Uint8Array(e.length+t.length);return r.set(e,0),r.set(t,e.length),r}function z(e,t,r={},n={}){const a=l(),{retrieveOptions:o={},streamingData:i}=n,s=i.chunkSize||function(e,t,r){const n=t[r];if("function"!=typeof n)return n;const a=P.get(e);return n(a,e)}(t,o,"chunkSize")||65536,c=new Promise((async(t,n)=>{const l=Object.assign({},r);Object.keys(l).forEach((function(e){null!==l[e]&&void 0!==l[e]||delete l[e]}));try{i.encodedData||(i.chunkSize=s,i.rangesFetched=0);const r=function(e,t){const{totalBytes:r,encodedData:n,chunkSize:a=65536}=e,{rangeIndex:o=0}=t;if(!(-1!==o||r&&n))return[0,""];if(-1===o||n?.byteLength>r-a)return[n?.byteLength||0,""];return[n?.byteLength||0,a*(o+1)-1]}(i,o),{encodedData:n,responseHeaders:a}=await async function(e,t,r,n){r&&(t=Object.assign(t,{Range:`bytes=${r[0]}-${r[1]}`}));let{encodedData:a}=n;if(r[1]&&a?.byteLength>r[1])return n;const o=await fetch(e,{headers:t,signal:void 0}),i=await o.arrayBuffer(),s=new Uint8Array(i),{status:l}=o;let c;a?(c=new Uint8Array(a.length+s.length),c.set(a,0),c.set(s,a.length),n.rangesFetched=1):(c=new Uint8Array(s.length),c.set(s,0),n.rangesFetched++);n.encodedData=a=c,n.responseHeaders=o.headers;const u=o.headers.get("Content-Range");u?n.totalBytes=Number(u.split("/")[1]):206===l&&r?""===r[1]||a?.length<r[1]?n.totalBytes=a.byteLength:n.totalBytes=Number.MAX_SAFE_INTEGER:n.totalBytes=a?.byteLength;return n}(e,l,r,i),c=a.get("content-type"),{totalBytes:u}=i,f=u===n.byteLength,d=$(c,n,{isPartial:!0}),m=V(o,f||d.extractDone);t({...d,imageQualityStatus:m,percentComplete:d.extractDone?100:100*s/u})}catch(e){(e=>{if("function"==typeof a.errorInterceptor){const e=new Error("request failed");a.errorInterceptor(e)}else console.warn("rangeRequest:Caught",e)})(e),console.error(e),n(e)}}));return c}const H=function(e,t,r="application/octet-stream",n){const{streamingData:a,retrieveOptions:o={}}=n||{},i={Accept:r};let s=o.urlArguments?`${e}${-1===e.indexOf("?")?"?":"&"}${o.urlArguments}`:e;if(o.framesPath&&(s=s.replace("/frames/",o.framesPath)),a?.url!==s&&(n.streamingData={url:s}),void 0!==o.rangeIndex)return z(s,t,i,n);if(o.streaming)return Z(s,t,i,n);const l=c(s,t,i),{xhr:u}=l;return l.then((function(e){const t=$(u.getResponseHeader("Content-Type")||"application/octet-stream",new Uint8Array(e));return t.imageQualityStatus=V(o,!0),t}))};const W=function(e){let t,r=e[0],n=e[0];const a=e.length;for(let o=1;o<a;o++)t=e[o],r=Math.min(r,t),n=Math.max(n,t);return{min:r,max:n}};function X(r,n,a){0===r.planarConfiguration?e(r.pixelData,n,a):t(r.pixelData,n,a)}function Q(e,t,a){if("RGB"===e.photometricInterpretation)X(e,t,a);else if("YBR_RCT"===e.photometricInterpretation)X(e,t,a);else if("YBR_ICT"===e.photometricInterpretation)X(e,t,a);else if("PALETTE COLOR"===e.photometricInterpretation)lt(e,t,a);else if("YBR_FULL_422"===e.photometricInterpretation)!function(e,t,r){if(void 0===e)throw new Error("convertYBRFull422ByPixel: ybrBuffer must be defined");if(e.length%2!=0)throw new Error(`convertYBRFull422ByPixel: ybrBuffer length ${e.length} must be divisible by 2`);const n=e.length/2;let a=0,o=0;if(r)for(let r=0;r<n;r+=2){const r=e[a++],n=e[a++],i=e[a++],s=e[a++];t[o++]=r+1.402*(s-128),t[o++]=r-.34414*(i-128)-.71414*(s-128),t[o++]=r+1.772*(i-128),t[o++]=255,t[o++]=n+1.402*(s-128),t[o++]=n-.34414*(i-128)-.71414*(s-128),t[o++]=n+1.772*(i-128),t[o++]=255}else for(let r=0;r<n;r+=2){const r=e[a++],n=e[a++],i=e[a++],s=e[a++];t[o++]=r+1.402*(s-128),t[o++]=r-.34414*(i-128)-.71414*(s-128),t[o++]=r+1.772*(i-128),t[o++]=n+1.402*(s-128),t[o++]=n-.34414*(i-128)-.71414*(s-128),t[o++]=n+1.772*(i-128)}}(e.pixelData,t,a);else{if("YBR_FULL"!==e.photometricInterpretation)throw new Error(`No color space conversion for photometric interpretation ${e.photometricInterpretation}`);!function(e,t,a){0===e.planarConfiguration?r(e.pixelData,t,a):n(e.pixelData,t,a)}(e,t,a)}}function K(e){return function(e){let t;try{return decodeURIComponent(escape(e))}catch(r){if(t=r,t instanceof URIError)return e;throw t}}(String.fromCharCode.apply(null,Array.prototype.slice.apply(new Uint8Array(e))))}const J=function(e,t,r){const n=(new Date).getTime(),a=new Blob([t],{type:"image/jpeg"});return new Promise(((t,o)=>{const i=new FileReader;void 0===i.readAsBinaryString?i.readAsArrayBuffer(a):i.readAsBinaryString(a),i.onload=function(){const a=new Image;a.onload=function(){r.height=a.height,r.width=a.width,e.rows=a.height,e.columns=a.width;const o=r.getContext("2d");o.drawImage(this,0,0);const i=o.getImageData(0,0,a.width,a.height),s=(new Date).getTime();e.pixelData=new Uint8Array(i.data.buffer),e.imageData=i,e.decodeTimeInMS=s-n;const l=W(e.pixelData);e.smallestPixelValue=l.min,e.largestPixelValue=l.max,e.pixelDataLength=e.pixelData.length,t(e)},a.onerror=function(e){o(e)},void 0===i.readAsBinaryString?a.src=`data:image/jpeg;base64,${window.btoa(K(i.result))}`:a.src=`data:image/jpeg;base64,${window.btoa(i.result)}`},i.onerror=e=>{o(e)}}))};var ee=a(578);function te(e,t,r,n,a){const o={...n};delete o.loader,delete o.streamingData;const i=ot.cornerstone.getWebWorkerManager(),s=o.priority||void 0;o.transferPixelData&&r.buffer;return i.executeTask("dicomImageLoader","decodeTask",{imageFrame:e,transferSyntax:t,pixelData:r,options:o,decodeConfig:a},{priority:s,requestType:o?.requestType})}window.pako={inflateRaw:ee.Hq};const re=function(e,t,r,n,a={},o){switch(t){case"1.2.840.10008.1.2":case"1.2.840.10008.1.2.1":case"1.2.840.10008.1.2.2":case"1.2.840.10008.1.2.1.99":case"1.2.840.10008.1.2.5":case"1.2.840.10008.1.2.4.51":case"1.2.840.10008.1.2.4.57":case"1.2.840.10008.1.2.4.70":case"1.2.840.10008.1.2.4.80":case"1.2.840.10008.1.2.4.81":case"1.2.840.10008.1.2.4.90":case"1.2.840.10008.1.2.4.91":case"3.2.840.10008.1.2.4.96":case"1.2.840.10008.1.2.4.201":case"1.2.840.10008.1.2.4.202":case"1.2.840.10008.1.2.4.203":return te(e,t,r,a,o);case"1.2.840.10008.1.2.4.50":return 8!==e.bitsAllocated||3!==e.samplesPerPixel&&4!==e.samplesPerPixel?te(e,t,r,a,o):J(e,r,n)}return Promise.reject(new Error(`No decoder for transfer syntax ${t}`))};const ne=function(e){const{cornerstone:t}=ot,r=t.metaData.get("imagePixelModule",e);return{samplesPerPixel:r.samplesPerPixel,photometricInterpretation:r.photometricInterpretation,planarConfiguration:r.planarConfiguration,rows:r.rows,columns:r.columns,bitsAllocated:r.bitsAllocated,bitsStored:r.bitsStored,pixelRepresentation:r.pixelRepresentation,smallestPixelValue:r.smallestPixelValue,largestPixelValue:r.largestPixelValue,redPaletteColorLookupTableDescriptor:r.redPaletteColorLookupTableDescriptor,greenPaletteColorLookupTableDescriptor:r.greenPaletteColorLookupTableDescriptor,bluePaletteColorLookupTableDescriptor:r.bluePaletteColorLookupTableDescriptor,redPaletteColorLookupTableData:r.redPaletteColorLookupTableData,greenPaletteColorLookupTableData:r.greenPaletteColorLookupTableData,bluePaletteColorLookupTableData:r.bluePaletteColorLookupTableData,pixelData:void 0,imageId:e}};function ae(e){return"RGB"===e||"PALETTE COLOR"===e||"YBR_FULL"===e||"YBR_FULL_422"===e||"YBR_PARTIAL_422"===e||"YBR_PARTIAL_420"===e||"YBR_RCT"===e||"YBR_ICT"===e}let oe="";function ie(e){const t=function(e,t){let r;return Number.isInteger(e)&&Number.isInteger(t)&&(e>=0?t<=255?r=Uint8Array:t<=65535&&(r=Uint16Array):e>=-128&&t<=127?r=Int8Array:e>=-32768&&t<=32767&&(r=Int16Array)),r||Float32Array}(e.smallestPixelValue,e.largestPixelValue);if(!t)throw new Error("Could not apply a typed array to the pixel data");{const r=new t(e.pixelData);e.pixelData=r}}const se=function(e,t,r,n={}){const a=n.useRGBA;if(n.preScale={enabled:!n.preScale||void 0===n.preScale.enabled||n.preScale.enabled},!t?.length)return Promise.reject(new Error("The pixel data is missing"));const{cornerstone:o}=ot,{MetadataModules:i}=o.Enums,s=document.createElement("canvas"),c=ne(e);if(c.decodeLevel=n.decodeLevel,n.allowFloatRendering=o.canRenderFloatTextures(),n.preScale.enabled){const t=function(e,t){const r=e.get("modalityLutModule",t)||{},n=e.get("generalSeriesModule",t)||{},{modality:a}=n,o={rescaleSlope:r.rescaleSlope,rescaleIntercept:r.rescaleIntercept,modality:a},i=e.get("scalingModule",t)||{};return{...o,..."PT"===a&&{suvbw:i.suvbw}}}(o.metaData,e);t&&(n.preScale={...n.preScale,scalingParameters:t})}n.isSharedArrayBuffer=n.targetBuffer?.arrayBuffer&&n.targetBuffer.arrayBuffer instanceof SharedArrayBuffer;const{decodeConfig:u}=l();u.use16BitDataType=!!(n&&"Uint16Array"===n.targetBuffer?.type||"Int16Array"===n.targetBuffer?.type)||(n.useNativeDataType||u.use16BitDataType),Object.keys(c).forEach((e=>{("function"==typeof c[e]||c[e]instanceof Promise)&&delete c[e]}));const f=re(c,r,t,s,n,u),{use16BitDataType:d}=u,m=ae(c.photometricInterpretation);return new Promise(((t,r)=>{f.then((function(r){if(n.skipCreateImage)return t(r);let l=!1;if(n.targetBuffer&&n.targetBuffer.type&&!m){const{arrayBuffer:e,type:t,offset:a=0,length:o}=n.targetBuffer,i=r.pixelDataLength,s=a,c=null!=o?o:i-s,u={Uint8Array,Uint16Array:d?Uint16Array:void 0,Int16Array:d?Int16Array:void 0,Float32Array};if(c!==r.pixelDataLength)throw new Error(`target array for image does not have the same length (${c}) as the decoded image length (${r.pixelDataLength}).`);const f=u[t],m=e?new f(e,s,c):new f(r.pixelData);if(c!==r.pixelDataLength)throw new Error("target array for image does not have the same length as the decoded image length.");r.pixelData=m,l=!0}l||ie(r);const c=o.metaData.get(i.IMAGE_PLANE,e)||{},u=o.metaData.get(i.VOI_LUT,e)||{},f=o.metaData.get(i.MODALITY_LUT,e)||{},g=o.metaData.get(i.SOP_COMMON,e)||{},h=o.metaData.get(i.CALIBRATION,e)||{},{rows:p,columns:x}=r;if(m){if(function(e){if(void 0===e)return!1;const{rows:t,columns:r,photometricInterpretation:n,pixelDataLength:a}=e;return a!==4*r*t&&(n.endsWith("420")?a===(3*Math.ceil(r/2)+Math.floor(r/2))*t:n.endsWith("422")?a===(3*Math.ceil(r/2)+Math.floor(r/2))*Math.ceil(t/2)+Math.floor(t/2)*r:"RGB"!==n)}(r)){s.height=r.rows,s.width=r.columns;let e=s.getContext("2d").createImageData(r.columns,r.rows);a||(e={...e,data:new Uint8ClampedArray(r.samplesPerPixel*r.columns*r.rows)}),Q(r,e.data,a),r.imageData=e,r.pixelData=e.data,r.pixelDataLength=e.data.length}else if(!a&&r.pixelDataLength===4*p*x){const e=new Uint8Array(r.pixelData.length/4*3);r.pixelData=function(e,t){const r=e.length/4;let n=0,a=0;for(let o=0;o<r;o++)t[a++]=e[n++],t[a++]=e[n++],t[a++]=e[n++],n++;return t}(r.pixelData,e),r.pixelDataLength=r.pixelData.length}const e=W(r.pixelData);r.smallestPixelValue=e.min,r.largestPixelValue=e.max}const b={imageId:e,color:m,calibration:h,columnPixelSpacing:c.columnPixelSpacing,columns:r.columns,height:r.rows,preScale:r.preScale,intercept:f.rescaleIntercept?f.rescaleIntercept:0,slope:f.rescaleSlope?f.rescaleSlope:1,invert:"MONOCHROME1"===r.photometricInterpretation,minPixelValue:r.smallestPixelValue,maxPixelValue:r.largestPixelValue,rowPixelSpacing:c.rowPixelSpacing,rows:r.rows,sizeInBytes:r.pixelData.byteLength,width:r.columns,windowCenter:u.windowCenter?u.windowCenter[0]:void 0,windowWidth:u.windowWidth?u.windowWidth[0]:void 0,voiLUTFunction:u.voiLUTFunction?u.voiLUTFunction:void 0,decodeTimeInMS:r.decodeTimeInMS,floatPixelData:void 0,imageFrame:r,rgba:m&&a,getPixelData:()=>r.pixelData,getCanvas:void 0,numComps:void 0};var w;if(b.color&&(b.getCanvas=function(){if(oe===e)return s;const t=b.columns,n=b.rows;s.height=n,s.width=t;const a=s.getContext("2d"),o=a.createImageData(t,n),i=r.pixelData;if(i.length===t*n*4)for(let e=0;e<i.length;e++)o.data[e]=i[e];else if(i.length===t*n*3){let e=0;for(let t=0;t<i.length;t+=3)o.data[e++]=i[t],o.data[e++]=i[t+1],o.data[e++]=i[t+2],o.data[e++]=255}return r.pixelData=o.data,r.pixelDataLength=o.data.length,r.imageData=o,a.putImageData(r.imageData,0,0),oe=e,s}),f.modalityLUTSequence&&f.modalityLUTSequence.length>0&&("1.2.840.10008.5.1.4.1.1.12.1"!==(w=g.sopClassUID)&&"1.2.840.10008.5.1.4.1.1.12.2.1"!==w)&&(b.modalityLUT=f.modalityLUTSequence[0]),u.voiLUTSequence&&u.voiLUTSequence.length>0&&(b.voiLUT=u.voiLUTSequence[0]),b.color&&(b.windowWidth=256,b.windowCenter=128),void 0===b.windowCenter||void 0===b.windowWidth){const e=b.imageFrame.minAfterScale,t=b.imageFrame.maxAfterScale;b.windowWidth=t-e,b.windowCenter=(t+e)/2}t(b)}),r)}))},{ProgressiveIterator:le}=N.utilities,{ImageQualityStatus:ce}=N.Enums,ue=new Set(["3.2.840.10008.1.2.4.96","1.2.840.10008.1.2.4.202","1.2.840.10008.1.2.4.203"]);function fe(e){const t="1.2.840.10008.1.2";if(!e)return t;const r=e.split(";"),n={};r.forEach((e=>{const t=e.split("=");if(2!==t.length)return;const r=t[1].trim().replace(/"/g,"");n[t[0].trim()]=r}));const a={"image/jpeg":"1.2.840.10008.1.2.4.50","image/x-dicom-rle":"1.2.840.10008.1.2.5","image/x-jls":"1.2.840.10008.1.2.4.80","image/jls":"1.2.840.10008.1.2.4.80","image/jll":"1.2.840.10008.1.2.4.70","image/jp2":"1.2.840.10008.1.2.4.90","image/jpx":"1.2.840.10008.1.2.4.92","image/jphc":"3.2.840.10008.1.2.4.96","image/jxl":"1.2.840.10008.1.2.4.140"};return n["transfer-syntax"]?n["transfer-syntax"]:e&&!Object.keys(n).length&&a[e]?a[e]:n.type&&a[n.type]?a[n.type]:a[e]?a[e]:t}function de(e,t=4){const r=e/100-.02;return r>1/4?Math.min(t,0):r>1/16?Math.min(t,1):r>1/64?Math.min(t,2):Math.min(t,3)}const me=function(e,t={}){const r=ot.cornerstone.imageRetrievalPoolManager,n=(new Date).getTime(),a=new le("decompress"),o=t.requestType||"interaction",i=t.additionalDetails||{imageId:e},s=void 0===t.priority?5:t.priority,l=t.addToBeginning||!1,c=e.substring(7);return r.addRequest(async function(e,r,o){a.generate((async a=>{const i=le.as(H(e,r,o,t));let s=10;for await(const e of i){const{pixelData:o,imageQualityStatus:i=ce.FULL_RESOLUTION,percentComplete:l,done:c=!0,extractDone:u=!0}=e,f=fe(e.contentType);if(!u&&!ue.has(f))continue;const d=e.decodeLevel??(i===ce.FULL_RESOLUTION?0:de(l,t.retrieveOptions?.decodeLevel));if(c||!(s<=d))try{const e={...t,decodeLevel:d},l=await se(r,o,f,e),u=(new Date).getTime();l.loadTimeInMS=u-n,l.transferSyntaxUID=f,l.imageQualityStatus=i,a.add(l,c),s=d}catch(e){if(u)throw console.warn("Couldn't decode",e),e}}}))}.bind(this,c,e,"multipart/related; type=application/octet-stream; transfer-syntax=*"),o,i,s,l),{promise:a.getDonePromise(),cancelFn:void 0}};const ge={metaData:{getNumberString:d,getNumberValue:m,getNumberValues:g,getValue:f,metaDataProvider:F},findIndexOfString:U,getPixelData:H,loadImage:me,metaDataManager:P,register:function(e){e.registerImageLoader("wadors",me),e.metaData.addProvider(F)}};function he(e,t){if(e.elements[t]&&6===e.elements[t].length)return[e.uint16(t,0),e.uint16(t,1),e.uint16(t,2)]}function pe(e,t,r){const n=[],a=e.elements[t];for(let o=0;o<r[0];o++)16===r[2]?n[o]=e.uint16(t,o):n[o]=e.byteArray[o+a.dataOffset];return n}const xe=function(e){const t={samplesPerPixel:e.uint16("x00280002"),photometricInterpretation:e.string("x00280004"),rows:e.uint16("x00280010"),columns:e.uint16("x00280011"),bitsAllocated:e.uint16("x00280100"),bitsStored:e.uint16("x00280101"),highBit:e.uint16("x00280102"),pixelRepresentation:e.uint16("x00280103"),planarConfiguration:e.uint16("x00280006"),pixelAspectRatio:e.string("x00280034")};return function(e,t){0===e.uint16("x00280103")?(t.smallestPixelValue=e.uint16("x00280106"),t.largestPixelValue=e.uint16("x00280107")):(t.smallestPixelValue=e.int16("x00280106"),t.largestPixelValue=e.int16("x00280107"))}(e,t),"PALETTE COLOR"===t.photometricInterpretation&&e.elements.x00281101&&function(e,t){t.redPaletteColorLookupTableDescriptor=he(e,"x00281101"),t.greenPaletteColorLookupTableDescriptor=he(e,"x00281102"),t.bluePaletteColorLookupTableDescriptor=he(e,"x00281103"),0===t.redPaletteColorLookupTableDescriptor[0]&&(t.redPaletteColorLookupTableDescriptor[0]=65536,t.greenPaletteColorLookupTableDescriptor[0]=65536,t.bluePaletteColorLookupTableDescriptor[0]=65536);const r=t.redPaletteColorLookupTableDescriptor[0],n=e.elements.x00281201.length===r?8:16;t.redPaletteColorLookupTableDescriptor[2]!==n&&(t.redPaletteColorLookupTableDescriptor[2]=n,t.greenPaletteColorLookupTableDescriptor[2]=n,t.bluePaletteColorLookupTableDescriptor[2]=n),t.redPaletteColorLookupTableData=pe(e,"x00281201",t.redPaletteColorLookupTableDescriptor),t.greenPaletteColorLookupTableData=pe(e,"x00281202",t.greenPaletteColorLookupTableDescriptor),t.bluePaletteColorLookupTableData=pe(e,"x00281203",t.bluePaletteColorLookupTableDescriptor)}(e,t),t};function be(e,t){let r=t.uint16("x00283002",0);0===r&&(r=65535);let n=0;n=0===e?t.uint16("x00283002",1):t.int16("x00283002",1);const a={id:"1",firstValueMapped:n,numBitsPerEntry:t.uint16("x00283002",2),lut:[]};for(let n=0;n<r;n++)a.lut[n]=0===e?t.uint16("x00283006",n):t.int16("x00283006",n);return a}const we=function(e,t){if(!t||!t.items||!t.items.length)return;const r=[];for(let n=0;n<t.items.length;n++){const a=be(e,t.items[n].dataSet);a&&r.push(a)}return r};const ye=function(e){const t=e.string("x00080016");if("1.2.840.10008.5.1.4.1.1.2"===t||"1.2.840.10008.5.1.4.1.1.2.1"===t)return 1;const r=e.floatString("x00281052"),n=e.floatString("x00281053");if(void 0!==r&&void 0!==n){const t=function(e){const t=e.uint16("x00280103"),r=e.uint16("x00280101");return 0===t?0:-1<<r-1}(e);return t*n+r<0?1:0}return e.elements.x00283000&&e.elements.x00283000.length>0?0:e.uint16("x00280103")};const Se=function(e,t,r){const n=[],a=e.string(t);if(!a)return;const o=a.split("\\");if(!(r&&o.length<r)){for(let e=0;e<o.length;e++)n.push(parseFloat(o[e]));return n}};const De=function(e){const t=e.indexOf(":");let r=e.substring(t+1);const n=r.indexOf("frame=");let a;if(-1!==n){const e=r.substring(n+6);a=parseInt(e,10),r=r.substring(0,n-1)}return{scheme:e.substring(0,t),url:r,frame:a,pixelDataFrame:void 0!==a?a-1:void 0}};function Pe(e){const{dicomParser:t}=ot;let r,n=t.parseDicom(e,{untilTag:"x7fe00010"});n.elements.x7fe00010||console.warn("Pixel data not found!");try{r=t.parseDicom(e)}catch(e){console.error(e),console.log("pixel data dataset:",e.dataSet),r=e.dataSet}return n.elements.x7fe00010=r.elements.x7fe00010,n=function(e){const t=e.elements.x7fe00010.fragments,r=e.byteArray.length;for(const e of t){const{position:t,length:n}=e;n>r-t&&(console.log(`Truncated fragment, changing fragment length from ${e.length} to ${r-t}`),e.length=r-t)}return e}(n),n}async function Te(e,t,r){const n=Pe(e),{uri:a,imageId:o,fileTotalLength:i}=r;return n.fetchMore=async function(s){const l=Object.assign({uri:a,imageId:o,fetchedLength:e.length,lengthToFetch:i-e.length},s),{fetchedLength:c,lengthToFetch:u}=l,{arrayBuffer:f}=await t(a,o,{byteRange:`${c}-${c+u}`}),d=new Uint8Array(f),m=new Uint8Array(n.byteArray.length+d.length);return m.set(n.byteArray),m.set(d,n.byteArray.length),Te(m,t,r)},n}function ve(e,t,r){const n={};(t?Object.values(t.items[0].dataSet.elements):[]).map((e=>n[e.tag]=e));const a={};return(e?Object.values(e.items[r-1].dataSet.elements):[]).map((e=>a[e.tag]=e)),{shared:n,perFrame:a}}function Ie(e){if(!e)return;const{elements:t,...r}=e,{x52009230:n,x52009229:a,...o}=t;return{NumberOfFrames:e.intString("x00280008"),PerFrameFunctionalGroupsSequence:n,SharedFunctionalGroupsSequence:a,otherElements:o,otherAttributtes:r}}function ke(e){if(Le[e])return Le[e]}function Ee(e){if(!e)return!1;const t=e.intString("x00280008");return t&&t>1}const Ae={_get:ke,generateMultiframeWADOURIs:function(e){const t=[],r=ke(e);if(Ee(r)){const n=r.intString("x00280008");for(let r=1;r<=n;r++)t.push(`${e}&frame=${r}`)}else t.push(e);return t},retrieveMultiframeDataset:function(e){const t=function(e){return e.indexOf("&frame=")}(e),r=-1===t?e:e.slice(0,t),n=parseInt(e.slice(t+7),10)||1;let a;return a=Le[r]?Le[r].dataSet:void 0,{dataSet:a,frame:n}},isMultiframeDataset:function(e){return Ee(ke(e))}};let _e=0,Le={},Ce={};function Oe(){return{cacheSizeInBytes:_e,numberOfDataSetsCached:Object.keys(Le).length}}const Re={isLoaded:function(e){return void 0!==Le[e]},load:function(e,t=c,r){const{cornerstone:n,dicomParser:a}=ot;if(Le[e])return new Promise((t=>{Le[e].cacheCount++,t(Le[e].dataSet)}));if(Ce[e])return Ce[e].cacheCount++,Ce[e];const o=t(e,r),i=new Promise(((s,l)=>{o.then((async function(o){const c={isPartialContent:!1,fileTotalLength:null};if(!(o instanceof ArrayBuffer)){if(!o.arrayBuffer)return l(new Error("If not returning ArrayBuffer, must return object with `arrayBuffer` parameter"));c.isPartialContent=o.flags.isPartialContent,c.fileTotalLength=o.flags.fileTotalLength,o=o.arrayBuffer}const u=new Uint8Array(o);let f;try{f=c.isPartialContent?await Te(u,t,{uri:e,imageId:r,fileTotalLength:c.fileTotalLength}):a.parseDicom(u)}catch(e){return l(e)}Le[e]={dataSet:f,cacheCount:i.cacheCount},_e+=f.byteArray.length,s(f),n.triggerEvent(n.events,"datasetscachechanged",{uri:e,action:"loaded",cacheInfo:Oe()})}),l).then((()=>{delete Ce[e]}),(()=>{delete Ce[e]}))}));return i.cacheCount=1,Ce[e]=i,i},unload:function(e){const{cornerstone:t}=ot;Le[e]&&(Le[e].cacheCount--,0===Le[e].cacheCount&&(_e-=Le[e].dataSet.byteArray.length,delete Le[e],t.triggerEvent(t.events,"datasetscachechanged",{uri:e,action:"unloaded",cacheInfo:Oe()})))},getInfo:Oe,purge:function(){Le={},Ce={},_e=0},get:function(e){let t;if(e.includes("&frame=")){const{frame:r,dataSet:n}=Ae.retrieveMultiframeDataset(e);t=function(e,t){if(!t)return;const{NumberOfFrames:r,PerFrameFunctionalGroupsSequence:n,SharedFunctionalGroupsSequence:a,otherElements:o}=Ie(t);if(n||r>1){const{shared:r,perFrame:i}=ve(n,a,e),s={elements:{...o,...r,...i}},l=Object.create(t);return Object.assign(l,s)}return t}(r,n)}else Le[e]&&(t=Le[e].dataSet);return t},update:function(e,t){const r=Le[e];r?(_e-=r.dataSet.byteArray.length,r.dataSet=t,_e+=t.byteArray.length,ot.cornerstone.triggerEvent(ot.cornerstone.events,"datasetscachechanged",{uri:e,action:"updated",cacheInfo:Oe()})):console.error(`No loaded dataSet for uri ${e}`)}};function Me(e,t){const r=e.string("x00080008");if(r){const e=r.split("\\");if(e.length>t)return e[t]}}function Fe(e){let t=Se(e,"x00200037",6);return!t&&e.elements.x00209116&&(t=Se(e.elements.x00209116.items[0].dataSet,"x00200037",6)),t||(t=function(e){let t;const r=e.string("x00080060");if(r?.includes("NM")){const r=Me(e,2);r&&T(r)&&e.elements.x00540022&&(t=Se(e.elements.x00540022.items[0].dataSet,"x00200037",6))}return t}(e)),t}function Be(e){let t=Se(e,"x00200032",3);return!t&&e.elements.x00209113&&(t=Se(e.elements.x00209113.items[0].dataSet,"x00200032",3)),t||(t=function(e){let t;const r=e.string("x00080060");if(r?.includes("NM")){const r=Me(e,2);r&&T(r)&&e.elements.x00540022&&(t=Se(e.elements.x00540022.items[0].dataSet,"x00200032",3))}return t}(e)),t}function Ue(e){let t=Se(e,"x00280030",2);return!t&&e.elements.x00289110&&(t=Se(e.elements.x00289110.items[0].dataSet,"x00280030",2)),t}function Ne(e){let t;return e.elements.x00180050?t=e.floatString("x00180050"):e.elements.x00289110&&e.elements.x00289110.items.length&&e.elements.x00289110.items[0].dataSet.elements.x00180050&&(t=e.elements.x00289110.items[0].dataSet.floatString("x00180050")),t}const je=function e(t,r){const{MetadataModules:n}=ot.cornerstone.Enums,{dicomParser:a}=ot;if(Array.isArray(r))return;const o=De(r);if(t===n.MULTIFRAME){const e=Ae.retrieveMultiframeDataset(o.url);if(!e.dataSet)return;const t=function(e,t){if(!e)return;const{NumberOfFrames:r,PerFrameFunctionalGroupsSequence:n,SharedFunctionalGroupsSequence:a}=Ie(e);if(n||r>1){const{shared:e,perFrame:o}=ve(n,a,t);return{NumberOfFrames:r,PerFrameFunctionalInformation:o,SharedFunctionalInformation:e}}return{NumberOfFrames:r}}(e.dataSet,e.frame);return t}let i=o.url;o.frame&&(i=`${i}&frame=${o.frame}`);const s=Re.get(i);if(s){if(t===n.GENERAL_STUDY)return{studyDescription:s.string("x00081030"),studyDate:a.parseDA(s.string("x00080020")),studyTime:a.parseTM(s.string("x00080030")||""),accessionNumber:s.string("x00080050")};if(t===n.GENERAL_SERIES)return{modality:s.string("x00080060"),seriesInstanceUID:s.string("x0020000e"),seriesNumber:s.intString("x00200011"),studyInstanceUID:s.string("x0020000d"),seriesDate:a.parseDA(s.string("x00080021")),seriesTime:a.parseTM(s.string("x00080031")||""),acquisitionDate:a.parseDA(s.string("x00080022")),acquisitionTime:a.parseTM(s.string("x00080032")||"")};if(t===n.GENERAL_IMAGE)return{sopInstanceUID:s.string("x00080018"),instanceNumber:s.intString("x00200013"),lossyImageCompression:s.string("x00282110"),lossyImageCompressionRatio:s.floatString("x00282112"),lossyImageCompressionMethod:s.string("x00282114")};if(t===n.PATIENT)return{patientID:s.string("x00100020"),patientName:s.string("x00100010")};if(t===n.PATIENT_STUDY)return{patientAge:s.intString("x00101010"),patientSize:s.floatString("x00101020"),patientSex:s.string("x00100040"),patientWeight:s.floatString("x00101030")};if(t===n.NM_MULTIFRAME_GEOMETRY){const e=s.string("x00080060"),t=Me(s,2);return{modality:e,imageType:s.string("x00080008"),imageSubType:t,imageOrientationPatient:Fe(s),imagePositionPatient:Be(s),sliceThickness:Ne(s),pixelSpacing:Ue(s),numberOfFrames:s.uint16("x00280008"),isNMReconstructable:T(t)&&e.includes("NM")}}if(t===n.IMAGE_PLANE){const e=Fe(s),t=Be(s),r=Ue(s),n=Ne(s);let a=null,o=null;r&&(o=r[0],a=r[1]);let i=null,l=null;return e&&(i=[parseFloat(e[0]),parseFloat(e[1]),parseFloat(e[2])],l=[parseFloat(e[3]),parseFloat(e[4]),parseFloat(e[5])]),{frameOfReferenceUID:s.string("x00200052"),rows:s.uint16("x00280010"),columns:s.uint16("x00280011"),imageOrientationPatient:e,rowCosines:i,columnCosines:l,imagePositionPatient:t,sliceThickness:n,sliceLocation:s.floatString("x00201041"),pixelSpacing:r,rowPixelSpacing:o,columnPixelSpacing:a}}if(t===n.CINE)return{frameTime:s.floatString("x00181063")};if(t===n.IMAGE_PIXEL)return xe(s);if(t===n.VOI_LUT){const e=ye(s);return{windowCenter:Se(s,"x00281050",1),windowWidth:Se(s,"x00281051",1),voiLUTSequence:we(e,s.elements.x00283010)}}if(t===n.MODALITY_LUT)return{rescaleIntercept:s.floatString("x00281052"),rescaleSlope:s.floatString("x00281053"),rescaleType:s.string("x00281054"),modalityLUTSequence:we(s.uint16("x00280103"),s.elements.x00283000)};if(t===n.SOP_COMMON)return{sopClassUID:s.string("x00080016"),sopInstanceUID:s.string("x00080018")};if(t===n.PET_ISOTOPE){const e=s.elements.x00540016;if(void 0===e)return;const t=e.items[0].dataSet;return{radiopharmaceuticalInfo:{radiopharmaceuticalStartTime:a.parseTM(t.string("x00181072")||""),radionuclideTotalDose:t.floatString("x00181074"),radionuclideHalfLife:t.floatString("x00181075")}}}if(t===n.OVERLAY_PLANE)return function(e){const t=[];for(let r=0;r<=30;r+=2){let n=`x60${r.toString(16)}`;4===n.length&&(n=`x600${r.toString(16)}`);const a=e.elements[`${n}3000`];if(!a)continue;const o=[];for(let t=0;t<a.length;t++)for(let r=0;r<8;r++){const n=e.byteArray[a.dataOffset+t];o[8*t+r]=n>>r&1}t.push({rows:e.uint16(`${n}0010`),columns:e.uint16(`${n}0011`),type:e.string(`${n}0040`),x:e.int16(`${n}0050`,1)-1,y:e.int16(`${n}0050`,0)-1,pixelData:o,description:e.string(`${n}0022`),label:e.string(`${n}1500`),roiArea:e.string(`${n}1301`),roiMean:e.string(`${n}1302`),roiStandardDeviation:e.string(`${n}1303`)})}return{overlays:t}}(s);if("transferSyntax"===t){let e;try{e=s.string("x00020010")}catch(e){}return{transferSyntaxUID:e}}return t===n.PET_SERIES?{correctedImage:s.string("x00280051"),units:s.string("x00541001"),decayCorrection:s.string("x00541102")}:t===n.PET_IMAGE?{frameReferenceTime:s.floatString(s.string("x00541300")||""),actualFrameDuration:s.intString(s.string("x00181242"))}:"instance"===t?A(r,e,L):void 0}};let $e=[];const Ge={add:function(e){return"dicomfile:"+($e.push(e)-1)},get:function(e){return $e[e]},remove:function(e){$e[e]=void 0},purge:function(){$e=[]}};var Ve=a(713);function qe(e,t){const{dicomParser:r}=ot;if(e.elements.x7fe00010&&e.elements.x7fe00010.basicOffsetTable.length)return r.readEncapsulatedImageFrame(e,e.elements.x7fe00010,t);if(function(e){return e.intString("x00280008")!==e.elements.x7fe00010.fragments.length}(e)){const n=r.createJPEGBasicOffsetTable(e,e.elements.x7fe00010);return r.readEncapsulatedImageFrame(e,e.elements.x7fe00010,t,n)}const n=e.elements.x7fe00010.fragments,a=new Ve.ByteStream(e.byteArrayParser,e.byteArray,e.elements.x7fe00010.dataOffset),o=(0,Ve.readSequenceItem)(a);if("xfffee000"!==o.tag)throw"dicomParser.readEncapsulatedPixelData: missing basic offset table xfffee000";a.seek(o.length);const i=a.position;if(t+1>n.length)throw"dicomParser.readEncapsulatedPixelData: frame exceeds number of fragments";const s=i+n[t].offset+8,l=n[t].length;return new Uint8Array(a.byteArray.buffer.slice(a.byteArray.byteOffset+s,a.byteArray.byteOffset+s+l))}function Ze(e,t){return e&1<<t}const Ye=function(e,t,r){const n=new Uint8Array(r);for(let a=0;a<r;a++){const r=e[Math.floor(a/8)+t],o=a%8;n[a]=Ze(r,o)?1:0}return n};const ze=function(e,t){const r=e.elements.x7fe00010||e.elements.x7fe00008,n=e.uint16("x00280100"),a=e.uint16("x00280010"),o=e.uint16("x00280011");let i=e.uint16("x00280002");"YBR_FULL_422"===e.string("x00280004")&&(i=2,console.warn("Using SamplesPerPixel of 2 for YBR_FULL_422 photometric interpretation.\n See http://dicom.nema.org/medical/dicom/current/output/chtml/part03/sect_C.7.6.3.html for more information."));const s=r.dataOffset,l=a*o*i;let c;if(8===n){if(c=s+t*l,c>=e.byteArray.length)throw new Error("frame exceeds size of pixelData");return new Uint8Array(e.byteArray.buffer.slice(c,c+l))}if(16===n){if(c=s+t*l*2,c>=e.byteArray.length)throw new Error("frame exceeds size of pixelData");return new Uint8Array(e.byteArray.buffer.slice(c,c+2*l))}if(1===n){if(c=s+t*l*.125,c>=e.byteArray.length)throw new Error("frame exceeds size of pixelData");return Ye(e.byteArray,c,l)}if(32===n){if(c=s+t*l*4,c>=e.byteArray.length)throw new Error("frame exceeds size of pixelData");return new Uint8Array(e.byteArray.buffer.slice(c,c+4*l))}throw new Error("unsupported pixel format")};const He=function(e){const t=De(e),r=parseInt(t.url,10),n=Ge.get(r);return new Promise(((e,t)=>{const r=new FileReader;r.onload=t=>{const r=t.target.result;e(r)},r.onerror=t,r.readAsArrayBuffer(n)}))};const We=function(e,t=0){const r=e.elements.x7fe00010||e.elements.x7fe00008;return r?r.encapsulatedPixelData?qe(e,t):ze(e,t):null};function Xe(e,t,r=0,n,a,o){const i=(new Date).getTime(),s={cancelFn:void 0,promise:void 0};return s.promise=new Promise(((l,c)=>{e.then((e=>{const u=We(e,r),f=e.string("x00020010"),d=(new Date).getTime(),m=se(t,u,f,a);!function(e,t){e.decache=function(){const e=De(t);Re.unload(e.url)}}(s,t),m.then((t=>{t.data=e,t.sharedCacheKey=n;const r=(new Date).getTime();t.loadTimeInMS=d-i,t.totalTimeInMS=r-i,void 0!==o&&void 0!==o.imageDoneCallback&&o.imageDoneCallback(t),l(t)}),(function(t){c({error:t,dataSet:e})}))}),(function(e){c({error:e})}))})),s}function Qe(e){return"dicomweb"===e||"wadouri"===e?c:"dicomfile"===e?He:void 0}function Ke(e,t={}){const r=De(e);delete(t=Object.assign({},t)).loader;const n=Qe(r.scheme);if(Re.isLoaded(r.url)){return function(e,t,r=0,n,a){const o=(new Date).getTime();return{promise:new Promise(((i,s)=>{const l=(new Date).getTime();let c;try{const n=We(e,r),o=e.string("x00020010");c=se(t,n,o,a)}catch(t){return void s({error:t,dataSet:e})}c.then((t=>{t.data=e,t.sharedCacheKey=n;const r=(new Date).getTime();t.loadTimeInMS=l-o,t.totalTimeInMS=r-o,i(t)}),s)})),cancelFn:void 0}}(Re.get(r.url,n,e),e,r.pixelDataFrame,r.url,t)}return Xe(Re.load(r.url,n,e),e,r.frame,r.url,t)}const Je={metaData:{getImagePixelModule:xe,getLUTs:we,getModalityLUTOutputPixelRepresentation:ye,getNumberValues:Se,metaDataProvider:je},dataSetCacheManager:Re,fileManager:Ge,getEncapsulatedImageFrame:qe,getUncompressedImageFrame:ze,loadFileRequest:He,loadImageFromPromise:Xe,getLoaderForScheme:Qe,loadImage:Ke,parseImageId:De,unpackBinaryFrame:Ye,register:function(e){e.registerImageLoader("dicomweb",Ke),e.registerImageLoader("wadouri",Ke),e.registerImageLoader("dicomfile",Ke),e.metaData.addProvider(je)}};const et=function(e){ge.register(e),Je.register(e)};let tt,rt;const nt=()=>new Worker(new URL(a.p+a.u(595),a.b),{type:void 0}),at={set cornerstone(e){tt=e,et(tt);const t=l();at.cornerstone.getWebWorkerManager().registerWorker("dicomImageLoader",nt,{maxWorkerInstances:t.maxWebWorkers||1})},get cornerstone(){if(!tt){if(tt=window&&window.cornerstone,!tt)throw new Error("cornerstoneDICOMImageLoader requires a copy of Cornerstone to work properly. Please add cornerstoneDICOMImageLoader.external.cornerstone = cornerstone; to your application.");et(tt)}return tt},set dicomParser(e){rt=e},get dicomParser(){if(!rt){if(!window||!window.dicomParser)throw new Error("cornerstoneDICOMImageLoader requires a copy of dicomParser to work properly. Please add cornerstoneDICOMImageLoader.external.dicomParser = dicomParser; to your application.");rt=window.dicomParser}return rt}},ot=at;function it(e,t){const r=e.length,n=new Uint8ClampedArray(r);for(let a=0;a<r;++a)n[a]=e[a]>>t;return n}function st(e,t,r){const n=e[`${t}PaletteColorLookupTableData`];if(n)return Promise.resolve(n);const a=ot.cornerstone.metaData.get("imagePixelModule",e.imageId);return a&&"function"==typeof a.then?a.then((e=>e?e[`${t}PaletteColorLookupTableData`]:r)):Promise.resolve(a?a[`${t}PaletteColorLookupTableData`]:r)}function lt(e,t,r){const n=e.columns*e.rows,a=e.pixelData;Promise.all([st(e,"red",null),st(e,"green",null),st(e,"blue",null)]).then((([o,i,s])=>{if(!o||!i||!s)throw new Error("The image does not have a complete color palette. R, G, and B palette data are required.");const l=o.length;let c=0,u=0;const f=e.redPaletteColorLookupTableDescriptor[1],d=8===e.redPaletteColorLookupTableDescriptor[2]?0:8,m=it(o,d),g=it(i,d),h=it(s,d);if(r)for(let e=0;e<n;++e){let e=a[c++];e<f?e=0:e>f+l-1?e=l-1:e-=f,t[u++]=m[e],t[u++]=g[e],t[u++]=h[e],t[u++]=255}else for(let e=0;e<n;++e){let e=a[c++];e<f?e=0:e>f+l-1?e=l-1:e-=f,t[u++]=m[e],t[u++]=g[e],t[u++]=h[e]}}))}const ct=function(e){if(!e.cornerstone||!e.dicomParser)throw new Error('cornerstoneWADOImageLoader.configure: Options object must contain the keys "cornerstone" and "dicomParser".');s(e),ot.cornerstone=e.cornerstone,ot.dicomParser=e.dicomParser};const ut=function(e,t){if(t=t||e.transferSyntax,8===e.bitsAllocated&&"1.2.840.10008.1.2.4.50"===t&&(3===e.samplesPerPixel||4===e.samplesPerPixel))return!0},ft={convertRGBColorByPixel:e,convertRGBColorByPlane:t,convertYBRFullByPixel:r,convertYBRFullByPlane:n,convertPALETTECOLOR:lt,wadouri:Je,wadors:ge,configure:ct,convertColorSpace:Q,createImage:se,decodeJPEGBaseline8BitColor:J,getImageFrame:ne,getPixelData:H,getMinMax:W,isColorImage:ae,isJPEGBaseline8BitColor:ut,internal:u,external:at}})(),o})()));
1
+ !function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("@cornerstonejs/core"),require("dicom-parser")):"function"==typeof define&&define.amd?define("cornerstoneDICOMImageLoader",["@cornerstonejs/core","dicom-parser"],t):"object"==typeof exports?exports.cornerstoneDICOMImageLoader=t(require("@cornerstonejs/core"),require("dicom-parser")):e.cornerstoneDICOMImageLoader=t(e["@cornerstonejs/core"],e.dicomParser)}(this,((e,t)=>(()=>{"use strict";var r={464:t=>{t.exports=e},713:e=>{e.exports=t}},n={};function o(e){var t=n[e];if(void 0!==t)return t.exports;var a=n[e]={exports:{}};return r[e](a,a.exports,o),a.exports}o.m=r,o.d=(e,t)=>{for(var r in t)o.o(t,r)&&!o.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},o.u=e=>e+".min.js",o.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),o.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),o.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},(()=>{var e;o.g.importScripts&&(e=o.g.location+"");var t=o.g.document;if(!e&&t&&(t.currentScript&&(e=t.currentScript.src),!e)){var r=t.getElementsByTagName("script");if(r.length)for(var n=r.length-1;n>-1&&!e;)e=r[n--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),o.p=e})(),o.b=document.baseURI||self.location.href;var a={};return(()=>{function e(e,t,r){if(void 0===e)throw new Error("decodeRGB: rgbBuffer must be defined");if(e.length%3!=0)throw new Error(`decodeRGB: rgbBuffer length ${e.length} must be divisible by 3`);const n=e.length/3;let o=0,a=0;if(r)for(let r=0;r<n;r++)t[a++]=e[o++],t[a++]=e[o++],t[a++]=e[o++],t[a++]=255;else t.set(e)}function t(e,t,r){if(void 0===e)throw new Error("decodeRGB: rgbBuffer must be defined");if(e.length%3!=0)throw new Error(`decodeRGB: rgbBuffer length ${e.length} must be divisible by 3`);const n=e.length/3;let o=0,a=0,i=n,s=2*n;if(r)for(let r=0;r<n;r++)t[o++]=e[a++],t[o++]=e[i++],t[o++]=e[s++],t[o++]=255;else for(let r=0;r<n;r++)t[o++]=e[a++],t[o++]=e[i++],t[o++]=e[s++]}function r(e,t,r){if(void 0===e)throw new Error("convertYBRFullByPixel: ybrBuffer must be defined");if(e.length%3!=0)throw new Error(`convertYBRFullByPixel: ybrBuffer length ${e.length} must be divisible by 3`);const n=e.length/3;let o=0,a=0;if(r)for(let r=0;r<n;r++){const r=e[o++],n=e[o++],i=e[o++];t[a++]=r+1.402*(i-128),t[a++]=r-.34414*(n-128)-.71414*(i-128),t[a++]=r+1.772*(n-128),t[a++]=255}else for(let r=0;r<n;r++){const r=e[o++],n=e[o++],i=e[o++];t[a++]=r+1.402*(i-128),t[a++]=r-.34414*(n-128)-.71414*(i-128),t[a++]=r+1.772*(n-128)}}function n(e,t,r){if(void 0===e)throw new Error("convertYBRFullByPlane: ybrBuffer must be defined");if(e.length%3!=0)throw new Error(`convertYBRFullByPlane: ybrBuffer length ${e.length} must be divisible by 3`);const n=e.length/3;let o=0,a=0,i=n,s=2*n;if(r)for(let r=0;r<n;r++){const r=e[a++],n=e[i++],l=e[s++];t[o++]=r+1.402*(l-128),t[o++]=r-.34414*(n-128)-.71414*(l-128),t[o++]=r+1.772*(n-128),t[o++]=255}else for(let r=0;r<n;r++){const r=e[a++],n=e[i++],l=e[s++];t[o++]=r+1.402*(l-128),t[o++]=r-.34414*(n-128)-.71414*(l-128),t[o++]=r+1.772*(n-128)}}o.r(a),o.d(a,{configure:()=>lt,convertColorSpace:()=>J,convertPALETTECOLOR:()=>st,convertRGBColorByPixel:()=>e,convertRGBColorByPlane:()=>t,convertYBRFullByPixel:()=>r,convertYBRFullByPlane:()=>n,createImage:()=>ie,decodeJPEGBaseline8BitColor:()=>Z,default:()=>ut,external:()=>ot,getImageFrame:()=>re,getMinMax:()=>Q,getPixelData:()=>H,internal:()=>u,isColorImage:()=>ne,isJPEGBaseline8BitColor:()=>ct,wadors:()=>me,wadouri:()=>Ke});let i={open(e,t){e.open("get",t,!0)},beforeSend(){},beforeProcessing:e=>Promise.resolve(e.response),imageCreated(){},strict:!1,decodeConfig:{convertFloatPixelDataToInt:!0,use16BitDataType:!1}};function s(e){i=Object.assign(i,e)}function l(){return i}const c=function(e,t,r={},n={}){const{cornerstone:o}=ot,a=l(),i=e=>{if("function"==typeof a.errorInterceptor){const t=new Error("request failed");t.request=e,t.response=e.response,t.status=e.status,a.errorInterceptor(t)}},s=new XMLHttpRequest,c=new Promise(((l,c)=>{a.open(s,e,r,n);const u=a.beforeSend(s,t,r,n);s.responseType="arraybuffer";const f=Object.assign({},r,u);Object.keys(f).forEach((function(t){null!==f[t]&&("Accept"===t&&-1!==e.indexOf("accept=")||s.setRequestHeader(t,f[t]))})),n.deferred={resolve:l,reject:c},n.url=e,n.imageId=t,s.onloadstart=function(r){a.onloadstart&&a.onloadstart(r,n);const i={url:e,imageId:t};o.triggerEvent(o.events,"cornerstoneimageloadstart",i)},s.onloadend=function(r){a.onloadend&&a.onloadend(r,n);const i={url:e,imageId:t};o.triggerEvent(o.events,"cornerstoneimageloadend",i)},s.onreadystatechange=function(e){a.onreadystatechange?a.onreadystatechange(e,n):4===s.readyState&&(200===s.status||206===s.status?a.beforeProcessing(s).then(l).catch((()=>{i(s),c(s)})):(i(s),c(s)))},s.onprogress=function(e){const t=e.loaded;let r,o;e.lengthComputable&&(r=e.total,o=Math.round(t/r*100)),a.onprogress&&a.onprogress(e,n)},s.onerror=function(){i(s),c(s)},s.onabort=function(){i(s),c(s)},s.send()}));return c.xhr=s,c},u={xhrRequest:c,setOptions:s,getOptions:l};const f=function(e,t,r){return t=t||0,e&&e.Value?e.Value.length<=t?r:e.Value[t]:r};const d=function(e,t,r){const n=f(e,t,r);if(void 0!==n)return parseFloat(n)};const m=function(e,t){const r=f(e,t);if(void 0!==r)return parseFloat(r)};const g=function(e,t){if(!e)return;if(!e.Value)return;if(!Array.isArray(e.Value))return;if(t&&e.Value.length<t)return;const r=[];for(let t=0;t<e.Value.length;t++)r.push(parseFloat(e.Value[t]));return r};function p(e){const t=e.indexOf(":");return e.substring(t+1)}function h(e,t=!0){return e&&e.Value?e.Value[0]&&t?e.Value[0]:e.Value:e}function x(e,t,r){return{shared:(t?Object.values(t[0]):[]).map((e=>e[0])).filter((e=>void 0!==e&&"object"==typeof e)),perFrame:(e?Object.values(e[r-1]):[]).map((e=>e.Value[0])).filter((e=>void 0!==e&&"object"==typeof e))}}function y(e){let{52009230:t,52009229:r,"00280008":n,...o}=e;return t=h(t,!1),r=h(r,!1),n=h(n),{PerFrameFunctionalGroupsSequence:t,SharedFunctionalGroupsSequence:r,NumberOfFrames:n,rest:o}}function b(e){const t=e.indexOf("/frames/")+8,r=e.slice(0,t),n=parseInt(e.slice(t),10);return{metadata:w[`${r}1`],frame:n}}const P={_retrieveMultiframeMetadata:b,retrieveMultiframeMetadata:function(e){return b(p(e))},isMultiframe:function(e){const t=f(e["00280008"]);return t&&t>1}};let w=[],D={};const S={add:function(e,t){const r=p(e);t.isMultiframe=P.isMultiframe(t),w[r]=t},get:function(e){const t=p(e),r=w[t];if(r&&!r?.isMultiframe)return r;const n=D[t];if(n)return n;const o=P._retrieveMultiframeMetadata(t);if(!o||!o.metadata)return;const{metadata:a,frame:i}=o;if(a){const e=function(e,t){const{PerFrameFunctionalGroupsSequence:r,SharedFunctionalGroupsSequence:n,NumberOfFrames:o,rest:a}=y(t);if(r||o>1){const{shared:i,perFrame:s}=x(r,n,e),l=Object.assign(t,{frameNumber:e});return[...i,...s].forEach((e=>{Object.entries(e).forEach((([e,t])=>{l[e]=t}))})),Object.assign(a,{"00280008":o},l)}return t}(i,a);return D[t]=e,e}},remove:function(e){const t=p(e);w[t]=void 0,D[t]=void 0},purge:function(){w=[],D={}}};function I(e){return"RECON TOMO"===e||"RECON GATED TOMO"===e}function T(e){return f(e["00080060"]).includes("NM")}function L(e,t){const r=h(e["00080008"],!1);if(r)return r[t]}function v(e){let t=g(e["00200037"],6);return!t&&T(e)&&(t=function(e){let t;const r=L(e,2);if(r&&I(r)){const r=h(e["00540022"]);r&&(t=g(r["00200037"],6))}return t}(e)),t}function C(e){let t=g(e["00200032"],3);return!t&&T(e)&&(t=function(e){let t;const r=L(e,2);if(r&&I(r)){const r=h(e["00540022"]);r&&(t=g(r["00200032"],3))}return t}(e)),t}function A(e,t,r){const n={};for(const o of r)try{const r=t(o,e);if(r){const e={};for(const t in r)if(t in r){e[E(t)]=r[t]}Object.assign(n,e)}}catch(e){console.error(`Error retrieving ${o} data:`,e)}return n}const E=e=>e.charAt(0).toUpperCase()+e.slice(1),M=["multiframeModule","generalSeriesModule","patientStudyModule","imagePlaneModule","nmMultiframeGeometryModule","imagePixelModule","modalityLutModule","voiLutModule","sopCommonModule","petIsotopeModule","overlayPlaneModule","transferSyntax","petSeriesModule","petImageModule"];function O(e,t){const r=g(e[t]);return r?r[0]:null}const F=function(e){return e?.Value?.length?Array.isArray(e.Value)?e.Value:"object"==typeof e.Value?(console.warn("Warning: Value should be an array, but an object was found. Encapsulating the object in an array."),[e.Value]):[]:[]};function B(e){const t=F(e["00186011"]);if(!t||!t.length)return null;return t.map((e=>{const t=O(e,"0018602C"),r=O(e,"0018602E"),n=O(e,"00186024"),o=O(e,"00186026");return{regionLocationMinY0:O(e,"0018601A"),regionLocationMaxY1:O(e,"0018601E"),regionLocationMinX0:O(e,"00186018"),regionLocationMaxX1:O(e,"0018601C"),referencePixelX0:O(e,"00186020"),referencePixelY0:O(e,"00186022"),physicalDeltaX:t,physicalDeltaY:r,physicalUnitsXDirection:n,physicalUnitsYDirection:o,referencePhysicalPixelValueY:O(e,"0018602A"),referencePhysicalPixelValueX:O(e,"00186028"),regionSpatialFormat:O(e,"00186012"),regionDataType:O(e,"00186014"),regionFlags:O(e,"00186016"),transducerFrequency:O(e,"00186030")}}))}function R(e,t){return{transferSyntaxUID:f(t["00020010"])||f(t["00083002"])}}const U=function e(t,r){const{MetadataModules:n}=ot.cornerstone.Enums,{dicomParser:o}=ot;if(t===n.MULTIFRAME){const{metadata:e,frame:t}=P.retrieveMultiframeMetadata(r);if(!e)return;const{PerFrameFunctionalGroupsSequence:n,SharedFunctionalGroupsSequence:o,NumberOfFrames:a}=y(e);if(n||a>1){const{shared:e,perFrame:r}=x(n,o,t);return{NumberOfFrames:a,PerFrameFunctionalInformation:r,SharedFunctionalInformation:e}}return{NumberOfFrames:a}}const a=S.get(r);if(a){if(t===n.GENERAL_STUDY)return{studyDescription:f(a["00081030"]),studyDate:o.parseDA(f(a["00080020"])),studyTime:o.parseTM(f(a["00080030"],0,"")),accessionNumber:f(a["00080050"])};if(t===n.GENERAL_SERIES)return{modality:f(a["00080060"]),seriesInstanceUID:f(a["0020000E"]),seriesNumber:m(a["00200011"]),studyInstanceUID:f(a["0020000D"]),seriesDate:o.parseDA(f(a["00080021"])),seriesTime:o.parseTM(f(a["00080031"],0,"")),acquisitionDate:o.parseDA(f(a["00080022"])),acquisitionTime:o.parseTM(f(a["00080032"],0,""))};if(t===n.GENERAL_IMAGE)return{sopInstanceUID:f(a["00080018"]),instanceNumber:m(a["00200013"]),lossyImageCompression:f(a["00282110"]),lossyImageCompressionRatio:m(a["00282112"]),lossyImageCompressionMethod:f(a["00282114"])};if(t===n.PATIENT)return{patientID:f(a["00100020"]),patientName:f(a["00100010"])};if(t===n.PATIENT_STUDY)return{patientAge:m(a["00101010"]),patientSize:m(a["00101020"]),patientSex:f(a["00100040"]),patientWeight:m(a["00101030"])};if(t===n.NM_MULTIFRAME_GEOMETRY){const e=f(a["00080060"]),t=L(a,2);return{modality:e,imageType:f(a["00080008"]),imageSubType:t,imageOrientationPatient:v(a),imagePositionPatient:C(a),sliceThickness:m(a["00180050"]),spacingBetweenSlices:m(a["00180088"]),pixelSpacing:g(a["00280030"],2),numberOfFrames:m(a["00280008"]),isNMReconstructable:I(t)&&e.includes("NM")}}if(t===n.IMAGE_PLANE){const e=v(a),t=C(a),r=g(a["00280030"],2);let n=null,o=null;r&&(o=r[0],n=r[1]);let i=null,s=null;return e&&(i=[parseFloat(e[0]),parseFloat(e[1]),parseFloat(e[2])],s=[parseFloat(e[3]),parseFloat(e[4]),parseFloat(e[5])]),{frameOfReferenceUID:f(a["00200052"]),rows:m(a["00280010"]),columns:m(a["00280011"]),imageOrientationPatient:e,rowCosines:i,columnCosines:s,imagePositionPatient:t,sliceThickness:m(a["00180050"]),sliceLocation:m(a["00201041"]),pixelSpacing:r,rowPixelSpacing:o,columnPixelSpacing:n}}if(t===n.ULTRASOUND_ENHANCED_REGION)return B(a);if(t===n.CALIBRATION){if("US"===f(a["00080060"])){return{sequenceOfUltrasoundRegions:B(a)}}}if(t===n.IMAGE_URL)return function(e,t){const{transferSyntaxUID:r}=R(e,t),n=ot.cornerstone.utilities.isVideoTransferSyntax(r),o=e.substring(7),a=o.replace("/frames/","/thumbnail/");let i=o.replace("/frames/","/rendered/");n&&(i=i.replace("/rendered/1","/rendered"));return{isVideo:n,rendered:i,thumbnail:a}}(r,a);if(t===n.CINE)return function(e,t){const r=f(t["00180040"]);return{cineRate:r,numberOfFrames:m(t["00280008"])}}(0,a);if(t===n.IMAGE_PIXEL)return{samplesPerPixel:m(a["00280002"]),photometricInterpretation:f(a["00280004"]),rows:m(a["00280010"]),columns:m(a["00280011"]),bitsAllocated:m(a["00280100"]),bitsStored:m(a["00280101"]),highBit:f(a["00280102"]),pixelRepresentation:m(a["00280103"]),planarConfiguration:m(a["00280006"]),pixelAspectRatio:f(a["00280034"]),smallestPixelValue:m(a["00280106"]),largestPixelValue:m(a["00280107"]),redPaletteColorLookupTableDescriptor:g(a["00281101"]),greenPaletteColorLookupTableDescriptor:g(a["00281102"]),bluePaletteColorLookupTableDescriptor:g(a["00281103"]),redPaletteColorLookupTableData:g(a["00281201"]),greenPaletteColorLookupTableData:g(a["00281202"]),bluePaletteColorLookupTableData:g(a["00281203"])};if(t===n.VOI_LUT)return{windowCenter:g(a["00281050"],1),windowWidth:g(a["00281051"],1)};if(t===n.MODALITY_LUT)return{rescaleIntercept:m(a["00281052"]),rescaleSlope:m(a["00281053"]),rescaleType:f(a["00281054"])};if(t===n.SOP_COMMON)return{sopClassUID:f(a["00080016"]),sopInstanceUID:f(a["00080018"])};if(t===n.PET_ISOTOPE){const e=f(a["00540016"]);if(void 0===e)return;return{radiopharmaceuticalInfo:{radiopharmaceuticalStartTime:o.parseTM(f(e["00181072"],0,"")),radiopharmaceuticalStartDateTime:f(e["00181078"],0,""),radionuclideTotalDose:m(e["00181074"]),radionuclideHalfLife:m(e["00181075"])}}}return t===n.OVERLAY_PLANE?function(e){const t=[];for(let r=0;r<=30;r+=2){let n=`x60${r.toString(16)}`;4===n.length&&(n=`x600${r.toString(16)}`);const o=f(e[`${n}3000`]);if(!o)continue;const a=[];for(let t=0;t<o.length;t++)for(let r=0;r<8;r++){const n=e.Value[o.dataOffset+t];a[8*t+r]=n>>r&1}t.push({rows:m(e[`${n}0010`]),columns:m(e[`${n}0011`]),type:f(e[`${n}0040`]),x:m(e[`${n}0050`],1)-1,y:m(e[`${n}0050`],0)-1,pixelData:a,description:f(e[`${n}0022`]),label:f(e[`${n}1500`]),roiArea:f(e[`${n}1301`]),roiMean:f(e[`${n}1302`]),roiStandardDeviation:f(e[`${n}1303`])})}return{overlays:t}}(a):"transferSyntax"===t?R(r,a):t===n.PET_SERIES?{correctedImage:f(a["00280051"]),units:f(a["00541001"]),decayCorrection:f(a["00541102"])}:t===n.PET_IMAGE?{frameReferenceTime:m(a["00541300"]),actualFrameDuration:m(a["00181242"])}:"instance"===t?A(r,e,M):void 0}};function N(e,t,r){if(r+e.length>t.length)return!1;let n=r;for(let r=0;r<e.length;r++)if(e[r]!==t[n++])return!1;return!0}const k=function(e,t,r){r=r||0;const n=function(e){const t=new Uint8Array(e.length);for(let r=0,n=e.length;r<n;r++)t[r]=e.charCodeAt(r);return t}(t);for(let t=r;t<e.length;t++)if(n[0]===e[t]&&N(n,e,t))return t;return-1};var _=o(464);const{ImageQualityStatus:$}=_.Enums;function j(e,t,r){r||={};const n=new Uint8Array(t),o=!!r?.isPartial;if(-1===e.indexOf("multipart"))return{contentType:e,imageQualityStatus:o?$.SUBRESOLUTION:$.FULL_RESOLUTION,pixelData:n};let{tokenIndex:a,responseHeaders:i,boundary:s,multipartContentType:l}=r;if(a||=k(n,"\r\n\r\n"),-1===a)throw new Error("invalid response - no multipart mime header");if(!s){const e=function(e,t,r){t=t||0,r=r||e.length-t;let n="";for(let o=t;o<t+r;o++)n+=String.fromCharCode(e[o]);return n}(n,0,a);if(i=e.split("\r\n"),s=function(e){for(let t=0;t<e.length;t++)if("--"===e[t].substr(0,2))return e[t]}(i),!s)throw new Error("invalid response - no boundary marker")}const c=a+4,u=k(n,s,c);if(-1===u&&!o)throw new Error("invalid response - terminating boundary not found");return l||=function(e){for(let t=0;t<e.length;t++)if("Content-Type:"===e[t].substr(0,13))return e[t].substr(13).trim()}(i),r.tokenIndex=a,r.boundary=s,r.responseHeaders=i,r.multipartContentType=l,r.isPartial=-1===u,{contentType:l,extractDone:!o||-1!==u,tokenIndex:a,responseHeaders:i,boundary:s,multipartContentType:l,pixelData:t.slice(c,u-2)}}const{ImageQualityStatus:V}=_.Enums;function G(e,t=!0){return t?e.imageQualityStatus??V.FULL_RESOLUTION:V.SUBRESOLUTION}const{ProgressiveIterator:q}=_.utilities;function Y(e,t,r={},n={}){const o=l(),{retrieveOptions:a={},streamingData:i={}}=n,s=a.chunkSize||131072,c=new q("streamRequest");return c.generate((async(n,l)=>{const c=Object.assign({},r);Object.keys(c).forEach((function(t){null===c[t]&&(c[t]=void 0),"Accept"===t&&-1!==e.indexOf("accept=")&&(c[t]=void 0)}));try{const o=await fetch(e,{headers:r,signal:void 0});if(200!==o.status)throw new Error(`Couldn't retrieve ${e} got status ${o.status}`);const l=o.body.getReader(),c=o.headers,u=c.get("content-type"),f=Number(c.get("Content-Length"));let d=!1,m=i.encodedData,g=i.lastSize||0;for(i.isPartial=!0;!d;){const{done:r,value:o}=await l.read();if(m=W(m,o),!m){if(d)throw new Error(`Done but no image frame available ${t}`);continue}if(d=r||m.byteLength===f,!d&&m.length<g+s)continue;g=m.length,i.isPartial=!r;const c=j(u,m,i),p=G(a,d),h={url:e,imageId:t,...c,percentComplete:r?100:100*c.pixelData?.length/f,imageQualityStatus:p,done:d};n.add(h,d)}}catch(e){(e=>{if("function"==typeof o.errorInterceptor){const e=new Error("request failed");o.errorInterceptor(e)}})(),console.error(e),l(e)}})),c.getNextPromise()}function W(e,t){if(!e)return t;if(!t)return e;const r=new Uint8Array(e.length+t.length);return r.set(e,0),r.set(t,e.length),r}function z(e,t,r={},n={}){const o=l(),{retrieveOptions:a={},streamingData:i}=n,s=i.chunkSize||function(e,t,r){const n=t[r];if("function"!=typeof n)return n;const o=S.get(e);return n(o,e)}(t,a,"chunkSize")||65536,c=new Promise((async(t,n)=>{const l=Object.assign({},r);Object.keys(l).forEach((function(e){null!==l[e]&&void 0!==l[e]||delete l[e]}));try{i.encodedData||(i.chunkSize=s,i.rangesFetched=0);const r=function(e,t){const{totalBytes:r,encodedData:n,chunkSize:o=65536}=e,{rangeIndex:a=0}=t;if(!(-1!==a||r&&n))return[0,""];if(-1===a||n?.byteLength>r-o)return[n?.byteLength||0,""];return[n?.byteLength||0,o*(a+1)-1]}(i,a),{encodedData:n,responseHeaders:o}=await async function(e,t,r,n){r&&(t=Object.assign(t,{Range:`bytes=${r[0]}-${r[1]}`}));let{encodedData:o}=n;if(r[1]&&o?.byteLength>r[1])return n;const a=await fetch(e,{headers:t,signal:void 0}),i=await a.arrayBuffer(),s=new Uint8Array(i),{status:l}=a;let c;o?(c=new Uint8Array(o.length+s.length),c.set(o,0),c.set(s,o.length),n.rangesFetched=1):(c=new Uint8Array(s.length),c.set(s,0),n.rangesFetched++);n.encodedData=o=c,n.responseHeaders=a.headers;const u=a.headers.get("Content-Range");u?n.totalBytes=Number(u.split("/")[1]):206===l&&r?""===r[1]||o?.length<r[1]?n.totalBytes=o.byteLength:n.totalBytes=Number.MAX_SAFE_INTEGER:n.totalBytes=o?.byteLength;return n}(e,l,r,i),c=o.get("content-type"),{totalBytes:u}=i,f=u===n.byteLength,d=j(c,n,{isPartial:!0}),m=G(a,f||d.extractDone);t({...d,imageQualityStatus:m,percentComplete:d.extractDone?100:100*s/u})}catch(e){(e=>{if("function"==typeof o.errorInterceptor){const e=new Error("request failed");o.errorInterceptor(e)}else console.warn("rangeRequest:Caught",e)})(e),console.error(e),n(e)}}));return c}const H=function(e,t,r="application/octet-stream",n){const{streamingData:o,retrieveOptions:a={}}=n||{},i={Accept:r};let s=a.urlArguments?`${e}${-1===e.indexOf("?")?"?":"&"}${a.urlArguments}`:e;if(a.framesPath&&(s=s.replace("/frames/",a.framesPath)),o?.url!==s&&(n.streamingData={url:s}),void 0!==a.rangeIndex)return z(s,t,i,n);if(a.streaming)return Y(s,t,i,n);const l=c(s,t,i),{xhr:u}=l;return l.then((function(e){const t=j(u.getResponseHeader("Content-Type")||"application/octet-stream",new Uint8Array(e));return t.imageQualityStatus=G(a,!0),t}))};const Q=function(e){let t,r=e[0],n=e[0];const o=e.length;for(let a=1;a<o;a++)t=e[a],r=Math.min(r,t),n=Math.max(n,t);return{min:r,max:n}};function X(r,n,o){0===r.planarConfiguration?e(r.pixelData,n,o):t(r.pixelData,n,o)}function J(e,t,o){if("RGB"===e.photometricInterpretation)X(e,t,o);else if("YBR_RCT"===e.photometricInterpretation)X(e,t,o);else if("YBR_ICT"===e.photometricInterpretation)X(e,t,o);else if("PALETTE COLOR"===e.photometricInterpretation)st(e,t,o);else if("YBR_FULL_422"===e.photometricInterpretation)!function(e,t,r){if(void 0===e)throw new Error("convertYBRFull422ByPixel: ybrBuffer must be defined");if(e.length%2!=0)throw new Error(`convertYBRFull422ByPixel: ybrBuffer length ${e.length} must be divisible by 2`);const n=e.length/2;let o=0,a=0;if(r)for(let r=0;r<n;r+=2){const r=e[o++],n=e[o++],i=e[o++],s=e[o++];t[a++]=r+1.402*(s-128),t[a++]=r-.34414*(i-128)-.71414*(s-128),t[a++]=r+1.772*(i-128),t[a++]=255,t[a++]=n+1.402*(s-128),t[a++]=n-.34414*(i-128)-.71414*(s-128),t[a++]=n+1.772*(i-128),t[a++]=255}else for(let r=0;r<n;r+=2){const r=e[o++],n=e[o++],i=e[o++],s=e[o++];t[a++]=r+1.402*(s-128),t[a++]=r-.34414*(i-128)-.71414*(s-128),t[a++]=r+1.772*(i-128),t[a++]=n+1.402*(s-128),t[a++]=n-.34414*(i-128)-.71414*(s-128),t[a++]=n+1.772*(i-128)}}(e.pixelData,t,o);else{if("YBR_FULL"!==e.photometricInterpretation)throw new Error(`No color space conversion for photometric interpretation ${e.photometricInterpretation}`);!function(e,t,o){0===e.planarConfiguration?r(e.pixelData,t,o):n(e.pixelData,t,o)}(e,t,o)}}function K(e){return function(e){let t;try{return decodeURIComponent(escape(e))}catch(r){if(t=r,t instanceof URIError)return e;throw t}}(String.fromCharCode.apply(null,Array.prototype.slice.apply(new Uint8Array(e))))}const Z=function(e,t,r){const n=(new Date).getTime(),o=new Blob([t],{type:"image/jpeg"});return new Promise(((t,a)=>{const i=new FileReader;void 0===i.readAsBinaryString?i.readAsArrayBuffer(o):i.readAsBinaryString(o),i.onload=function(){const o=new Image;o.onload=function(){r.height=o.height,r.width=o.width,e.rows=o.height,e.columns=o.width;const a=r.getContext("2d");a.drawImage(this,0,0);const i=a.getImageData(0,0,o.width,o.height),s=(new Date).getTime();e.pixelData=new Uint8Array(i.data.buffer),e.imageData=i,e.decodeTimeInMS=s-n;const l=Q(e.pixelData);e.smallestPixelValue=l.min,e.largestPixelValue=l.max,e.pixelDataLength=e.pixelData.length,t(e)},o.onerror=function(e){a(e)},void 0===i.readAsBinaryString?o.src=`data:image/jpeg;base64,${window.btoa(K(i.result))}`:o.src=`data:image/jpeg;base64,${window.btoa(i.result)}`},i.onerror=e=>{a(e)}}))};function ee(e,t,r,n,o){const a={...n};delete a.loader,delete a.streamingData;const i=ot.cornerstone.getWebWorkerManager(),s=a.priority||void 0;a.transferPixelData&&r.buffer;return i.executeTask("dicomImageLoader","decodeTask",{imageFrame:e,transferSyntax:t,pixelData:r,options:a,decodeConfig:o},{priority:s,requestType:a?.requestType})}const te=function(e,t,r,n,o={},a){switch(t){case"1.2.840.10008.1.2":case"1.2.840.10008.1.2.1":case"1.2.840.10008.1.2.2":case"1.2.840.10008.1.2.1.99":case"1.2.840.10008.1.2.5":case"1.2.840.10008.1.2.4.51":case"1.2.840.10008.1.2.4.57":case"1.2.840.10008.1.2.4.70":case"1.2.840.10008.1.2.4.80":case"1.2.840.10008.1.2.4.81":case"1.2.840.10008.1.2.4.90":case"1.2.840.10008.1.2.4.91":case"3.2.840.10008.1.2.4.96":case"1.2.840.10008.1.2.4.201":case"1.2.840.10008.1.2.4.202":case"1.2.840.10008.1.2.4.203":return ee(e,t,r,o,a);case"1.2.840.10008.1.2.4.50":return 8!==e.bitsAllocated||3!==e.samplesPerPixel&&4!==e.samplesPerPixel?ee(e,t,r,o,a):Z(e,r,n)}return Promise.reject(new Error(`No decoder for transfer syntax ${t}`))};const re=function(e){const{cornerstone:t}=ot,r=t.metaData.get("imagePixelModule",e);return{samplesPerPixel:r.samplesPerPixel,photometricInterpretation:r.photometricInterpretation,planarConfiguration:r.planarConfiguration,rows:r.rows,columns:r.columns,bitsAllocated:r.bitsAllocated,bitsStored:r.bitsStored,pixelRepresentation:r.pixelRepresentation,smallestPixelValue:r.smallestPixelValue,largestPixelValue:r.largestPixelValue,redPaletteColorLookupTableDescriptor:r.redPaletteColorLookupTableDescriptor,greenPaletteColorLookupTableDescriptor:r.greenPaletteColorLookupTableDescriptor,bluePaletteColorLookupTableDescriptor:r.bluePaletteColorLookupTableDescriptor,redPaletteColorLookupTableData:r.redPaletteColorLookupTableData,greenPaletteColorLookupTableData:r.greenPaletteColorLookupTableData,bluePaletteColorLookupTableData:r.bluePaletteColorLookupTableData,pixelData:void 0,imageId:e}};function ne(e){return"RGB"===e||"PALETTE COLOR"===e||"YBR_FULL"===e||"YBR_FULL_422"===e||"YBR_PARTIAL_422"===e||"YBR_PARTIAL_420"===e||"YBR_RCT"===e||"YBR_ICT"===e}let oe="";function ae(e){const t=function(e,t){let r;return Number.isInteger(e)&&Number.isInteger(t)&&(e>=0?t<=255?r=Uint8Array:t<=65535&&(r=Uint16Array):e>=-128&&t<=127?r=Int8Array:e>=-32768&&t<=32767&&(r=Int16Array)),r||Float32Array}(e.smallestPixelValue,e.largestPixelValue);if(!t)throw new Error("Could not apply a typed array to the pixel data");{const r=new t(e.pixelData);e.pixelData=r}}const ie=function(e,t,r,n={}){const o=n.useRGBA;if(n.preScale={enabled:!n.preScale||void 0===n.preScale.enabled||n.preScale.enabled},!t?.length)return Promise.reject(new Error("The pixel data is missing"));const{cornerstone:a}=ot,{MetadataModules:i}=a.Enums,s=document.createElement("canvas"),c=re(e);if(c.decodeLevel=n.decodeLevel,n.allowFloatRendering=a.canRenderFloatTextures(),n.preScale.enabled){const t=function(e,t){const r=e.get("modalityLutModule",t)||{},n=e.get("generalSeriesModule",t)||{},{modality:o}=n,a={rescaleSlope:r.rescaleSlope,rescaleIntercept:r.rescaleIntercept,modality:o},i=e.get("scalingModule",t)||{};return{...a,..."PT"===o&&{suvbw:i.suvbw}}}(a.metaData,e);t&&(n.preScale={...n.preScale,scalingParameters:t})}n.isSharedArrayBuffer=n.targetBuffer?.arrayBuffer&&n.targetBuffer.arrayBuffer instanceof SharedArrayBuffer;const{decodeConfig:u}=l();u.use16BitDataType=!!(n&&"Uint16Array"===n.targetBuffer?.type||"Int16Array"===n.targetBuffer?.type)||(n.useNativeDataType||u.use16BitDataType),Object.keys(c).forEach((e=>{("function"==typeof c[e]||c[e]instanceof Promise)&&delete c[e]}));const f=te(c,r,t,s,n,u),{use16BitDataType:d}=u,m=ne(c.photometricInterpretation);return new Promise(((t,r)=>{f.then((function(r){if(n.skipCreateImage)return t(r);let l=!1;if(n.targetBuffer&&n.targetBuffer.type&&!m){const{arrayBuffer:e,type:t,offset:o=0,length:a}=n.targetBuffer,i=r.pixelDataLength,s=o,c=null!=a?a:i-s,u={Uint8Array,Uint16Array:d?Uint16Array:void 0,Int16Array:d?Int16Array:void 0,Float32Array};if(c!==r.pixelDataLength)throw new Error(`target array for image does not have the same length (${c}) as the decoded image length (${r.pixelDataLength}).`);const f=u[t],m=e?new f(e,s,c):new f(r.pixelData);if(c!==r.pixelDataLength)throw new Error("target array for image does not have the same length as the decoded image length.");r.pixelData=m,l=!0}l||ae(r);const c=a.metaData.get(i.IMAGE_PLANE,e)||{},u=a.metaData.get(i.VOI_LUT,e)||{},f=a.metaData.get(i.MODALITY_LUT,e)||{},g=a.metaData.get(i.SOP_COMMON,e)||{},p=a.metaData.get(i.CALIBRATION,e)||{},{rows:h,columns:x}=r;if(m){if(function(e){if(void 0===e)return!1;const{rows:t,columns:r,photometricInterpretation:n,pixelDataLength:o}=e;return o!==4*r*t&&(n.endsWith("420")?o===(3*Math.ceil(r/2)+Math.floor(r/2))*t:n.endsWith("422")?o===(3*Math.ceil(r/2)+Math.floor(r/2))*Math.ceil(t/2)+Math.floor(t/2)*r:"RGB"!==n)}(r)){s.height=r.rows,s.width=r.columns;let e=s.getContext("2d").createImageData(r.columns,r.rows);o||(e={...e,data:new Uint8ClampedArray(r.samplesPerPixel*r.columns*r.rows)}),J(r,e.data,o),r.imageData=e,r.pixelData=e.data,r.pixelDataLength=e.data.length}else if(!o&&r.pixelDataLength===4*h*x){const e=new Uint8Array(r.pixelData.length/4*3);r.pixelData=function(e,t){const r=e.length/4;let n=0,o=0;for(let a=0;a<r;a++)t[o++]=e[n++],t[o++]=e[n++],t[o++]=e[n++],n++;return t}(r.pixelData,e),r.pixelDataLength=r.pixelData.length}const e=Q(r.pixelData);r.smallestPixelValue=e.min,r.largestPixelValue=e.max}const y={imageId:e,color:m,calibration:p,columnPixelSpacing:c.columnPixelSpacing,columns:r.columns,height:r.rows,preScale:r.preScale,intercept:f.rescaleIntercept?f.rescaleIntercept:0,slope:f.rescaleSlope?f.rescaleSlope:1,invert:"MONOCHROME1"===r.photometricInterpretation,minPixelValue:r.smallestPixelValue,maxPixelValue:r.largestPixelValue,rowPixelSpacing:c.rowPixelSpacing,rows:r.rows,sizeInBytes:r.pixelData.byteLength,width:r.columns,windowCenter:u.windowCenter?u.windowCenter[0]:void 0,windowWidth:u.windowWidth?u.windowWidth[0]:void 0,voiLUTFunction:u.voiLUTFunction?u.voiLUTFunction:void 0,decodeTimeInMS:r.decodeTimeInMS,floatPixelData:void 0,imageFrame:r,rgba:m&&o,getPixelData:()=>r.pixelData,getCanvas:void 0,numComps:void 0};var b;if(y.color&&(y.getCanvas=function(){if(oe===e)return s;const t=y.columns,n=y.rows;s.height=n,s.width=t;const o=s.getContext("2d"),a=o.createImageData(t,n),i=r.pixelData;if(i.length===t*n*4)for(let e=0;e<i.length;e++)a.data[e]=i[e];else if(i.length===t*n*3){let e=0;for(let t=0;t<i.length;t+=3)a.data[e++]=i[t],a.data[e++]=i[t+1],a.data[e++]=i[t+2],a.data[e++]=255}return r.pixelData=a.data,r.pixelDataLength=a.data.length,r.imageData=a,o.putImageData(r.imageData,0,0),oe=e,s}),f.modalityLUTSequence&&f.modalityLUTSequence.length>0&&("1.2.840.10008.5.1.4.1.1.12.1"!==(b=g.sopClassUID)&&"1.2.840.10008.5.1.4.1.1.12.2.1"!==b)&&(y.modalityLUT=f.modalityLUTSequence[0]),u.voiLUTSequence&&u.voiLUTSequence.length>0&&(y.voiLUT=u.voiLUTSequence[0]),y.color&&(y.windowWidth=256,y.windowCenter=128),void 0===y.windowCenter||void 0===y.windowWidth){const e=y.imageFrame.minAfterScale,t=y.imageFrame.maxAfterScale;y.windowWidth=t-e,y.windowCenter=(t+e)/2}t(y)}),r)}))},{ProgressiveIterator:se}=_.utilities,{ImageQualityStatus:le}=_.Enums,ce=new Set(["3.2.840.10008.1.2.4.96","1.2.840.10008.1.2.4.202","1.2.840.10008.1.2.4.203"]);function ue(e){const t="1.2.840.10008.1.2";if(!e)return t;const r=e.split(";"),n={};r.forEach((e=>{const t=e.split("=");if(2!==t.length)return;const r=t[1].trim().replace(/"/g,"");n[t[0].trim()]=r}));const o={"image/jpeg":"1.2.840.10008.1.2.4.50","image/x-dicom-rle":"1.2.840.10008.1.2.5","image/x-jls":"1.2.840.10008.1.2.4.80","image/jls":"1.2.840.10008.1.2.4.80","image/jll":"1.2.840.10008.1.2.4.70","image/jp2":"1.2.840.10008.1.2.4.90","image/jpx":"1.2.840.10008.1.2.4.92","image/jphc":"3.2.840.10008.1.2.4.96","image/jxl":"1.2.840.10008.1.2.4.140"};return n["transfer-syntax"]?n["transfer-syntax"]:e&&!Object.keys(n).length&&o[e]?o[e]:n.type&&o[n.type]?o[n.type]:o[e]?o[e]:t}function fe(e,t=4){const r=e/100-.02;return r>1/4?Math.min(t,0):r>1/16?Math.min(t,1):r>1/64?Math.min(t,2):Math.min(t,3)}const de=function(e,t={}){const r=ot.cornerstone.imageRetrievalPoolManager,n=(new Date).getTime(),o=new se("decompress"),a=t.requestType||"interaction",i=t.additionalDetails||{imageId:e},s=void 0===t.priority?5:t.priority,l=t.addToBeginning||!1,c=e.substring(7);return r.addRequest(async function(e,r,a){o.generate((async o=>{const i=se.as(H(e,r,a,t));let s=10;for await(const e of i){const{pixelData:a,imageQualityStatus:i=le.FULL_RESOLUTION,percentComplete:l,done:c=!0,extractDone:u=!0}=e,f=ue(e.contentType);if(!u&&!ce.has(f))continue;const d=e.decodeLevel??(i===le.FULL_RESOLUTION?0:fe(l,t.retrieveOptions?.decodeLevel));if(c||!(s<=d))try{const e={...t,decodeLevel:d},l=await ie(r,a,f,e),u=(new Date).getTime();l.loadTimeInMS=u-n,l.transferSyntaxUID=f,l.imageQualityStatus=i,o.add(l,c),s=d}catch(e){if(u)throw console.warn("Couldn't decode",e),e}}}))}.bind(this,c,e,"multipart/related; type=application/octet-stream; transfer-syntax=*"),a,i,s,l),{promise:o.getDonePromise(),cancelFn:void 0}};const me={metaData:{getNumberString:d,getNumberValue:m,getNumberValues:g,getValue:f,metaDataProvider:U},findIndexOfString:k,getPixelData:H,loadImage:de,metaDataManager:S,register:function(e){e.registerImageLoader("wadors",de),e.metaData.addProvider(U)}};function ge(e,t){if(e.elements[t]&&6===e.elements[t].length)return[e.uint16(t,0),e.uint16(t,1),e.uint16(t,2)]}function pe(e,t,r){const n=[],o=e.elements[t];for(let a=0;a<r[0];a++)16===r[2]?n[a]=e.uint16(t,a):n[a]=e.byteArray[a+o.dataOffset];return n}const he=function(e){const t={samplesPerPixel:e.uint16("x00280002"),photometricInterpretation:e.string("x00280004"),rows:e.uint16("x00280010"),columns:e.uint16("x00280011"),bitsAllocated:e.uint16("x00280100"),bitsStored:e.uint16("x00280101"),highBit:e.uint16("x00280102"),pixelRepresentation:e.uint16("x00280103"),planarConfiguration:e.uint16("x00280006"),pixelAspectRatio:e.string("x00280034")};return function(e,t){0===e.uint16("x00280103")?(t.smallestPixelValue=e.uint16("x00280106"),t.largestPixelValue=e.uint16("x00280107")):(t.smallestPixelValue=e.int16("x00280106"),t.largestPixelValue=e.int16("x00280107"))}(e,t),"PALETTE COLOR"===t.photometricInterpretation&&e.elements.x00281101&&function(e,t){t.redPaletteColorLookupTableDescriptor=ge(e,"x00281101"),t.greenPaletteColorLookupTableDescriptor=ge(e,"x00281102"),t.bluePaletteColorLookupTableDescriptor=ge(e,"x00281103"),0===t.redPaletteColorLookupTableDescriptor[0]&&(t.redPaletteColorLookupTableDescriptor[0]=65536,t.greenPaletteColorLookupTableDescriptor[0]=65536,t.bluePaletteColorLookupTableDescriptor[0]=65536);const r=t.redPaletteColorLookupTableDescriptor[0],n=e.elements.x00281201.length===r?8:16;t.redPaletteColorLookupTableDescriptor[2]!==n&&(t.redPaletteColorLookupTableDescriptor[2]=n,t.greenPaletteColorLookupTableDescriptor[2]=n,t.bluePaletteColorLookupTableDescriptor[2]=n),t.redPaletteColorLookupTableData=pe(e,"x00281201",t.redPaletteColorLookupTableDescriptor),t.greenPaletteColorLookupTableData=pe(e,"x00281202",t.greenPaletteColorLookupTableDescriptor),t.bluePaletteColorLookupTableData=pe(e,"x00281203",t.bluePaletteColorLookupTableDescriptor)}(e,t),t};function xe(e,t){let r=t.uint16("x00283002",0);0===r&&(r=65535);let n=0;n=0===e?t.uint16("x00283002",1):t.int16("x00283002",1);const o={id:"1",firstValueMapped:n,numBitsPerEntry:t.uint16("x00283002",2),lut:[]};for(let n=0;n<r;n++)o.lut[n]=0===e?t.uint16("x00283006",n):t.int16("x00283006",n);return o}const ye=function(e,t){if(!t||!t.items||!t.items.length)return;const r=[];for(let n=0;n<t.items.length;n++){const o=xe(e,t.items[n].dataSet);o&&r.push(o)}return r};const be=function(e){const t=e.string("x00080016");if("1.2.840.10008.5.1.4.1.1.2"===t||"1.2.840.10008.5.1.4.1.1.2.1"===t)return 1;const r=e.floatString("x00281052"),n=e.floatString("x00281053");if(void 0!==r&&void 0!==n){const t=function(e){const t=e.uint16("x00280103"),r=e.uint16("x00280101");return 0===t?0:-1<<r-1}(e);return t*n+r<0?1:0}return e.elements.x00283000&&e.elements.x00283000.length>0?0:e.uint16("x00280103")};const Pe=function(e,t,r){const n=[],o=e.string(t);if(!o)return;const a=o.split("\\");if(!(r&&a.length<r)){for(let e=0;e<a.length;e++)n.push(parseFloat(a[e]));return n}};const we=function(e){const t=e.indexOf(":");let r=e.substring(t+1);const n=r.indexOf("frame=");let o;if(-1!==n){const e=r.substring(n+6);o=parseInt(e,10),r=r.substring(0,n-1)}return{scheme:e.substring(0,t),url:r,frame:o,pixelDataFrame:void 0!==o?o-1:void 0}};function De(e){const{dicomParser:t}=ot;let r,n=t.parseDicom(e,{untilTag:"x7fe00010"});n.elements.x7fe00010||console.warn("Pixel data not found!");try{r=t.parseDicom(e)}catch(e){console.error(e),console.log("pixel data dataset:",e.dataSet),r=e.dataSet}return n.elements.x7fe00010=r.elements.x7fe00010,n=function(e){const t=e.elements.x7fe00010.fragments,r=e.byteArray.length;for(const e of t){const{position:t,length:n}=e;n>r-t&&(console.log(`Truncated fragment, changing fragment length from ${e.length} to ${r-t}`),e.length=r-t)}return e}(n),n}async function Se(e,t,r){const n=De(e),{uri:o,imageId:a,fileTotalLength:i}=r;return n.fetchMore=async function(s){const l=Object.assign({uri:o,imageId:a,fetchedLength:e.length,lengthToFetch:i-e.length},s),{fetchedLength:c,lengthToFetch:u}=l,{arrayBuffer:f}=await t(o,a,{byteRange:`${c}-${c+u}`}),d=new Uint8Array(f),m=new Uint8Array(n.byteArray.length+d.length);return m.set(n.byteArray),m.set(d,n.byteArray.length),Se(m,t,r)},n}function Ie(e,t,r){const n={};(t?Object.values(t.items[0].dataSet.elements):[]).map((e=>n[e.tag]=e));const o={};return(e?Object.values(e.items[r-1].dataSet.elements):[]).map((e=>o[e.tag]=e)),{shared:n,perFrame:o}}function Te(e){if(!e)return;const{elements:t,...r}=e,{x52009230:n,x52009229:o,...a}=t;return{NumberOfFrames:e.intString("x00280008"),PerFrameFunctionalGroupsSequence:n,SharedFunctionalGroupsSequence:o,otherElements:a,otherAttributtes:r}}function Le(e){if(Ee[e])return Ee[e]}function ve(e){if(!e)return!1;const t=e.intString("x00280008");return t&&t>1}const Ce={_get:Le,generateMultiframeWADOURIs:function(e){const t=[],r=Le(e);if(ve(r)){const n=r.intString("x00280008");for(let r=1;r<=n;r++)t.push(`${e}&frame=${r}`)}else t.push(e);return t},retrieveMultiframeDataset:function(e){const t=function(e){return e.indexOf("&frame=")}(e),r=-1===t?e:e.slice(0,t),n=parseInt(e.slice(t+7),10)||1;let o;return o=Ee[r]?Ee[r].dataSet:void 0,{dataSet:o,frame:n}},isMultiframeDataset:function(e){return ve(Le(e))}};let Ae=0,Ee={},Me={};function Oe(){return{cacheSizeInBytes:Ae,numberOfDataSetsCached:Object.keys(Ee).length}}const Fe={isLoaded:function(e){return void 0!==Ee[e]},load:function(e,t=c,r){const{cornerstone:n,dicomParser:o}=ot;if(Ee[e])return new Promise((t=>{Ee[e].cacheCount++,t(Ee[e].dataSet)}));if(Me[e])return Me[e].cacheCount++,Me[e];const a=t(e,r),i=new Promise(((s,l)=>{a.then((async function(a){const c={isPartialContent:!1,fileTotalLength:null};if(!(a instanceof ArrayBuffer)){if(!a.arrayBuffer)return l(new Error("If not returning ArrayBuffer, must return object with `arrayBuffer` parameter"));c.isPartialContent=a.flags.isPartialContent,c.fileTotalLength=a.flags.fileTotalLength,a=a.arrayBuffer}const u=new Uint8Array(a);let f;try{f=c.isPartialContent?await Se(u,t,{uri:e,imageId:r,fileTotalLength:c.fileTotalLength}):o.parseDicom(u)}catch(e){return l(e)}Ee[e]={dataSet:f,cacheCount:i.cacheCount},Ae+=f.byteArray.length,s(f),n.triggerEvent(n.events,"datasetscachechanged",{uri:e,action:"loaded",cacheInfo:Oe()})}),l).then((()=>{delete Me[e]}),(()=>{delete Me[e]}))}));return i.cacheCount=1,Me[e]=i,i},unload:function(e){const{cornerstone:t}=ot;Ee[e]&&(Ee[e].cacheCount--,0===Ee[e].cacheCount&&(Ae-=Ee[e].dataSet.byteArray.length,delete Ee[e],t.triggerEvent(t.events,"datasetscachechanged",{uri:e,action:"unloaded",cacheInfo:Oe()})))},getInfo:Oe,purge:function(){Ee={},Me={},Ae=0},get:function(e){let t;if(e.includes("&frame=")){const{frame:r,dataSet:n}=Ce.retrieveMultiframeDataset(e);t=function(e,t){if(!t)return;const{NumberOfFrames:r,PerFrameFunctionalGroupsSequence:n,SharedFunctionalGroupsSequence:o,otherElements:a}=Te(t);if(n||r>1){const{shared:r,perFrame:i}=Ie(n,o,e),s={elements:{...a,...r,...i}},l=Object.create(t);return Object.assign(l,s)}return t}(r,n)}else Ee[e]&&(t=Ee[e].dataSet);return t},update:function(e,t){const r=Ee[e];r?(Ae-=r.dataSet.byteArray.length,r.dataSet=t,Ae+=t.byteArray.length,ot.cornerstone.triggerEvent(ot.cornerstone.events,"datasetscachechanged",{uri:e,action:"updated",cacheInfo:Oe()})):console.error(`No loaded dataSet for uri ${e}`)}};function Be(e,t){const r=e.string("x00080008");if(r){const e=r.split("\\");if(e.length>t)return e[t]}}function Re(e){let t=Pe(e,"x00200037",6);return!t&&e.elements.x00209116&&(t=Pe(e.elements.x00209116.items[0].dataSet,"x00200037",6)),t||(t=function(e){let t;const r=e.string("x00080060");if(r?.includes("NM")){const r=Be(e,2);r&&I(r)&&e.elements.x00540022&&(t=Pe(e.elements.x00540022.items[0].dataSet,"x00200037",6))}return t}(e)),t}function Ue(e){let t=Pe(e,"x00200032",3);return!t&&e.elements.x00209113&&(t=Pe(e.elements.x00209113.items[0].dataSet,"x00200032",3)),t||(t=function(e){let t;const r=e.string("x00080060");if(r?.includes("NM")){const r=Be(e,2);r&&I(r)&&e.elements.x00540022&&(t=Pe(e.elements.x00540022.items[0].dataSet,"x00200032",3))}return t}(e)),t}function Ne(e){let t=Pe(e,"x00280030",2);return!t&&e.elements.x00289110&&(t=Pe(e.elements.x00289110.items[0].dataSet,"x00280030",2)),t}function ke(e){let t;return e.elements.x00180050?t=e.floatString("x00180050"):e.elements.x00289110&&e.elements.x00289110.items.length&&e.elements.x00289110.items[0].dataSet.elements.x00180050&&(t=e.elements.x00289110.items[0].dataSet.floatString("x00180050")),t}const _e=function e(t,r){const{MetadataModules:n}=ot.cornerstone.Enums,{dicomParser:o}=ot;if(Array.isArray(r))return;const a=we(r);if(t===n.MULTIFRAME){const e=Ce.retrieveMultiframeDataset(a.url);if(!e.dataSet)return;const t=function(e,t){if(!e)return;const{NumberOfFrames:r,PerFrameFunctionalGroupsSequence:n,SharedFunctionalGroupsSequence:o}=Te(e);if(n||r>1){const{shared:e,perFrame:a}=Ie(n,o,t);return{NumberOfFrames:r,PerFrameFunctionalInformation:a,SharedFunctionalInformation:e}}return{NumberOfFrames:r}}(e.dataSet,e.frame);return t}let i=a.url;a.frame&&(i=`${i}&frame=${a.frame}`);const s=Fe.get(i);if(s){if(t===n.GENERAL_STUDY)return{studyDescription:s.string("x00081030"),studyDate:o.parseDA(s.string("x00080020")),studyTime:o.parseTM(s.string("x00080030")||""),accessionNumber:s.string("x00080050")};if(t===n.GENERAL_SERIES)return{modality:s.string("x00080060"),seriesInstanceUID:s.string("x0020000e"),seriesNumber:s.intString("x00200011"),studyInstanceUID:s.string("x0020000d"),seriesDate:o.parseDA(s.string("x00080021")),seriesTime:o.parseTM(s.string("x00080031")||""),acquisitionDate:o.parseDA(s.string("x00080022")),acquisitionTime:o.parseTM(s.string("x00080032")||"")};if(t===n.GENERAL_IMAGE)return{sopInstanceUID:s.string("x00080018"),instanceNumber:s.intString("x00200013"),lossyImageCompression:s.string("x00282110"),lossyImageCompressionRatio:s.floatString("x00282112"),lossyImageCompressionMethod:s.string("x00282114")};if(t===n.PATIENT)return{patientID:s.string("x00100020"),patientName:s.string("x00100010")};if(t===n.PATIENT_STUDY)return{patientAge:s.intString("x00101010"),patientSize:s.floatString("x00101020"),patientSex:s.string("x00100040"),patientWeight:s.floatString("x00101030")};if(t===n.NM_MULTIFRAME_GEOMETRY){const e=s.string("x00080060"),t=Be(s,2);return{modality:e,imageType:s.string("x00080008"),imageSubType:t,imageOrientationPatient:Re(s),imagePositionPatient:Ue(s),sliceThickness:ke(s),pixelSpacing:Ne(s),numberOfFrames:s.uint16("x00280008"),isNMReconstructable:I(t)&&e.includes("NM")}}if(t===n.IMAGE_PLANE){const e=Re(s),t=Ue(s),r=Ne(s),n=ke(s);let o=null,a=null;r&&(a=r[0],o=r[1]);let i=null,l=null;return e&&(i=[parseFloat(e[0]),parseFloat(e[1]),parseFloat(e[2])],l=[parseFloat(e[3]),parseFloat(e[4]),parseFloat(e[5])]),{frameOfReferenceUID:s.string("x00200052"),rows:s.uint16("x00280010"),columns:s.uint16("x00280011"),imageOrientationPatient:e,rowCosines:i,columnCosines:l,imagePositionPatient:t,sliceThickness:n,sliceLocation:s.floatString("x00201041"),pixelSpacing:r,rowPixelSpacing:a,columnPixelSpacing:o}}if(t===n.CINE)return{frameTime:s.floatString("x00181063")};if(t===n.IMAGE_PIXEL)return he(s);if(t===n.VOI_LUT){const e=be(s);return{windowCenter:Pe(s,"x00281050",1),windowWidth:Pe(s,"x00281051",1),voiLUTSequence:ye(e,s.elements.x00283010)}}if(t===n.MODALITY_LUT)return{rescaleIntercept:s.floatString("x00281052"),rescaleSlope:s.floatString("x00281053"),rescaleType:s.string("x00281054"),modalityLUTSequence:ye(s.uint16("x00280103"),s.elements.x00283000)};if(t===n.SOP_COMMON)return{sopClassUID:s.string("x00080016"),sopInstanceUID:s.string("x00080018")};if(t===n.PET_ISOTOPE){const e=s.elements.x00540016;if(void 0===e)return;const t=e.items[0].dataSet;return{radiopharmaceuticalInfo:{radiopharmaceuticalStartTime:o.parseTM(t.string("x00181072")||""),radionuclideTotalDose:t.floatString("x00181074"),radionuclideHalfLife:t.floatString("x00181075")}}}if(t===n.OVERLAY_PLANE)return function(e){const t=[];for(let r=0;r<=30;r+=2){let n=`x60${r.toString(16)}`;4===n.length&&(n=`x600${r.toString(16)}`);const o=e.elements[`${n}3000`];if(!o)continue;const a=[];for(let t=0;t<o.length;t++)for(let r=0;r<8;r++){const n=e.byteArray[o.dataOffset+t];a[8*t+r]=n>>r&1}t.push({rows:e.uint16(`${n}0010`),columns:e.uint16(`${n}0011`),type:e.string(`${n}0040`),x:e.int16(`${n}0050`,1)-1,y:e.int16(`${n}0050`,0)-1,pixelData:a,description:e.string(`${n}0022`),label:e.string(`${n}1500`),roiArea:e.string(`${n}1301`),roiMean:e.string(`${n}1302`),roiStandardDeviation:e.string(`${n}1303`)})}return{overlays:t}}(s);if("transferSyntax"===t){let e;try{e=s.string("x00020010")}catch(e){}return{transferSyntaxUID:e}}return t===n.PET_SERIES?{correctedImage:s.string("x00280051"),units:s.string("x00541001"),decayCorrection:s.string("x00541102")}:t===n.PET_IMAGE?{frameReferenceTime:s.floatString(s.string("x00541300")||""),actualFrameDuration:s.intString(s.string("x00181242"))}:"instance"===t?A(r,e,M):void 0}};let $e=[];const je={add:function(e){return"dicomfile:"+($e.push(e)-1)},get:function(e){return $e[e]},remove:function(e){$e[e]=void 0},purge:function(){$e=[]}};var Ve=o(713);function Ge(e,t){const{dicomParser:r}=ot;if(e.elements.x7fe00010&&e.elements.x7fe00010.basicOffsetTable.length)return r.readEncapsulatedImageFrame(e,e.elements.x7fe00010,t);if(function(e){return e.intString("x00280008")!==e.elements.x7fe00010.fragments.length}(e)){const n=r.createJPEGBasicOffsetTable(e,e.elements.x7fe00010);return r.readEncapsulatedImageFrame(e,e.elements.x7fe00010,t,n)}const n=e.elements.x7fe00010.fragments,o=new Ve.ByteStream(e.byteArrayParser,e.byteArray,e.elements.x7fe00010.dataOffset),a=(0,Ve.readSequenceItem)(o);if("xfffee000"!==a.tag)throw"dicomParser.readEncapsulatedPixelData: missing basic offset table xfffee000";o.seek(a.length);const i=o.position;if(t+1>n.length)throw"dicomParser.readEncapsulatedPixelData: frame exceeds number of fragments";const s=i+n[t].offset+8,l=n[t].length;return new Uint8Array(o.byteArray.buffer.slice(o.byteArray.byteOffset+s,o.byteArray.byteOffset+s+l))}function qe(e,t){return e&1<<t}const Ye=function(e,t,r){const n=new Uint8Array(r);for(let o=0;o<r;o++){const r=e[Math.floor(o/8)+t],a=o%8;n[o]=qe(r,a)?1:0}return n};const We=function(e,t){const r=e.elements.x7fe00010||e.elements.x7fe00008,n=e.uint16("x00280100"),o=e.uint16("x00280010"),a=e.uint16("x00280011");let i=e.uint16("x00280002");"YBR_FULL_422"===e.string("x00280004")&&(i=2,console.warn("Using SamplesPerPixel of 2 for YBR_FULL_422 photometric interpretation.\n See http://dicom.nema.org/medical/dicom/current/output/chtml/part03/sect_C.7.6.3.html for more information."));const s=r.dataOffset,l=o*a*i;let c;if(8===n){if(c=s+t*l,c>=e.byteArray.length)throw new Error("frame exceeds size of pixelData");return new Uint8Array(e.byteArray.buffer.slice(c,c+l))}if(16===n){if(c=s+t*l*2,c>=e.byteArray.length)throw new Error("frame exceeds size of pixelData");return new Uint8Array(e.byteArray.buffer.slice(c,c+2*l))}if(1===n){if(c=s+t*l*.125,c>=e.byteArray.length)throw new Error("frame exceeds size of pixelData");return Ye(e.byteArray,c,l)}if(32===n){if(c=s+t*l*4,c>=e.byteArray.length)throw new Error("frame exceeds size of pixelData");return new Uint8Array(e.byteArray.buffer.slice(c,c+4*l))}throw new Error("unsupported pixel format")};const ze=function(e){const t=we(e),r=parseInt(t.url,10),n=je.get(r);return new Promise(((e,t)=>{const r=new FileReader;r.onload=t=>{const r=t.target.result;e(r)},r.onerror=t,r.readAsArrayBuffer(n)}))};const He=function(e,t=0){const r=e.elements.x7fe00010||e.elements.x7fe00008;return r?r.encapsulatedPixelData?Ge(e,t):We(e,t):null};function Qe(e,t,r=0,n,o,a){const i=(new Date).getTime(),s={cancelFn:void 0,promise:void 0};return s.promise=new Promise(((l,c)=>{e.then((e=>{const u=He(e,r),f=e.string("x00020010"),d=(new Date).getTime(),m=ie(t,u,f,o);!function(e,t){e.decache=function(){const e=we(t);Fe.unload(e.url)}}(s,t),m.then((t=>{t.data=e,t.sharedCacheKey=n;const r=(new Date).getTime();t.loadTimeInMS=d-i,t.totalTimeInMS=r-i,void 0!==a&&void 0!==a.imageDoneCallback&&a.imageDoneCallback(t),l(t)}),(function(t){c({error:t,dataSet:e})}))}),(function(e){c({error:e})}))})),s}function Xe(e){return"dicomweb"===e||"wadouri"===e?c:"dicomfile"===e?ze:void 0}function Je(e,t={}){const r=we(e);delete(t=Object.assign({},t)).loader;const n=Xe(r.scheme);if(Fe.isLoaded(r.url)){return function(e,t,r=0,n,o){const a=(new Date).getTime();return{promise:new Promise(((i,s)=>{const l=(new Date).getTime();let c;try{const n=He(e,r),a=e.string("x00020010");c=ie(t,n,a,o)}catch(t){return void s({error:t,dataSet:e})}c.then((t=>{t.data=e,t.sharedCacheKey=n;const r=(new Date).getTime();t.loadTimeInMS=l-a,t.totalTimeInMS=r-a,i(t)}),s)})),cancelFn:void 0}}(Fe.get(r.url,n,e),e,r.pixelDataFrame,r.url,t)}return Qe(Fe.load(r.url,n,e),e,r.frame,r.url,t)}const Ke={metaData:{getImagePixelModule:he,getLUTs:ye,getModalityLUTOutputPixelRepresentation:be,getNumberValues:Pe,metaDataProvider:_e},dataSetCacheManager:Fe,fileManager:je,getEncapsulatedImageFrame:Ge,getUncompressedImageFrame:We,loadFileRequest:ze,loadImageFromPromise:Qe,getLoaderForScheme:Xe,loadImage:Je,parseImageId:we,unpackBinaryFrame:Ye,register:function(e){e.registerImageLoader("dicomweb",Je),e.registerImageLoader("wadouri",Je),e.registerImageLoader("dicomfile",Je),e.metaData.addProvider(_e)}};const Ze=function(e){me.register(e),Ke.register(e)};let et,tt;const rt=()=>new Worker(new URL(o.p+o.u(918),o.b),{type:void 0}),nt={set cornerstone(e){et=e,Ze(et);const t=l();nt.cornerstone.getWebWorkerManager().registerWorker("dicomImageLoader",rt,{maxWorkerInstances:t.maxWebWorkers||1})},get cornerstone(){if(!et){if(et=window&&window.cornerstone,!et)throw new Error("cornerstoneDICOMImageLoader requires a copy of Cornerstone to work properly. Please add cornerstoneDICOMImageLoader.external.cornerstone = cornerstone; to your application.");Ze(et)}return et},set dicomParser(e){tt=e},get dicomParser(){if(!tt){if(!window||!window.dicomParser)throw new Error("cornerstoneDICOMImageLoader requires a copy of dicomParser to work properly. Please add cornerstoneDICOMImageLoader.external.dicomParser = dicomParser; to your application.");tt=window.dicomParser}return tt}},ot=nt;function at(e,t){const r=e.length,n=new Uint8ClampedArray(r);for(let o=0;o<r;++o)n[o]=e[o]>>t;return n}function it(e,t,r){const n=e[`${t}PaletteColorLookupTableData`];if(n)return Promise.resolve(n);const o=ot.cornerstone.metaData.get("imagePixelModule",e.imageId);return o&&"function"==typeof o.then?o.then((e=>e?e[`${t}PaletteColorLookupTableData`]:r)):Promise.resolve(o?o[`${t}PaletteColorLookupTableData`]:r)}function st(e,t,r){const n=e.columns*e.rows,o=e.pixelData;Promise.all([it(e,"red",null),it(e,"green",null),it(e,"blue",null)]).then((([a,i,s])=>{if(!a||!i||!s)throw new Error("The image does not have a complete color palette. R, G, and B palette data are required.");const l=a.length;let c=0,u=0;const f=e.redPaletteColorLookupTableDescriptor[1],d=8===e.redPaletteColorLookupTableDescriptor[2]?0:8,m=at(a,d),g=at(i,d),p=at(s,d);if(r)for(let e=0;e<n;++e){let e=o[c++];e<f?e=0:e>f+l-1?e=l-1:e-=f,t[u++]=m[e],t[u++]=g[e],t[u++]=p[e],t[u++]=255}else for(let e=0;e<n;++e){let e=o[c++];e<f?e=0:e>f+l-1?e=l-1:e-=f,t[u++]=m[e],t[u++]=g[e],t[u++]=p[e]}}))}const lt=function(e){if(!e.cornerstone||!e.dicomParser)throw new Error('cornerstoneWADOImageLoader.configure: Options object must contain the keys "cornerstone" and "dicomParser".');s(e),ot.cornerstone=e.cornerstone,ot.dicomParser=e.dicomParser};const ct=function(e,t){if(t=t||e.transferSyntax,8===e.bitsAllocated&&"1.2.840.10008.1.2.4.50"===t&&(3===e.samplesPerPixel||4===e.samplesPerPixel))return!0},ut={convertRGBColorByPixel:e,convertRGBColorByPlane:t,convertYBRFullByPixel:r,convertYBRFullByPlane:n,convertPALETTECOLOR:st,wadouri:Ke,wadors:me,configure:lt,convertColorSpace:J,createImage:ie,decodeJPEGBaseline8BitColor:Z,getImageFrame:re,getPixelData:H,getMinMax:Q,isColorImage:ne,isJPEGBaseline8BitColor:ct,internal:u,external:nt}})(),a})()));
2
2
  //# sourceMappingURL=cornerstoneDICOMImageLoader.min.js.map