@ohif/extension-tmtv 3.9.2 → 3.9.3

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.
@@ -1,2 +1,2 @@
1
1
  /*! For license information please see ohif-extension-tmtv.umd.js.LICENSE.txt */
2
- !function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("@cornerstonejs/adapters"),require("@cornerstonejs/core"),require("@cornerstonejs/tools"),require("@ohif/core"),require("@ohif/core/src/utils"),require("@ohif/extension-cornerstone"),require("@ohif/ui"),require("@ohif/ui-next"),require("dcmjs")):"function"==typeof define&&define.amd?define(["@cornerstonejs/adapters","@cornerstonejs/core","@cornerstonejs/tools","@ohif/core","@ohif/core/src/utils","@ohif/extension-cornerstone","@ohif/ui","@ohif/ui-next","dcmjs"],t):"object"==typeof exports?exports["ohif-extension-tmtv"]=t(require("@cornerstonejs/adapters"),require("@cornerstonejs/core"),require("@cornerstonejs/tools"),require("@ohif/core"),require("@ohif/core/src/utils"),require("@ohif/extension-cornerstone"),require("@ohif/ui"),require("@ohif/ui-next"),require("dcmjs")):e["ohif-extension-tmtv"]=t(e["@cornerstonejs/adapters"],e["@cornerstonejs/core"],e["@cornerstonejs/tools"],e["@ohif/core"],e["@ohif/core/src/utils"],e["@ohif/extension-cornerstone"],e["@ohif/ui"],e["@ohif/ui-next"],e.dcmjs)}(self,((e,t,n,a,o,r,i,s,c)=>(()=>{var l={856:(e,t,n)=>{"use strict";var a=n(183);function o(){}function r(){}r.resetWarningCache=o,e.exports=function(){function e(e,t,n,o,r,i){if(i!==a){var s=new Error("Calling PropTypes validators directly is not supported by the `prop-types` package. Use PropTypes.checkPropTypes() to call them. Read more at http://fb.me/use-check-prop-types");throw s.name="Invariant Violation",s}}function t(){return e}e.isRequired=e;var n={array:e,bigint:e,bool:e,func:e,number:e,object:e,string:e,symbol:e,any:e,arrayOf:t,element:e,elementType:e,instanceOf:t,node:e,objectOf:t,oneOf:t,oneOfType:t,shape:t,exact:t,checkPropTypes:r,resetWarningCache:o};return n.PropTypes=n,n}},598:(e,t,n)=>{e.exports=n(856)()},183:e=>{"use strict";e.exports="SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED"},249:(e,t)=>{"use strict";var n=Symbol.for("react.element"),a=Symbol.for("react.portal"),o=Symbol.for("react.fragment"),r=Symbol.for("react.strict_mode"),i=Symbol.for("react.profiler"),s=Symbol.for("react.provider"),c=Symbol.for("react.context"),l=Symbol.for("react.forward_ref"),u=Symbol.for("react.suspense"),p=Symbol.for("react.memo"),m=Symbol.for("react.lazy"),d=Symbol.iterator;var g={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},f=Object.assign,y={};function h(e,t,n){this.props=e,this.context=t,this.refs=y,this.updater=n||g}function v(){}function S(e,t,n){this.props=e,this.context=t,this.refs=y,this.updater=n||g}h.prototype.isReactComponent={},h.prototype.setState=function(e,t){if("object"!=typeof e&&"function"!=typeof e&&null!=e)throw Error("setState(...): takes an object of state variables to update or a function which returns an object of state variables.");this.updater.enqueueSetState(this,e,t,"setState")},h.prototype.forceUpdate=function(e){this.updater.enqueueForceUpdate(this,e,"forceUpdate")},v.prototype=h.prototype;var b=S.prototype=new v;b.constructor=S,f(b,h.prototype),b.isPureReactComponent=!0;var I=Array.isArray,x=Object.prototype.hasOwnProperty,T={current:null},w={key:!0,ref:!0,__self:!0,__source:!0};function E(e,t,a){var o,r={},i=null,s=null;if(null!=t)for(o in void 0!==t.ref&&(s=t.ref),void 0!==t.key&&(i=""+t.key),t)x.call(t,o)&&!w.hasOwnProperty(o)&&(r[o]=t[o]);var c=arguments.length-2;if(1===c)r.children=a;else if(1<c){for(var l=Array(c),u=0;u<c;u++)l[u]=arguments[u+2];r.children=l}if(e&&e.defaultProps)for(o in c=e.defaultProps)void 0===r[o]&&(r[o]=c[o]);return{$$typeof:n,type:e,key:i,ref:s,props:r,_owner:T.current}}function R(e){return"object"==typeof e&&null!==e&&e.$$typeof===n}var O=/\/+/g;function C(e,t){return"object"==typeof e&&null!==e&&null!=e.key?function(e){var t={"=":"=0",":":"=2"};return"$"+e.replace(/[=:]/g,(function(e){return t[e]}))}(""+e.key):t.toString(36)}function M(e,t,o,r,i){var s=typeof e;"undefined"!==s&&"boolean"!==s||(e=null);var c=!1;if(null===e)c=!0;else switch(s){case"string":case"number":c=!0;break;case"object":switch(e.$$typeof){case n:case a:c=!0}}if(c)return i=i(c=e),e=""===r?"."+C(c,0):r,I(i)?(o="",null!=e&&(o=e.replace(O,"$&/")+"/"),M(i,t,o,"",(function(e){return e}))):null!=i&&(R(i)&&(i=function(e,t){return{$$typeof:n,type:e.type,key:t,ref:e.ref,props:e.props,_owner:e._owner}}(i,o+(!i.key||c&&c.key===i.key?"":(""+i.key).replace(O,"$&/")+"/")+e)),t.push(i)),1;if(c=0,r=""===r?".":r+":",I(e))for(var l=0;l<e.length;l++){var u=r+C(s=e[l],l);c+=M(s,t,o,u,i)}else if(u=function(e){return null===e||"object"!=typeof e?null:"function"==typeof(e=d&&e[d]||e["@@iterator"])?e:null}(e),"function"==typeof u)for(e=u.call(e),l=0;!(s=e.next()).done;)c+=M(s=s.value,t,o,u=r+C(s,l++),i);else if("object"===s)throw t=String(e),Error("Objects are not valid as a React child (found: "+("[object Object]"===t?"object with keys {"+Object.keys(e).join(", ")+"}":t)+"). If you meant to render a collection of children, use an array instead.");return c}function D(e,t,n){if(null==e)return e;var a=[],o=0;return M(e,a,"","",(function(e){return t.call(n,e,o++)})),a}function N(e){if(-1===e._status){var t=e._result;(t=t()).then((function(t){0!==e._status&&-1!==e._status||(e._status=1,e._result=t)}),(function(t){0!==e._status&&-1!==e._status||(e._status=2,e._result=t)})),-1===e._status&&(e._status=0,e._result=t)}if(1===e._status)return e._result.default;throw e._result}var P={current:null},L={transition:null},k={ReactCurrentDispatcher:P,ReactCurrentBatchConfig:L,ReactCurrentOwner:T};function j(){throw Error("act(...) is not supported in production builds of React.")}t.Children={map:D,forEach:function(e,t,n){D(e,(function(){t.apply(this,arguments)}),n)},count:function(e){var t=0;return D(e,(function(){t++})),t},toArray:function(e){return D(e,(function(e){return e}))||[]},only:function(e){if(!R(e))throw Error("React.Children.only expected to receive a single React element child.");return e}},t.Component=h,t.Fragment=o,t.Profiler=i,t.PureComponent=S,t.StrictMode=r,t.Suspense=u,t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=k,t.act=j,t.cloneElement=function(e,t,a){if(null==e)throw Error("React.cloneElement(...): The argument must be a React element, but you passed "+e+".");var o=f({},e.props),r=e.key,i=e.ref,s=e._owner;if(null!=t){if(void 0!==t.ref&&(i=t.ref,s=T.current),void 0!==t.key&&(r=""+t.key),e.type&&e.type.defaultProps)var c=e.type.defaultProps;for(l in t)x.call(t,l)&&!w.hasOwnProperty(l)&&(o[l]=void 0===t[l]&&void 0!==c?c[l]:t[l])}var l=arguments.length-2;if(1===l)o.children=a;else if(1<l){c=Array(l);for(var u=0;u<l;u++)c[u]=arguments[u+2];o.children=c}return{$$typeof:n,type:e.type,key:r,ref:i,props:o,_owner:s}},t.createContext=function(e){return(e={$$typeof:c,_currentValue:e,_currentValue2:e,_threadCount:0,Provider:null,Consumer:null,_defaultValue:null,_globalName:null}).Provider={$$typeof:s,_context:e},e.Consumer=e},t.createElement=E,t.createFactory=function(e){var t=E.bind(null,e);return t.type=e,t},t.createRef=function(){return{current:null}},t.forwardRef=function(e){return{$$typeof:l,render:e}},t.isValidElement=R,t.lazy=function(e){return{$$typeof:m,_payload:{_status:-1,_result:e},_init:N}},t.memo=function(e,t){return{$$typeof:p,type:e,compare:void 0===t?null:t}},t.startTransition=function(e){var t=L.transition;L.transition={};try{e()}finally{L.transition=t}},t.unstable_act=j,t.useCallback=function(e,t){return P.current.useCallback(e,t)},t.useContext=function(e){return P.current.useContext(e)},t.useDebugValue=function(){},t.useDeferredValue=function(e){return P.current.useDeferredValue(e)},t.useEffect=function(e,t){return P.current.useEffect(e,t)},t.useId=function(){return P.current.useId()},t.useImperativeHandle=function(e,t,n){return P.current.useImperativeHandle(e,t,n)},t.useInsertionEffect=function(e,t){return P.current.useInsertionEffect(e,t)},t.useLayoutEffect=function(e,t){return P.current.useLayoutEffect(e,t)},t.useMemo=function(e,t){return P.current.useMemo(e,t)},t.useReducer=function(e,t,n){return P.current.useReducer(e,t,n)},t.useRef=function(e){return P.current.useRef(e)},t.useState=function(e){return P.current.useState(e)},t.useSyncExternalStore=function(e,t,n){return P.current.useSyncExternalStore(e,t,n)},t.useTransition=function(){return P.current.useTransition()},t.version="18.3.1"},326:(e,t,n)=>{"use strict";e.exports=n(249)},741:e=>{e.exports={area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0}},142:t=>{"use strict";t.exports=e},557:e=>{"use strict";e.exports=t},713:e=>{"use strict";e.exports=n},2:e=>{"use strict";e.exports=a},141:e=>{"use strict";e.exports=o},669:e=>{"use strict";e.exports=r},307:e=>{"use strict";e.exports=i},55:e=>{"use strict";e.exports=s},111:e=>{"use strict";e.exports=c}},u={};function p(e){var t=u[e];if(void 0!==t)return t.exports;var n=u[e]={exports:{}};return l[e](n,n.exports,p),n.exports}p.m=l,p.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return p.d(t,{a:t}),t},p.d=(e,t)=>{for(var n in t)p.o(t,n)&&!p.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},p.u=e=>"dist/"+e+".ohif-extension-tmtv.umd.js",p.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),p.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},p.p="/",p.b=document.baseURI||self.location.href;var m={};return(()=>{"use strict";p.r(m),p.d(m,{default:()=>ke});const e=JSON.parse('{"UU":"@ohif/extension-tmtv"}').UU,t=e=>({type:"cameraPosition",id:e,source:!0,target:!0}),n={type:"hydrateseg",id:"sameFORId",source:!0,target:!0,options:{matchingRules:["sameFOR"]}},a={viewportOptions:{viewportId:"ctAXIAL",viewportType:"volume",orientation:"axial",toolGroupId:"ctToolGroup",initialImageOptions:{preset:"first"},syncGroups:[t("axialSync"),{type:"voi",id:"ctWLSync",source:!0,target:!0,options:{syncColormap:!0}},n]},displaySets:[{id:"ctDisplaySet"}]},o={viewportOptions:{viewportId:"ctSAGITTAL",viewportType:"volume",orientation:"sagittal",toolGroupId:"ctToolGroup",syncGroups:[t("sagittalSync"),{type:"voi",id:"ctWLSync",source:!0,target:!0,options:{syncColormap:!0}},n]},displaySets:[{id:"ctDisplaySet"}]},r={viewportOptions:{viewportId:"ctCORONAL",viewportType:"volume",orientation:"coronal",toolGroupId:"ctToolGroup",syncGroups:[t("coronalSync"),{type:"voi",id:"ctWLSync",source:!0,target:!0,options:{syncColormap:!0}},n]},displaySets:[{id:"ctDisplaySet"}]},i={viewportOptions:{viewportId:"ptAXIAL",viewportType:"volume",background:[1,1,1],orientation:"axial",toolGroupId:"ptToolGroup",initialImageOptions:{preset:"first"},syncGroups:[t("axialSync"),{type:"voi",id:"ptWLSync",source:!0,target:!0,options:{syncColormap:!0}},{type:"voi",id:"ptFusionWLSync",source:!0,target:!1,options:{syncColormap:!1,syncInvertState:!1}},n]},displaySets:[{options:{voi:{custom:"getPTVOIRange"},voiInverted:!0},id:"ptDisplaySet"}]},s={viewportOptions:{viewportId:"ptSAGITTAL",viewportType:"volume",orientation:"sagittal",background:[1,1,1],toolGroupId:"ptToolGroup",syncGroups:[t("sagittalSync"),{type:"voi",id:"ptWLSync",source:!0,target:!0,options:{syncColormap:!0}},{type:"voi",id:"ptFusionWLSync",source:!0,target:!1,options:{syncColormap:!1,syncInvertState:!1}},n]},displaySets:[{options:{voi:{custom:"getPTVOIRange"},voiInverted:!0},id:"ptDisplaySet"}]},c={viewportOptions:{viewportId:"ptCORONAL",viewportType:"volume",orientation:"coronal",background:[1,1,1],toolGroupId:"ptToolGroup",syncGroups:[t("coronalSync"),{type:"voi",id:"ptWLSync",source:!0,target:!0,options:{syncColormap:!0}},{type:"voi",id:"ptFusionWLSync",source:!0,target:!1,options:{syncColormap:!1,syncInvertState:!1}},n]},displaySets:[{options:{voi:{custom:"getPTVOIRange"},voiInverted:!0},id:"ptDisplaySet"}]},l={viewportOptions:{viewportId:"fusionAXIAL",viewportType:"volume",orientation:"axial",toolGroupId:"fusionToolGroup",initialImageOptions:{preset:"first"},syncGroups:[t("axialSync"),{type:"voi",id:"ctWLSync",source:!1,target:!0},{type:"voi",id:"fusionWLSync",source:!0,target:!0,options:{syncColormap:!0}},{type:"voi",id:"ptFusionWLSync",source:!1,target:!0,options:{syncColormap:!1,syncInvertState:!1}},n]},displaySets:[{id:"ctDisplaySet"},{id:"ptDisplaySet",options:{colormap:{name:"hsv",opacity:[{value:0,opacity:0},{value:.1,opacity:.8},{value:1,opacity:.9}]},voi:{custom:"getPTVOIRange"}}}]},u={viewportOptions:{viewportId:"fusionSAGITTAL",viewportType:"volume",orientation:"sagittal",toolGroupId:"fusionToolGroup",syncGroups:[t("sagittalSync"),{type:"voi",id:"ctWLSync",source:!1,target:!0},{type:"voi",id:"fusionWLSync",source:!0,target:!0,options:{syncColormap:!0}},{type:"voi",id:"ptFusionWLSync",source:!1,target:!0,options:{syncColormap:!1,syncInvertState:!1}},n]},displaySets:[{id:"ctDisplaySet"},{id:"ptDisplaySet",options:{colormap:{name:"hsv",opacity:[{value:0,opacity:0},{value:.1,opacity:.8},{value:1,opacity:.9}]},voi:{custom:"getPTVOIRange"}}}]},d={viewportOptions:{viewportId:"fusionCoronal",viewportType:"volume",orientation:"coronal",toolGroupId:"fusionToolGroup",syncGroups:[t("coronalSync"),{type:"voi",id:"ctWLSync",source:!1,target:!0},{type:"voi",id:"fusionWLSync",source:!0,target:!0,options:{syncColormap:!0}},{type:"voi",id:"ptFusionWLSync",source:!1,target:!0,options:{syncColormap:!1,syncInvertState:!1}},n]},displaySets:[{id:"ctDisplaySet"},{id:"ptDisplaySet",options:{colormap:{name:"hsv",opacity:[{value:0,opacity:0},{value:.1,opacity:.8},{value:1,opacity:.9}]},voi:{custom:"getPTVOIRange"}}}]},g={viewportOptions:{viewportId:"mipSagittal",viewportType:"volume",orientation:"sagittal",background:[1,1,1],toolGroupId:"mipToolGroup",syncGroups:[{type:"voi",id:"ptWLSync",source:!0,target:!0,options:{syncColormap:!0}},{type:"voi",id:"ptFusionWLSync",source:!0,target:!1,options:{syncColormap:!1,syncInvertState:!1}},n],customViewportProps:{hideOverlays:!0}},displaySets:[{options:{blendMode:"MIP",slabThickness:"fullVolume",voi:{custom:"getPTVOIRange"},voiInverted:!0},id:"ptDisplaySet"}]},f={id:"@ohif/extension-tmtv.hangingProtocolModule.ptCT",locked:!0,name:"Default",createdDate:"2021-02-23T19:22:08.894Z",modifiedDate:"2022-10-04T19:22:08.894Z",availableTo:{},editableBy:{},imageLoadStrategy:"interleaveTopToBottom",protocolMatchingRules:[{attribute:"ModalitiesInStudy",constraint:{contains:["CT","PT"]}},{attribute:"StudyDescription",constraint:{contains:"PETCT"}},{attribute:"StudyDescription",constraint:{contains:"PET/CT"}}],displaySetSelectors:{ctDisplaySet:{seriesMatchingRules:[{attribute:"Modality",constraint:{equals:{value:"CT"}},required:!0},{attribute:"isReconstructable",constraint:{equals:{value:!0}},required:!0},{attribute:"SeriesDescription",constraint:{contains:"CT"}},{attribute:"SeriesDescription",constraint:{contains:"CT WB"}}]},ptDisplaySet:{seriesMatchingRules:[{attribute:"Modality",constraint:{equals:"PT"},required:!0},{attribute:"isReconstructable",constraint:{equals:{value:!0}},required:!0},{attribute:"SeriesDescription",constraint:{contains:"Corrected"}},{weight:2,attribute:"SeriesDescription",constraint:{doesNotContain:{value:"Uncorrected"}}}]}},stages:[{name:"default",id:"default",viewportStructure:{layoutType:"grid",properties:{rows:3,columns:4,layoutOptions:[{x:0,y:0,width:1/4,height:1/3},{x:1/4,y:0,width:1/4,height:1/3},{x:.5,y:0,width:1/4,height:1/3},{x:0,y:1/3,width:1/4,height:1/3},{x:1/4,y:1/3,width:1/4,height:1/3},{x:.5,y:1/3,width:1/4,height:1/3},{x:0,y:2/3,width:1/4,height:1/3},{x:1/4,y:2/3,width:1/4,height:1/3},{x:.5,y:2/3,width:1/4,height:1/3},{x:3/4,y:0,width:1/4,height:1}]}},viewports:[a,o,r,i,s,c,l,u,d,g],createdDate:"2021-02-23T18:32:42.850Z"},{name:"Fusion 2x2",id:"Fusion-2x2",viewportStructure:{layoutType:"grid",properties:{rows:2,columns:2}},viewports:[a,l,i,g]},{name:"2x3-layout",id:"2x3-layout",viewportStructure:{layoutType:"grid",properties:{rows:2,columns:3}},viewports:[a,o,r,i,s,c]},{name:"2x4-layout",id:"2x4-layout",viewportStructure:{layoutType:"grid",properties:{rows:2,columns:4,layoutOptions:[{x:0,y:0,width:1/4,height:.5},{x:1/4,y:0,width:1/4,height:.5},{x:.5,y:0,width:1/4,height:.5},{x:3/4,y:0,width:1/4,height:1},{x:0,y:.5,width:1/4,height:.5},{x:1/4,y:.5,width:1/4,height:.5},{x:.5,y:.5,width:1/4,height:.5}]}},viewports:[c,s,i,g,d,u,l]}],numberOfPriorsReferenced:-1};const y=function(){return[{name:f.id,protocol:f}]};var h=p(326),v=p(598),S=p.n(v),b=p(307),I=p(2),x=p.n(I);function T(e){return T="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},T(e)}function w(e){var t=function(e,t){if("object"!=T(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var a=n.call(e,t||"default");if("object"!=T(a))return a;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}(e,"string");return"symbol"==T(t)?t:t+""}function E(e,t,n){return(t=w(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}p(741);Object.create(null);function R(){if(console&&console.warn){for(var e,t=arguments.length,n=new Array(t),a=0;a<t;a++)n[a]=arguments[a];"string"==typeof n[0]&&(n[0]="react-i18next:: ".concat(n[0])),(e=console).warn.apply(e,n)}}var O={};function C(){for(var e=arguments.length,t=new Array(e),n=0;n<e;n++)t[n]=arguments[n];"string"==typeof t[0]&&O[t[0]]||("string"==typeof t[0]&&(O[t[0]]=new Date),R.apply(void 0,t))}var M=function(e,t){return function(){if(e.isInitialized)t();else{e.on("initialized",(function n(){setTimeout((function(){e.off("initialized",n)}),0),t()}))}}};function D(e,t,n){e.loadNamespaces(t,M(e,n))}function N(e,t,n,a){"string"==typeof n&&(n=[n]),n.forEach((function(t){e.options.ns.indexOf(t)<0&&e.options.ns.push(t)})),e.loadLanguages(t,M(e,a))}var P=/&(?:amp|#38|lt|#60|gt|#62|apos|#39|quot|#34|nbsp|#160|copy|#169|reg|#174|hellip|#8230|#x2F|#47);/g,L={"&amp;":"&","&#38;":"&","&lt;":"<","&#60;":"<","&gt;":">","&#62;":">","&apos;":"'","&#39;":"'","&quot;":'"',"&#34;":'"',"&nbsp;":" ","&#160;":" ","&copy;":"©","&#169;":"©","&reg;":"®","&#174;":"®","&hellip;":"…","&#8230;":"…","&#x2F;":"/","&#47;":"/"},k=function(e){return L[e]};var j,U={bindI18n:"languageChanged",bindI18nStore:"",transEmptyNodeValue:"",transSupportBasicHtmlNodes:!0,transWrapTextNodes:"",transKeepBasicHtmlNodesFor:["br","strong","i","p"],useSuspense:!0,unescape:function(e){return e.replace(P,k)}};function V(e,t){for(var n=0;n<t.length;n++){var a=t[n];a.enumerable=a.enumerable||!1,a.configurable=!0,"value"in a&&(a.writable=!0),Object.defineProperty(e,w(a.key),a)}}var _=(0,h.createContext)(),A=function(){function e(){!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.usedNamespaces={}}return function(e,t,n){t&&V(e.prototype,t),n&&V(e,n),Object.defineProperty(e,"prototype",{writable:!1})}(e,[{key:"addUsedNamespaces",value:function(e){var t=this;e.forEach((function(e){t.usedNamespaces[e]||(t.usedNamespaces[e]=!0)}))}},{key:"getUsedNamespaces",value:function(){return Object.keys(this.usedNamespaces)}}]),e}();function F(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,a=Array(t);n<t;n++)a[n]=e[n];return a}function q(e,t){return function(e){if(Array.isArray(e))return e}(e)||function(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var a,o,r,i,s=[],c=!0,l=!1;try{if(r=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;c=!1}else for(;!(c=(a=r.call(n)).done)&&(s.push(a.value),s.length!==t);c=!0);}catch(e){l=!0,o=e}finally{try{if(!c&&null!=n.return&&(i=n.return(),Object(i)!==i))return}finally{if(l)throw o}}return s}}(e,t)||function(e,t){if(e){if("string"==typeof e)return F(e,t);var n={}.toString.call(e).slice(8,-1);return"Object"===n&&e.constructor&&(n=e.constructor.name),"Map"===n||"Set"===n?Array.from(e):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?F(e,t):void 0}}(e,t)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function G(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function W(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?G(Object(n),!0).forEach((function(t){E(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):G(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}var $=function(e,t){var n=(0,h.useRef)();return(0,h.useEffect)((function(){n.current=t?n.current:e}),[e,t]),n.current};function B(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=t.i18n,a=(0,h.useContext)(_)||{},o=a.i18n,r=a.defaultNS,i=n||o||j;if(i&&!i.reportNamespaces&&(i.reportNamespaces=new A),!i){C("You will need to pass in an i18next instance by using initReactI18next");var s=function(e,t){return"string"==typeof t?t:t&&"object"===T(t)&&"string"==typeof t.defaultValue?t.defaultValue:Array.isArray(e)?e[e.length-1]:e},c=[s,{},!1];return c.t=s,c.i18n={},c.ready=!1,c}i.options.react&&void 0!==i.options.react.wait&&C("It seems you are still using the old wait option, you may migrate to the new useSuspense behaviour.");var l=W(W(W({},U),i.options.react),t),u=l.useSuspense,p=l.keyPrefix,m=e||r||i.options&&i.options.defaultNS;m="string"==typeof m?[m]:m||["translation"],i.reportNamespaces.addUsedNamespaces&&i.reportNamespaces.addUsedNamespaces(m);var d=(i.isInitialized||i.initializedStoreOnce)&&m.every((function(e){return function(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};return t.languages&&t.languages.length?void 0!==t.options.ignoreJSONStructure?t.hasLoadedNamespace(e,{lng:n.lng,precheck:function(t,a){if(n.bindI18n&&n.bindI18n.indexOf("languageChanging")>-1&&t.services.backendConnector.backend&&t.isLanguageChangingTo&&!a(t.isLanguageChangingTo,e))return!1}}):function(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},a=t.languages[0],o=!!t.options&&t.options.fallbackLng,r=t.languages[t.languages.length-1];if("cimode"===a.toLowerCase())return!0;var i=function(e,n){var a=t.services.backendConnector.state["".concat(e,"|").concat(n)];return-1===a||2===a};return!(n.bindI18n&&n.bindI18n.indexOf("languageChanging")>-1&&t.services.backendConnector.backend&&t.isLanguageChangingTo&&!i(t.isLanguageChangingTo,e)||!t.hasResourceBundle(a,e)&&t.services.backendConnector.backend&&(!t.options.resources||t.options.partialBundledLanguages)&&(!i(a,e)||o&&!i(r,e)))}(e,t,n):(C("i18n.languages were undefined or empty",t.languages),!0)}(e,i,l)}));function g(){return i.getFixedT(t.lng||null,"fallback"===l.nsMode?m:m[0],p)}var f=q((0,h.useState)(g),2),y=f[0],v=f[1],S=m.join();t.lng&&(S="".concat(t.lng).concat(S));var b=$(S),I=(0,h.useRef)(!0);(0,h.useEffect)((function(){var e=l.bindI18n,n=l.bindI18nStore;function a(){I.current&&v(g)}return I.current=!0,d||u||(t.lng?N(i,t.lng,m,(function(){I.current&&v(g)})):D(i,m,(function(){I.current&&v(g)}))),d&&b&&b!==S&&I.current&&v(g),e&&i&&i.on(e,a),n&&i&&i.store.on(n,a),function(){I.current=!1,e&&i&&e.split(" ").forEach((function(e){return i.off(e,a)})),n&&i&&n.split(" ").forEach((function(e){return i.store.off(e,a)}))}}),[i,S]);var x=(0,h.useRef)(!0);(0,h.useEffect)((function(){I.current&&!x.current&&v(g),x.current=!1}),[i,p]);var w=[y,i,d];if(w.t=y,w.i18n=i,w.ready=d,d)return w;if(!d&&!u)return w;throw new Promise((function(e){t.lng?N(i,t.lng,m,(function(){return e()})):D(i,m,(function(){return e()}))}))}const H={PatientWeight:null,PatientSex:null,SeriesTime:null,RadiopharmaceuticalInformationSequence:{RadionuclideTotalDose:null,RadionuclideHalfLife:null,RadiopharmaceuticalStartTime:null}};function z({servicesManager:e,commandsManager:t}){const{t:n}=B("PanelSUV"),{displaySetService:a,toolGroupService:o,toolbarService:r,hangingProtocolService:i}=e.services,[s,c]=(0,h.useState)(H),[l,u]=(0,h.useState)(null),p=e=>{c((t=>{const n={...t};return Object.keys(e).forEach((a=>{"object"==typeof e[a]?n[a]={...t[a],...e[a]}:n[a]=e[a]})),n}))},m=e=>{const n=t.runCommand("getMatchingPTDisplaySet",{viewportMatchDetails:e});if(!n)return;return{ptDisplaySet:n,metadata:t.runCommand("getPTMetadata",{ptDisplaySet:n})}};return(0,h.useEffect)((()=>{const e=a.getActiveDisplaySets(),{viewportMatchDetails:t}=i.getMatchDetails();if(!e.length)return;const n=m(t);if(!n)return;const{ptDisplaySet:o,metadata:r}=n;u(o),c(r)}),[]),(0,h.useEffect)((()=>{const{unsubscribe:e}=i.subscribe(i.EVENTS.PROTOCOL_CHANGED,(({viewportMatchDetails:e})=>{const t=m(e);if(!t)return;const{ptDisplaySet:n,metadata:a}=t;u(n),c(a)}));return()=>{e()}}),[]),h.createElement(h.Fragment,null,h.createElement("div",{className:"ohif-scrollbar flex min-h-0 flex-auto select-none flex-col justify-between overflow-auto"},h.createElement("div",{className:"flex min-h-0 flex-1 flex-col bg-black text-[13px] font-[300]"},h.createElement(b.PanelSection,{title:n("Patient Information")},h.createElement("div",{className:"flex flex-col"},h.createElement("div",{className:"bg-primary-dark flex flex-col gap-4 p-2"},h.createElement(b.Input,{containerClassName:"!flex-row !justify-between items-center",label:n("Patient Sex"),labelClassName:"text-[13px] font-inter text-white",className:"!m-0 !h-[26px] !w-[117px]",value:s.PatientSex||"",onChange:e=>{p({PatientSex:e.target.value})}}),h.createElement(b.Input,{containerClassName:"!flex-row !justify-between items-center",label:n("Weight"),labelChildren:h.createElement("span",{className:"text-aqua-pale"}," kg"),labelClassName:"text-[13px] font-inter text-white",className:"!m-0 !h-[26px] !w-[117px]",value:s.PatientWeight||"",onChange:e=>{p({PatientWeight:e.target.value})},id:"weight-input"}),h.createElement(b.Input,{containerClassName:"!flex-row !justify-between items-center",label:n("Total Dose"),labelChildren:h.createElement("span",{className:"text-aqua-pale"}," bq"),labelClassName:"text-[13px] font-inter text-white",className:"!m-0 !h-[26px] !w-[117px]",value:s.RadiopharmaceuticalInformationSequence.RadionuclideTotalDose||"",onChange:e=>{p({RadiopharmaceuticalInformationSequence:{RadionuclideTotalDose:e.target.value}})}}),h.createElement(b.Input,{containerClassName:"!flex-row !justify-between items-center",label:n("Half Life"),labelChildren:h.createElement("span",{className:"text-aqua-pale"}," s"),labelClassName:"text-[13px] font-inter text-white",className:"!m-0 !h-[26px] !w-[117px]",value:s.RadiopharmaceuticalInformationSequence.RadionuclideHalfLife||"",onChange:e=>{p({RadiopharmaceuticalInformationSequence:{RadionuclideHalfLife:e.target.value}})}}),h.createElement(b.Input,{containerClassName:"!flex-row !justify-between items-center",label:n("Injection Time"),labelChildren:h.createElement("span",{className:"text-aqua-pale"}," s"),labelClassName:"text-[13px] font-inter text-white",className:"!m-0 !h-[26px] !w-[117px]",value:s.RadiopharmaceuticalInformationSequence.RadiopharmaceuticalStartTime||"",onChange:e=>{p({RadiopharmaceuticalInformationSequence:{RadiopharmaceuticalStartTime:e.target.value}})}}),h.createElement(b.Input,{containerClassName:"!flex-row !justify-between items-center",label:n("Acquisition Time"),labelChildren:h.createElement("span",{className:"text-aqua-pale"}," s"),labelClassName:"text-[13px] font-inter text-white",className:"!m-0 !h-[26px] !w-[117px]",value:s.SeriesTime||"",onChange:()=>{}}),h.createElement(b.Button,{className:"!h-[26px] !w-[115px] self-end !p-0",onClick:function(){if(!l)throw new Error("No ptDisplaySet found");I.DicomMetadataStore.updateMetadataForSeries(l.StudyInstanceUID,l.SeriesInstanceUID,s),a.setDisplaySetMetadataInvalidated(l.displaySetInstanceUID),setTimeout((()=>{t.runCommand("resetCrosshairs")}),0)}},"Reload Data")))))))}z.propTypes={servicesManager:S().shape({services:S().shape({measurementService:S().shape({getMeasurements:S().func.isRequired,subscribe:S().func.isRequired,EVENTS:S().object.isRequired,VALUE_TYPES:S().object.isRequired}).isRequired}).isRequired}).isRequired};var K=p(669),Y=p(557);const J=async({segmentationId:e,commandsManager:t,segmentationService:n})=>{const a=n.getSegmentation(e);(0,Y.triggerEvent)(Y.eventTarget,Y.Enums.Events.WEB_WORKER_PROGRESS,{progress:0,type:"Calculate Lesion Stats",id:e});const o={};for(const[n,r]of Object.entries(a.segments)){if(!r)continue;const i=Number(n),s=await t.run("getLesionStats",{segmentationId:e,segmentIndex:i}),c={lesionStats:s,suvPeak:await t.run("calculateSuvPeak",{segmentationId:e,segmentIndex:i}),lesionGlyoclysisStats:s.volume*s.meanValue},l={...r,cachedStats:{...r.cachedStats,...c}};o[i]=c,a.segments[n]=l}const r=n.getSegmentations(),i=await t.run("calculateTMTV",{segmentations:r});(0,Y.triggerEvent)(Y.eventTarget,Y.Enums.Events.WEB_WORKER_PROGRESS,{progress:100,type:"Calculate Lesion Stats",id:e}),r.forEach((e=>{e.cachedStats={...e.cachedStats,tmtv:i},Object.keys(e.segments).forEach((t=>{e.segments[t].cachedStats={...e.segments[t].cachedStats,tmtv:i}}));const t={...e,segments:{...e.segments}};n.addOrUpdateSegmentation(t)}))};var X=p(141);const Z=function({servicesManager:e,commandsManager:t}){const{segmentationService:n}=e.services,{segmentationsWithRepresentations:a}=(0,K.useActiveViewportSegmentationRepresentations)({servicesManager:e});(0,h.useEffect)((()=>{const e=a.map((e=>e.segmentation.segmentationId));(async()=>{for(const a of e)await J({segmentationId:a,commandsManager:t,segmentationService:n})})()}),[]),(0,h.useEffect)((()=>{const e=(0,X.debounce)((async e=>{const{segmentationId:a}=e;await J({segmentationId:a,commandsManager:t,segmentationService:n})}),100),a=n.subscribe(n.EVENTS.SEGMENTATION_DATA_MODIFIED,(t=>{e(t)}));return()=>{a.unsubscribe()}}),[t,n]);const o=a.find((e=>void 0!==e.segmentation.cachedStats?.tmtv)),r=o?.segmentation.cachedStats?.tmtv;return h.createElement("div",{className:"mt-2 mb-10 flex flex-col"},h.createElement("div",{className:"invisible-scrollbar overflow-y-auto overflow-x-hidden"},null!=r?h.createElement("div",{className:"bg-secondary-dark flex items-baseline justify-between px-2 py-1"},h.createElement("span",{className:"text-base font-bold uppercase tracking-widest text-white"},"TMTV:"),h.createElement("div",{className:"text-white"},`${r.toFixed(3)} mL`)):null))};var Q=p(55);function ee({servicesManager:e,commandsManager:t,extensionManager:n,configuration:a}){return h.createElement(h.Fragment,null,h.createElement(K.PanelSegmentation,{servicesManager:e,commandsManager:t,extensionManager:n,configuration:a},h.createElement(te,{servicesManager:e,commandsManager:t})))}const te=({servicesManager:e,commandsManager:t})=>{const{segmentationsWithRepresentations:n}=(0,K.useActiveViewportSegmentationRepresentations)({servicesManager:e}),a=n[0]?.segmentation.cachedStats?.tmtv,o=n.map((e=>e.segmentation));return o.length?h.createElement("div",{className:"flex h-8 w-full items-center rounded pr-0.5"},h.createElement(Q.Button,{size:"sm",variant:"ghost",className:"pl-1.5",onClick:()=>{t.runCommand("exportTMTVReportCSV",{segmentations:o,tmtv:a,config:{}})}},h.createElement(Q.Icons.Download,null),h.createElement("span",{className:"pl-1"},"CSV"))):null};const ne=function({commandsManager:e,extensionManager:t,servicesManager:n}){return[{name:"petSUV",iconName:"tab-patient-info",iconLabel:"Patient Info",label:"Patient Info",component:()=>h.createElement(z,{commandsManager:e,servicesManager:n,extensionManager:t})},{name:"tmtv",iconName:"tab-segmentation",iconLabel:"Segmentation",component:()=>h.createElement(h.Fragment,null,h.createElement(Q.Toolbox,{commandsManager:e,servicesManager:n,extensionManager:t,buttonSectionId:"ROIThresholdToolbox",title:"Threshold Tools"}),h.createElement(ee,{commandsManager:e,servicesManager:n}),h.createElement(Z,{commandsManager:e,servicesManager:n}))},{name:"tmtvBox",iconName:"tab-segmentation",iconLabel:"Segmentation",label:"Segmentation Toolbox",component:()=>h.createElement(Q.Toolbox,{commandsManager:e,servicesManager:n,extensionManager:t,buttonSectionId:"ROIThresholdToolbox",title:"Threshold Tools"})},{name:"tmtvExport",iconName:"tab-segmentation",iconLabel:"Segmentation",label:"Segmentation Export",component:()=>h.createElement(Z,{commandsManager:e,servicesManager:n})}]};var ae=p(713);const oe=["RectangleROIStartEndThreshold"],re={toAnnotation:(e,t)=>{},toMeasurement:(e,t,n)=>{const{annotation:a,viewportId:o}=e,{metadata:r,data:i,annotationUID:s}=a;if(!r||!i)return console.warn("Length tool: Missing metadata or data"),null;const{toolName:c,referencedImageId:l,FrameOfReferenceUID:u}=r;if(!oe.includes(c))throw new Error("Tool not supported");const{SOPInstanceUID:p,SeriesInstanceUID:m,StudyInstanceUID:d}=(0,K.getSOPInstanceAttributes)(l,n,o);let g;return g=p?t.getDisplaySetForSOPInstanceUID(p,m):t.getDisplaySetsForSeries(m),{uid:s,SOPInstanceUID:p,FrameOfReferenceUID:u,metadata:r,referenceSeriesUID:m,referenceStudyUID:d,toolName:r.toolName,displaySetInstanceUID:g.displaySetInstanceUID,label:r.label,data:i.cachedStats,type:"RectangleROIStartEndThreshold"}}},ie={toAnnotation:(e,t)=>{},toMeasurement:(e,t,n)=>{const{annotation:a,viewportId:o}=e,{metadata:r,data:i,annotationUID:s}=a;if(!r||!i)return console.warn("Length tool: Missing metadata or data"),null;const{toolName:c,referencedImageId:l,FrameOfReferenceUID:u}=r;if(!oe.includes(c))throw new Error("Tool not supported");const{SOPInstanceUID:p,SeriesInstanceUID:m,StudyInstanceUID:d}=(0,K.getSOPInstanceAttributes)(l,n,o);let g;g=p?t.getDisplaySetForSOPInstanceUID(p,m):t.getDisplaySetsForSeries(m);const{cachedStats:f}=i;return{uid:s,SOPInstanceUID:p,FrameOfReferenceUID:u,metadata:r,referenceSeriesUID:m,referenceStudyUID:d,toolName:r.toolName,displaySetInstanceUID:g.displaySetInstanceUID,label:r.label,data:i.cachedStats,type:"CircleROIStartEndThreshold"}}},se=(e,t,n)=>({RectangleROIStartEndThreshold:{toAnnotation:re.toAnnotation,toMeasurement:e=>re.toMeasurement(e,t,n),matchingCriteria:[{valueType:e.VALUE_TYPES.ROI_THRESHOLD_MANUAL}]},CircleROIStartEndThreshold:{toAnnotation:ie.toAnnotation,toMeasurement:e=>ie.toMeasurement(e,t,n),matchingCriteria:[{valueType:e.VALUE_TYPES.ROI_THRESHOLD_MANUAL}]}}),{CORNERSTONE_3D_TOOLS_SOURCE_NAME:ce,CORNERSTONE_3D_TOOLS_SOURCE_VERSION:le}=K.Enums;function ue(e,t){const{imageData:n}=e,a=n.getPointData().getScalars().getData(),{fn:o,baseValue:r}=function(e){const t=-1/0,n=(e,t)=>(e>t&&(t=e),t);return{fn:n,baseValue:t}}();let i=r;const s=ae.utilities.rectangleROITool.getBoundsIJKFromRectangleAnnotations(t,e),[[c,l],[u,p],[m,d]]=s;for(let e=c;e<=l;e++)for(let t=u;t<=p;t++)for(let r=m;r<=d;r++){i=o(a[n.computeOffsetIndex([e,t,r])],i)}return i}const pe=function(e,t,n){if("range"===n.strategy)return{ptLower:Number(n.ptLower),ptUpper:Number(n.ptUpper),ctLower:Number(n.ctLower),ctUpper:Number(n.ctUpper)};const{weight:a}=n,o=e.map((e=>ae.annotation.state.getAnnotation(e)));return{ctLower:-1/0,ctUpper:1/0,ptLower:a*ue(t[0],o),ptUpper:1/0}};var me=p(111),de=p.n(me),ge=p(142);const{datasetToBlob:fe}=de().data,ye=I.classes.MetadataProvider;const he=function(e){const t=ge.adaptersRT.Cornerstone3D.RTSS.generateRTSSFromAnnotations(e,ye,I.DicomMetadataStore),n=fe(t);var a=URL.createObjectURL(n);window.location.assign(a)},{SegmentationRepresentations:ve}=ae.Enums,Se=I.classes.MetadataProvider,be=["RectangleROIStartEndThreshold","RectangleROIThreshold","CircleROIStartEndThreshold"],Ie=(0,Y.getWebWorkerManager)(),xe={maxWorkerInstances:1,autoTerminateOnIdle:{enabled:!0,idleTimeThreshold:3e3}},Te=()=>new Worker(new URL(p.p+p.u(584),p.b),{name:"suv-peak-worker"});function we(e){const t=ae.segmentation.state.getSegmentation(e).representationData[ve.Labelmap],{volumeId:n,referencedVolumeId:a}=t;return{labelmapVolume:Y.cache.getVolume(n),referencedVolume:Y.cache.getVolume(a)}}function Ee(e){const{representationData:t}=e,{volumeId:n}=t[ve.Labelmap];return Y.cache.getVolume(n)}const Re=({servicesManager:e,commandsManager:t,extensionManager:n})=>{const{viewportGridService:a,uiNotificationService:o,displaySetService:r,hangingProtocolService:i,toolGroupService:s,cornerstoneViewportService:c,segmentationService:l}=e.services,u=n.getModuleEntry("@ohif/extension-cornerstone.utilityModule.common"),{getEnabledElement:p}=u.exports;function m(){const{activeViewportId:e}=a.getState(),{element:t}=p(e)||{};return Y.getEnabledElement(t)}function d(e){return e.reduce(((e,t)=>{const n=ae.annotation.selection.getAnnotationsSelectedByToolName(t);return e.concat(n)}),[])}const g={getMatchingPTDisplaySet:({viewportMatchDetails:e})=>{let t=null;for(const[n,a]of e){const{displaySetsInfo:e}=a,n=e.map((({displaySetInstanceUID:e})=>r.getDisplaySetByUID(e)));if(n&&0!==n.length&&(t=n.find((e=>"PT"===e.Modality)),t))break}return t},getPTMetadata:({ptDisplaySet:e})=>{const t=n.getDataSources()[0].getImageIdsForDisplaySet(e)[0],a=Se.get("instance",t);if("PT"!==a.Modality)return;return{SeriesTime:a.SeriesTime,Modality:a.Modality,PatientSex:a.PatientSex,PatientWeight:a.PatientWeight,RadiopharmaceuticalInformationSequence:{RadionuclideTotalDose:a.RadiopharmaceuticalInformationSequence[0].RadionuclideTotalDose,RadionuclideHalfLife:a.RadiopharmaceuticalInformationSequence[0].RadionuclideHalfLife,RadiopharmaceuticalStartTime:a.RadiopharmaceuticalInformationSequence[0].RadiopharmaceuticalStartTime,RadiopharmaceuticalStartDateTime:a.RadiopharmaceuticalInformationSequence[0].RadiopharmaceuticalStartDateTime}}},createNewLabelmapFromPT:async({label:e})=>{const{viewportMatchDetails:t}=i.getMatchDetails(),n=g.getMatchingPTDisplaySet({viewportMatchDetails:t});let a=null;for(const[e,{displaySetsInfo:o}]of t.entries()){if(o.some((({displaySetInstanceUID:e})=>e===n.displaySetInstanceUID))){a=e;break}}if(!n)return void o.error("No matching PT display set found");const s=l.getSegmentationRepresentations(a),c=r.getDisplaySetByUID(n.displaySetInstanceUID),u=await l.createLabelmapForDisplaySet(c,{label:`Segmentation ${s.length+1}`,segments:{1:{label:"Segment 1",active:!0}}});return l.addSegmentationRepresentation(a,{segmentationId:u}),u},thresholdSegmentationByRectangleROITool:({segmentationId:e,config:t,segmentIndex:n})=>{const r=ae.segmentation.state.getSegmentation(e),{representationData:s}=r,{displaySetMatchDetails:c}=i.getMatchDetails(),l=`cornerstoneStreamingImageVolume:${c.get("ctDisplaySet").displaySetInstanceUID}`,{volumeId:u}=s[ve.Labelmap],{referencedVolumeId:p}=Y.cache.getVolume(u),m=d(be);if(0===m.length)return void o.show({title:"Commands Module",message:"No ROIThreshold Tool is Selected",type:"error"});const g=Y.cache.getVolume(e);let f=Y.cache.getVolume(p);const y=Y.cache.getVolume(l);if(!f)throw new Error("No Reference volume found");if(!g)throw new Error("No Reference labelmap found");const h=ae.annotation.state.getAnnotation(m[0]),{metadata:{enabledElement:{viewport:v}}}=h;if(!v.hasVolumeId(p)){a.getDisplaySetsUIDsForViewport(v.id).forEach((e=>{const t=Y.cache.getVolumes().find((t=>t.volumeId.includes(e)));Y.utilities.isEqual(t.dimensions,g.dimensions)&&Y.utilities.isEqual(t.spacing,g.spacing)&&(f=t)}))}const{ptLower:S,ptUpper:b,ctLower:I,ctUpper:x}=pe(m,[f,y],t);return ae.utilities.segmentation.rectangleROIThresholdVolumeByRange(m,g,[{volume:f,lower:S,upper:b},{volume:y,lower:I,upper:x}],{overwrite:!0,segmentIndex:n})},calculateSuvPeak:async({segmentationId:e,segmentIndex:t})=>{const n=l.getSegmentation(e),{representationData:a}=n,{volumeId:o,referencedVolumeId:r}=a[ve.Labelmap],i=Y.cache.getVolume(o),s=Y.cache.getVolume(r);Ie.registerWorker("suv-peak-worker",Te,xe);const c=d(be).map((e=>ae.annotation.state.getAnnotation(e))),u={dimensions:i.dimensions,origin:i.origin,direction:i.direction,spacing:i.spacing,metadata:i.metadata,scalarData:i.voxelManager.getCompleteScalarDataArray()},p={dimensions:s.dimensions,origin:s.origin,direction:s.direction,spacing:s.spacing,metadata:s.metadata,scalarData:s.voxelManager.getCompleteScalarDataArray()},m=c.map((e=>({...e,metadata:{...e.metadata,enabledElement:{...e.metadata.enabledElement,viewport:null,renderingEngine:null,element:null}}}))),g=await Ie.executeTask("suv-peak-worker","calculateSuvPeak",{labelmapProps:u,referenceVolumeProps:p,annotations:m,segmentIndex:t})||{};return{suvPeak:g.mean,suvMax:g.max,suvMaxIJK:g.maxIJK,suvMaxLPS:g.maxLPS}},getLesionStats:({segmentationId:e,segmentIndex:t=1})=>{const{labelmapVolume:n,referencedVolume:a}=we(e),{voxelManager:o,imageData:r,spacing:i}=n,{voxelManager:s}=a;let c=-1/0,l=1/0;const u=[];let p=0;o.forEach((({value:e,index:n})=>{if(e===t){const e=s.getAtIndex(n);u.push(e),e>c&&(c=e),e<l&&(l=e),p++}}),{imageData:r});const m=u.reduce(((e,t)=>e+t),0)/p;return{minValue:l,maxValue:c,meanValue:m,stdValue:Math.sqrt(u.map((e=>(e-m)**2)).reduce(((e,t)=>e+t),0)/p),volume:p*i[0]*i[1]*i[2]*.001}},calculateLesionGlycolysis:({lesionStats:e})=>{const{meanValue:t,volume:n}=e;return{lesionGlyoclysisStats:n*t}},calculateTMTV:async({segmentations:e})=>{const t=e.map((e=>{const t=Ee(e);return{dimensions:t.dimensions,spacing:t.spacing,scalarData:t.voxelManager.getCompleteScalarDataArray(),origin:t.origin,direction:t.direction}}));if(t.length)return await Ie.executeTask("suv-peak-worker","calculateTMTV",t)},exportTMTVReportCSV:async({segmentations:e,tmtv:n,config:a,options:o})=>{const r=t.runCommand("getSegmentationCSVReport",{segmentations:e}),i=[{key:"Total Lesion Glycolysis",value:{tlg:(await g.getTotalLesionGlycolysis({segmentations:e})).toFixed(4)}},{key:"Threshold Configuration",value:{...a}}];void 0!==n&&i.unshift({key:"Total Metabolic Tumor Volume",value:{tmtv:n}}),function(e,t,n={}){const a=e[Object.keys(e)[0]],o=Object.keys(a),r=[o.join(",")];Object.values(e).forEach((e=>{const t=[];o.forEach((n=>{t.push(Array.isArray(e[n])?e[n].join(" "):e[n])})),r.push(t.join(","))})),r.push(""),r.push(""),r.push(""),r.push(`Patient ID,${a.PatientID}`),r.push(`Study Date,${a.StudyDate}`),r.push(""),t.forEach((({key:e,value:t})=>{const n=[];n.push(`${e}`),Object.keys(t).forEach((e=>{n.push(`${e}`),n.push(`${t[e]}`)})),r.push(n.join(","))}));const i=new Blob([r.join("\n")],{type:"text/csv;charset=utf-8"}),s=URL.createObjectURL(i),c=document.createElement("a");c.href=s,c.download=n.filename??`${a.PatientID}_tmtv.csv`,c.click()}(r,i,o)},getTotalLesionGlycolysis:async({segmentations:e})=>{const t=e.map((e=>{const t=Ee(e);return{dimensions:t.dimensions,spacing:t.spacing,scalarData:t.voxelManager.getCompleteScalarDataArray(),origin:t.origin,direction:t.direction}})),{referencedVolume:n}=we(e[0].segmentationId),a={dimensions:n.dimensions,spacing:n.spacing,scalarData:n.voxelManager.getCompleteScalarDataArray(),origin:n.origin,direction:n.direction};return await Ie.executeTask("suv-peak-worker","getTotalLesionGlycolysis",{labelmapProps:t,referenceVolumeProps:a})},setStartSliceForROIThresholdTool:()=>{const{viewport:e}=m(),{focalPoint:t}=e.getCamera(),n=d(be)[0],a=ae.annotation.state.getAnnotation(n);a.data.startCoordinate=t,a.invalidated=!0,e.render()},setEndSliceForROIThresholdTool:()=>{const{viewport:e}=m(),t=d(be)[0],n=ae.annotation.state.getAnnotation(t),a=e.getCamera().focalPoint;n.data.endCoordinate=a,n.invalidated=!0,e.render()},createTMTVRTReport:()=>{const e=ae.annotation.state.getAnnotationManager(),n=[];Object.keys(e.annotations).forEach((t=>{const a=e.annotations[t],o=be.reduce(((e,t)=>[...e,...a[t]??[]]),[]);n.push(...o)})),t.runCommand("exportRTReportForAnnotations",{annotations:n})},getSegmentationCSVReport:({segmentations:e})=>{e&&e.length||(e=l.getSegmentations());const t={};for(const n of e){const{label:e,segmentationId:a,representationData:o}=n,r=a,i={id:r,label:e};if(!o){t[r]=i;continue}const{cachedStats:s}=n.segments[1]||{};s&&Object.entries(s).forEach((([e,t])=>{"object"!=typeof t?i[e]=t:Object.entries(t).forEach((([t,n])=>{i[`${e}_${t}`]=n}))}));const c=n.representationData[ve.Labelmap];if(!c){t[r]=i;continue}const l=c.referencedVolumeId,u=Y.cache.getVolume(l);if(!u){t[r]=i;continue}if(!u.imageIds||!u.imageIds.length){t[r]=i;continue}const p=u.imageIds[0],m=x().classes.MetadataProvider.get("instance",p);m?t[r]={...i,PatientID:m.PatientID??"000000",PatientName:m.PatientName.Alphabetic,StudyInstanceUID:m.StudyInstanceUID,SeriesInstanceUID:m.SeriesInstanceUID,StudyDate:m.StudyDate}:t[r]=i}return t},exportRTReportForAnnotations:({annotations:e})=>{he(e)},setFusionPTColormap:({toolGroupId:e,colormap:n})=>{const a=s.getToolGroup(e);if(!a)return;const{viewportMatchDetails:o}=i.getMatchDetails(),r=g.getMatchingPTDisplaySet({viewportMatchDetails:o});if(!r)return;const l=a.getViewportIds(),u=[];l.forEach((e=>{t.runCommand("setViewportColormap",{viewportId:e,displaySetInstanceUID:r.displaySetInstanceUID,colormap:{name:n}}),u.push(c.getCornerstoneViewport(e))})),u.forEach((e=>{e.render()}))}},f={setEndSliceForROIThresholdTool:{commandFn:g.setEndSliceForROIThresholdTool},setStartSliceForROIThresholdTool:{commandFn:g.setStartSliceForROIThresholdTool},getMatchingPTDisplaySet:{commandFn:g.getMatchingPTDisplaySet},getPTMetadata:{commandFn:g.getPTMetadata},createNewLabelmapFromPT:{commandFn:g.createNewLabelmapFromPT},thresholdSegmentationByRectangleROITool:{commandFn:g.thresholdSegmentationByRectangleROITool},getTotalLesionGlycolysis:{commandFn:g.getTotalLesionGlycolysis},calculateSuvPeak:{commandFn:g.calculateSuvPeak},getLesionStats:{commandFn:g.getLesionStats},calculateTMTV:{commandFn:g.calculateTMTV},exportTMTVReportCSV:{commandFn:g.exportTMTVReportCSV},createTMTVRTReport:{commandFn:g.createTMTVRTReport},getSegmentationCSVReport:{commandFn:g.getSegmentationCSVReport},exportRTReportForAnnotations:{commandFn:g.exportRTReportForAnnotations},setFusionPTColormap:{commandFn:g.setFusionPTColormap}};return{actions:g,definitions:f,defaultContext:"TMTV:CORNERSTONE"}},Oe="roi_stat",Ce=[{value:Oe,label:"Max",placeHolder:"Max"},{value:"range",label:"Range",placeHolder:"Range"}];const Me=function({config:e,dispatch:t,runCommand:n}){const{t:a}=B("ROIThresholdConfiguration");return h.createElement("div",{className:"bg-primary-dark flex flex-col space-y-4"},h.createElement("div",{className:"flex items-end space-x-2"},h.createElement("div",{className:"flex w-1/2 flex-col"},h.createElement(b.Select,{label:a("Strategy"),closeMenuOnSelect:!0,className:"border-primary-main mr-2 bg-black text-white ",options:Ce,placeholder:Ce.find((t=>t.value===e.strategy)).placeHolder,value:e.strategy,onChange:({value:e})=>{t({type:"setStrategy",payload:{strategy:e}})}})),h.createElement("div",{className:"w-1/2"},h.createElement(b.LegacyButtonGroup,null,h.createElement(b.LegacyButton,{size:"initial",className:"px-2 py-2 text-base text-white",color:"primaryLight",variant:"outlined",onClick:()=>n("setStartSliceForROIThresholdTool")},a("Start")),h.createElement(b.LegacyButton,{size:"initial",color:"primaryLight",variant:"outlined",className:"px-2 py-2 text-base text-white",onClick:()=>n("setEndSliceForROIThresholdTool")},a("End"))))),e.strategy===Oe&&h.createElement(b.Input,{label:a("Percentage of Max SUV"),labelClassName:"text-[13px] font-inter text-white",className:"border-primary-main bg-black",type:"text",containerClassName:"mr-2",value:e.weight,onChange:e=>{t({type:"setWeight",payload:{weight:e.target.value}})}}),e.strategy!==Oe&&h.createElement("div",{className:"mr-2 text-sm"},h.createElement("table",null,h.createElement("tbody",null,h.createElement("tr",{className:"mt-2"},h.createElement("td",{className:"pr-4",colSpan:"3"},h.createElement(b.Label,{className:"font-inter text-[13px] text-white",text:"Lower & Upper Ranges"}))),h.createElement("tr",{className:"mt-2"},h.createElement("td",{className:"pr-4 pt-2 text-center"},h.createElement(b.Label,{className:"text-white",text:"CT"})),h.createElement("td",null,h.createElement("div",{className:"flex justify-between"},h.createElement(b.Input,{label:a(""),labelClassName:"text-white",className:"border-primary-main mt-2 bg-black",type:"text",containerClassName:"mr-2",value:e.ctLower,onChange:e=>{t({type:"setThreshold",payload:{ctLower:e.target.value}})}}),h.createElement(b.Input,{label:a(""),labelClassName:"text-white",className:"border-primary-main mt-2 bg-black",type:"text",containerClassName:"mr-2",value:e.ctUpper,onChange:e=>{t({type:"setThreshold",payload:{ctUpper:e.target.value}})}})))),h.createElement("tr",null,h.createElement("td",{className:"pr-4 pt-2 text-center"},h.createElement(b.Label,{className:"text-white",text:"PT"})),h.createElement("td",null,h.createElement("div",{className:"flex justify-between"},h.createElement(b.Input,{label:a(""),labelClassName:"text-white",className:"border-primary-main mt-2 bg-black",type:"text",containerClassName:"mr-2",value:e.ptLower,onChange:e=>{t({type:"setThreshold",payload:{ptLower:e.target.value}})}}),h.createElement(b.Input,{label:a(""),labelClassName:"text-white",className:"border-primary-main mt-2 bg-black",type:"text",containerClassName:"mr-2",value:e.ptUpper,onChange:e=>{t({type:"setThreshold",payload:{ptUpper:e.target.value}})}}))))))))},De=Oe;function Ne(e,t){const{payload:n}=t,{strategy:a,ctLower:o,ctUpper:r,ptLower:i,ptUpper:s,weight:c}=n;switch(t.type){case"setStrategy":return{...e,strategy:a};case"setThreshold":return{...e,ctLower:o||e.ctLower,ctUpper:r||e.ctUpper,ptLower:i||e.ptLower,ptUpper:s||e.ptUpper};case"setWeight":return{...e,weight:c};default:return e}}const Pe=function({servicesManager:e,commandsManager:t}){const{segmentationService:n}=e.services,[a,o]=(0,h.useState)(null),r=(0,h.useCallback)(((e,n={})=>t.runCommand(e,n)),[t]),[i,s]=(0,h.useReducer)(Ne,{strategy:De,ctLower:-1024,ctUpper:1024,ptLower:2.5,ptUpper:100,weight:.41}),c=(0,h.useCallback)((()=>{const e=a,t=ae.segmentation.segmentIndex.getActiveSegmentIndex(e);r("thresholdSegmentationByRectangleROITool",{segmentationId:e,config:i,segmentIndex:t})}),[a,i]);return(0,h.useEffect)((()=>{const e=n.getSegmentationRepresentations();if(!e.length)return;const t=e.find((e=>e.isActive));o(t.id)}),[]),(0,h.useEffect)((()=>{const e=n.EVENTS.SEGMENTATION_MODIFIED,t=[];return[e].forEach((e=>{const{unsubscribe:a}=n.subscribe(e,(()=>{const e=n.getSegmentationRepresentations();if(!e.length)return;const t=e.find((e=>e.isActive));o(t.id)}));t.push(a)})),()=>{t.forEach((e=>{e()}))}}),[]),h.createElement("div",{className:"invisible-scrollbar mb-2 flex flex-col overflow-y-auto overflow-x-hidden"},h.createElement(Me,{config:i,dispatch:s,runCommand:r}),null!==a&&h.createElement(b.Button,{className:"mt-2 !h-[26px] !w-[75px]",onClick:c},"Run"))};const Le={id:e,preRegistration({servicesManager:e,commandsManager:t,extensionManager:n,configuration:a={}}){!function({servicesManager:e}){const{measurementService:t,displaySetService:n,cornerstoneViewportService:a}=e.services;(0,ae.addTool)(ae.RectangleROIStartEndThresholdTool),(0,ae.addTool)(ae.CircleROIStartEndThresholdTool);const{RectangleROIStartEndThreshold:o,CircleROIStartEndThreshold:r}=se(t,n,a),i=t.getSource(ce,le);t.addMapping(i,"RectangleROIStartEndThreshold",o.matchingCriteria,o.toAnnotation,o.toMeasurement),t.addMapping(i,"CircleROIStartEndThreshold",r.matchingCriteria,r.toAnnotation,r.toMeasurement)}({servicesManager:e,commandsManager:t,extensionManager:n,configuration:a})},getToolbarModule:function({commandsManager:e,servicesManager:t}){return[{name:"tmtv.RectangleROIThresholdOptions",defaultComponent:()=>Pe({commandsManager:e,servicesManager:t})}]},getPanelModule:ne,getHangingProtocolModule:y,getCommandsModule:({servicesManager:e,commandsManager:t,extensionManager:n})=>Re({servicesManager:e,commandsManager:t,extensionManager:n})},ke=Le})(),m})()));
2
+ !function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("@cornerstonejs/adapters"),require("@cornerstonejs/core"),require("@cornerstonejs/tools"),require("@ohif/core"),require("@ohif/core/src/utils"),require("@ohif/extension-cornerstone"),require("@ohif/ui"),require("@ohif/ui-next"),require("dcmjs")):"function"==typeof define&&define.amd?define(["@cornerstonejs/adapters","@cornerstonejs/core","@cornerstonejs/tools","@ohif/core","@ohif/core/src/utils","@ohif/extension-cornerstone","@ohif/ui","@ohif/ui-next","dcmjs"],t):"object"==typeof exports?exports["ohif-extension-tmtv"]=t(require("@cornerstonejs/adapters"),require("@cornerstonejs/core"),require("@cornerstonejs/tools"),require("@ohif/core"),require("@ohif/core/src/utils"),require("@ohif/extension-cornerstone"),require("@ohif/ui"),require("@ohif/ui-next"),require("dcmjs")):e["ohif-extension-tmtv"]=t(e["@cornerstonejs/adapters"],e["@cornerstonejs/core"],e["@cornerstonejs/tools"],e["@ohif/core"],e["@ohif/core/src/utils"],e["@ohif/extension-cornerstone"],e["@ohif/ui"],e["@ohif/ui-next"],e.dcmjs)}(self,((e,t,n,a,o,r,i,s,c)=>(()=>{var l={856:(e,t,n)=>{"use strict";var a=n(183);function o(){}function r(){}r.resetWarningCache=o,e.exports=function(){function e(e,t,n,o,r,i){if(i!==a){var s=new Error("Calling PropTypes validators directly is not supported by the `prop-types` package. Use PropTypes.checkPropTypes() to call them. Read more at http://fb.me/use-check-prop-types");throw s.name="Invariant Violation",s}}function t(){return e}e.isRequired=e;var n={array:e,bigint:e,bool:e,func:e,number:e,object:e,string:e,symbol:e,any:e,arrayOf:t,element:e,elementType:e,instanceOf:t,node:e,objectOf:t,oneOf:t,oneOfType:t,shape:t,exact:t,checkPropTypes:r,resetWarningCache:o};return n.PropTypes=n,n}},598:(e,t,n)=>{e.exports=n(856)()},183:e=>{"use strict";e.exports="SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED"},249:(e,t)=>{"use strict";var n=Symbol.for("react.element"),a=Symbol.for("react.portal"),o=Symbol.for("react.fragment"),r=Symbol.for("react.strict_mode"),i=Symbol.for("react.profiler"),s=Symbol.for("react.provider"),c=Symbol.for("react.context"),l=Symbol.for("react.forward_ref"),u=Symbol.for("react.suspense"),p=Symbol.for("react.memo"),m=Symbol.for("react.lazy"),d=Symbol.iterator;var g={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},f=Object.assign,y={};function h(e,t,n){this.props=e,this.context=t,this.refs=y,this.updater=n||g}function v(){}function S(e,t,n){this.props=e,this.context=t,this.refs=y,this.updater=n||g}h.prototype.isReactComponent={},h.prototype.setState=function(e,t){if("object"!=typeof e&&"function"!=typeof e&&null!=e)throw Error("setState(...): takes an object of state variables to update or a function which returns an object of state variables.");this.updater.enqueueSetState(this,e,t,"setState")},h.prototype.forceUpdate=function(e){this.updater.enqueueForceUpdate(this,e,"forceUpdate")},v.prototype=h.prototype;var b=S.prototype=new v;b.constructor=S,f(b,h.prototype),b.isPureReactComponent=!0;var I=Array.isArray,x=Object.prototype.hasOwnProperty,T={current:null},w={key:!0,ref:!0,__self:!0,__source:!0};function E(e,t,a){var o,r={},i=null,s=null;if(null!=t)for(o in void 0!==t.ref&&(s=t.ref),void 0!==t.key&&(i=""+t.key),t)x.call(t,o)&&!w.hasOwnProperty(o)&&(r[o]=t[o]);var c=arguments.length-2;if(1===c)r.children=a;else if(1<c){for(var l=Array(c),u=0;u<c;u++)l[u]=arguments[u+2];r.children=l}if(e&&e.defaultProps)for(o in c=e.defaultProps)void 0===r[o]&&(r[o]=c[o]);return{$$typeof:n,type:e,key:i,ref:s,props:r,_owner:T.current}}function R(e){return"object"==typeof e&&null!==e&&e.$$typeof===n}var O=/\/+/g;function C(e,t){return"object"==typeof e&&null!==e&&null!=e.key?function(e){var t={"=":"=0",":":"=2"};return"$"+e.replace(/[=:]/g,(function(e){return t[e]}))}(""+e.key):t.toString(36)}function M(e,t,o,r,i){var s=typeof e;"undefined"!==s&&"boolean"!==s||(e=null);var c=!1;if(null===e)c=!0;else switch(s){case"string":case"number":c=!0;break;case"object":switch(e.$$typeof){case n:case a:c=!0}}if(c)return i=i(c=e),e=""===r?"."+C(c,0):r,I(i)?(o="",null!=e&&(o=e.replace(O,"$&/")+"/"),M(i,t,o,"",(function(e){return e}))):null!=i&&(R(i)&&(i=function(e,t){return{$$typeof:n,type:e.type,key:t,ref:e.ref,props:e.props,_owner:e._owner}}(i,o+(!i.key||c&&c.key===i.key?"":(""+i.key).replace(O,"$&/")+"/")+e)),t.push(i)),1;if(c=0,r=""===r?".":r+":",I(e))for(var l=0;l<e.length;l++){var u=r+C(s=e[l],l);c+=M(s,t,o,u,i)}else if(u=function(e){return null===e||"object"!=typeof e?null:"function"==typeof(e=d&&e[d]||e["@@iterator"])?e:null}(e),"function"==typeof u)for(e=u.call(e),l=0;!(s=e.next()).done;)c+=M(s=s.value,t,o,u=r+C(s,l++),i);else if("object"===s)throw t=String(e),Error("Objects are not valid as a React child (found: "+("[object Object]"===t?"object with keys {"+Object.keys(e).join(", ")+"}":t)+"). If you meant to render a collection of children, use an array instead.");return c}function D(e,t,n){if(null==e)return e;var a=[],o=0;return M(e,a,"","",(function(e){return t.call(n,e,o++)})),a}function N(e){if(-1===e._status){var t=e._result;(t=t()).then((function(t){0!==e._status&&-1!==e._status||(e._status=1,e._result=t)}),(function(t){0!==e._status&&-1!==e._status||(e._status=2,e._result=t)})),-1===e._status&&(e._status=0,e._result=t)}if(1===e._status)return e._result.default;throw e._result}var P={current:null},L={transition:null},k={ReactCurrentDispatcher:P,ReactCurrentBatchConfig:L,ReactCurrentOwner:T};function j(){throw Error("act(...) is not supported in production builds of React.")}t.Children={map:D,forEach:function(e,t,n){D(e,(function(){t.apply(this,arguments)}),n)},count:function(e){var t=0;return D(e,(function(){t++})),t},toArray:function(e){return D(e,(function(e){return e}))||[]},only:function(e){if(!R(e))throw Error("React.Children.only expected to receive a single React element child.");return e}},t.Component=h,t.Fragment=o,t.Profiler=i,t.PureComponent=S,t.StrictMode=r,t.Suspense=u,t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=k,t.act=j,t.cloneElement=function(e,t,a){if(null==e)throw Error("React.cloneElement(...): The argument must be a React element, but you passed "+e+".");var o=f({},e.props),r=e.key,i=e.ref,s=e._owner;if(null!=t){if(void 0!==t.ref&&(i=t.ref,s=T.current),void 0!==t.key&&(r=""+t.key),e.type&&e.type.defaultProps)var c=e.type.defaultProps;for(l in t)x.call(t,l)&&!w.hasOwnProperty(l)&&(o[l]=void 0===t[l]&&void 0!==c?c[l]:t[l])}var l=arguments.length-2;if(1===l)o.children=a;else if(1<l){c=Array(l);for(var u=0;u<l;u++)c[u]=arguments[u+2];o.children=c}return{$$typeof:n,type:e.type,key:r,ref:i,props:o,_owner:s}},t.createContext=function(e){return(e={$$typeof:c,_currentValue:e,_currentValue2:e,_threadCount:0,Provider:null,Consumer:null,_defaultValue:null,_globalName:null}).Provider={$$typeof:s,_context:e},e.Consumer=e},t.createElement=E,t.createFactory=function(e){var t=E.bind(null,e);return t.type=e,t},t.createRef=function(){return{current:null}},t.forwardRef=function(e){return{$$typeof:l,render:e}},t.isValidElement=R,t.lazy=function(e){return{$$typeof:m,_payload:{_status:-1,_result:e},_init:N}},t.memo=function(e,t){return{$$typeof:p,type:e,compare:void 0===t?null:t}},t.startTransition=function(e){var t=L.transition;L.transition={};try{e()}finally{L.transition=t}},t.unstable_act=j,t.useCallback=function(e,t){return P.current.useCallback(e,t)},t.useContext=function(e){return P.current.useContext(e)},t.useDebugValue=function(){},t.useDeferredValue=function(e){return P.current.useDeferredValue(e)},t.useEffect=function(e,t){return P.current.useEffect(e,t)},t.useId=function(){return P.current.useId()},t.useImperativeHandle=function(e,t,n){return P.current.useImperativeHandle(e,t,n)},t.useInsertionEffect=function(e,t){return P.current.useInsertionEffect(e,t)},t.useLayoutEffect=function(e,t){return P.current.useLayoutEffect(e,t)},t.useMemo=function(e,t){return P.current.useMemo(e,t)},t.useReducer=function(e,t,n){return P.current.useReducer(e,t,n)},t.useRef=function(e){return P.current.useRef(e)},t.useState=function(e){return P.current.useState(e)},t.useSyncExternalStore=function(e,t,n){return P.current.useSyncExternalStore(e,t,n)},t.useTransition=function(){return P.current.useTransition()},t.version="18.3.1"},326:(e,t,n)=>{"use strict";e.exports=n(249)},741:e=>{e.exports={area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0}},142:t=>{"use strict";t.exports=e},557:e=>{"use strict";e.exports=t},713:e=>{"use strict";e.exports=n},2:e=>{"use strict";e.exports=a},141:e=>{"use strict";e.exports=o},669:e=>{"use strict";e.exports=r},307:e=>{"use strict";e.exports=i},55:e=>{"use strict";e.exports=s},111:e=>{"use strict";e.exports=c}},u={};function p(e){var t=u[e];if(void 0!==t)return t.exports;var n=u[e]={exports:{}};return l[e](n,n.exports,p),n.exports}p.m=l,p.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return p.d(t,{a:t}),t},p.d=(e,t)=>{for(var n in t)p.o(t,n)&&!p.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},p.u=e=>"dist/"+e+".ohif-extension-tmtv.umd.js",p.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),p.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},p.p="/",p.b=document.baseURI||self.location.href;var m={};return(()=>{"use strict";p.r(m),p.d(m,{default:()=>je});const e=JSON.parse('{"UU":"@ohif/extension-tmtv"}').UU,t=e=>({type:"cameraPosition",id:e,source:!0,target:!0}),n={type:"hydrateseg",id:"sameFORId",source:!0,target:!0,options:{matchingRules:["sameFOR"]}},a={viewportOptions:{viewportId:"ctAXIAL",viewportType:"volume",orientation:"axial",toolGroupId:"ctToolGroup",initialImageOptions:{preset:"first"},syncGroups:[t("axialSync"),{type:"voi",id:"ctWLSync",source:!0,target:!0,options:{syncColormap:!0}},n]},displaySets:[{id:"ctDisplaySet"}]},o={viewportOptions:{viewportId:"ctSAGITTAL",viewportType:"volume",orientation:"sagittal",toolGroupId:"ctToolGroup",syncGroups:[t("sagittalSync"),{type:"voi",id:"ctWLSync",source:!0,target:!0,options:{syncColormap:!0}},n]},displaySets:[{id:"ctDisplaySet"}]},r={viewportOptions:{viewportId:"ctCORONAL",viewportType:"volume",orientation:"coronal",toolGroupId:"ctToolGroup",syncGroups:[t("coronalSync"),{type:"voi",id:"ctWLSync",source:!0,target:!0,options:{syncColormap:!0}},n]},displaySets:[{id:"ctDisplaySet"}]},i={viewportOptions:{viewportId:"ptAXIAL",viewportType:"volume",background:[1,1,1],orientation:"axial",toolGroupId:"ptToolGroup",initialImageOptions:{preset:"first"},syncGroups:[t("axialSync"),{type:"voi",id:"ptWLSync",source:!0,target:!0,options:{syncColormap:!0}},{type:"voi",id:"ptFusionWLSync",source:!0,target:!1,options:{syncColormap:!1,syncInvertState:!1}},n]},displaySets:[{options:{voi:{custom:"getPTVOIRange"},voiInverted:!0},id:"ptDisplaySet"}]},s={viewportOptions:{viewportId:"ptSAGITTAL",viewportType:"volume",orientation:"sagittal",background:[1,1,1],toolGroupId:"ptToolGroup",syncGroups:[t("sagittalSync"),{type:"voi",id:"ptWLSync",source:!0,target:!0,options:{syncColormap:!0}},{type:"voi",id:"ptFusionWLSync",source:!0,target:!1,options:{syncColormap:!1,syncInvertState:!1}},n]},displaySets:[{options:{voi:{custom:"getPTVOIRange"},voiInverted:!0},id:"ptDisplaySet"}]},c={viewportOptions:{viewportId:"ptCORONAL",viewportType:"volume",orientation:"coronal",background:[1,1,1],toolGroupId:"ptToolGroup",syncGroups:[t("coronalSync"),{type:"voi",id:"ptWLSync",source:!0,target:!0,options:{syncColormap:!0}},{type:"voi",id:"ptFusionWLSync",source:!0,target:!1,options:{syncColormap:!1,syncInvertState:!1}},n]},displaySets:[{options:{voi:{custom:"getPTVOIRange"},voiInverted:!0},id:"ptDisplaySet"}]},l={viewportOptions:{viewportId:"fusionAXIAL",viewportType:"volume",orientation:"axial",toolGroupId:"fusionToolGroup",initialImageOptions:{preset:"first"},syncGroups:[t("axialSync"),{type:"voi",id:"ctWLSync",source:!1,target:!0},{type:"voi",id:"fusionWLSync",source:!0,target:!0,options:{syncColormap:!0}},{type:"voi",id:"ptFusionWLSync",source:!1,target:!0,options:{syncColormap:!1,syncInvertState:!1}},n]},displaySets:[{id:"ctDisplaySet"},{id:"ptDisplaySet",options:{colormap:{name:"hsv",opacity:[{value:0,opacity:0},{value:.1,opacity:.8},{value:1,opacity:.9}]},voi:{custom:"getPTVOIRange"}}}]},u={viewportOptions:{viewportId:"fusionSAGITTAL",viewportType:"volume",orientation:"sagittal",toolGroupId:"fusionToolGroup",syncGroups:[t("sagittalSync"),{type:"voi",id:"ctWLSync",source:!1,target:!0},{type:"voi",id:"fusionWLSync",source:!0,target:!0,options:{syncColormap:!0}},{type:"voi",id:"ptFusionWLSync",source:!1,target:!0,options:{syncColormap:!1,syncInvertState:!1}},n]},displaySets:[{id:"ctDisplaySet"},{id:"ptDisplaySet",options:{colormap:{name:"hsv",opacity:[{value:0,opacity:0},{value:.1,opacity:.8},{value:1,opacity:.9}]},voi:{custom:"getPTVOIRange"}}}]},d={viewportOptions:{viewportId:"fusionCoronal",viewportType:"volume",orientation:"coronal",toolGroupId:"fusionToolGroup",syncGroups:[t("coronalSync"),{type:"voi",id:"ctWLSync",source:!1,target:!0},{type:"voi",id:"fusionWLSync",source:!0,target:!0,options:{syncColormap:!0}},{type:"voi",id:"ptFusionWLSync",source:!1,target:!0,options:{syncColormap:!1,syncInvertState:!1}},n]},displaySets:[{id:"ctDisplaySet"},{id:"ptDisplaySet",options:{colormap:{name:"hsv",opacity:[{value:0,opacity:0},{value:.1,opacity:.8},{value:1,opacity:.9}]},voi:{custom:"getPTVOIRange"}}}]},g={viewportOptions:{viewportId:"mipSagittal",viewportType:"volume",orientation:"sagittal",background:[1,1,1],toolGroupId:"mipToolGroup",syncGroups:[{type:"voi",id:"ptWLSync",source:!0,target:!0,options:{syncColormap:!0}},{type:"voi",id:"ptFusionWLSync",source:!0,target:!1,options:{syncColormap:!1,syncInvertState:!1}},n],customViewportProps:{hideOverlays:!0}},displaySets:[{options:{blendMode:"MIP",slabThickness:"fullVolume",voi:{custom:"getPTVOIRange"},voiInverted:!0},id:"ptDisplaySet"}]},f={id:"@ohif/extension-tmtv.hangingProtocolModule.ptCT",locked:!0,name:"Default",createdDate:"2021-02-23T19:22:08.894Z",modifiedDate:"2022-10-04T19:22:08.894Z",availableTo:{},editableBy:{},imageLoadStrategy:"interleaveTopToBottom",protocolMatchingRules:[{attribute:"ModalitiesInStudy",constraint:{contains:["CT","PT"]}},{attribute:"StudyDescription",constraint:{contains:"PETCT"}},{attribute:"StudyDescription",constraint:{contains:"PET/CT"}}],displaySetSelectors:{ctDisplaySet:{seriesMatchingRules:[{attribute:"Modality",constraint:{equals:{value:"CT"}},required:!0},{attribute:"isReconstructable",constraint:{equals:{value:!0}},required:!0},{attribute:"SeriesDescription",constraint:{contains:"CT"}},{attribute:"SeriesDescription",constraint:{contains:"CT WB"}}]},ptDisplaySet:{seriesMatchingRules:[{attribute:"Modality",constraint:{equals:"PT"},required:!0},{attribute:"isReconstructable",constraint:{equals:{value:!0}},required:!0},{attribute:"SeriesDescription",constraint:{contains:"Corrected"}},{weight:2,attribute:"SeriesDescription",constraint:{doesNotContain:{value:"Uncorrected"}}}]}},stages:[{name:"default",id:"default",viewportStructure:{layoutType:"grid",properties:{rows:3,columns:4,layoutOptions:[{x:0,y:0,width:1/4,height:1/3},{x:1/4,y:0,width:1/4,height:1/3},{x:.5,y:0,width:1/4,height:1/3},{x:0,y:1/3,width:1/4,height:1/3},{x:1/4,y:1/3,width:1/4,height:1/3},{x:.5,y:1/3,width:1/4,height:1/3},{x:0,y:2/3,width:1/4,height:1/3},{x:1/4,y:2/3,width:1/4,height:1/3},{x:.5,y:2/3,width:1/4,height:1/3},{x:3/4,y:0,width:1/4,height:1}]}},viewports:[a,o,r,i,s,c,l,u,d,g],createdDate:"2021-02-23T18:32:42.850Z"},{name:"Fusion 2x2",id:"Fusion-2x2",viewportStructure:{layoutType:"grid",properties:{rows:2,columns:2}},viewports:[a,l,i,g]},{name:"2x3-layout",id:"2x3-layout",viewportStructure:{layoutType:"grid",properties:{rows:2,columns:3}},viewports:[a,o,r,i,s,c]},{name:"2x4-layout",id:"2x4-layout",viewportStructure:{layoutType:"grid",properties:{rows:2,columns:4,layoutOptions:[{x:0,y:0,width:1/4,height:.5},{x:1/4,y:0,width:1/4,height:.5},{x:.5,y:0,width:1/4,height:.5},{x:3/4,y:0,width:1/4,height:1},{x:0,y:.5,width:1/4,height:.5},{x:1/4,y:.5,width:1/4,height:.5},{x:.5,y:.5,width:1/4,height:.5}]}},viewports:[c,s,i,g,d,u,l]}],numberOfPriorsReferenced:-1};const y=function(){return[{name:f.id,protocol:f}]};var h=p(326),v=p(598),S=p.n(v),b=p(307),I=p(2),x=p.n(I);function T(e){return T="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},T(e)}function w(e){var t=function(e,t){if("object"!=T(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var a=n.call(e,t||"default");if("object"!=T(a))return a;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}(e,"string");return"symbol"==T(t)?t:t+""}function E(e,t,n){return(t=w(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}p(741);Object.create(null);function R(){if(console&&console.warn){for(var e,t=arguments.length,n=new Array(t),a=0;a<t;a++)n[a]=arguments[a];"string"==typeof n[0]&&(n[0]="react-i18next:: ".concat(n[0])),(e=console).warn.apply(e,n)}}var O={};function C(){for(var e=arguments.length,t=new Array(e),n=0;n<e;n++)t[n]=arguments[n];"string"==typeof t[0]&&O[t[0]]||("string"==typeof t[0]&&(O[t[0]]=new Date),R.apply(void 0,t))}var M=function(e,t){return function(){if(e.isInitialized)t();else{e.on("initialized",(function n(){setTimeout((function(){e.off("initialized",n)}),0),t()}))}}};function D(e,t,n){e.loadNamespaces(t,M(e,n))}function N(e,t,n,a){"string"==typeof n&&(n=[n]),n.forEach((function(t){e.options.ns.indexOf(t)<0&&e.options.ns.push(t)})),e.loadLanguages(t,M(e,a))}var P=/&(?:amp|#38|lt|#60|gt|#62|apos|#39|quot|#34|nbsp|#160|copy|#169|reg|#174|hellip|#8230|#x2F|#47);/g,L={"&amp;":"&","&#38;":"&","&lt;":"<","&#60;":"<","&gt;":">","&#62;":">","&apos;":"'","&#39;":"'","&quot;":'"',"&#34;":'"',"&nbsp;":" ","&#160;":" ","&copy;":"©","&#169;":"©","&reg;":"®","&#174;":"®","&hellip;":"…","&#8230;":"…","&#x2F;":"/","&#47;":"/"},k=function(e){return L[e]};var j,U={bindI18n:"languageChanged",bindI18nStore:"",transEmptyNodeValue:"",transSupportBasicHtmlNodes:!0,transWrapTextNodes:"",transKeepBasicHtmlNodesFor:["br","strong","i","p"],useSuspense:!0,unescape:function(e){return e.replace(P,k)}};function V(e,t){for(var n=0;n<t.length;n++){var a=t[n];a.enumerable=a.enumerable||!1,a.configurable=!0,"value"in a&&(a.writable=!0),Object.defineProperty(e,w(a.key),a)}}var _=(0,h.createContext)(),A=function(){function e(){!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.usedNamespaces={}}return function(e,t,n){t&&V(e.prototype,t),n&&V(e,n),Object.defineProperty(e,"prototype",{writable:!1})}(e,[{key:"addUsedNamespaces",value:function(e){var t=this;e.forEach((function(e){t.usedNamespaces[e]||(t.usedNamespaces[e]=!0)}))}},{key:"getUsedNamespaces",value:function(){return Object.keys(this.usedNamespaces)}}]),e}();function F(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,a=Array(t);n<t;n++)a[n]=e[n];return a}function q(e,t){return function(e){if(Array.isArray(e))return e}(e)||function(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var a,o,r,i,s=[],c=!0,l=!1;try{if(r=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;c=!1}else for(;!(c=(a=r.call(n)).done)&&(s.push(a.value),s.length!==t);c=!0);}catch(e){l=!0,o=e}finally{try{if(!c&&null!=n.return&&(i=n.return(),Object(i)!==i))return}finally{if(l)throw o}}return s}}(e,t)||function(e,t){if(e){if("string"==typeof e)return F(e,t);var n={}.toString.call(e).slice(8,-1);return"Object"===n&&e.constructor&&(n=e.constructor.name),"Map"===n||"Set"===n?Array.from(e):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?F(e,t):void 0}}(e,t)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function G(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function W(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?G(Object(n),!0).forEach((function(t){E(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):G(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}var $=function(e,t){var n=(0,h.useRef)();return(0,h.useEffect)((function(){n.current=t?n.current:e}),[e,t]),n.current};function B(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=t.i18n,a=(0,h.useContext)(_)||{},o=a.i18n,r=a.defaultNS,i=n||o||j;if(i&&!i.reportNamespaces&&(i.reportNamespaces=new A),!i){C("You will need to pass in an i18next instance by using initReactI18next");var s=function(e,t){return"string"==typeof t?t:t&&"object"===T(t)&&"string"==typeof t.defaultValue?t.defaultValue:Array.isArray(e)?e[e.length-1]:e},c=[s,{},!1];return c.t=s,c.i18n={},c.ready=!1,c}i.options.react&&void 0!==i.options.react.wait&&C("It seems you are still using the old wait option, you may migrate to the new useSuspense behaviour.");var l=W(W(W({},U),i.options.react),t),u=l.useSuspense,p=l.keyPrefix,m=e||r||i.options&&i.options.defaultNS;m="string"==typeof m?[m]:m||["translation"],i.reportNamespaces.addUsedNamespaces&&i.reportNamespaces.addUsedNamespaces(m);var d=(i.isInitialized||i.initializedStoreOnce)&&m.every((function(e){return function(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};return t.languages&&t.languages.length?void 0!==t.options.ignoreJSONStructure?t.hasLoadedNamespace(e,{lng:n.lng,precheck:function(t,a){if(n.bindI18n&&n.bindI18n.indexOf("languageChanging")>-1&&t.services.backendConnector.backend&&t.isLanguageChangingTo&&!a(t.isLanguageChangingTo,e))return!1}}):function(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},a=t.languages[0],o=!!t.options&&t.options.fallbackLng,r=t.languages[t.languages.length-1];if("cimode"===a.toLowerCase())return!0;var i=function(e,n){var a=t.services.backendConnector.state["".concat(e,"|").concat(n)];return-1===a||2===a};return!(n.bindI18n&&n.bindI18n.indexOf("languageChanging")>-1&&t.services.backendConnector.backend&&t.isLanguageChangingTo&&!i(t.isLanguageChangingTo,e)||!t.hasResourceBundle(a,e)&&t.services.backendConnector.backend&&(!t.options.resources||t.options.partialBundledLanguages)&&(!i(a,e)||o&&!i(r,e)))}(e,t,n):(C("i18n.languages were undefined or empty",t.languages),!0)}(e,i,l)}));function g(){return i.getFixedT(t.lng||null,"fallback"===l.nsMode?m:m[0],p)}var f=q((0,h.useState)(g),2),y=f[0],v=f[1],S=m.join();t.lng&&(S="".concat(t.lng).concat(S));var b=$(S),I=(0,h.useRef)(!0);(0,h.useEffect)((function(){var e=l.bindI18n,n=l.bindI18nStore;function a(){I.current&&v(g)}return I.current=!0,d||u||(t.lng?N(i,t.lng,m,(function(){I.current&&v(g)})):D(i,m,(function(){I.current&&v(g)}))),d&&b&&b!==S&&I.current&&v(g),e&&i&&i.on(e,a),n&&i&&i.store.on(n,a),function(){I.current=!1,e&&i&&e.split(" ").forEach((function(e){return i.off(e,a)})),n&&i&&n.split(" ").forEach((function(e){return i.store.off(e,a)}))}}),[i,S]);var x=(0,h.useRef)(!0);(0,h.useEffect)((function(){I.current&&!x.current&&v(g),x.current=!1}),[i,p]);var w=[y,i,d];if(w.t=y,w.i18n=i,w.ready=d,d)return w;if(!d&&!u)return w;throw new Promise((function(e){t.lng?N(i,t.lng,m,(function(){return e()})):D(i,m,(function(){return e()}))}))}const H={PatientWeight:null,PatientSex:null,SeriesTime:null,RadiopharmaceuticalInformationSequence:{RadionuclideTotalDose:null,RadionuclideHalfLife:null,RadiopharmaceuticalStartTime:null}};function z({servicesManager:e,commandsManager:t}){const{t:n}=B("PanelSUV"),{displaySetService:a,toolGroupService:o,toolbarService:r,hangingProtocolService:i}=e.services,[s,c]=(0,h.useState)(H),[l,u]=(0,h.useState)(null),p=e=>{c((t=>{const n={...t};return Object.keys(e).forEach((a=>{"object"==typeof e[a]?n[a]={...t[a],...e[a]}:n[a]=e[a]})),n}))},m=e=>{const n=t.runCommand("getMatchingPTDisplaySet",{viewportMatchDetails:e});if(!n)return;return{ptDisplaySet:n,metadata:t.runCommand("getPTMetadata",{ptDisplaySet:n})}};return(0,h.useEffect)((()=>{const e=a.getActiveDisplaySets(),{viewportMatchDetails:t}=i.getMatchDetails();if(!e.length)return;const n=m(t);if(!n)return;const{ptDisplaySet:o,metadata:r}=n;u(o),c(r)}),[]),(0,h.useEffect)((()=>{const{unsubscribe:e}=i.subscribe(i.EVENTS.PROTOCOL_CHANGED,(({viewportMatchDetails:e})=>{const t=m(e);if(!t)return;const{ptDisplaySet:n,metadata:a}=t;u(n),c(a)}));return()=>{e()}}),[]),h.createElement(h.Fragment,null,h.createElement("div",{className:"ohif-scrollbar flex min-h-0 flex-auto select-none flex-col justify-between overflow-auto"},h.createElement("div",{className:"flex min-h-0 flex-1 flex-col bg-black text-[13px] font-[300]"},h.createElement(b.PanelSection,{title:n("Patient Information")},h.createElement("div",{className:"flex flex-col"},h.createElement("div",{className:"bg-primary-dark flex flex-col gap-4 p-2"},h.createElement(b.Input,{containerClassName:"!flex-row !justify-between items-center",label:n("Patient Sex"),labelClassName:"text-[13px] font-inter text-white",className:"!m-0 !h-[26px] !w-[117px]",value:s.PatientSex||"",onChange:e=>{p({PatientSex:e.target.value})}}),h.createElement(b.Input,{containerClassName:"!flex-row !justify-between items-center",label:n("Weight"),labelChildren:h.createElement("span",{className:"text-aqua-pale"}," kg"),labelClassName:"text-[13px] font-inter text-white",className:"!m-0 !h-[26px] !w-[117px]",value:s.PatientWeight||"",onChange:e=>{p({PatientWeight:e.target.value})},id:"weight-input"}),h.createElement(b.Input,{containerClassName:"!flex-row !justify-between items-center",label:n("Total Dose"),labelChildren:h.createElement("span",{className:"text-aqua-pale"}," bq"),labelClassName:"text-[13px] font-inter text-white",className:"!m-0 !h-[26px] !w-[117px]",value:s.RadiopharmaceuticalInformationSequence.RadionuclideTotalDose||"",onChange:e=>{p({RadiopharmaceuticalInformationSequence:{RadionuclideTotalDose:e.target.value}})}}),h.createElement(b.Input,{containerClassName:"!flex-row !justify-between items-center",label:n("Half Life"),labelChildren:h.createElement("span",{className:"text-aqua-pale"}," s"),labelClassName:"text-[13px] font-inter text-white",className:"!m-0 !h-[26px] !w-[117px]",value:s.RadiopharmaceuticalInformationSequence.RadionuclideHalfLife||"",onChange:e=>{p({RadiopharmaceuticalInformationSequence:{RadionuclideHalfLife:e.target.value}})}}),h.createElement(b.Input,{containerClassName:"!flex-row !justify-between items-center",label:n("Injection Time"),labelChildren:h.createElement("span",{className:"text-aqua-pale"}," s"),labelClassName:"text-[13px] font-inter text-white",className:"!m-0 !h-[26px] !w-[117px]",value:s.RadiopharmaceuticalInformationSequence.RadiopharmaceuticalStartTime||"",onChange:e=>{p({RadiopharmaceuticalInformationSequence:{RadiopharmaceuticalStartTime:e.target.value}})}}),h.createElement(b.Input,{containerClassName:"!flex-row !justify-between items-center",label:n("Acquisition Time"),labelChildren:h.createElement("span",{className:"text-aqua-pale"}," s"),labelClassName:"text-[13px] font-inter text-white",className:"!m-0 !h-[26px] !w-[117px]",value:s.SeriesTime||"",onChange:()=>{}}),h.createElement(b.Button,{className:"!h-[26px] !w-[115px] self-end !p-0",onClick:function(){if(!l)throw new Error("No ptDisplaySet found");I.DicomMetadataStore.updateMetadataForSeries(l.StudyInstanceUID,l.SeriesInstanceUID,s),a.setDisplaySetMetadataInvalidated(l.displaySetInstanceUID),setTimeout((()=>{t.runCommand("resetCrosshairs")}),0)}},"Reload Data")))))))}z.propTypes={servicesManager:S().shape({services:S().shape({measurementService:S().shape({getMeasurements:S().func.isRequired,subscribe:S().func.isRequired,EVENTS:S().object.isRequired,VALUE_TYPES:S().object.isRequired}).isRequired}).isRequired}).isRequired};var K=p(669),Y=p(557);const J=async({segmentationId:e,commandsManager:t,segmentationService:n})=>{const a=n.getSegmentation(e);(0,Y.triggerEvent)(Y.eventTarget,Y.Enums.Events.WEB_WORKER_PROGRESS,{progress:0,type:"Calculate Lesion Stats",id:e});const o={};for(const[n,r]of Object.entries(a.segments)){if(!r)continue;const i=Number(n),s=await t.run("getLesionStats",{segmentationId:e,segmentIndex:i}),c={lesionStats:s,suvPeak:await t.run("calculateSuvPeak",{segmentationId:e,segmentIndex:i}),lesionGlyoclysisStats:s.volume*s.meanValue},l={...r,cachedStats:{...r.cachedStats,...c}};o[i]=c,a.segments[n]=l}const r=n.getSegmentations(),i=await t.run("calculateTMTV",{segmentations:r});(0,Y.triggerEvent)(Y.eventTarget,Y.Enums.Events.WEB_WORKER_PROGRESS,{progress:100,type:"Calculate Lesion Stats",id:e}),r.forEach((e=>{e.cachedStats={...e.cachedStats,tmtv:i},Object.keys(e.segments).forEach((t=>{e.segments[t].cachedStats={...e.segments[t].cachedStats,tmtv:i}}));const t={...e,segments:{...e.segments}};n.addOrUpdateSegmentation(t)}))};var X=p(141);const Z=function({servicesManager:e,commandsManager:t}){const{segmentationService:n}=e.services,{segmentationsWithRepresentations:a}=(0,K.useActiveViewportSegmentationRepresentations)({servicesManager:e});(0,h.useEffect)((()=>{const e=a.map((e=>e.segmentation.segmentationId));(async()=>{for(const a of e)await J({segmentationId:a,commandsManager:t,segmentationService:n})})()}),[]),(0,h.useEffect)((()=>{const e=(0,X.debounce)((async e=>{const{segmentationId:a}=e;await J({segmentationId:a,commandsManager:t,segmentationService:n})}),100),a=n.subscribe(n.EVENTS.SEGMENTATION_DATA_MODIFIED,(t=>{e(t)}));return()=>{a.unsubscribe()}}),[t,n]);const o=a.find((e=>void 0!==e.segmentation.cachedStats?.tmtv)),r=o?.segmentation.cachedStats?.tmtv;return h.createElement("div",{className:"mt-2 mb-10 flex flex-col"},h.createElement("div",{className:"invisible-scrollbar overflow-y-auto overflow-x-hidden"},null!=r?h.createElement("div",{className:"bg-secondary-dark flex items-baseline justify-between px-2 py-1"},h.createElement("span",{className:"text-base font-bold uppercase tracking-widest text-white"},"TMTV:"),h.createElement("div",{className:"text-white"},`${r.toFixed(3)} mL`)):null))};var Q=p(55);function ee({servicesManager:e,commandsManager:t,extensionManager:n,configuration:a}){return h.createElement(h.Fragment,null,h.createElement(K.PanelSegmentation,{servicesManager:e,commandsManager:t,extensionManager:n,configuration:a},h.createElement(te,{servicesManager:e,commandsManager:t})))}const te=({servicesManager:e,commandsManager:t})=>{const{segmentationsWithRepresentations:n}=(0,K.useActiveViewportSegmentationRepresentations)({servicesManager:e}),a=n[0]?.segmentation.cachedStats?.tmtv,o=n.map((e=>e.segmentation));return o.length?h.createElement("div",{className:"flex h-8 w-full items-center rounded pr-0.5"},h.createElement(Q.Button,{size:"sm",variant:"ghost",className:"pl-1.5",onClick:()=>{t.runCommand("exportTMTVReportCSV",{segmentations:o,tmtv:a,config:{}})}},h.createElement(Q.Icons.Download,null),h.createElement("span",{className:"pl-1"},"CSV"))):null};const ne=function({commandsManager:e,extensionManager:t,servicesManager:n}){return[{name:"petSUV",iconName:"tab-patient-info",iconLabel:"Patient Info",label:"Patient Info",component:()=>h.createElement(z,{commandsManager:e,servicesManager:n,extensionManager:t})},{name:"tmtv",iconName:"tab-segmentation",iconLabel:"Segmentation",component:()=>h.createElement(h.Fragment,null,h.createElement(Q.Toolbox,{commandsManager:e,servicesManager:n,extensionManager:t,buttonSectionId:"ROIThresholdToolbox",title:"Threshold Tools"}),h.createElement(ee,{commandsManager:e,servicesManager:n}),h.createElement(Z,{commandsManager:e,servicesManager:n}))},{name:"tmtvBox",iconName:"tab-segmentation",iconLabel:"Segmentation",label:"Segmentation Toolbox",component:()=>h.createElement(Q.Toolbox,{commandsManager:e,servicesManager:n,extensionManager:t,buttonSectionId:"ROIThresholdToolbox",title:"Threshold Tools"})},{name:"tmtvExport",iconName:"tab-segmentation",iconLabel:"Segmentation",label:"Segmentation Export",component:()=>h.createElement(Z,{commandsManager:e,servicesManager:n})}]};var ae=p(713);const oe=["RectangleROIStartEndThreshold"],re={toAnnotation:(e,t)=>{},toMeasurement:(e,t,n)=>{const{annotation:a,viewportId:o}=e,{metadata:r,data:i,annotationUID:s}=a;if(!r||!i)return console.warn("Length tool: Missing metadata or data"),null;const{toolName:c,referencedImageId:l,FrameOfReferenceUID:u}=r;if(!oe.includes(c))throw new Error("Tool not supported");const{SOPInstanceUID:p,SeriesInstanceUID:m,StudyInstanceUID:d}=(0,K.getSOPInstanceAttributes)(l,n,o);let g;return g=p?t.getDisplaySetForSOPInstanceUID(p,m):t.getDisplaySetsForSeries(m),{uid:s,SOPInstanceUID:p,FrameOfReferenceUID:u,metadata:r,referenceSeriesUID:m,referenceStudyUID:d,toolName:r.toolName,displaySetInstanceUID:g.displaySetInstanceUID,label:r.label,data:i.cachedStats,type:"RectangleROIStartEndThreshold"}}},ie={toAnnotation:(e,t)=>{},toMeasurement:(e,t,n)=>{const{annotation:a,viewportId:o}=e,{metadata:r,data:i,annotationUID:s}=a;if(!r||!i)return console.warn("Length tool: Missing metadata or data"),null;const{toolName:c,referencedImageId:l,FrameOfReferenceUID:u}=r;if(!oe.includes(c))throw new Error("Tool not supported");const{SOPInstanceUID:p,SeriesInstanceUID:m,StudyInstanceUID:d}=(0,K.getSOPInstanceAttributes)(l,n,o);let g;g=p?t.getDisplaySetForSOPInstanceUID(p,m):t.getDisplaySetsForSeries(m);const{cachedStats:f}=i;return{uid:s,SOPInstanceUID:p,FrameOfReferenceUID:u,metadata:r,referenceSeriesUID:m,referenceStudyUID:d,toolName:r.toolName,displaySetInstanceUID:g.displaySetInstanceUID,label:r.label,data:i.cachedStats,type:"CircleROIStartEndThreshold"}}},se=(e,t,n)=>({RectangleROIStartEndThreshold:{toAnnotation:re.toAnnotation,toMeasurement:e=>re.toMeasurement(e,t,n),matchingCriteria:[{valueType:e.VALUE_TYPES.ROI_THRESHOLD_MANUAL}]},CircleROIStartEndThreshold:{toAnnotation:ie.toAnnotation,toMeasurement:e=>ie.toMeasurement(e,t,n),matchingCriteria:[{valueType:e.VALUE_TYPES.ROI_THRESHOLD_MANUAL}]}}),{CORNERSTONE_3D_TOOLS_SOURCE_NAME:ce,CORNERSTONE_3D_TOOLS_SOURCE_VERSION:le}=K.Enums;function ue(e,t){const{imageData:n}=e,a=n.getPointData().getScalars().getData(),{fn:o,baseValue:r}=function(e){const t=-1/0,n=(e,t)=>(e>t&&(t=e),t);return{fn:n,baseValue:t}}();let i=r;const s=ae.utilities.rectangleROITool.getBoundsIJKFromRectangleAnnotations(t,e),[[c,l],[u,p],[m,d]]=s;for(let e=c;e<=l;e++)for(let t=u;t<=p;t++)for(let r=m;r<=d;r++){i=o(a[n.computeOffsetIndex([e,t,r])],i)}return i}const pe=function(e,t,n){if("range"===n.strategy)return{ptLower:Number(n.ptLower),ptUpper:Number(n.ptUpper),ctLower:Number(n.ctLower),ctUpper:Number(n.ctUpper)};const{weight:a}=n,o=e.map((e=>ae.annotation.state.getAnnotation(e)));return{ctLower:-1/0,ctUpper:1/0,ptLower:a*ue(t[0],o),ptUpper:1/0}};var me=p(111),de=p.n(me),ge=p(142);const{datasetToBlob:fe}=de().data,ye=I.classes.MetadataProvider;const he=function(e){const t=ge.adaptersRT.Cornerstone3D.RTSS.generateRTSSFromAnnotations(e,ye,I.DicomMetadataStore),n=fe(t);var a=URL.createObjectURL(n);window.location.assign(a)},{SegmentationRepresentations:ve}=ae.Enums,{formatPN:Se}=I.utils,be=I.classes.MetadataProvider,Ie=["RectangleROIStartEndThreshold","RectangleROIThreshold","CircleROIStartEndThreshold"],xe=(0,Y.getWebWorkerManager)(),Te={maxWorkerInstances:1,autoTerminateOnIdle:{enabled:!0,idleTimeThreshold:3e3}},we=()=>new Worker(new URL(p.p+p.u(584),p.b),{name:"suv-peak-worker"});function Ee(e){const t=ae.segmentation.state.getSegmentation(e).representationData[ve.Labelmap],{volumeId:n,referencedVolumeId:a}=t;return{labelmapVolume:Y.cache.getVolume(n),referencedVolume:Y.cache.getVolume(a)}}function Re(e){const{representationData:t}=e,{volumeId:n}=t[ve.Labelmap];return Y.cache.getVolume(n)}const Oe=({servicesManager:e,commandsManager:t,extensionManager:n})=>{const{viewportGridService:a,uiNotificationService:o,displaySetService:r,hangingProtocolService:i,toolGroupService:s,cornerstoneViewportService:c,segmentationService:l}=e.services,u=n.getModuleEntry("@ohif/extension-cornerstone.utilityModule.common"),{getEnabledElement:p}=u.exports;function m(){const{activeViewportId:e}=a.getState(),{element:t}=p(e)||{};return Y.getEnabledElement(t)}function d(e){return e.reduce(((e,t)=>{const n=ae.annotation.selection.getAnnotationsSelectedByToolName(t);return e.concat(n)}),[])}const g={getMatchingPTDisplaySet:({viewportMatchDetails:e})=>{let t=null;for(const[n,a]of e){const{displaySetsInfo:e}=a,n=e.map((({displaySetInstanceUID:e})=>r.getDisplaySetByUID(e)));if(n&&0!==n.length&&(t=n.find((e=>"PT"===e.Modality)),t))break}return t},getPTMetadata:({ptDisplaySet:e})=>{const t=n.getDataSources()[0].getImageIdsForDisplaySet(e)[0],a=be.get("instance",t);if("PT"!==a.Modality)return;return{SeriesTime:a.SeriesTime,Modality:a.Modality,PatientSex:a.PatientSex,PatientWeight:a.PatientWeight,RadiopharmaceuticalInformationSequence:{RadionuclideTotalDose:a.RadiopharmaceuticalInformationSequence[0].RadionuclideTotalDose,RadionuclideHalfLife:a.RadiopharmaceuticalInformationSequence[0].RadionuclideHalfLife,RadiopharmaceuticalStartTime:a.RadiopharmaceuticalInformationSequence[0].RadiopharmaceuticalStartTime,RadiopharmaceuticalStartDateTime:a.RadiopharmaceuticalInformationSequence[0].RadiopharmaceuticalStartDateTime}}},createNewLabelmapFromPT:async({label:e})=>{const{viewportMatchDetails:t}=i.getMatchDetails(),n=g.getMatchingPTDisplaySet({viewportMatchDetails:t});let a=null;for(const[e,{displaySetsInfo:o}]of t.entries()){if(o.some((({displaySetInstanceUID:e})=>e===n.displaySetInstanceUID))){a=e;break}}if(!n)return void o.error("No matching PT display set found");const s=l.getSegmentationRepresentations(a),c=r.getDisplaySetByUID(n.displaySetInstanceUID),u=await l.createLabelmapForDisplaySet(c,{label:`Segmentation ${s.length+1}`,segments:{1:{label:"Segment 1",active:!0}}});return l.addSegmentationRepresentation(a,{segmentationId:u}),u},thresholdSegmentationByRectangleROITool:({segmentationId:e,config:t,segmentIndex:n})=>{const r=ae.segmentation.state.getSegmentation(e),{representationData:s}=r,{displaySetMatchDetails:c}=i.getMatchDetails(),l=`cornerstoneStreamingImageVolume:${c.get("ctDisplaySet").displaySetInstanceUID}`,{volumeId:u}=s[ve.Labelmap],{referencedVolumeId:p}=Y.cache.getVolume(u),m=d(Ie);if(0===m.length)return void o.show({title:"Commands Module",message:"No ROIThreshold Tool is Selected",type:"error"});const g=Y.cache.getVolume(e);let f=Y.cache.getVolume(p);const y=Y.cache.getVolume(l);if(!f)throw new Error("No Reference volume found");if(!g)throw new Error("No Reference labelmap found");const h=ae.annotation.state.getAnnotation(m[0]),{metadata:{enabledElement:{viewport:v}}}=h;if(!v.hasVolumeId(p)){a.getDisplaySetsUIDsForViewport(v.id).forEach((e=>{const t=Y.cache.getVolumes().find((t=>t.volumeId.includes(e)));Y.utilities.isEqual(t.dimensions,g.dimensions)&&Y.utilities.isEqual(t.spacing,g.spacing)&&(f=t)}))}const{ptLower:S,ptUpper:b,ctLower:I,ctUpper:x}=pe(m,[f,y],t);return ae.utilities.segmentation.rectangleROIThresholdVolumeByRange(m,g,[{volume:f,lower:S,upper:b},{volume:y,lower:I,upper:x}],{overwrite:!0,segmentIndex:n})},calculateSuvPeak:async({segmentationId:e,segmentIndex:t})=>{const n=l.getSegmentation(e),{representationData:a}=n,{volumeId:o,referencedVolumeId:r}=a[ve.Labelmap],i=Y.cache.getVolume(o),s=Y.cache.getVolume(r);xe.registerWorker("suv-peak-worker",we,Te);const c=d(Ie).map((e=>ae.annotation.state.getAnnotation(e))),u={dimensions:i.dimensions,origin:i.origin,direction:i.direction,spacing:i.spacing,metadata:i.metadata,scalarData:i.voxelManager.getCompleteScalarDataArray()},p={dimensions:s.dimensions,origin:s.origin,direction:s.direction,spacing:s.spacing,metadata:s.metadata,scalarData:s.voxelManager.getCompleteScalarDataArray()},m=c.map((e=>({...e,metadata:{...e.metadata,enabledElement:{...e.metadata.enabledElement,viewport:null,renderingEngine:null,element:null}}}))),g=await xe.executeTask("suv-peak-worker","calculateSuvPeak",{labelmapProps:u,referenceVolumeProps:p,annotations:m,segmentIndex:t})||{};return{suvPeak:g.mean,suvMax:g.max,suvMaxIJK:g.maxIJK,suvMaxLPS:g.maxLPS}},getLesionStats:({segmentationId:e,segmentIndex:t=1})=>{const{labelmapVolume:n,referencedVolume:a}=Ee(e),{voxelManager:o,imageData:r,spacing:i}=n,{voxelManager:s}=a;let c=-1/0,l=1/0;const u=[];let p=0;o.forEach((({value:e,index:n})=>{if(e===t){const e=s.getAtIndex(n);u.push(e),e>c&&(c=e),e<l&&(l=e),p++}}),{imageData:r});const m=u.reduce(((e,t)=>e+t),0)/p;return{minValue:l,maxValue:c,meanValue:m,stdValue:Math.sqrt(u.map((e=>(e-m)**2)).reduce(((e,t)=>e+t),0)/p),volume:p*i[0]*i[1]*i[2]*.001}},calculateLesionGlycolysis:({lesionStats:e})=>{const{meanValue:t,volume:n}=e;return{lesionGlyoclysisStats:n*t}},calculateTMTV:async({segmentations:e})=>{const t=e.map((e=>{const t=Re(e);return{dimensions:t.dimensions,spacing:t.spacing,scalarData:t.voxelManager.getCompleteScalarDataArray(),origin:t.origin,direction:t.direction}}));if(t.length)return await xe.executeTask("suv-peak-worker","calculateTMTV",t)},exportTMTVReportCSV:async({segmentations:e,tmtv:n,config:a,options:o})=>{const r=t.runCommand("getSegmentationCSVReport",{segmentations:e}),i=[{key:"Total Lesion Glycolysis",value:{tlg:(await g.getTotalLesionGlycolysis({segmentations:e})).toFixed(4)}},{key:"Threshold Configuration",value:{...a}}];void 0!==n&&i.unshift({key:"Total Metabolic Tumor Volume",value:{tmtv:n}}),function(e,t,n={}){const a=e[Object.keys(e)[0]],o=Object.keys(a),r=[o.join(",")];Object.values(e).forEach((e=>{const t=[];o.forEach((n=>{t.push(Array.isArray(e[n])?e[n].join(" "):e[n])})),r.push(t.join(","))})),r.push(""),r.push(""),r.push(""),r.push(`Patient ID,${a.PatientID}`),r.push(`Study Date,${a.StudyDate}`),r.push(""),t.forEach((({key:e,value:t})=>{const n=[];n.push(`${e}`),Object.keys(t).forEach((e=>{n.push(`${e}`),n.push(`${t[e]}`)})),r.push(n.join(","))}));const i=new Blob([r.join("\n")],{type:"text/csv;charset=utf-8"}),s=URL.createObjectURL(i),c=document.createElement("a");c.href=s,c.download=n.filename??`${a.PatientID}_tmtv.csv`,c.click()}(r,i,o)},getTotalLesionGlycolysis:async({segmentations:e})=>{const t=e.map((e=>{const t=Re(e);return{dimensions:t.dimensions,spacing:t.spacing,scalarData:t.voxelManager.getCompleteScalarDataArray(),origin:t.origin,direction:t.direction}})),{referencedVolume:n}=Ee(e[0].segmentationId),a={dimensions:n.dimensions,spacing:n.spacing,scalarData:n.voxelManager.getCompleteScalarDataArray(),origin:n.origin,direction:n.direction};return await xe.executeTask("suv-peak-worker","getTotalLesionGlycolysis",{labelmapProps:t,referenceVolumeProps:a})},setStartSliceForROIThresholdTool:()=>{const{viewport:e}=m(),{focalPoint:t}=e.getCamera(),n=d(Ie)[0],a=ae.annotation.state.getAnnotation(n);a.data.startCoordinate=t,a.invalidated=!0,e.render()},setEndSliceForROIThresholdTool:()=>{const{viewport:e}=m(),t=d(Ie)[0],n=ae.annotation.state.getAnnotation(t),a=e.getCamera().focalPoint;n.data.endCoordinate=a,n.invalidated=!0,e.render()},createTMTVRTReport:()=>{const e=ae.annotation.state.getAnnotationManager(),n=[];Object.keys(e.annotations).forEach((t=>{const a=e.annotations[t],o=Ie.reduce(((e,t)=>[...e,...a[t]??[]]),[]);n.push(...o)})),t.runCommand("exportRTReportForAnnotations",{annotations:n})},getSegmentationCSVReport:({segmentations:e})=>{e&&e.length||(e=l.getSegmentations());const t={};for(const n of e){const{label:e,segmentationId:a,representationData:o}=n,r=a,i={id:r,label:e};if(!o){t[r]=i;continue}const{cachedStats:s}=n.segments[1]||{};s&&Object.entries(s).forEach((([e,t])=>{"object"!=typeof t?i[e]=t:Object.entries(t).forEach((([t,n])=>{i[`${e}_${t}`]=n}))}));const c=n.representationData[ve.Labelmap];if(!c){t[r]=i;continue}const l=c.referencedVolumeId,u=Y.cache.getVolume(l);if(!u){t[r]=i;continue}if(!u.imageIds||!u.imageIds.length){t[r]=i;continue}const p=u.imageIds[0],m=x().classes.MetadataProvider.get("instance",p);m?t[r]={...i,PatientID:m.PatientID??"000000",PatientName:Se(m.PatientName),StudyInstanceUID:m.StudyInstanceUID,SeriesInstanceUID:m.SeriesInstanceUID,StudyDate:m.StudyDate}:t[r]=i}return t},exportRTReportForAnnotations:({annotations:e})=>{he(e)},setFusionPTColormap:({toolGroupId:e,colormap:n})=>{const a=s.getToolGroup(e);if(!a)return;const{viewportMatchDetails:o}=i.getMatchDetails(),r=g.getMatchingPTDisplaySet({viewportMatchDetails:o});if(!r)return;const l=a.getViewportIds(),u=[];l.forEach((e=>{t.runCommand("setViewportColormap",{viewportId:e,displaySetInstanceUID:r.displaySetInstanceUID,colormap:{name:n}}),u.push(c.getCornerstoneViewport(e))})),u.forEach((e=>{e.render()}))}},f={setEndSliceForROIThresholdTool:{commandFn:g.setEndSliceForROIThresholdTool},setStartSliceForROIThresholdTool:{commandFn:g.setStartSliceForROIThresholdTool},getMatchingPTDisplaySet:{commandFn:g.getMatchingPTDisplaySet},getPTMetadata:{commandFn:g.getPTMetadata},createNewLabelmapFromPT:{commandFn:g.createNewLabelmapFromPT},thresholdSegmentationByRectangleROITool:{commandFn:g.thresholdSegmentationByRectangleROITool},getTotalLesionGlycolysis:{commandFn:g.getTotalLesionGlycolysis},calculateSuvPeak:{commandFn:g.calculateSuvPeak},getLesionStats:{commandFn:g.getLesionStats},calculateTMTV:{commandFn:g.calculateTMTV},exportTMTVReportCSV:{commandFn:g.exportTMTVReportCSV},createTMTVRTReport:{commandFn:g.createTMTVRTReport},getSegmentationCSVReport:{commandFn:g.getSegmentationCSVReport},exportRTReportForAnnotations:{commandFn:g.exportRTReportForAnnotations},setFusionPTColormap:{commandFn:g.setFusionPTColormap}};return{actions:g,definitions:f,defaultContext:"TMTV:CORNERSTONE"}},Ce="roi_stat",Me=[{value:Ce,label:"Max",placeHolder:"Max"},{value:"range",label:"Range",placeHolder:"Range"}];const De=function({config:e,dispatch:t,runCommand:n}){const{t:a}=B("ROIThresholdConfiguration");return h.createElement("div",{className:"bg-primary-dark flex flex-col space-y-4"},h.createElement("div",{className:"flex items-end space-x-2"},h.createElement("div",{className:"flex w-1/2 flex-col"},h.createElement(b.Select,{label:a("Strategy"),closeMenuOnSelect:!0,className:"border-primary-main mr-2 bg-black text-white ",options:Me,placeholder:Me.find((t=>t.value===e.strategy)).placeHolder,value:e.strategy,onChange:({value:e})=>{t({type:"setStrategy",payload:{strategy:e}})}})),h.createElement("div",{className:"w-1/2"},h.createElement(b.LegacyButtonGroup,null,h.createElement(b.LegacyButton,{size:"initial",className:"px-2 py-2 text-base text-white",color:"primaryLight",variant:"outlined",onClick:()=>n("setStartSliceForROIThresholdTool")},a("Start")),h.createElement(b.LegacyButton,{size:"initial",color:"primaryLight",variant:"outlined",className:"px-2 py-2 text-base text-white",onClick:()=>n("setEndSliceForROIThresholdTool")},a("End"))))),e.strategy===Ce&&h.createElement(b.Input,{label:a("Percentage of Max SUV"),labelClassName:"text-[13px] font-inter text-white",className:"border-primary-main bg-black",type:"text",containerClassName:"mr-2",value:e.weight,onChange:e=>{t({type:"setWeight",payload:{weight:e.target.value}})}}),e.strategy!==Ce&&h.createElement("div",{className:"mr-2 text-sm"},h.createElement("table",null,h.createElement("tbody",null,h.createElement("tr",{className:"mt-2"},h.createElement("td",{className:"pr-4",colSpan:"3"},h.createElement(b.Label,{className:"font-inter text-[13px] text-white",text:"Lower & Upper Ranges"}))),h.createElement("tr",{className:"mt-2"},h.createElement("td",{className:"pr-4 pt-2 text-center"},h.createElement(b.Label,{className:"text-white",text:"CT"})),h.createElement("td",null,h.createElement("div",{className:"flex justify-between"},h.createElement(b.Input,{label:a(""),labelClassName:"text-white",className:"border-primary-main mt-2 bg-black",type:"text",containerClassName:"mr-2",value:e.ctLower,onChange:e=>{t({type:"setThreshold",payload:{ctLower:e.target.value}})}}),h.createElement(b.Input,{label:a(""),labelClassName:"text-white",className:"border-primary-main mt-2 bg-black",type:"text",containerClassName:"mr-2",value:e.ctUpper,onChange:e=>{t({type:"setThreshold",payload:{ctUpper:e.target.value}})}})))),h.createElement("tr",null,h.createElement("td",{className:"pr-4 pt-2 text-center"},h.createElement(b.Label,{className:"text-white",text:"PT"})),h.createElement("td",null,h.createElement("div",{className:"flex justify-between"},h.createElement(b.Input,{label:a(""),labelClassName:"text-white",className:"border-primary-main mt-2 bg-black",type:"text",containerClassName:"mr-2",value:e.ptLower,onChange:e=>{t({type:"setThreshold",payload:{ptLower:e.target.value}})}}),h.createElement(b.Input,{label:a(""),labelClassName:"text-white",className:"border-primary-main mt-2 bg-black",type:"text",containerClassName:"mr-2",value:e.ptUpper,onChange:e=>{t({type:"setThreshold",payload:{ptUpper:e.target.value}})}}))))))))},Ne=Ce;function Pe(e,t){const{payload:n}=t,{strategy:a,ctLower:o,ctUpper:r,ptLower:i,ptUpper:s,weight:c}=n;switch(t.type){case"setStrategy":return{...e,strategy:a};case"setThreshold":return{...e,ctLower:o||e.ctLower,ctUpper:r||e.ctUpper,ptLower:i||e.ptLower,ptUpper:s||e.ptUpper};case"setWeight":return{...e,weight:c};default:return e}}const Le=function({servicesManager:e,commandsManager:t}){const{segmentationService:n}=e.services,[a,o]=(0,h.useState)(null),r=(0,h.useCallback)(((e,n={})=>t.runCommand(e,n)),[t]),[i,s]=(0,h.useReducer)(Pe,{strategy:Ne,ctLower:-1024,ctUpper:1024,ptLower:2.5,ptUpper:100,weight:.41}),c=(0,h.useCallback)((()=>{const e=a,t=ae.segmentation.segmentIndex.getActiveSegmentIndex(e);r("thresholdSegmentationByRectangleROITool",{segmentationId:e,config:i,segmentIndex:t})}),[a,i]);return(0,h.useEffect)((()=>{const e=n.getSegmentationRepresentations();if(!e.length)return;const t=e.find((e=>e.isActive));o(t.id)}),[]),(0,h.useEffect)((()=>{const e=n.EVENTS.SEGMENTATION_MODIFIED,t=[];return[e].forEach((e=>{const{unsubscribe:a}=n.subscribe(e,(()=>{const e=n.getSegmentationRepresentations();if(!e.length)return;const t=e.find((e=>e.isActive));o(t.id)}));t.push(a)})),()=>{t.forEach((e=>{e()}))}}),[]),h.createElement("div",{className:"invisible-scrollbar mb-2 flex flex-col overflow-y-auto overflow-x-hidden"},h.createElement(De,{config:i,dispatch:s,runCommand:r}),null!==a&&h.createElement(b.Button,{className:"mt-2 !h-[26px] !w-[75px]",onClick:c},"Run"))};const ke={id:e,preRegistration({servicesManager:e,commandsManager:t,extensionManager:n,configuration:a={}}){!function({servicesManager:e}){const{measurementService:t,displaySetService:n,cornerstoneViewportService:a}=e.services;(0,ae.addTool)(ae.RectangleROIStartEndThresholdTool),(0,ae.addTool)(ae.CircleROIStartEndThresholdTool);const{RectangleROIStartEndThreshold:o,CircleROIStartEndThreshold:r}=se(t,n,a),i=t.getSource(ce,le);t.addMapping(i,"RectangleROIStartEndThreshold",o.matchingCriteria,o.toAnnotation,o.toMeasurement),t.addMapping(i,"CircleROIStartEndThreshold",r.matchingCriteria,r.toAnnotation,r.toMeasurement)}({servicesManager:e,commandsManager:t,extensionManager:n,configuration:a})},getToolbarModule:function({commandsManager:e,servicesManager:t}){return[{name:"tmtv.RectangleROIThresholdOptions",defaultComponent:()=>Le({commandsManager:e,servicesManager:t})}]},getPanelModule:ne,getHangingProtocolModule:y,getCommandsModule:({servicesManager:e,commandsManager:t,extensionManager:n})=>Oe({servicesManager:e,commandsManager:t,extensionManager:n})},je=ke})(),m})()));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ohif/extension-tmtv",
3
- "version": "3.9.2",
3
+ "version": "3.9.3",
4
4
  "description": "OHIF extension for Total Metabolic Tumor Volume",
5
5
  "author": "OHIF",
6
6
  "license": "MIT",
@@ -30,8 +30,8 @@
30
30
  "test:unit:ci": "jest --ci --runInBand --collectCoverage --passWithNoTests"
31
31
  },
32
32
  "peerDependencies": {
33
- "@ohif/core": "3.9.2",
34
- "@ohif/ui": "3.9.2",
33
+ "@ohif/core": "3.9.3",
34
+ "@ohif/ui": "3.9.3",
35
35
  "dcmjs": "*",
36
36
  "dicom-parser": "^1.8.9",
37
37
  "hammerjs": "^2.0.8",