UNPKG

@alireza-beta-script/dicom-image-loader-new

Version:

Cornerstone Image Loader for DICOM WADO-URI and WADO-RS and Local file

1 lines 67 kB
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define("cornerstoneDICOMImageLoader",[],t):"object"==typeof exports?exports.cornerstoneDICOMImageLoader=t():e.cornerstoneDICOMImageLoader=t()}(this,(()=>(()=>{"use strict";var e={578:(e,t,n)=>{const r=n(823),o=n(187),a=n(592),i=n(604),s=n(249),l=n(968),c=Object.prototype.toString,{Z_NO_FLUSH:u,Z_FINISH:d,Z_OK:f,Z_STREAM_END:m,Z_NEED_DICT:g,Z_STREAM_ERROR:h,Z_DATA_ERROR:p,Z_MEM_ERROR:x}=n(684);function w(e){this.options=o.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&&0==(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 n=r.inflateInit2(this.strm,t.windowBits);if(n!==f)throw new Error(i[n]);if(this.header=new l,r.inflateGetHeader(this.strm,this.header),t.dictionary&&("string"==typeof t.dictionary?t.dictionary=a.string2buf(t.dictionary):"[object ArrayBuffer]"===c.call(t.dictionary)&&(t.dictionary=new Uint8Array(t.dictionary)),t.raw&&(n=r.inflateSetDictionary(this.strm,t.dictionary),n!==f)))throw new Error(i[n])}function b(e,t){const n=new w(t);if(n.push(e),n.err)throw n.msg||i[n.err];return n.result}w.prototype.push=function(e,t){const n=this.strm,o=this.options.chunkSize,i=this.options.dictionary;let s,l,w;if(this.ended)return!1;for(l=t===~~t?t:!0===t?d:u,"[object ArrayBuffer]"===c.call(e)?n.input=new Uint8Array(e):n.input=e,n.next_in=0,n.avail_in=n.input.length;;){for(0===n.avail_out&&(n.output=new Uint8Array(o),n.next_out=0,n.avail_out=o),s=r.inflate(n,l),s===g&&i&&(s=r.inflateSetDictionary(n,i),s===f?s=r.inflate(n,l):s===p&&(s=g));n.avail_in>0&&s===m&&n.state.wrap>0&&0!==e[n.next_in];)r.inflateReset(n),s=r.inflate(n,l);switch(s){case h:case p:case g:case x:return this.onEnd(s),this.ended=!0,!1}if(w=n.avail_out,n.next_out&&(0===n.avail_out||s===m))if("string"===this.options.to){let e=a.utf8border(n.output,n.next_out),t=n.next_out-e,r=a.buf2string(n.output,e);n.next_out=t,n.avail_out=o-t,t&&n.output.set(n.output.subarray(e,e+t),0),this.onData(r)}else this.onData(n.output.length===n.next_out?n.output:n.output.subarray(0,n.next_out));if(s!==f||0!==w){if(s===m)return s=r.inflateEnd(this.strm),this.onEnd(s),this.ended=!0,!0;if(0===n.avail_in)break}}return!0},w.prototype.onData=function(e){this.chunks.push(e)},w.prototype.onEnd=function(e){e===f&&("string"===this.options.to?this.result=this.chunks.join(""):this.result=o.flattenChunks(this.chunks)),this.chunks=[],this.err=e,this.msg=this.strm.msg},e.exports.Hq=function(e,t){return(t=t||{}).raw=!0,b(e,t)},n(684)},187:e=>{const t=(e,t)=>Object.prototype.hasOwnProperty.call(e,t);e.exports.assign=function(e){const n=Array.prototype.slice.call(arguments,1);for(;n.length;){const r=n.shift();if(r){if("object"!=typeof r)throw new TypeError(r+"must be non-object");for(const n in r)t(r,n)&&(e[n]=r[n])}}return e},e.exports.flattenChunks=e=>{let t=0;for(let n=0,r=e.length;n<r;n++)t+=e[n].length;const n=new Uint8Array(t);for(let t=0,r=0,o=e.length;t<o;t++){let o=e[t];n.set(o,r),r+=o.length}return n}},592:e=>{let t=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch(e){t=!1}const n=new Uint8Array(256);for(let e=0;e<256;e++)n[e]=e>=252?6:e>=248?5:e>=240?4:e>=224?3:e>=192?2:1;n[254]=n[254]=1,e.exports.string2buf=e=>{if("function"==typeof TextEncoder&&TextEncoder.prototype.encode)return(new TextEncoder).encode(e);let t,n,r,o,a,i=e.length,s=0;for(o=0;o<i;o++)n=e.charCodeAt(o),55296==(64512&n)&&o+1<i&&(r=e.charCodeAt(o+1),56320==(64512&r)&&(n=65536+(n-55296<<10)+(r-56320),o++)),s+=n<128?1:n<2048?2:n<65536?3:4;for(t=new Uint8Array(s),a=0,o=0;a<s;o++)n=e.charCodeAt(o),55296==(64512&n)&&o+1<i&&(r=e.charCodeAt(o+1),56320==(64512&r)&&(n=65536+(n-55296<<10)+(r-56320),o++)),n<128?t[a++]=n:n<2048?(t[a++]=192|n>>>6,t[a++]=128|63&n):n<65536?(t[a++]=224|n>>>12,t[a++]=128|n>>>6&63,t[a++]=128|63&n):(t[a++]=240|n>>>18,t[a++]=128|n>>>12&63,t[a++]=128|n>>>6&63,t[a++]=128|63&n);return t};e.exports.buf2string=(e,r)=>{const o=r||e.length;if("function"==typeof TextDecoder&&TextDecoder.prototype.decode)return(new TextDecoder).decode(e.subarray(0,r));let a,i;const s=new Array(2*o);for(i=0,a=0;a<o;){let t=e[a++];if(t<128){s[i++]=t;continue}let r=n[t];if(r>4)s[i++]=65533,a+=r-1;else{for(t&=2===r?31:3===r?15:7;r>1&&a<o;)t=t<<6|63&e[a++],r--;r>1?s[i++]=65533:t<65536?s[i++]=t:(t-=65536,s[i++]=55296|t>>10&1023,s[i++]=56320|1023&t)}}return((e,n)=>{if(n<65534&&e.subarray&&t)return String.fromCharCode.apply(null,e.length===n?e:e.subarray(0,n));let r="";for(let t=0;t<n;t++)r+=String.fromCharCode(e[t]);return r})(s,i)},e.exports.utf8border=(e,t)=>{(t=t||e.length)>e.length&&(t=e.length);let r=t-1;for(;r>=0&&128==(192&e[r]);)r--;return r<0||0===r?t:r+n[e[r]]>t?r:t}},693:e=>{e.exports=(e,t,n,r)=>{let o=65535&e|0,a=e>>>16&65535|0,i=0;for(;0!==n;){i=n>2e3?2e3:n,n-=i;do{o=o+t[r++]|0,a=a+o|0}while(--i);o%=65521,a%=65521}return o|a<<16|0}},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}},464:e=>{const t=new Uint32Array((()=>{let e,t=[];for(var n=0;n<256;n++){e=n;for(var r=0;r<8;r++)e=1&e?3988292384^e>>>1:e>>>1;t[n]=e}return t})());e.exports=(e,n,r,o)=>{const a=t,i=o+r;e^=-1;for(let t=o;t<i;t++)e=e>>>8^a[255&(e^n[t])];return-1^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,n){let r,o,a,i,s,l,c,u,d,f,m,g,h,p,x,w,b,y,k,v,T,D,S,P;const I=e.state;r=e.next_in,S=e.input,o=r+(e.avail_in-5),a=e.next_out,P=e.output,i=a-(n-e.avail_out),s=a+(e.avail_out-257),l=I.dmax,c=I.wsize,u=I.whave,d=I.wnext,f=I.window,m=I.hold,g=I.bits,h=I.lencode,p=I.distcode,x=(1<<I.lenbits)-1,w=(1<<I.distbits)-1;e:do{g<15&&(m+=S[r++]<<g,g+=8,m+=S[r++]<<g,g+=8),b=h[m&x];t:for(;;){if(y=b>>>24,m>>>=y,g-=y,y=b>>>16&255,0===y)P[a++]=65535&b;else{if(!(16&y)){if(0==(64&y)){b=h[(65535&b)+(m&(1<<y)-1)];continue t}if(32&y){I.mode=16191;break e}e.msg="invalid literal/length code",I.mode=t;break e}k=65535&b,y&=15,y&&(g<y&&(m+=S[r++]<<g,g+=8),k+=m&(1<<y)-1,m>>>=y,g-=y),g<15&&(m+=S[r++]<<g,g+=8,m+=S[r++]<<g,g+=8),b=p[m&w];n:for(;;){if(y=b>>>24,m>>>=y,g-=y,y=b>>>16&255,!(16&y)){if(0==(64&y)){b=p[(65535&b)+(m&(1<<y)-1)];continue n}e.msg="invalid distance code",I.mode=t;break e}if(v=65535&b,y&=15,g<y&&(m+=S[r++]<<g,g+=8,g<y&&(m+=S[r++]<<g,g+=8)),v+=m&(1<<y)-1,v>l){e.msg="invalid distance too far back",I.mode=t;break e}if(m>>>=y,g-=y,y=a-i,v>y){if(y=v-y,y>u&&I.sane){e.msg="invalid distance too far back",I.mode=t;break e}if(T=0,D=f,0===d){if(T+=c-y,y<k){k-=y;do{P[a++]=f[T++]}while(--y);T=a-v,D=P}}else if(d<y){if(T+=c+d-y,y-=d,y<k){k-=y;do{P[a++]=f[T++]}while(--y);if(T=0,d<k){y=d,k-=y;do{P[a++]=f[T++]}while(--y);T=a-v,D=P}}}else if(T+=d-y,y<k){k-=y;do{P[a++]=f[T++]}while(--y);T=a-v,D=P}for(;k>2;)P[a++]=D[T++],P[a++]=D[T++],P[a++]=D[T++],k-=3;k&&(P[a++]=D[T++],k>1&&(P[a++]=D[T++]))}else{T=a-v;do{P[a++]=P[T++],P[a++]=P[T++],P[a++]=P[T++],k-=3}while(k>2);k&&(P[a++]=P[T++],k>1&&(P[a++]=P[T++]))}break}}break}}while(r<o&&a<s);k=g>>3,r-=k,g-=k<<3,m&=(1<<g)-1,e.next_in=r,e.next_out=a,e.avail_in=r<o?o-r+5:5-(r-o),e.avail_out=a<s?s-a+257:257-(a-s),I.hold=m,I.bits=g}},823:(e,t,n)=>{const r=n(693),o=n(464),a=n(365),i=n(446),{Z_FINISH:s,Z_BLOCK:l,Z_TREES:c,Z_OK:u,Z_STREAM_END:d,Z_NEED_DICT:f,Z_STREAM_ERROR:m,Z_DATA_ERROR:g,Z_MEM_ERROR:h,Z_BUF_ERROR:p,Z_DEFLATED:x}=n(684),w=16180,b=16190,y=16191,k=16192,v=16194,T=16199,D=16200,S=16206,P=16209,I=16210,C=e=>(e>>>24&255)+(e>>>8&65280)+((65280&e)<<8)+((255&e)<<24);function _(){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 L=e=>{if(!e)return 1;const t=e.state;return!t||t.strm!==e||t.mode<w||t.mode>16211?1:0},A=e=>{if(L(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=w,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},E=e=>{if(L(e))return m;const t=e.state;return t.wsize=0,t.whave=0,t.wnext=0,A(e)},M=(e,t)=>{let n;if(L(e))return m;const r=e.state;return t<0?(n=0,t=-t):(n=5+(t>>4),t<48&&(t&=15)),t&&(t<8||t>15)?m:(null!==r.window&&r.wbits!==t&&(r.window=null),r.wrap=n,r.wbits=t,E(e))},R=(e,t)=>{if(!e)return m;const n=new _;e.state=n,n.strm=e,n.window=null,n.mode=w;const r=M(e,t);return r!==u&&(e.state=null),r};let F,O,B=!0;const U=e=>{if(B){F=new Int32Array(512),O=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,F,0,e.work,{bits:9}),t=0;t<32;)e.lens[t++]=5;i(2,e.lens,0,32,O,0,e.work,{bits:5}),B=!1}e.lencode=F,e.lenbits=9,e.distcode=O,e.distbits=5},N=(e,t,n,r)=>{let o;const a=e.state;return null===a.window&&(a.wsize=1<<a.wbits,a.wnext=0,a.whave=0,a.window=new Uint8Array(a.wsize)),r>=a.wsize?(a.window.set(t.subarray(n-a.wsize,n),0),a.wnext=0,a.whave=a.wsize):(o=a.wsize-a.wnext,o>r&&(o=r),a.window.set(t.subarray(n-r,n-r+o),a.wnext),(r-=o)?(a.window.set(t.subarray(n-r,n),0),a.wnext=r,a.whave=a.wsize):(a.wnext+=o,a.wnext===a.wsize&&(a.wnext=0),a.whave<a.wsize&&(a.whave+=o))),0};e.exports.inflateReset=E,e.exports.inflateReset2=M,e.exports.inflateResetKeep=A,e.exports.inflateInit=e=>R(e,15),e.exports.inflateInit2=R,e.exports.inflate=(e,t)=>{let n,_,A,E,M,R,F,O,B,j,W,Z,$,G,V,q,z,Y,H,K,J,X,Q=0;const ee=new Uint8Array(4);let te,ne;const re=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]);if(L(e)||!e.output||!e.input&&0!==e.avail_in)return m;n=e.state,n.mode===y&&(n.mode=k),M=e.next_out,A=e.output,F=e.avail_out,E=e.next_in,_=e.input,R=e.avail_in,O=n.hold,B=n.bits,j=R,W=F,X=u;e:for(;;)switch(n.mode){case w:if(0===n.wrap){n.mode=k;break}for(;B<16;){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}if(2&n.wrap&&35615===O){0===n.wbits&&(n.wbits=15),n.check=0,ee[0]=255&O,ee[1]=O>>>8&255,n.check=o(n.check,ee,2,0),O=0,B=0,n.mode=16181;break}if(n.head&&(n.head.done=!1),!(1&n.wrap)||(((255&O)<<8)+(O>>8))%31){e.msg="incorrect header check",n.mode=P;break}if((15&O)!==x){e.msg="unknown compression method",n.mode=P;break}if(O>>>=4,B-=4,J=8+(15&O),0===n.wbits&&(n.wbits=J),J>15||J>n.wbits){e.msg="invalid window size",n.mode=P;break}n.dmax=1<<n.wbits,n.flags=0,e.adler=n.check=1,n.mode=512&O?16189:y,O=0,B=0;break;case 16181:for(;B<16;){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}if(n.flags=O,(255&n.flags)!==x){e.msg="unknown compression method",n.mode=P;break}if(57344&n.flags){e.msg="unknown header flags set",n.mode=P;break}n.head&&(n.head.text=O>>8&1),512&n.flags&&4&n.wrap&&(ee[0]=255&O,ee[1]=O>>>8&255,n.check=o(n.check,ee,2,0)),O=0,B=0,n.mode=16182;case 16182:for(;B<32;){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}n.head&&(n.head.time=O),512&n.flags&&4&n.wrap&&(ee[0]=255&O,ee[1]=O>>>8&255,ee[2]=O>>>16&255,ee[3]=O>>>24&255,n.check=o(n.check,ee,4,0)),O=0,B=0,n.mode=16183;case 16183:for(;B<16;){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}n.head&&(n.head.xflags=255&O,n.head.os=O>>8),512&n.flags&&4&n.wrap&&(ee[0]=255&O,ee[1]=O>>>8&255,n.check=o(n.check,ee,2,0)),O=0,B=0,n.mode=16184;case 16184:if(1024&n.flags){for(;B<16;){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}n.length=O,n.head&&(n.head.extra_len=O),512&n.flags&&4&n.wrap&&(ee[0]=255&O,ee[1]=O>>>8&255,n.check=o(n.check,ee,2,0)),O=0,B=0}else n.head&&(n.head.extra=null);n.mode=16185;case 16185:if(1024&n.flags&&(Z=n.length,Z>R&&(Z=R),Z&&(n.head&&(J=n.head.extra_len-n.length,n.head.extra||(n.head.extra=new Uint8Array(n.head.extra_len)),n.head.extra.set(_.subarray(E,E+Z),J)),512&n.flags&&4&n.wrap&&(n.check=o(n.check,_,Z,E)),R-=Z,E+=Z,n.length-=Z),n.length))break e;n.length=0,n.mode=16186;case 16186:if(2048&n.flags){if(0===R)break e;Z=0;do{J=_[E+Z++],n.head&&J&&n.length<65536&&(n.head.name+=String.fromCharCode(J))}while(J&&Z<R);if(512&n.flags&&4&n.wrap&&(n.check=o(n.check,_,Z,E)),R-=Z,E+=Z,J)break e}else n.head&&(n.head.name=null);n.length=0,n.mode=16187;case 16187:if(4096&n.flags){if(0===R)break e;Z=0;do{J=_[E+Z++],n.head&&J&&n.length<65536&&(n.head.comment+=String.fromCharCode(J))}while(J&&Z<R);if(512&n.flags&&4&n.wrap&&(n.check=o(n.check,_,Z,E)),R-=Z,E+=Z,J)break e}else n.head&&(n.head.comment=null);n.mode=16188;case 16188:if(512&n.flags){for(;B<16;){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}if(4&n.wrap&&O!==(65535&n.check)){e.msg="header crc mismatch",n.mode=P;break}O=0,B=0}n.head&&(n.head.hcrc=n.flags>>9&1,n.head.done=!0),e.adler=n.check=0,n.mode=y;break;case 16189:for(;B<32;){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}e.adler=n.check=C(O),O=0,B=0,n.mode=b;case b:if(0===n.havedict)return e.next_out=M,e.avail_out=F,e.next_in=E,e.avail_in=R,n.hold=O,n.bits=B,f;e.adler=n.check=1,n.mode=y;case y:if(t===l||t===c)break e;case k:if(n.last){O>>>=7&B,B-=7&B,n.mode=S;break}for(;B<3;){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}switch(n.last=1&O,O>>>=1,B-=1,3&O){case 0:n.mode=16193;break;case 1:if(U(n),n.mode=T,t===c){O>>>=2,B-=2;break e}break;case 2:n.mode=16196;break;case 3:e.msg="invalid block type",n.mode=P}O>>>=2,B-=2;break;case 16193:for(O>>>=7&B,B-=7&B;B<32;){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}if((65535&O)!=(O>>>16^65535)){e.msg="invalid stored block lengths",n.mode=P;break}if(n.length=65535&O,O=0,B=0,n.mode=v,t===c)break e;case v:n.mode=16195;case 16195:if(Z=n.length,Z){if(Z>R&&(Z=R),Z>F&&(Z=F),0===Z)break e;A.set(_.subarray(E,E+Z),M),R-=Z,E+=Z,F-=Z,M+=Z,n.length-=Z;break}n.mode=y;break;case 16196:for(;B<14;){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}if(n.nlen=257+(31&O),O>>>=5,B-=5,n.ndist=1+(31&O),O>>>=5,B-=5,n.ncode=4+(15&O),O>>>=4,B-=4,n.nlen>286||n.ndist>30){e.msg="too many length or distance symbols",n.mode=P;break}n.have=0,n.mode=16197;case 16197:for(;n.have<n.ncode;){for(;B<3;){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}n.lens[re[n.have++]]=7&O,O>>>=3,B-=3}for(;n.have<19;)n.lens[re[n.have++]]=0;if(n.lencode=n.lendyn,n.lenbits=7,te={bits:n.lenbits},X=i(0,n.lens,0,19,n.lencode,0,n.work,te),n.lenbits=te.bits,X){e.msg="invalid code lengths set",n.mode=P;break}n.have=0,n.mode=16198;case 16198:for(;n.have<n.nlen+n.ndist;){for(;Q=n.lencode[O&(1<<n.lenbits)-1],V=Q>>>24,q=Q>>>16&255,z=65535&Q,!(V<=B);){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}if(z<16)O>>>=V,B-=V,n.lens[n.have++]=z;else{if(16===z){for(ne=V+2;B<ne;){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}if(O>>>=V,B-=V,0===n.have){e.msg="invalid bit length repeat",n.mode=P;break}J=n.lens[n.have-1],Z=3+(3&O),O>>>=2,B-=2}else if(17===z){for(ne=V+3;B<ne;){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}O>>>=V,B-=V,J=0,Z=3+(7&O),O>>>=3,B-=3}else{for(ne=V+7;B<ne;){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}O>>>=V,B-=V,J=0,Z=11+(127&O),O>>>=7,B-=7}if(n.have+Z>n.nlen+n.ndist){e.msg="invalid bit length repeat",n.mode=P;break}for(;Z--;)n.lens[n.have++]=J}}if(n.mode===P)break;if(0===n.lens[256]){e.msg="invalid code -- missing end-of-block",n.mode=P;break}if(n.lenbits=9,te={bits:n.lenbits},X=i(1,n.lens,0,n.nlen,n.lencode,0,n.work,te),n.lenbits=te.bits,X){e.msg="invalid literal/lengths set",n.mode=P;break}if(n.distbits=6,n.distcode=n.distdyn,te={bits:n.distbits},X=i(2,n.lens,n.nlen,n.ndist,n.distcode,0,n.work,te),n.distbits=te.bits,X){e.msg="invalid distances set",n.mode=P;break}if(n.mode=T,t===c)break e;case T:n.mode=D;case D:if(R>=6&&F>=258){e.next_out=M,e.avail_out=F,e.next_in=E,e.avail_in=R,n.hold=O,n.bits=B,a(e,W),M=e.next_out,A=e.output,F=e.avail_out,E=e.next_in,_=e.input,R=e.avail_in,O=n.hold,B=n.bits,n.mode===y&&(n.back=-1);break}for(n.back=0;Q=n.lencode[O&(1<<n.lenbits)-1],V=Q>>>24,q=Q>>>16&255,z=65535&Q,!(V<=B);){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}if(q&&0==(240&q)){for(Y=V,H=q,K=z;Q=n.lencode[K+((O&(1<<Y+H)-1)>>Y)],V=Q>>>24,q=Q>>>16&255,z=65535&Q,!(Y+V<=B);){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}O>>>=Y,B-=Y,n.back+=Y}if(O>>>=V,B-=V,n.back+=V,n.length=z,0===q){n.mode=16205;break}if(32&q){n.back=-1,n.mode=y;break}if(64&q){e.msg="invalid literal/length code",n.mode=P;break}n.extra=15&q,n.mode=16201;case 16201:if(n.extra){for(ne=n.extra;B<ne;){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}n.length+=O&(1<<n.extra)-1,O>>>=n.extra,B-=n.extra,n.back+=n.extra}n.was=n.length,n.mode=16202;case 16202:for(;Q=n.distcode[O&(1<<n.distbits)-1],V=Q>>>24,q=Q>>>16&255,z=65535&Q,!(V<=B);){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}if(0==(240&q)){for(Y=V,H=q,K=z;Q=n.distcode[K+((O&(1<<Y+H)-1)>>Y)],V=Q>>>24,q=Q>>>16&255,z=65535&Q,!(Y+V<=B);){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}O>>>=Y,B-=Y,n.back+=Y}if(O>>>=V,B-=V,n.back+=V,64&q){e.msg="invalid distance code",n.mode=P;break}n.offset=z,n.extra=15&q,n.mode=16203;case 16203:if(n.extra){for(ne=n.extra;B<ne;){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}n.offset+=O&(1<<n.extra)-1,O>>>=n.extra,B-=n.extra,n.back+=n.extra}if(n.offset>n.dmax){e.msg="invalid distance too far back",n.mode=P;break}n.mode=16204;case 16204:if(0===F)break e;if(Z=W-F,n.offset>Z){if(Z=n.offset-Z,Z>n.whave&&n.sane){e.msg="invalid distance too far back",n.mode=P;break}Z>n.wnext?(Z-=n.wnext,$=n.wsize-Z):$=n.wnext-Z,Z>n.length&&(Z=n.length),G=n.window}else G=A,$=M-n.offset,Z=n.length;Z>F&&(Z=F),F-=Z,n.length-=Z;do{A[M++]=G[$++]}while(--Z);0===n.length&&(n.mode=D);break;case 16205:if(0===F)break e;A[M++]=n.length,F--,n.mode=D;break;case S:if(n.wrap){for(;B<32;){if(0===R)break e;R--,O|=_[E++]<<B,B+=8}if(W-=F,e.total_out+=W,n.total+=W,4&n.wrap&&W&&(e.adler=n.check=n.flags?o(n.check,A,W,M-W):r(n.check,A,W,M-W)),W=F,4&n.wrap&&(n.flags?O:C(O))!==n.check){e.msg="incorrect data check",n.mode=P;break}O=0,B=0}n.mode=16207;case 16207:if(n.wrap&&n.flags){for(;B<32;){if(0===R)break e;R--,O+=_[E++]<<B,B+=8}if(4&n.wrap&&O!==(4294967295&n.total)){e.msg="incorrect length check",n.mode=P;break}O=0,B=0}n.mode=16208;case 16208:X=d;break e;case P:X=g;break e;case I:return h;default:return m}return e.next_out=M,e.avail_out=F,e.next_in=E,e.avail_in=R,n.hold=O,n.bits=B,(n.wsize||W!==e.avail_out&&n.mode<P&&(n.mode<S||t!==s))&&N(e,e.output,e.next_out,W-e.avail_out)?(n.mode=I,h):(j-=e.avail_in,W-=e.avail_out,e.total_in+=j,e.total_out+=W,n.total+=W,4&n.wrap&&W&&(e.adler=n.check=n.flags?o(n.check,A,W,e.next_out-W):r(n.check,A,W,e.next_out-W)),e.data_type=n.bits+(n.last?64:0)+(n.mode===y?128:0)+(n.mode===T||n.mode===v?256:0),(0===j&&0===W||t===s)&&X===u&&(X=p),X)},e.exports.inflateEnd=e=>{if(L(e))return m;let t=e.state;return t.window&&(t.window=null),e.state=null,u},e.exports.inflateGetHeader=(e,t)=>{if(L(e))return m;const n=e.state;return 0==(2&n.wrap)?m:(n.head=t,t.done=!1,u)},e.exports.inflateSetDictionary=(e,t)=>{const n=t.length;let o,a,i;return L(e)?m:(o=e.state,0!==o.wrap&&o.mode!==b?m:o.mode===b&&(a=1,a=r(a,t,n,0),a!==o.check)?g:(i=N(e,t,n,n),i?(o.mode=I,h):(o.havedict=1,u)))},e.exports.inflateInfo="pako inflate (from Nodeca project)"},446:e=>{const t=15,n=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]),r=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]),o=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]),a=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,d,f)=>{const m=f.bits;let g,h,p,x,w,b,y=0,k=0,v=0,T=0,D=0,S=0,P=0,I=0,C=0,_=0,L=null;const A=new Uint16Array(16),E=new Uint16Array(16);let M,R,F,O=null;for(y=0;y<=t;y++)A[y]=0;for(k=0;k<l;k++)A[i[s+k]]++;for(D=m,T=t;T>=1&&0===A[T];T--);if(D>T&&(D=T),0===T)return c[u++]=20971520,c[u++]=20971520,f.bits=1,0;for(v=1;v<T&&0===A[v];v++);for(D<v&&(D=v),I=1,y=1;y<=t;y++)if(I<<=1,I-=A[y],I<0)return-1;if(I>0&&(0===e||1!==T))return-1;for(E[1]=0,y=1;y<t;y++)E[y+1]=E[y]+A[y];for(k=0;k<l;k++)0!==i[s+k]&&(d[E[i[s+k]]++]=k);if(0===e?(L=O=d,b=20):1===e?(L=n,O=r,b=257):(L=o,O=a,b=0),_=0,k=0,y=v,w=u,S=D,P=0,p=-1,C=1<<D,x=C-1,1===e&&C>852||2===e&&C>592)return 1;for(;;){M=y-P,d[k]+1<b?(R=0,F=d[k]):d[k]>=b?(R=O[d[k]-b],F=L[d[k]-b]):(R=96,F=0),g=1<<y-P,h=1<<S,v=h;do{h-=g,c[w+(_>>P)+h]=M<<24|R<<16|F|0}while(0!==h);for(g=1<<y-1;_&g;)g>>=1;if(0!==g?(_&=g-1,_+=g):_=0,k++,0==--A[y]){if(y===T)break;y=i[s+d[k]]}if(y>D&&(_&x)!==p){for(0===P&&(P=D),w+=v,S=y-P,I=1<<S;S+P<T&&(I-=A[S+P],!(I<=0));)S++,I<<=1;if(C+=1<<S,1===e&&C>852||2===e&&C>592)return 1;p=_&x,c[p]=D<<24|S<<16|w-u|0}}return 0!==_&&(c[w+_]=y-P<<24|64<<16|0),f.bits=D,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}}},t={};function n(r){var o=t[r];if(void 0!==o)return o.exports;var a=t[r]={exports:{}};return e[r](a,a.exports,n),a.exports}n.d=(e,t)=>{for(var r in t)n.o(t,r)&&!n.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},n.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),n.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),n.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},(()=>{var e;n.g.importScripts&&(e=n.g.location+"");var t=n.g.document;if(!e&&t&&(t.currentScript&&(e=t.currentScript.src),!e)){var r=t.getElementsByTagName("script");if(r.length)for(var o=r.length-1;o>-1&&!e;)e=r[o--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),n.p=e})();var r={};return(()=>{function e(e,t,n){if(void 0===e)throw new Error("decodeRGB: rgbBuffer must not be undefined");if(e.length%3!=0)throw new Error("decodeRGB: rgbBuffer length must be divisible by 3");const r=e.length/3;let o=0,a=0;if(n)for(let n=0;n<r;n++)t[a++]=e[o++],t[a++]=e[o++],t[a++]=e[o++],t[a++]=255;else t.set(e)}function t(e,t,n){if(void 0===e)throw new Error("decodeRGB: rgbBuffer must not be undefined");if(e.length%3!=0)throw new Error("decodeRGB: rgbBuffer length must be divisible by 3");const r=e.length/3;let o=0,a=0,i=r,s=2*r;if(n)for(let n=0;n<r;n++)t[o++]=e[a++],t[o++]=e[i++],t[o++]=e[s++],t[o++]=255;else t.set(e)}function o(e,t,n){if(void 0===e)throw new Error("decodeRGB: ybrBuffer must not be undefined");if(e.length%3!=0)throw new Error("decodeRGB: ybrBuffer length must be divisble by 3");const r=e.length/3;let o=0,a=0;if(n)for(let n=0;n<r;n++){const n=e[o++],r=e[o++],i=e[o++];t[a++]=n+1.402*(i-128),t[a++]=n-.34414*(r-128)-.71414*(i-128),t[a++]=n+1.772*(r-128),t[a++]=255}else for(let n=0;n<r;n++){const n=e[o++],r=e[o++],i=e[o++];t[a++]=n+1.402*(i-128),t[a++]=n-.34414*(r-128)-.71414*(i-128),t[a++]=n+1.772*(r-128)}}function a(e,t,n){if(void 0===e)throw new Error("decodeRGB: ybrBuffer must not be undefined");if(e.length%3!=0)throw new Error("decodeRGB: ybrBuffer length must be divisble by 3");const r=e.length/3;let o=0,a=0,i=r,s=2*r;if(n)for(let n=0;n<r;n++){const n=e[a++],r=e[i++],l=e[s++];t[o++]=n+1.402*(l-128),t[o++]=n-.34414*(r-128)-.71414*(l-128),t[o++]=n+1.772*(r-128),t[o++]=255}else for(let n=0;n<r;n++){const n=e[a++],r=e[i++],l=e[s++];t[o++]=n+1.402*(l-128),t[o++]=n-.34414*(r-128)-.71414*(l-128),t[o++]=n+1.772*(r-128)}}function i(e,t){const n=e.length,r=new Uint8ClampedArray(n);for(let o=0;o<n;++o)r[o]=e[o]>>t;return r}function s(e,t,n){const r=e.columns*e.rows,o=e.pixelData,a=e.redPaletteColorLookupTableData,s=e.greenPaletteColorLookupTableData,l=e.bluePaletteColorLookupTableData,c=e.redPaletteColorLookupTableData.length;let u=0,d=0;const f=e.redPaletteColorLookupTableDescriptor[1],m=8===e.redPaletteColorLookupTableDescriptor[2]?0:8,g=i(a,m),h=i(s,m),p=i(l,m);if(n)for(let e=0;e<r;++e){let e=o[u++];e<f?e=0:e>f+c-1?e=c-1:e-=f,t[d++]=g[e],t[d++]=h[e],t[d++]=p[e],t[d++]=255}else for(let e=0;e<r;++e){let e=o[u++];e<f?e=0:e>f+c-1?e=c-1:e-=f,t[d++]=g[e],t[d++]=h[e],t[d++]=p[e]}}function l(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 c(e,t,n){const r=[],o=e.elements[t];for(let a=0;a<n[0];a++)16===n[2]?r[a]=e.uint16(t,a):r[a]=e.byteArray[a+o.dataOffset];return r}n.r(r),n.d(r,{configure:()=>tt,convertColorSpace:()=>V,convertPALETTECOLOR:()=>s,convertRGBColorByPixel:()=>e,convertRGBColorByPlane:()=>t,convertYBRFullByPixel:()=>o,convertYBRFullByPlane:()=>a,createImage:()=>pe,decodeImageFrame:()=>ce,decodeJPEGBaseline8BitColor:()=>z,default:()=>nt,external:()=>Te,getImageFrame:()=>ue,getMinMax:()=>$,getPixelData:()=>Z,internal:()=>j,isColorImage:()=>de,isJPEGBaseline8BitColor:()=>fe,wadors:()=>we,wadouri:()=>et,webWorkerManager:()=>ie});const u=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=l(e,"x00281101"),t.greenPaletteColorLookupTableDescriptor=l(e,"x00281102"),t.bluePaletteColorLookupTableDescriptor=l(e,"x00281103"),0===t.redPaletteColorLookupTableDescriptor[0]&&(t.redPaletteColorLookupTableDescriptor[0]=65536,t.greenPaletteColorLookupTableDescriptor[0]=65536,t.bluePaletteColorLookupTableDescriptor[0]=65536);const n=t.redPaletteColorLookupTableDescriptor[0],r=e.elements.x00281201.length===n?8:16;t.redPaletteColorLookupTableDescriptor[2]!==r&&(t.redPaletteColorLookupTableDescriptor[2]=r,t.greenPaletteColorLookupTableDescriptor[2]=r,t.bluePaletteColorLookupTableDescriptor[2]=r),t.redPaletteColorLookupTableData=c(e,"x00281201",t.redPaletteColorLookupTableDescriptor),t.greenPaletteColorLookupTableData=c(e,"x00281202",t.greenPaletteColorLookupTableDescriptor),t.bluePaletteColorLookupTableData=c(e,"x00281203",t.bluePaletteColorLookupTableDescriptor)}(e,t),t};function d(e,t){let n=t.uint16("x00283002",0);0===n&&(n=65535);let r=0;r=0===e?t.uint16("x00283002",1):t.int16("x00283002",1);const o={id:"1",firstValueMapped:r,numBitsPerEntry:t.uint16("x00283002",2),lut:[]};for(let r=0;r<n;r++)o.lut[r]=0===e?t.uint16("x00283006",r):t.int16("x00283006",r);return o}const f=function(e,t){if(!t||!t.items||!t.items.length)return;const n=[];for(let r=0;r<t.items.length;r++){const o=d(e,t.items[r].dataSet);o&&n.push(o)}return n};const m=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 n=e.floatString("x00281052"),r=e.floatString("x00281053");if(void 0!==n&&void 0!==r){const t=function(e){const t=e.uint16("x00280103"),n=e.uint16("x00280101");return 0===t?0:-1<<n-1}(e);return t*r+n<0?1:0}return e.elements.x00283000&&e.elements.x00283000.length>0?0:e.uint16("x00280103")};const g=function(e,t,n){const r=[],o=e.string(t);if(!o)return;const a=o.split("\\");if(!(n&&a.length<n)){for(let e=0;e<a.length;e++)r.push(parseFloat(a[e]));return r}};const h=function(e,t,n){return t=t||0,e&&e.Value?e.Value.length<=t?n:e.Value[t]:n};const p=function(e,t,n){const r=h(e,t,n);if(void 0!==r)return parseFloat(r)};const x=function(e,t){const n=h(e,t);if(void 0!==n)return parseFloat(n)};const w=function(e,t){if(!e)return;if(!e.Value)return;if(!Array.isArray(e.Value))return;if(t&&e.Value.length<t)return;const n=[];for(let t=0;t<e.Value.length;t++)n.push(parseFloat(e.Value[t]));return n};function b(e){const t=e.indexOf(":");return e.substring(t+1)}function y(e){let t=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];return e&&e.Value?e.Value[0]&&t?e.Value[0]:e.Value:e}function k(e,t,n){return{shared:(t?Object.values(t[0]):[]).map((e=>e[0])).filter((e=>void 0!==e&&"object"==typeof e)),perFrame:(e?Object.values(e[n-1]):[]).map((e=>e.Value[0])).filter((e=>void 0!==e&&"object"==typeof e))}}function v(e){let{52009230:t,52009229:n,"00280008":r,...o}=e;return t=y(t,!1),n=y(n,!1),r=y(r),{PerFrameFunctionalGroupsSequence:t,SharedFunctionalGroupsSequence:n,NumberOfFrames:r,rest:o}}function T(e){const t=e.indexOf("/frames/")+8,n=e.slice(0,t),r=parseInt(e.slice(t),10);return{metadata:S[`${n}1`],frame:r}}const D={_retrieveMultiframeMetadata:T,retrieveMultiframeMetadata:function(e){return T(b(e))},isMultiframe:function(e){const t=h(e["00280008"]);return t&&t>1}};let S=[],P={};const I={add:function(e,t){const n=b(e);t.isMultiframe=D.isMultiframe(t),S[n]=t},get:function(e){const t=b(e),n=S[t];if(n&&!n?.isMultiframe)return n;const r=P[t];if(r)return r;const o=D._retrieveMultiframeMetadata(t);if(!o||!o.metadata)return;const{metadata:a,frame:i}=o;if(a){const e=function(e,t){const{PerFrameFunctionalGroupsSequence:n,SharedFunctionalGroupsSequence:r,NumberOfFrames:o,rest:a}=v(t);if(n||o>1){const{shared:i,perFrame:s}=k(n,r,e),l=Object.assign(t,{frameNumber:e});return[...i,...s].forEach((e=>{Object.entries(e).forEach((e=>{let[t,n]=e;l[t]=n}))})),Object.assign(a,{"00280008":o},l)}return t}(i,a);return P[t]=e,e}},remove:function(e){const t=b(e);S[t]=void 0,P[t]=void 0},purge:function(){S=[],P={}}};function C(e){return"RECON TOMO"===e||"RECON GATED TOMO"===e}function _(e){return h(e["00080060"]).includes("NM")}function L(e,t){const n=y(e["00080008"],!1);if(n)return n[t]}function A(e){let t=w(e["00200037"],6);return!t&&_(e)&&(t=function(e){let t;const n=L(e,2);if(n&&C(n)){const n=y(e["00540022"]);n&&(t=w(n["00200037"],6))}return t}(e)),t}function E(e){let t=w(e["00200032"],3);return!t&&_(e)&&(t=function(e){let t;const n=L(e,2);if(n&&C(n)){const n=y(e["00540022"]);n&&(t=w(n["00200032"],3))}return t}(e)),t}const M=function(e,t){if("multiframeModule"===e){const{metadata:e,frame:n}=D.retrieveMultiframeMetadata(t);if(!e)return;const{PerFrameFunctionalGroupsSequence:r,SharedFunctionalGroupsSequence:o,NumberOfFrames:a}=v(e);if(r||a>1){const{shared:e,perFrame:t}=k(r,o,n);return{NumberOfFrames:a,PerFrameFunctionalInformation:t,SharedFunctionalInformation:e}}return{NumberOfFrames:a}}const{dicomParser:n}=Te,r=I.get(t);if(r){if("generalSeriesModule"===e)return{modality:h(r["00080060"]),seriesInstanceUID:h(r["0020000E"]),seriesNumber:x(r["00200011"]),studyInstanceUID:h(r["0020000D"]),seriesDate:n.parseDA(h(r["00080021"])),seriesTime:n.parseTM(h(r["00080031"],0,"")),acquisitionDate:n.parseDA(h(r["00080022"]),""),acquisitionTime:n.parseTM(h(r["00080032"],0,""))};if("patientStudyModule"===e)return{patientAge:x(r["00101010"]),patientSize:x(r["00101020"]),patientSex:h(r["00100040"]),patientWeight:x(r["00101030"])};if("nmMultiframeGeometryModule"===e){const e=h(r["00080060"]),t=L(r,2);return{modality:e,imageType:h(r["00080008"]),imageSubType:t,imageOrientationPatient:A(r),imagePositionPatient:E(r),sliceThickness:x(r["00180050"]),pixelSpacing:w(r["00280030"],2),numberOfFrames:x(r["00280008"]),isNMReconstructable:C(t)&&e.includes("NM")}}if("imagePlaneModule"===e){const e=A(r),t=E(r),n=w(r["00280030"],2);let o=null,a=null;n&&(a=n[0],o=n[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:h(r["00200052"]),rows:x(r["00280010"]),columns:x(r["00280011"]),imageOrientationPatient:e,rowCosines:i,columnCosines:s,imagePositionPatient:t,sliceThickness:x(r["00180050"]),sliceLocation:x(r["00201041"]),pixelSpacing:n,rowPixelSpacing:a,columnPixelSpacing:o}}if("imagePixelModule"===e)return{samplesPerPixel:x(r["00280002"]),photometricInterpretation:h(r["00280004"]),rows:x(r["00280010"]),columns:x(r["00280011"]),bitsAllocated:x(r["00280100"]),bitsStored:x(r["00280101"]),highBit:h(r["00280102"]),pixelRepresentation:x(r["00280103"]),planarConfiguration:x(r["00280006"]),pixelAspectRatio:h(r["00280034"]),smallestPixelValue:x(r["00280106"]),largestPixelValue:x(r["00280107"]),redPaletteColorLookupTableDescriptor:w(r["00281101"]),greenPaletteColorLookupTableDescriptor:w(r["00281102"]),bluePaletteColorLookupTableDescriptor:w(r["00281103"]),redPaletteColorLookupTableData:w(r["00281201"]),greenPaletteColorLookupTableData:w(r["00281202"]),bluePaletteColorLookupTableData:w(r["00281203"])};if("voiLutModule"===e)return{windowCenter:w(r["00281050"],1),windowWidth:w(r["00281051"],1)};if("modalityLutModule"===e)return{rescaleIntercept:x(r["00281052"]),rescaleSlope:x(r["00281053"]),rescaleType:h(r["00281054"])};if("sopCommonModule"===e)return{sopClassUID:h(r["00080016"]),sopInstanceUID:h(r["00080018"])};if("petIsotopeModule"===e){const e=h(r["00540016"]);if(void 0===e)return;return{radiopharmaceuticalInfo:{radiopharmaceuticalStartTime:n.parseTM(h(e["00181072"],0,"")),radiopharmaceuticalStartDateTime:h(e["00181078"],0,""),radionuclideTotalDose:x(e["00181074"]),radionuclideHalfLife:x(e["00181075"])}}}return"overlayPlaneModule"===e?function(e){const t=[];for(let n=0;n<=30;n+=2){let r=`x60${n.toString(16)}`;4===r.length&&(r=`x600${n.toString(16)}`);const o=h(e[`${r}3000`]);if(!o)continue;const a=[];for(let t=0;t<o.length;t++)for(let n=0;n<8;n++){const r=e.Value[o.dataOffset+t];a[8*t+n]=r>>n&1}t.push({rows:x(e[`${r}0010`]),columns:x(e[`${r}0011`]),type:h(e[`${r}0040`]),x:x(e[`${r}0050`],1)-1,y:x(e[`${r}0050`],0)-1,pixelData:a,description:h(e[`${r}0022`]),label:h(e[`${r}1500`]),roiArea:h(e[`${r}1301`]),roiMean:h(e[`${r}1302`]),roiStandardDeviation:h(e[`${r}1303`])})}return{overlays:t}}(r):"transferSyntax"===e?{transferSyntaxUID:h(r["00020010"])}:"petSeriesModule"===e?{correctedImage:h(r["00280051"]),units:h(r["00541001"]),decayCorrection:h(r["00541102"])}:"petImageModule"===e?{frameReferenceTime:x(r["00541300"]),actualFrameDuration:x(r["00181242"])}:void 0}};function R(e,t,n){if(n+e.length>t.length)return!1;let r=n;for(let n=0;n<e.length;n++)if(e[n]!==t[r++])return!1;return!0}const F=function(e,t,n){n=n||0;const r=function(e){const t=new Uint8Array(e.length);for(let n=0,r=e.length;n<r;n++)t[n]=e.charCodeAt(n);return t}(t);for(let t=n;t<e.length;t++)if(r[0]===e[t]&&R(r,e,t))return t;return-1};let O={open(e,t){e.open("get",t,!0)},beforeSend(){},beforeProcessing:e=>Promise.resolve(e.response),imageCreated(){},strict:!1,decodeConfig:{convertFloatPixelDataToInt:!0,use16BitDataType:!1}};function B(e){O=Object.assign(O,e)}function U(){return O}const N=function(e,t){let n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};const{cornerstone:o}=Te,a=U(),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,l=new Promise(((l,c)=>{a.open(s,e,n,r);const u=a.beforeSend(s,t,n,r);s.responseType="arraybuffer";const d=Object.assign({},n,u);Object.keys(d).forEach((function(t){null!==d[t]&&("Accept"===t&&-1!==e.indexOf("accept=")||s.setRequestHeader(t,d[t]))})),r.deferred={resolve:l,reject:c},r.url=e,r.imageId=t,s.onloadstart=function(n){a.onloadstart&&a.onloadstart(n,r);const i={url:e,imageId:t};o.triggerEvent(o.events,"cornerstoneimageloadstart",i)},s.onloadend=function(n){a.onloadend&&a.onloadend(n,r);const i={url:e,imageId:t};o.triggerEvent(o.events,"cornerstoneimageloadend",i)},s.onreadystatechange=function(e){a.onreadystatechange?a.onreadystatechange(e,r):4===s.readyState&&(200===s.status?a.beforeProcessing(s).then(l).catch((()=>{i(s),c(s)})):(i(s),c(s)))},s.onprogress=function(n){const i=n.loaded;let s,l;n.lengthComputable&&(s=n.total,l=Math.round(i/s*100)),a.onprogress&&a.onprogress(n,r);const c={url:e,imageId:t,loaded:i,total:s,percentComplete:l};o.triggerEvent(o.events,o.EVENTS.IMAGE_LOAD_PROGRESS,c)},s.onerror=function(){i(s),c(s)},s.onabort=function(){i(s),c(s)},s.send()}));return l.xhr=s,l},j={xhrRequest:N,setOptions:B,getOptions:U};function W(e){for(let t=0;t<e.length;t++)if("Content-Type:"===e[t].substr(0,13))return e[t].substr(13).trim()}const Z=function(e,t){const n={Accept:arguments.length>2&&void 0!==arguments[2]?arguments[2]:"application/octet-stream"};return new Promise(((r,o)=>{const a=N(e,t,n),{xhr:i}=a;a.then((function(e){const t=new Uint8Array(e),n=i.getResponseHeader("Content-Type")||"application/octet-stream";if(-1===n.indexOf("multipart"))return void r({contentType:n,imageFrame:{pixelData:t}});const a=F(t,"\r\n\r\n");-1===a&&o(new Error("invalid response - no multipart mime header"));const s=function(e,t,n){t=t||0,n=n||e.length-t;let r="";for(let o=t;o<t+n;o++)r+=String.fromCharCode(e[o]);return r}(t,0,a),l=s.split("\r\n"),c=function(e){for(let t=0;t<e.length;t++)if("--"===e[t].substr(0,2))return e[t]}(l);c||o(new Error("invalid response - no boundary marker"));const u=a+4,d=F(t,c,u);-1===d&&o(new Error("invalid response - terminating boundary not found"));const f=d-u-2;r({contentType:W(l),imageFrame:{pixelData:new Uint8Array(e,u,f)}})}),o)}))};const $=function(e){let t,n=e[0],r=e[0];const o=e.length;for(let a=1;a<o;a++)t=e[a],n=Math.min(n,t),r=Math.max(r,t);return{min:n,max:r}};function G(n,r,o){0===n.planarConfiguration?e(n.pixelData,r,o):t(n.pixelData,r,o)}function V(e,t,n){if("RGB"===e.photometricInterpretation)G(e,t,n);else if("YBR_RCT"===e.photometricInterpretation)G(e,t,n);else if("YBR_ICT"===e.photometricInterpretation)G(e,t,n);else if("PALETTE COLOR"===e.photometricInterpretation)s(e,t,n);else if("YBR_FULL_422"===e.photometricInterpretation)!function(e,t,n){if(void 0===e)throw new Error("decodeRGB: ybrBuffer must not be undefined");if(e.length%2!=0)throw new Error("decodeRGB: ybrBuffer length must be divisble by 3");const r=e.length/2;let o=0,a=0;if(n)for(let n=0;n<r;n+=2){const n=e[o++],r=e[o++],i=e[o++],s=e[o++];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,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}else for(let n=0;n<r;n+=2){const n=e[o++],r=e[o++],i=e[o++],s=e[o++];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++]=r+1.402*(s-128),t[a++]=r-.34414*(i-128)-.71414*(s-128),t[a++]=r+1.772*(i-128)}}(e.pixelData,t,n);else{if("YBR_FULL"!==e.photometricInterpretation)throw new Error(`No color space conversion for photometric interpretation ${e.photometricInterpretation}`);!function(e,t,n){0===e.planarConfiguration?o(e.pixelData,t,n):a(e.pixelData,t,n)}(e,t,n)}}function q(e){return function(e){let t;try{return decodeURIComponent(escape(e))}catch(n){if(t=n,t instanceof URIError)return e;throw t}}(String.fromCharCode.apply(null,Array.prototype.slice.apply(new Uint8Array(e))))}const z=function(e,t,n){const r=(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(){n.height=o.height,n.width=o.width,e.rows=o.height,e.columns=o.width;const a=n.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-r;const l=$(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(q(i.result))}`:o.src=`data:image/jpeg;base64,${window.btoa(i.result)}`},i.onerror=e=>{a(e)}}))};function Y(){return new Worker(n.p+"index.worker.ea71efba2ce63c499055.worker.js")}let H=0;const K=[],J=[],X=U(),Q={maxWebWorkers:navigator.hardwareConcurrency||1,startWebWorkersOnDemand:!0,webWorkerTaskPaths:[],taskConfiguration:{decodeTask:{initializeCodecsOnStartup:!1,strict:X.strict}}};let ee;const te={maxWebWorkers:0,numWebWorkers:0,numTasksQueued:0,numTasksExecuting:0,numTasksCompleted:0,totalTaskTimeInMS:0,totalTimeDelayedInMS:0};function ne(){if(K.length){for(let e=0;e<J.length;e++)if("ready"===J[e].status){J[e].status="busy";const t=K.shift();t.start=(new Date).getTime();const n=(new Date).getTime();return te.totalTimeDelayedInMS+=n-t.added,J[e].task=t,J[e].worker.postMessage({taskType:t.taskType,workerIndex:e,data:t.data},t.transferList),void te.numTasksExecuting++}J.length<ee.maxWebWorkers&&oe()}}function re(e){if("initialize"===e.data.taskType)J[e.data.workerIndex].status="ready",ne();else{const t=J[e.data.workerIndex].task.start,n="success"===e.data.status?"resolve":"reject";try{J[e.data.workerIndex].task.deferred[n](e.data.result)}catch(e){console.warn("Caught error delivering response",e)}J[e.data.workerIndex].task=void 0,te.numTasksExecuting--,J[e.data.workerIndex].status="ready",te.numTasksCompleted++;const r=(new Date).getTime();te.totalTaskTimeInMS+=r-t,ne()}}function oe(){if(J.length>=ee.maxWebWorkers)return;const e=new Y;J.push({worker:e,status:"initializing"}),e.addEventListener("message",re),e.postMessage({taskType:"initialize",workerIndex:J.length-1,config:ee})}function ae(e){if(ee=e=e||Q,ee.maxWebWorkers=ee.maxWebWorkers||navigator.hardwareConcurrency||1,!ee.startWebWorkersOnDemand)for(let e=0;e<ee.maxWebWorkers;e++)oe()}const ie={initialize:ae,loadWebWorkerTask:function(e,t){ee.webWorkerTaskPaths.push(e),t&&(ee.taskConfiguration=Object.assign(ee.taskConfiguration,t));for(let t=0;t<J.length;t++)J[t].worker.postMessage({taskType:"loadWebWorkerTask",workerIndex:J.length-1,sourcePath:e,config:ee})},addTask:function(e,t){let n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,r=arguments.length>3?arguments[3]:void 0;ee||ae();let o={resolve:void 0,reject:void 0};const a=new Promise(((e,t)=>{o={resolve:e,reject:t}}));let i;for(i=0;i<K.length&&!(K[i].priority<n);i++);const s=H++;return K.splice(i,0,{taskId:s,taskType:e,status:"ready",added:(new Date).getTime(),data:t,deferred:o,priority:n,transferList:r}),ne(),{taskId:s,promise:a}},getStatistics:function(){return te.maxWebWorkers=ee.maxWebWorkers,te.numWebWorkers=J.length,te.numTasksQueued=K.length,te},setTaskPriority:function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;for(let n=0;n<K.length;n++)if(K[n].taskId===e){const e=K.splice(n,1)[0];for(e.priority=t,n=0;n<K.length&&!(K[n].priority<t);n++);return K.splice(n,0,e),!0}return!1},cancelTask:function(e,t){for(let n=0;n<K.length;n++)if(K[n].taskId===e){return K.splice(n,1).deferred.reject(t),!0}return!1},webWorkers:J,terminate:function(){for(let e=0;e<J.length;e++)J[e].worker.terminate();J.length=0,ee=void 0}};var se=n(578);function le(e,t,n,r,o){const a=r.priority||void 0,i=r.transferPixelData?[n.buffer]:void 0;return ie.addTask("decodeTask",{imageFrame:e,transferSyntax:t,pixelData:n,options:r,decodeConfig:o},a,i).promise}window.pako={inflateRaw:se.Hq};const ce=function(e,t,n,r){let o=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{},a=arguments.length>5?arguments[5]:void 0;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":return le(e,t,n,o,a);case"1.2.840.10008.1.2.4.50":return 8!==e.bitsAllocated||3!==e.samplesPerPixel&&4!==e.samplesPerPixel?le(e,t,n,o,a):z(e,n,r)}return Promise.reject(new Error(`No decoder for transfer syntax ${t}`))};const ue=function(e){const{cornerstone:t}=Te,n=t.metaData.get("imagePixelModule",e);return{samplesPerPixel:n.samplesPerPixel,photometricInterpretation:n.photometricInterpretation,planarConfiguration:n.planarConfiguration,rows:n.rows,columns:n.columns,bitsAllocated:n.bitsAllocated,bitsStored:n.bitsStored,pixelRepresentation:n.pixelRepresentation,smallestPixelValue:n.smallestPixelValue,largestPixelValue:n.largestPixelValue,redPaletteColorLookupTableDescriptor:n.redPaletteColorLookupTableDescriptor,greenPaletteColorLookupTableDescriptor:n.greenPaletteColorLookupTableDescriptor,bluePaletteColorLookupTableDescriptor:n.bluePaletteColorLookupTableDescriptor,redPaletteColorLookupTableData:n.redPaletteColorLookupTableData,greenPaletteColorLookupTableData:n.greenPaletteColorLookupTableData,bluePaletteColorLookupTableData:n.bluePaletteColorLookupTableData,pixelData:void 0}};function de(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}const fe=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};let me="";function ge(e){const t=function(e,t){let n;return Number.isInteger(e)&&Number.isInteger(t)?e>=0?t<=255?n=Uint8Array:t<=65535&&(n=Uint16Array):e>=-128&&t<=127?n=Int8Array:e>=-32768&&t<=32767&&(n=Int16Array):n=Float32Array,n}(e.smallestPixelValue,e.largestPixelValue);if(!t)throw new Error("Could not apply a typed array to the pixel data");{const n=new t(e.pixelData);e.pixelData=n}}function he(e,t){const n=e.length/4;let r=0,o=0;for(let a=0;a<n;a++)t[o++]=e[r++],t[o++]=e[r++],t[o++]=e[r++],r++;return t}const pe=function(e,t,n){let r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};const o=r.useRGBA;if(r.preScale={enabled:!(!r.preScale||void 0===r.preScale.enabled)&&r.preScale.enabled},!t||!t.length)return Promise.reject(new Error("The file does not contain image data."));const{cornerstone:a}=Te,i=document.createElement("canvas"),s=ue(e);if(r.preScale.enabled){const t=function(e,t){const n=e.get("modalityLutModule",t)||{},r=e.get("generalSeriesModule",t)||{},{modality:o}=r,a={rescaleSlope:n.rescaleSlope,rescaleIntercept:n.rescaleIntercept,modality:o},i=e.get("scalingModule",t)||{};return{...a,..."PT"===o&&{suvbw:i.suvbw}}}(a.metaData,e);t&&(r.preScale={...r.preScale,scalingParameters:t})}const{decodeConfig:l}=U(),c=ce(s,n,t,i,r,l),{use16BitDataType:u}=l,d=de(s.photometricInterpretation);return new Promise(((t,s)=>{c.then((function(s){if(r.skipCreateImage)return t(s);let l=!1;if(r.targetBuffer&&r.targetBuffer.type&&!d){const{arrayBuffer:e,type:t,offset:n=0,length:o}=r.targetBuffer,a=s.pixelDataLength,i=n,c=null!=o?o:a-i,d={Uint8Array,Uint16Array:u?Uint16Array:void 0,Int16Array:u?Int16Array:void 0,Float32Array};if(c!==s.pixelDataLength)throw new Error(`target array for image does not have the same length (${c}) as the decoded image length (${s.pixelDataLength}).`);const f=d[t],m=e?new f(e,i,c):new f(s.pixelData);if(c!==s.pixelDataLength)throw new Error("target array for image does not have the same length as the decoded image length.");s.pixelData=m,l=!0}l||ge(s);const c=a.metaData.get("imagePlaneModule",e)||{},f=a.metaData.get("voiLutModule",e)||{},m=a.metaData.get("modalityLutModule",e)||{},g=a.metaData.get("sopCommonModule",e)||{};if(d){if(o){if(!fe(s,n)&&"RGB"!==s.photometricInterpretation){i.height=s.rows,i.width=s.columns;const e=i.getContext("2d").createImageData(s.columns,s.rows);V(s,e.data,o),s.imageData=e,s.pixelData=e.data,s.pixelDataLength=e.data.length}}else if(fe(s,n)){const e=new Uint8Array(s.pixelData.length/4*3);s.pixelData=he(s.pixelData,e),s.pixelDataLength=s.pixelData.length}else if("PALETTE COLOR"===s.photometricInterpretation){i.height=s.rows,i.width=s.columns;const e=i.getContext("2d").createImageData(s.columns,s.rows);V(s,e.data,!0);const t=new e.data.constructor(e.data.length/4*3);s.pixelData=new Uint8Array(he(e.data,t)),s.pixelDataLength=s.pixelData.length}const e=$(s.pixelData);s.smallestPixelValue=e.min,s.largestPixelValue=e.max}const h={imageId:e,color:d,columnPixelSpacing:c.columnPixelSpacing,columns:s.columns,height:s.rows,preScale:s.preScale,intercept:m.rescaleIntercept?m.rescaleIntercept:0,slope:m.rescaleSlope?m.rescaleSlope:1,invert:"MONOCHROME1"===s.photometricInterpretation,minPixelValue:s.smallestPixelValue,maxPixelValue:s.largestPixelValue,rowPixelSpacing:c.rowPixelSpacing,rows:s.rows,sizeInBytes:s.pixelData.byteLength,width:s.columns,windowCenter:f.windowCenter?f.windowCenter[0]:void 0,windowWidth:f.windowWidth?f.windowWidth[0]:void 0,voiLUTFunction:f.voiLUTFunction?f.voiLUTFunction:void 0,decodeTimeInMS:s.decodeTimeInMS,floatPixelData:void 0,imageFrame:s,rgba:d&&o,getPixelData:()=>s.pixelData,getCanvas:void 0,numComps:void 0};var p;if(window.image=h,h.color&&(h.getCanvas=function(){if(me===e)return i;const t=h.columns,n=h.rows;i.height=n,i.width=t;const r=i.getContext("2d"),o=r.createImageData(t,n),a=s.pixelData;if(a.length===t*n*4)for(let e=0;e<a.length;e++)o.data[e]=a[e];else if(a.length===t*n*3){let e=0;for(let t=0;t<a.length;t+=3)o.data[e++]=a[t],o.data[e++]=a[t+1],o.data[e++]=a[t+2],o.data[e++]=255}return s.pixelData=o.data,s.pixelDataLength=o.data.