@ohif/extension-cornerstone-dynamic-volume 3.13.0-beta.89 → 3.13.0-beta.92

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 @@
1
- /*! For license information please see ohif-extension-cornerstone-dynamic-volume.umd.js.LICENSE.txt */
2
- !function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("@cornerstonejs/core"),require("@cornerstonejs/tools"),require("@ohif/core"),require("@ohif/extension-cornerstone"),require("@ohif/extension-default"),require("@ohif/ui-next")):"function"==typeof define&&define.amd?define(["@cornerstonejs/core","@cornerstonejs/tools","@ohif/core","@ohif/extension-cornerstone","@ohif/extension-default","@ohif/ui-next"],t):"object"==typeof exports?exports["ohif-extension-cornerstone"]=t(require("@cornerstonejs/core"),require("@cornerstonejs/tools"),require("@ohif/core"),require("@ohif/extension-cornerstone"),require("@ohif/extension-default"),require("@ohif/ui-next")):e["ohif-extension-cornerstone"]=t(e["@cornerstonejs/core"],e["@cornerstonejs/tools"],e["@ohif/core"],e["@ohif/extension-cornerstone"],e["@ohif/extension-default"],e["@ohif/ui-next"])}(globalThis,(e,t,n,o,r,a)=>(()=>{"use strict";var i={249(e,t){var n=Symbol.for("react.element"),o=Symbol.for("react.portal"),r=Symbol.for("react.fragment"),a=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 y={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},f=Object.assign,g={};function S(e,t,n){this.props=e,this.context=t,this.refs=g,this.updater=n||y}function v(){}function h(e,t,n){this.props=e,this.context=t,this.refs=g,this.updater=n||y}S.prototype.isReactComponent={},S.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")},S.prototype.forceUpdate=function(e){this.updater.enqueueForceUpdate(this,e,"forceUpdate")},v.prototype=S.prototype;var D=h.prototype=new v;D.constructor=h,f(D,S.prototype),D.isPureReactComponent=!0;var I=Array.isArray,b=Object.prototype.hasOwnProperty,w={current:null},E={key:!0,ref:!0,__self:!0,__source:!0};function C(e,t,o){var r,a={},i=null,s=null;if(null!=t)for(r in void 0!==t.ref&&(s=t.ref),void 0!==t.key&&(i=""+t.key),t)b.call(t,r)&&!E.hasOwnProperty(r)&&(a[r]=t[r]);var c=arguments.length-2;if(1===c)a.children=o;else if(1<c){for(var l=Array(c),u=0;u<c;u++)l[u]=arguments[u+2];a.children=l}if(e&&e.defaultProps)for(r in c=e.defaultProps)void 0===a[r]&&(a[r]=c[r]);return{$$typeof:n,type:e,key:i,ref:s,props:a,_owner:w.current}}function x(e){return"object"==typeof e&&null!==e&&e.$$typeof===n}var T=/\/+/g;function M(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 O(e,t,r,a,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 o:c=!0}}if(c)return i=i(c=e),e=""===a?"."+M(c,0):a,I(i)?(r="",null!=e&&(r=e.replace(T,"$&/")+"/"),O(i,t,r,"",function(e){return e})):null!=i&&(x(i)&&(i=function(e,t){return{$$typeof:n,type:e.type,key:t,ref:e.ref,props:e.props,_owner:e._owner}}(i,r+(!i.key||c&&c.key===i.key?"":(""+i.key).replace(T,"$&/")+"/")+e)),t.push(i)),1;if(c=0,a=""===a?".":a+":",I(e))for(var l=0;l<e.length;l++){var u=a+M(s=e[l],l);c+=O(s,t,r,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+=O(s=s.value,t,r,u=a+M(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 N(e,t,n){if(null==e)return e;var o=[],r=0;return O(e,o,"","",function(e){return t.call(n,e,r++)}),o}function P(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 R={current:null},U={transition:null},_={ReactCurrentDispatcher:R,ReactCurrentBatchConfig:U,ReactCurrentOwner:w};function V(){throw Error("act(...) is not supported in production builds of React.")}t.Children={map:N,forEach:function(e,t,n){N(e,function(){t.apply(this,arguments)},n)},count:function(e){var t=0;return N(e,function(){t++}),t},toArray:function(e){return N(e,function(e){return e})||[]},only:function(e){if(!x(e))throw Error("React.Children.only expected to receive a single React element child.");return e}},t.Component=S,t.Fragment=r,t.Profiler=i,t.PureComponent=h,t.StrictMode=a,t.Suspense=u,t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=_,t.act=V,t.cloneElement=function(e,t,o){if(null==e)throw Error("React.cloneElement(...): The argument must be a React element, but you passed "+e+".");var r=f({},e.props),a=e.key,i=e.ref,s=e._owner;if(null!=t){if(void 0!==t.ref&&(i=t.ref,s=w.current),void 0!==t.key&&(a=""+t.key),e.type&&e.type.defaultProps)var c=e.type.defaultProps;for(l in t)b.call(t,l)&&!E.hasOwnProperty(l)&&(r[l]=void 0===t[l]&&void 0!==c?c[l]:t[l])}var l=arguments.length-2;if(1===l)r.children=o;else if(1<l){c=Array(l);for(var u=0;u<l;u++)c[u]=arguments[u+2];r.children=c}return{$$typeof:n,type:e.type,key:a,ref:i,props:r,_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=C,t.createFactory=function(e){var t=C.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=x,t.lazy=function(e){return{$$typeof:m,_payload:{_status:-1,_result:e},_init:P}},t.memo=function(e,t){return{$$typeof:p,type:e,compare:void 0===t?null:t}},t.startTransition=function(e){var t=U.transition;U.transition={};try{e()}finally{U.transition=t}},t.unstable_act=V,t.useCallback=function(e,t){return R.current.useCallback(e,t)},t.useContext=function(e){return R.current.useContext(e)},t.useDebugValue=function(){},t.useDeferredValue=function(e){return R.current.useDeferredValue(e)},t.useEffect=function(e,t){return R.current.useEffect(e,t)},t.useId=function(){return R.current.useId()},t.useImperativeHandle=function(e,t,n){return R.current.useImperativeHandle(e,t,n)},t.useInsertionEffect=function(e,t){return R.current.useInsertionEffect(e,t)},t.useLayoutEffect=function(e,t){return R.current.useLayoutEffect(e,t)},t.useMemo=function(e,t){return R.current.useMemo(e,t)},t.useReducer=function(e,t,n){return R.current.useReducer(e,t,n)},t.useRef=function(e){return R.current.useRef(e)},t.useState=function(e){return R.current.useState(e)},t.useSyncExternalStore=function(e,t,n){return R.current.useSyncExternalStore(e,t,n)},t.useTransition=function(){return R.current.useTransition()},t.version="18.3.1"},326(e,t,n){e.exports=n(249)},557(t){t.exports=e},713(e){e.exports=t},2(e){e.exports=n},669(e){e.exports=o},438(e){e.exports=r},55(e){e.exports=a}},s={};function c(e){var t=s[e];if(void 0!==t)return t.exports;var n=s[e]={exports:{}};return i[e](n,n.exports,c),n.exports}c.d=(e,t)=>{for(var n in t)c.o(t,n)&&!c.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},c.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),c.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var l={};c.r(l),c.d(l,{default:()=>B});var u={};c.r(u),c.d(u,{updateSegmentationsChartDisplaySet:()=>b});const p=JSON.parse('{"UU":"@ohif/extension-cornerstone-dynamic-volume"}').UU;var m=c(713),d=c(557),y=c(2);const f="CHT",g=y.utils.guid(),S="1.9.451.13215.7.3.2.7.6.1",{utilities:v}=m;function h(e,t){const n=e.imageIds.reduce((e,n)=>{const o=y.DicomMetadataStore.getInstanceByImageId(n)[t];return void 0!==o&&e.add(o),e},new Set);return Array.from(n).sort((e,t)=>e-t)}function D(e,t,{servicesManager:n}){const{displaySetService:o,segmentationService:r,viewportGridService:a}=n.services;let i;const s=o.getActiveDisplaySets().find(e=>{const t=e.instances?.[0];return!!t&&(void 0!==t.FrameReferenceTime||void 0!==t.NumberOfTimeSlices)}).displaySetInstanceUID;for(const[e]of d.cache._volumeCache)if(e.includes(s)){i=e;break}let c;i&&(c=d.cache.getVolume(i));const{StudyInstanceUID:l,StudyDescription:u}=y.DicomMetadataStore.getInstanceByImageId(c.imageIds[0]),p=r.getLabelmapVolume(e.segmentationId),m=p?.volumeId,[f,g]=v.dynamicVolume.getDataInTime(c,{maskVolumeId:m}),S=f.length;if(0===S)return[];const D=a.getActiveViewportId(),I=r.getSegmentColor(D,e.segmentationId,1),b=d.utilities.color.rgbToHex(I[0],I[1],I[2]);let w=t.get(c);w||(w=function(e){const t={FrameReferenceTime:{unit:"ms"}},n=Object.keys(t);let o,r;for(let a=0;a<n.length;a++){const i=n[a],s=h(e,i);if(s.length){o=s,r=t[i].unit;break}}if(!o.length){const e=n.join(", ");throw new Error(`Could not extract time points data for the following tags: ${e}`)}const a=function(e,t){const n=["ms","s","m","h"],o=[1e3,60,60],r=n.indexOf(t);let a=1;if(-1!==r){for(let i=r;i<n.length-1;i++){const r=a*o[i];if(e.filter(e=>e>r).length<=e.length/2)break;a=r,t=n[i+1]}a>1&&(e=e.map(e=>e/a))}return{timePoints:e,timePointsUnit:t}}(o,r);return o=a.timePoints,r=a.timePointsUnit,{timePoints:o,timePointsUnit:r}}(c),t.set(c,w));const{timePoints:E,timePointsUnit:C}=w;if(E.length!==f[0].length)throw new Error("Invalid number of time points returned");const x=E.length,T=new Array(x);for(let e=0;e<x;e++){const t=f.reduce((t,n)=>t+n[e]/S,0);T[e]=[E[e],t]}return{StudyInstanceUID:l,StudyDescription:u,chartData:{series:{label:e.label,points:T,color:b},axis:{x:{label:`Time (${C})`},y:{label:"Vl (Bq/ml)"}}}}}function I(e,{servicesManager:t}){if(!e.length)return;const n=new WeakMap,o=e.map(e=>D(e,n,{servicesManager:t})),{date:r,time:a}=function(){const e=new Date;return{date:e.getFullYear()+("0"+e.getUTCMonth()).slice(-2)+("0"+e.getUTCDate()).slice(-2),time:("0"+e.getUTCHours()).slice(-2)+("0"+e.getUTCMinutes()).slice(-2)+("0"+e.getUTCSeconds()).slice(-2)}}(),i=o.reduce((e,t)=>[...e,t.chartData.series],[]),s={SOPClassUID:S,Modality:f,SOPInstanceUID:y.utils.guid(),SeriesDate:r,SeriesTime:a,SeriesInstanceUID:g,StudyInstanceUID:o[0].StudyInstanceUID,StudyDescription:o[0].StudyDescription,SeriesNumber:100,SeriesDescription:"Segmentation chart series data",chartData:{series:i,axis:{...o[0].chartData.axis}}};return{seriesMetadata:{StudyInstanceUID:s.StudyInstanceUID,StudyDescription:s.StudyDescription,SeriesInstanceUID:s.SeriesInstanceUID,SeriesDescription:s.SeriesDescription,SeriesNumber:s.SeriesNumber,SeriesTime:s.SeriesTime,SOPClassUID:s.SOPClassUID,Modality:s.Modality},instance:s}}function b({servicesManager:e}){const{segmentationService:t}=e.services,n=t.getSegmentations(),{seriesMetadata:o,instance:r}=I(n,{servicesManager:e})??{};o&&r&&(y.DicomMetadataStore.addSeriesMetadata([o],!0),y.DicomMetadataStore.addInstances([r],!0))}const{downloadCsv:w}=y.utils,E=({commandsManager:e,servicesManager:t})=>{const n=t.services,{displaySetService:o,viewportGridService:r,segmentationService:a}=n,i={...u,getDynamic4DDisplaySet:()=>o.getActiveDisplaySets().find(e=>{const t=e.instances?.[0];return!!t&&(void 0!==t.FrameReferenceTime||void 0!==t.NumberOfTimeSlices||void 0!==t.TemporalPositionIdentifier)}),getComputedDisplaySets:()=>[...o.getDisplaySetCache().values()].filter(e=>e.isDerived),exportTimeReportCSV:({segmentations:e,summaryStats:t})=>{const n=i.getDynamic4DDisplaySet(),o=n?.displaySetInstanceUID;let r,s;for(const[e]of d.cache._volumeCache)if(e.includes(o)){r=e;break}r&&(s=d.cache.getVolume(r));const c=n.instances[0],l=[];function u(e){const t=e.length,n=e.reduce((e,t)=>e+t,0)/t,o=e.map(e=>(e-n)**2).reduce((e,t)=>e+t,0)/t;return Math.sqrt(o)}l.push(`Patient ID,${c.PatientID},`),l.push(`Study Date,${c.StudyDate},`),l.push(`StudyInstanceUID,${c.StudyInstanceUID},`),l.push(`StudyDescription,${c.StudyDescription},`),l.push(`SeriesInstanceUID,${c.SeriesInstanceUID},`),l.push(""),l.push(""),e.forEach(e=>{const n=a.getLabelmapVolume(e.segmentationId),[o,r]=m.utilities.dynamicVolume.getDataInTime(s,{maskVolumeId:n.volumeId});if(t){let t="Operation,Segmentation Label ID";const n=s.numTimePoints;for(let e=0;e<n;e++)t+=`,Time Point ${e}`;l.push(t);const a=[],i=[],c=[],p=[],m=[],d=[],y=o.length;for(let e=0;e<n;e++){const t=[];let n=0,s=1/0,l=-1/0,f=0,g=0;for(let r=0;r<y;r++){const a=o[r][e];t.push(a),n+=a,a<s&&(s=a,f=r),a>l&&(l=a,g=r)}a.push(n/y),i.push(s),c.push(r[f]),p.push(l),m.push(r[g]),d.push(u(t))}let f=`Mean,${e.label}`;for(let e=0;e<n;e++)f+=`,${a[e]}`;l.push(f),f=`Standard Deviation,${e.label}`;for(let e=0;e<n;e++)f+=`,${d[e]}`;l.push(f),f=`Min,${e.label}`;for(let e=0;e<n;e++)f+=`,${i[e]}`;l.push(f),f=`Max,${e.label}`;for(let e=0;e<n;e++)f+=`,${p[e]}`;l.push(f)}else{let t="Pixel Identifier (IJK),Segmentation Label ID";const n=s.numTimePoints;for(let e=0;e<n;e++)t+=`,Time Point ${e}`;l.push(t);for(let t=0;t<o.length;t++){let n=`${`${r[t][0]}_${r[t][1]}_${r[t][2]}`},${e.label}`;for(let e=0;e<o[t].length;e++)n+=`,${o[t][e]}`;l.push(n)}}});const p=l.join("\n"),y=`${c.PatientID}.csv`;w(p,{filename:y})},swapDynamicWithComputedDisplaySet:({displaySet:t})=>{const n=t,a=o.getDisplaySetCache(),s=[a.keys()],{displaySetInstanceUID:c}=n;s.includes(c)||a.set(c,n);const{viewports:l}=r.getState(),u=i.getDynamic4DDisplaySet(),p=[];for(const[e,t]of l){const e=t,n=e.viewportOptions,{displaySetInstanceUIDs:o}=e,r=o.indexOf(u.displaySetInstanceUID);if(-1!==r){const t={viewportId:e.viewportId,displaySetInstanceUIDs:[...o.slice(0,r),c,...o.slice(r+1)],viewportOptions:{initialImageOptions:n.initialImageOptions,viewportType:"volume",orientation:n.orientation,background:n.background}};p.push(t)}}e.run("setDisplaySetsForViewports",{viewportsToUpdate:p})},swapComputedWithDynamicDisplaySet:()=>{const t=i.getDynamic4DDisplaySet(),n=o.getDisplaySetCache(),a=[...n.keys()],{displaySetInstanceUID:s}=t;a.includes(s)||n.set(s,t);const{viewports:c}=r.getState(),l=i.getComputedDisplaySets()[0],u=[];for(const[e,t]of c){const e=t,n=e.viewportOptions,{displaySetInstanceUIDs:o}=e,r=o.indexOf(l.displaySetInstanceUID);if(-1!==r){const t={viewportId:e.viewportId,displaySetInstanceUIDs:[...o.slice(0,r),s,...o.slice(r+1)],viewportOptions:{initialImageOptions:n.initialImageOptions,viewportType:"volume",orientation:n.orientation,background:n.background}};u.push(t)}}e.run("setDisplaySetsForViewports",{viewportsToUpdate:u})},createNewLabelMapForDynamicVolume:async({label:e})=>{const{viewports:t,activeViewportId:n}=r.getState(),s=i.getDynamic4DDisplaySet(),c=s.displaySetInstanceUID;let l;if(t.get(n).displaySetInstanceUIDs.includes(c)&&(l=s),!l){const e=o.getDisplaySetCache();for(const[t,n]of e)if(n.referenceDisplaySetUID===c){l=n;break}}if(!l)throw new Error("No reference display set found based on the dynamic data");const u=o.getDisplaySetByUID(l.displaySetInstanceUID),p=await a.createLabelmapForDisplaySet(u,{label:e}),m=t.values().next().value;return await a.addSegmentationRepresentation(m.viewportId,{segmentationId:p}),p}},s={updateSegmentationsChartDisplaySet:{commandFn:i.updateSegmentationsChartDisplaySet,storeContexts:[],options:{}},exportTimeReportCSV:{commandFn:i.exportTimeReportCSV,storeContexts:[],options:{}},swapDynamicWithComputedDisplaySet:{commandFn:i.swapDynamicWithComputedDisplaySet,storeContexts:[],options:{}},createNewLabelMapForDynamicVolume:{commandFn:i.createNewLabelMapForDynamicVolume,storeContexts:[],options:{}},swapComputedWithDynamicDisplaySet:{commandFn:i.swapComputedWithDynamicDisplaySet,storeContexts:[],options:{}}};return{actions:i,definitions:s,defaultContext:"DYNAMIC-VOLUME:CORNERSTONE"}};var C=c(326),x=c(55);const T=e=>null==e?"":String(e).toUpperCase(),M=({title:e,tooltip:t})=>C.createElement("div",{className:"flex items-center space-x-1"},C.createElement(x.Tooltip,null,C.createElement(x.TooltipTrigger,{asChild:!0},C.createElement("span",null,C.createElement(x.Icons.ByName,{name:"info-link",className:"text-primary h-3 w-3"}))),C.createElement(x.TooltipContent,{sideOffset:4,className:"max-w-xs"},C.createElement("div",null,t))),C.createElement("span",{className:"text-muted-foreground text-xs uppercase tracking-wide"},e)),O=({isPlaying:e,onPlayPauseChange:t,fps:n,onFpsChange:o,minFps:r,maxFps:a,currentDimensionGroupNumber:i,onDimensionGroupChange:s,numDimensionGroups:c,onGenerate:l,onDoubleRangeChange:u,rangeValues:p,onDynamicClick:m})=>{const[y,f]=(0,C.useState)(!1),[g,S]=(0,C.useState)(d.Enums.DynamicOperatorType.SUM);return C.createElement("div",{className:"flex select-none flex-col"},C.createElement(x.PanelSection,{defaultOpen:!0},C.createElement(x.PanelSection.Header,null,"Controls"),C.createElement(x.PanelSection.Content,{className:"bg-muted space-y-4 px-5 pt-2 pb-4"},C.createElement("div",{className:"mb-4"},C.createElement(M,{title:"View",tooltip:"Select the view mode, 4D to view the dynamic volume or Computed to view the computed volume"}),C.createElement(x.Tabs,{value:y?"computed":"4d",onValueChange:e=>{const t="computed"===e;f(t),t||"function"!=typeof m||m()},className:"my-2 w-full"},C.createElement(x.TabsList,{className:"w-full"},C.createElement(x.TabsTrigger,{value:"4d",className:"w-1/2"},"4D"),C.createElement(x.TabsTrigger,{value:"computed",className:"w-1/2"},"Computed")))),C.createElement("div",null,C.createElement(N,{onPlayPauseChange:t,isPlaying:e,computedView:y,fps:n,onFpsChange:o,minFps:r,maxFps:a,numDimensionGroups:c,onDimensionGroupChange:s,currentDimensionGroupNumber:i})),C.createElement("div",{className:"mt-3 flex flex-col "+(y?"":"ohif-disabled")},C.createElement(M,{title:"Computed Operation",tooltip:C.createElement("div",null,"Operation Buttons (SUM, AVERAGE, SUBTRACT): Select the mathematical operation to be applied to the data set.",C.createElement("br",null)," Range Slider: Choose the numeric range of dimension groups within which the operation will be performed.",C.createElement("br",null),"Generate Button: Execute the chosen operation on the specified range of data.")}),C.createElement(x.Tabs,{value:String(g),onValueChange:e=>{S(e)},className:"mt-2 w-full"},C.createElement(x.TabsList,{className:"w-full gap-1"}," ",C.createElement(x.TabsTrigger,{value:String(d.Enums.DynamicOperatorType.SUM),className:"w-1/3"},T(d.Enums.DynamicOperatorType.SUM)),C.createElement(x.TabsTrigger,{value:String(d.Enums.DynamicOperatorType.AVERAGE),className:"w-1/3"},T(d.Enums.DynamicOperatorType.AVERAGE)),C.createElement(x.TabsTrigger,{value:String(d.Enums.DynamicOperatorType.SUBTRACT),className:"w-1/3"},T(d.Enums.DynamicOperatorType.SUBTRACT)))),C.createElement("div",{className:"mt-2 w-full"},C.createElement(x.Numeric.Container,{mode:"doubleRange",min:1,max:c||1,values:p||[1,c||1],onChange:u||(()=>{})},C.createElement(x.Numeric.DoubleRange,{showNumberInputs:!0}))),C.createElement(x.Button,{variant:"default",size:"sm",className:"mt-2 h-[26px] w-[115px] self-start p-0",onClick:()=>{try{"function"==typeof l?l(g):console.error("onGenerate is not a function",l)}catch(e){console.error("Error in onGenerate:",e)}}},"Generate")))))};function N({isPlaying:e,onPlayPauseChange:t,fps:n,minFps:o,maxFps:r,onFpsChange:a,numDimensionGroups:i,onDimensionGroupChange:s,currentDimensionGroupNumber:c,computedView:l}){return C.createElement("div",{className:l?"ohif-disabled":""},C.createElement(M,{title:"4D Controls",tooltip:C.createElement("div",null,"Play/Pause Button: Begin or pause the animation of the 4D visualization. ",C.createElement("br",null),"Dimension Group Selector: Navigate through individual dimension groups of the 4D data."," ",C.createElement("br",null),"FPS (Frames Per Second) Selector: Adjust the playback speed of the animation.")}),C.createElement("div",{className:"mt-3 flex justify-between"},C.createElement(x.Button,{id:"play-pause-button",variant:"secondary",size:"default",className:"w-[58px]",onClick:()=>{"function"==typeof t&&t(!e)}},C.createElement(x.Icons.ByName,{name:e?"icon-pause":"icon-play",className:"text-foreground h-[24px] w-[24px]"})),C.createElement(x.Numeric.Container,{mode:"stepper",value:c||1,onChange:s||(()=>{}),min:1,max:i||1,step:1},C.createElement("div",{className:"flex flex-col items-center"},C.createElement(x.Numeric.NumberStepper,{className:"h-[28px] w-[58px]",direction:"horizontal"}),C.createElement(x.Numeric.Label,{className:"text-muted-foreground mt-1 text-sm"},"Frame"))),C.createElement(x.Numeric.Container,{mode:"stepper",value:n||1,onChange:a||(()=>{}),min:o||1,max:r||30,step:1},C.createElement("div",{className:"flex flex-col items-center"},C.createElement(x.Numeric.NumberStepper,{className:"h-[28px] w-[58px]",direction:"horizontal"}),C.createElement(x.Numeric.Label,{className:"text-muted-foreground mt-1 text-sm"},"FPS")))))}function P({servicesManager:e,commandsManager:t}){const{cornerstoneViewportService:n,viewportGridService:o,displaySetService:r}=e.services,[{isCineEnabled:a},i]=(0,x.useCine)(),[{activeViewportId:s}]=(0,x.useViewportGrid)(),[c,l]=(0,C.useState)([1,1]),[u,p]=(0,C.useState)(null),[y,f]=(0,C.useState)(null),[g,S]=(0,C.useState)(20),[v,h]=(0,C.useState)(a),[D,I]=(0,C.useState)(null),[b,w]=(0,C.useState)(!1),E=(0,C.useRef)(d.utilities.uuidv4()),T=(0,C.useRef)(null),M=`cornerstoneStreamingImageVolume:${E.current}`;function N(e){t.runCommand("swapDynamicWithComputedDisplaySet",{displaySet:e}),w(!0)}(0,C.useEffect)(()=>{const t=n.EVENTS.VIEWPORT_DATA_CHANGED,o=e.services.cineService.EVENTS.CINE_STATE_CHANGED,{unsubscribe:r}=n.subscribe(t,e=>{e.viewportData.data.forEach(e=>{if(e.volume?.isDynamicVolume()){f(e.volume),T.current=e.displaySetInstanceUID;const t=[1,e.volume.numDimensionGroups];l(t)}})}),{unsubscribe:a}=e.services.cineService.subscribe(o,e=>{h(e.isPlaying)});return()=>{r(),a()}},[n,i,e.services.cineService]),(0,C.useEffect)(()=>{const e=d.Enums.Events.DYNAMIC_VOLUME_DIMENSION_GROUP_CHANGED,t=e=>{I(e.detail.dimensionGroupNumber)};return d.eventTarget.addEventListener(e,t),()=>{d.eventTarget.removeEventListener(e,t)}},[]),(0,C.useEffect)(()=>{const e=o.getDisplaySetsUIDsForViewport(s);if(!e?.length)return;const t=e.map(r.getDisplaySetByUID).find(e=>e.isDynamicVolume);if(!t)return;const n=d.cache.getVolumes().find(e=>e.volumeId.includes(t.displaySetInstanceUID));n&&(f(n),T.current=t.displaySetInstanceUID,l([1,n.numDimensionGroups]))},[s,o,r,n,i]);const P=()=>{h(!0);const e=n.getViewportInfo(s);if(!e)return;const{element:t}=e;i.playClip(t,{framesPerSecond:g,viewportId:s})},R=()=>{h(!1);const{element:e}=n.getViewportInfo(s);i.stopClip(e)};return C.createElement(O,{fps:g,isPlaying:v,onPlayPauseChange:e=>{e?P():R()},minFps:1,maxFps:50,onFpsChange:e=>{S(e),R(),P()},currentDimensionGroupNumber:D,numDimensionGroups:y?.numDimensionGroups||1,onDimensionGroupChange:e=>{y.dimensionGroupNumber=e},onGenerate:async function(e){const o=y.volumeId;if(!o)return;let r=d.cache.getVolume(M);r||(r=await d.volumeLoader.createAndCacheDerivedVolume(o,{volumeId:M}));const[a,i]=c,s=Array.from({length:i-a+1},(e,t)=>a+t),l={dimensionGroupNumbers:"SUBTRACT"===e?[a,i]:s,targetVolume:r};if(m.utilities.dynamicVolume.updateVolumeFromTimeData(y,e,l),u)t.runCommand("updateVolumeData",{volume:r}),n.getRenderingEngine().render(),N(u);else{const e={volumeLoaderSchema:r.volumeId.split(":")[0],displaySetInstanceUID:E.current,SOPClassHandlerId:"@ohif/extension-default.sopClassHandlerModule.stack",Modality:y.metadata.Modality,isMultiFrame:!1,numImageFrames:1,uid:E.current,referenceDisplaySetUID:y.volumeId.split(":")[1],madeInClient:!0,FrameOfReferenceUID:y.metadata.FrameOfReferenceUID,isDerived:!0,imageIds:r.imageIds};p(e),N(e)}},onDynamicClick:b?()=>{t.runCommand("swapComputedWithDynamicDisplaySet")}:null,onDoubleRangeChange:l,rangeValues:c})}const R=function({servicesManager:e,commandsManager:t,tab:n}){return C.createElement(C.Fragment,null,C.createElement("div",{className:"text-foreground flex flex-col","data-cy":"dynamic-volume-panel"},C.createElement(P,{commandsManager:t,servicesManager:e})))};var U=c(438),_=c(669);const V=function({commandsManager:e,servicesManager:t}){const n=(0,_.useSegmentations)({servicesManager:t});return n?.length?C.createElement("div",{className:"flex gap-2"},C.createElement("div",{className:"flex h-8 w-full items-center rounded pr-0.5"},C.createElement(x.Button,{size:"sm",variant:"ghost",className:"pl-1.5",onClick:()=>{e.runCommand("exportTimeReportCSV",{segmentations:n,options:{filename:"TimeData.csv"}})}},C.createElement(x.Icons.Export,null),C.createElement("span",{className:"pl-1"},"Time Data"))),C.createElement("div",{className:"flex h-8 w-full items-center rounded pr-0.5"},C.createElement(x.Button,{size:"sm",variant:"ghost",className:"pl-1.5",onClick:()=>{e.runCommand("exportTimeReportCSV",{segmentations:n,summaryStats:!0,options:{filename:"ROIStats.csv"}})}},C.createElement(x.Icons.Export,null),C.createElement("span",{className:"pl-1"},"ROI Stats")))):null};const F=function({commandsManager:e,extensionManager:t,servicesManager:n,configuration:o}){const{toolbarService:r}=n.services;return[{name:"dynamic-volume",iconName:"tab-4d",iconLabel:"4D Workflow",label:"4D Workflow",component:()=>C.createElement(R,{commandsManager:e,servicesManager:n,extensionManager:t})},{name:"dynamic-segmentation",iconName:"tab-segmentation",iconLabel:"Segmentation",label:"Segmentation",component:()=>C.createElement(C.Fragment,null,C.createElement(U.Toolbox,{buttonSectionId:r.sections.dynamicToolbox,title:"Buttons:Threshold Tools"}),C.createElement(_.PanelSegmentation,{servicesManager:n,commandsManager:e,extensionManager:t,configuration:o},C.createElement(V,{servicesManager:n,commandsManager:e})))}]},G="2hot",k="dynamic4D-pt",$="dynamic4D-fusion",L="dynamic4D-ct";function A({colormap:e,voiInverted:t}={}){return{blendMode:"MIP",colormap:e,voi:{windowWidth:5,windowCenter:2.5},voiInverted:t}}function j(){const e={colormap:{name:G,opacity:[{value:0,opacity:0},{value:.1,opacity:1},{value:1,opacity:1}]},voiInverted:!1};return[{viewportOptions:{viewportId:"ptAxial",viewportType:"volume",orientation:"axial",toolGroupId:k,initialImageOptions:{preset:"middle"},syncGroups:[{type:"cameraPosition",id:"axialSync",source:!0,target:!0},{type:"voi",id:"ptWLSync",source:!0,target:!0}]},displaySets:[{id:"ptDisplaySet",options:{...A(e)}}]},{viewportOptions:{viewportId:"ptSagittal",viewportType:"volume",orientation:"sagittal",toolGroupId:k,initialImageOptions:{preset:"middle"},syncGroups:[{type:"cameraPosition",id:"sagittalSync",source:!0,target:!0},{type:"voi",id:"ptWLSync",source:!0,target:!0}]},displaySets:[{id:"ptDisplaySet",options:{...A(e)}}]},{viewportOptions:{viewportId:"ptCoronal",viewportType:"volume",orientation:"coronal",toolGroupId:k,initialImageOptions:{preset:"middle"},syncGroups:[{type:"cameraPosition",id:"coronalSync",source:!0,target:!0},{type:"voi",id:"ptWLSync",source:!0,target:!0}]},displaySets:[{id:"ptDisplaySet",options:{...A(e)}}]}]}function q(){const e={colormap:{name:G,opacity:[{value:0,opacity:0},{value:.1,opacity:.8},{value:1,opacity:.8}]}};return[{viewportOptions:{viewportId:"fusionAxial",viewportType:"volume",orientation:"axial",toolGroupId:$,initialImageOptions:{preset:"middle"},syncGroups:[{type:"cameraPosition",id:"axialSync",source:!0,target:!0},{type:"voi",id:"ctWLSync",source:!1,target:!0},{type:"voi",id:"fusionWLSync",source:!0,target:!0},{type:"voi",id:"ptFusionWLSync",source:!1,target:!0,options:{syncInvertState:!1}},{type:"hydrateseg",id:"sameFORId",source:!0,target:!0,options:{matchingRules:["sameFOR"]}}]},displaySets:[{id:"ctDisplaySet"},{options:{...A(e)},id:"ptDisplaySet"}]},{viewportOptions:{viewportId:"fusionSagittal",viewportType:"volume",orientation:"sagittal",toolGroupId:$,initialImageOptions:{preset:"middle"},syncGroups:[{type:"cameraPosition",id:"sagittalSync",source:!0,target:!0},{type:"voi",id:"ctWLSync",source:!1,target:!0},{type:"voi",id:"fusionWLSync",source:!0,target:!0},{type:"voi",id:"ptFusionWLSync",source:!1,target:!0,options:{syncInvertState:!1}},{type:"hydrateseg",id:"sameFORId",source:!0,target:!0,options:{matchingRules:["sameFOR"]}}]},displaySets:[{id:"ctDisplaySet"},{options:{...A(e)},id:"ptDisplaySet"}]},{viewportOptions:{viewportId:"fusionCoronal",viewportType:"volume",orientation:"coronal",toolGroupId:$,initialImageOptions:{preset:"middle"},syncGroups:[{type:"cameraPosition",id:"coronalSync",source:!0,target:!0},{type:"voi",id:"ctWLSync",source:!1,target:!0},{type:"voi",id:"fusionWLSync",source:!0,target:!0},{type:"voi",id:"ptFusionWLSync",source:!1,target:!0,options:{syncInvertState:!1}},{type:"hydrateseg",id:"sameFORId",source:!0,target:!0,options:{matchingRules:["sameFOR"]}}]},displaySets:[{id:"ctDisplaySet"},{options:{...A(e)},id:"ptDisplaySet"}]}]}const W={id:"default4D",locked:!0,hasUpdatedPriorsInformation:!1,name:"Default",createdDate:"2023-01-01T00:00:00.000Z",modifiedDate:"2023-01-01T00:00:00.000Z",availableTo:{},editableBy:{},imageLoadStrategy:"default",protocolMatchingRules:[{attribute:"ModalitiesInStudy",constraint:{contains:["CT","PT"]}}],numberOfPriorsReferenced:-1,displaySetSelectors:{defaultDisplaySetId:{imageMatchingRules:[],seriesMatchingRules:[{attribute:"numImageFrames",constraint:{greaterThan:{value:0}}}]},ctDisplaySet:{imageMatchingRules:[],seriesMatchingRules:[{attribute:"Modality",constraint:{equals:{value:"CT"}},required:!0},{attribute:"isReconstructable",constraint:{equals:{value:!0}},required:!0}]},ptDisplaySet:{imageMatchingRules:[],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"}}}]},chartDisplaySet:{imageMatchingRules:[],seriesMatchingRules:[{attribute:"Modality",constraint:{equals:{value:"CHT"}},required:!0}]}},stages:[{id:"dataPreparation",name:"Data Preparation",viewportStructure:{layoutType:"grid",properties:{rows:1,columns:3}},viewports:[...j()],createdDate:"2023-01-01T00:00:00.000Z"},{id:"registration",name:"Registration",viewportStructure:{layoutType:"grid",properties:{rows:3,columns:3}},viewports:[...q(),{viewportOptions:{viewportId:"ctAxial",viewportType:"volume",orientation:"axial",toolGroupId:L,initialImageOptions:{preset:"middle"},syncGroups:[{type:"cameraPosition",id:"axialSync",source:!0,target:!0},{type:"voi",id:"ctWLSync",source:!0,target:!0}]},displaySets:[{id:"ctDisplaySet"}]},{viewportOptions:{viewportId:"ctSagittal",viewportType:"volume",orientation:"sagittal",toolGroupId:L,initialImageOptions:{preset:"middle"},syncGroups:[{type:"cameraPosition",id:"sagittalSync",source:!0,target:!0},{type:"voi",id:"ctWLSync",source:!0,target:!0}]},displaySets:[{id:"ctDisplaySet"}]},{viewportOptions:{viewportId:"ctCoronal",viewportType:"volume",orientation:"coronal",toolGroupId:L,initialImageOptions:{preset:"middle"},syncGroups:[{type:"cameraPosition",id:"coronalSync",source:!0,target:!0},{type:"voi",id:"ctWLSync",source:!0,target:!0}]},displaySets:[{id:"ctDisplaySet"}]},...j()],createdDate:"2023-01-01T00:00:00.000Z"},{id:"roiQuantification",name:"ROI Quantification",viewportStructure:{layoutType:"grid",properties:{rows:1,columns:3}},viewports:[...q()],createdDate:"2023-01-01T00:00:00.000Z"},{id:"kineticAnalysis",name:"Kinetic Analysis",viewportStructure:{layoutType:"grid",properties:{rows:2,columns:3,layoutOptions:[{x:0,y:0,width:1/3,height:.5},{x:1/3,y:0,width:1/3,height:.5},{x:2/3,y:0,width:1/3,height:.5},{x:0,y:.5,width:1,height:.5}]}},viewports:[...q(),{viewportOptions:{viewportId:"seriesChart"},displaySets:[{id:"chartDisplaySet",options:{skipLoading:!0}}]}],createdDate:"2023-01-01T00:00:00.000Z"}]};const B={id:p,preRegistration:({servicesManager:e,commandsManager:t,configuration:n={}})=>{d.cache.setMaxCacheSize(5368709120)},getPanelModule:F,getHangingProtocolModule:function(){return[{name:W.id,protocol:W}]},getCommandsModule:({servicesManager:e,commandsManager:t,extensionManager:n})=>E({servicesManager:e,commandsManager:t,extensionManager:n})};return l})());
1
+ !function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("@ohif/core"),require("@cornerstonejs/core"),require("@ohif/extension-cornerstone"),require("@cornerstonejs/tools"),require("@ohif/ui-next"),require("@ohif/extension-default")):"function"==typeof define&&define.amd?define(["@ohif/core","@cornerstonejs/core","@ohif/extension-cornerstone","@cornerstonejs/tools","@ohif/ui-next","@ohif/extension-default"],t):"object"==typeof exports?exports["ohif-extension-cornerstone"]=t(require("@ohif/core"),require("@cornerstonejs/core"),require("@ohif/extension-cornerstone"),require("@cornerstonejs/tools"),require("@ohif/ui-next"),require("@ohif/extension-default")):e["ohif-extension-cornerstone"]=t(e["@ohif/core"],e["@cornerstonejs/core"],e["@ohif/extension-cornerstone"],e["@cornerstonejs/tools"],e["@ohif/ui-next"],e["@ohif/extension-default"])}(globalThis,(e,t,i,a,n,o)=>(()=>{"use strict";var r={249(e,t){var i=Symbol.for("react.element"),a=Symbol.for("react.portal"),n=Symbol.for("react.fragment"),o=(Symbol.for("react.strict_mode"),Symbol.for("react.profiler"),Symbol.for("react.provider"),Symbol.for("react.context"),Symbol.for("react.forward_ref"),Symbol.for("react.suspense"),Symbol.for("react.memo"),Symbol.for("react.lazy"),Symbol.iterator),r={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},s=Object.assign,l={};function c(e,t,i){this.props=e,this.context=t,this.refs=l,this.updater=i||r}function u(){}function p(e,t,i){this.props=e,this.context=t,this.refs=l,this.updater=i||r}c.prototype.isReactComponent={},c.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")},c.prototype.forceUpdate=function(e){this.updater.enqueueForceUpdate(this,e,"forceUpdate")},u.prototype=c.prototype;var m=p.prototype=new u;m.constructor=p,s(m,c.prototype),m.isPureReactComponent=!0;var d=Array.isArray,y=Object.prototype.hasOwnProperty,f=null,g={key:!0,ref:!0,__self:!0,__source:!0},S=null;t.Fragment=n,t.createElement=function(e,t,a){var n,o={},r=null,s=null;if(null!=t)for(n in void 0!==t.ref&&(s=t.ref),void 0!==t.key&&(r=""+t.key),t)y.call(t,n)&&!g.hasOwnProperty(n)&&(o[n]=t[n]);var l=arguments.length-2;if(1===l)o.children=a;else if(1<l){for(var c=Array(l),u=0;u<l;u++)c[u]=arguments[u+2];o.children=c}if(e&&e.defaultProps)for(n in l=e.defaultProps)void 0===o[n]&&(o[n]=l[n]);return{$$typeof:i,type:e,key:r,ref:s,props:o,_owner:f}},t.useEffect=function(e,t){return S.useEffect(e,t)},t.useRef=function(e){return S.useRef(e)},t.useState=function(e){return S.useState(e)}},326(e,t,i){e.exports=i(249)},557(e){e.exports=t},713(e){e.exports=a},2(t){t.exports=e},669(e){e.exports=i},438(e){e.exports=o},55(e){e.exports=n}},s={};function l(e){var t=s[e];if(void 0!==t)return t.exports;var i=s[e]={exports:{}};return r[e](i,i.exports,l),i.exports}l.d=(e,t)=>{for(var i in t)l.o(t,i)&&!l.o(e,i)&&Object.defineProperty(e,i,{enumerable:!0,get:t[i]})},l.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),l.r=e=>{"u">typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var c={};return(()=>{l.r(c),l.d(c,{default:()=>M});var e={};l.r(e),l.d(e,{updateSegmentationsChartDisplaySet:()=>s});let t=JSON.parse('{"UU":"@ohif/extension-cornerstone-dynamic-volume"}').UU;var i=l(713),a=l(557),n=l(2);let o=n.utils.guid(),{utilities:r}=i;function s({servicesManager:e}){let{segmentationService:t}=e.services,{seriesMetadata:i,instance:l}=function(e,{servicesManager:t}){let i;if(!e.length)return;let s=new WeakMap,l=e.map(e=>(function(e,t,{servicesManager:i}){let o,s,{displaySetService:l,segmentationService:c,viewportGridService:u}=i.services,p=l.getActiveDisplaySets().find(e=>{let t=e.instances?.[0];return!!t&&(void 0!==t.FrameReferenceTime||void 0!==t.NumberOfTimeSlices)}).displaySetInstanceUID;for(let[e]of a.cache._volumeCache)if(e.includes(p)){o=e;break}o&&(s=a.cache.getVolume(o));let{StudyInstanceUID:m,StudyDescription:d}=n.DicomMetadataStore.getInstanceByImageId(s.imageIds[0]),y=c.getLabelmapVolume(e.segmentationId),f=y?.volumeId,[g,S]=r.dynamicVolume.getDataInTime(s,{maskVolumeId:f}),v=g.length;if(0===v)return[];let h=u.getActiveViewportId(),D=c.getSegmentColor(h,e.segmentationId,1),I=a.utilities.color.rgbToHex(D[0],D[1],D[2]),b=t.get(s);b||(b=function(e){let t,i,a={FrameReferenceTime:{unit:"ms"}},o=Object.keys(a);for(let r=0;r<o.length;r++){let s=o[r],l=function(e,t){return Array.from(e.imageIds.reduce((e,i)=>{let a=n.DicomMetadataStore.getInstanceByImageId(i)[t];return void 0!==a&&e.add(a),e},new Set)).sort((e,t)=>e-t)}(e,s);if(l.length){t=l,i=a[s].unit;break}}if(!t.length){let e=o.join(", ");throw Error(`Could not extract time points data for the following tags: ${e}`)}let r=function(e,t){let i=["ms","s","m","h"],a=[1e3,60,60],n=i.indexOf(t),o=1;if(-1!==n){for(let r=n;r<i.length-1;r++){let n=o*a[r];if(e.filter(e=>e>n).length<=e.length/2)break;o=n,t=i[r+1]}o>1&&(e=e.map(e=>e/o))}return{timePoints:e,timePointsUnit:t}}(t,i);return{timePoints:t=r.timePoints,timePointsUnit:i=r.timePointsUnit}}(s),t.set(s,b));let{timePoints:w,timePointsUnit:x}=b;if(w.length!==g[0].length)throw Error("Invalid number of time points returned");let E=w.length,C=Array(E);for(let e=0;e<E;e++){let t=g.reduce((t,i)=>t+i[e]/v,0);C[e]=[w[e],t]}return{StudyInstanceUID:m,StudyDescription:d,chartData:{series:{label:e.label,points:C,color:I},axis:{x:{label:`Time (${x})`},y:{label:"Vl (Bq/ml)"}}}}})(e,s,{servicesManager:t})),{date:c,time:u}={date:(i=new Date).getFullYear()+("0"+i.getUTCMonth()).slice(-2)+("0"+i.getUTCDate()).slice(-2),time:("0"+i.getUTCHours()).slice(-2)+("0"+i.getUTCMinutes()).slice(-2)+("0"+i.getUTCSeconds()).slice(-2)},p=l.reduce((e,t)=>[...e,t.chartData.series],[]),m={SOPClassUID:"1.9.451.13215.7.3.2.7.6.1",Modality:"CHT",SOPInstanceUID:n.utils.guid(),SeriesDate:c,SeriesTime:u,SeriesInstanceUID:o,StudyInstanceUID:l[0].StudyInstanceUID,StudyDescription:l[0].StudyDescription,SeriesNumber:100,SeriesDescription:"Segmentation chart series data",chartData:{series:p,axis:{...l[0].chartData.axis}}};return{seriesMetadata:{StudyInstanceUID:m.StudyInstanceUID,StudyDescription:m.StudyDescription,SeriesInstanceUID:m.SeriesInstanceUID,SeriesDescription:m.SeriesDescription,SeriesNumber:m.SeriesNumber,SeriesTime:m.SeriesTime,SOPClassUID:m.SOPClassUID,Modality:m.Modality},instance:m}}(t.getSegmentations(),{servicesManager:e})??{};i&&l&&(n.DicomMetadataStore.addSeriesMetadata([i],!0),n.DicomMetadataStore.addInstances([l],!0))}let{downloadCsv:u}=n.utils;var p=l(326),m=l(55);let d=e=>null==e?"":String(e).toUpperCase(),y=({title:e,tooltip:t})=>p.createElement("div",{className:"flex items-center space-x-1"},p.createElement(m.Tooltip,null,p.createElement(m.TooltipTrigger,{asChild:!0},p.createElement("span",null,p.createElement(m.Icons.ByName,{name:"info-link",className:"text-primary h-3 w-3"}))),p.createElement(m.TooltipContent,{sideOffset:4,className:"max-w-xs"},p.createElement("div",null,t))),p.createElement("span",{className:"text-muted-foreground text-xs uppercase tracking-wide"},e)),f=({isPlaying:e,onPlayPauseChange:t,fps:i,onFpsChange:n,minFps:o,maxFps:r,currentDimensionGroupNumber:s,onDimensionGroupChange:l,numDimensionGroups:c,onGenerate:u,onDoubleRangeChange:f,rangeValues:S,onDynamicClick:v})=>{let[h,D]=(0,p.useState)(!1),[I,b]=(0,p.useState)(a.Enums.DynamicOperatorType.SUM);return p.createElement("div",{className:"flex select-none flex-col"},p.createElement(m.PanelSection,{defaultOpen:!0},p.createElement(m.PanelSection.Header,null,"Controls"),p.createElement(m.PanelSection.Content,{className:"bg-muted space-y-4 px-5 pt-2 pb-4"},p.createElement("div",{className:"mb-4"},p.createElement(y,{title:"View",tooltip:"Select the view mode, 4D to view the dynamic volume or Computed to view the computed volume"}),p.createElement(m.Tabs,{value:h?"computed":"4d",onValueChange:e=>{let t="computed"===e;D(t),t||"function"!=typeof v||v()},className:"my-2 w-full"},p.createElement(m.TabsList,{className:"w-full"},p.createElement(m.TabsTrigger,{value:"4d",className:"w-1/2"},"4D"),p.createElement(m.TabsTrigger,{value:"computed",className:"w-1/2"},"Computed")))),p.createElement("div",null,p.createElement(g,{onPlayPauseChange:t,isPlaying:e,computedView:h,fps:i,onFpsChange:n,minFps:o,maxFps:r,numDimensionGroups:c,onDimensionGroupChange:l,currentDimensionGroupNumber:s})),p.createElement("div",{className:`mt-3 flex flex-col ${h?"":"ohif-disabled"}`},p.createElement(y,{title:"Computed Operation",tooltip:p.createElement("div",null,"Operation Buttons (SUM, AVERAGE, SUBTRACT): Select the mathematical operation to be applied to the data set.",p.createElement("br",null)," Range Slider: Choose the numeric range of dimension groups within which the operation will be performed.",p.createElement("br",null),"Generate Button: Execute the chosen operation on the specified range of data.")}),p.createElement(m.Tabs,{value:String(I),onValueChange:e=>{b(e)},className:"mt-2 w-full"},p.createElement(m.TabsList,{className:"w-full gap-1"}," ",p.createElement(m.TabsTrigger,{value:String(a.Enums.DynamicOperatorType.SUM),className:"w-1/3"},d(a.Enums.DynamicOperatorType.SUM)),p.createElement(m.TabsTrigger,{value:String(a.Enums.DynamicOperatorType.AVERAGE),className:"w-1/3"},d(a.Enums.DynamicOperatorType.AVERAGE)),p.createElement(m.TabsTrigger,{value:String(a.Enums.DynamicOperatorType.SUBTRACT),className:"w-1/3"},d(a.Enums.DynamicOperatorType.SUBTRACT)))),p.createElement("div",{className:"mt-2 w-full"},p.createElement(m.Numeric.Container,{mode:"doubleRange",min:1,max:c||1,values:S||[1,c||1],onChange:f||(()=>{})},p.createElement(m.Numeric.DoubleRange,{showNumberInputs:!0}))),p.createElement(m.Button,{variant:"default",size:"sm",className:"mt-2 h-[26px] w-[115px] self-start p-0",onClick:()=>{try{"function"==typeof u?u(I):console.error("onGenerate is not a function",u)}catch(e){console.error("Error in onGenerate:",e)}}},"Generate")))))};function g({isPlaying:e,onPlayPauseChange:t,fps:i,minFps:a,maxFps:n,onFpsChange:o,numDimensionGroups:r,onDimensionGroupChange:s,currentDimensionGroupNumber:l,computedView:c}){return p.createElement("div",{className:c?"ohif-disabled":""},p.createElement(y,{title:"4D Controls",tooltip:p.createElement("div",null,"Play/Pause Button: Begin or pause the animation of the 4D visualization. ",p.createElement("br",null),"Dimension Group Selector: Navigate through individual dimension groups of the 4D data."," ",p.createElement("br",null),"FPS (Frames Per Second) Selector: Adjust the playback speed of the animation.")}),p.createElement("div",{className:"mt-3 flex justify-between"},p.createElement(m.Button,{id:"play-pause-button",variant:"secondary",size:"default",className:"w-[58px]",onClick:()=>{"function"==typeof t&&t(!e)}},p.createElement(m.Icons.ByName,{name:e?"icon-pause":"icon-play",className:"text-foreground h-[24px] w-[24px]"})),p.createElement(m.Numeric.Container,{mode:"stepper",value:l||1,onChange:s||(()=>{}),min:1,max:r||1,step:1},p.createElement("div",{className:"flex flex-col items-center"},p.createElement(m.Numeric.NumberStepper,{className:"h-[28px] w-[58px]",direction:"horizontal"}),p.createElement(m.Numeric.Label,{className:"text-muted-foreground mt-1 text-sm"},"Frame"))),p.createElement(m.Numeric.Container,{mode:"stepper",value:i||1,onChange:o||(()=>{}),min:a||1,max:n||30,step:1},p.createElement("div",{className:"flex flex-col items-center"},p.createElement(m.Numeric.NumberStepper,{className:"h-[28px] w-[58px]",direction:"horizontal"}),p.createElement(m.Numeric.Label,{className:"text-muted-foreground mt-1 text-sm"},"FPS")))))}function S({servicesManager:e,commandsManager:t}){let{cornerstoneViewportService:n,viewportGridService:o,displaySetService:r}=e.services,[{isCineEnabled:s},l]=(0,m.useCine)(),[{activeViewportId:c}]=(0,m.useViewportGrid)(),[u,d]=(0,p.useState)([1,1]),[y,g]=(0,p.useState)(null),[v,h]=(0,p.useState)(null),[D,I]=(0,p.useState)(20),[b,w]=(0,p.useState)(s),[x,E]=(0,p.useState)(null),[C,T]=(0,p.useState)(!1),N=(0,p.useRef)(a.utilities.uuidv4()),O=(0,p.useRef)(null),M=`cornerstoneStreamingImageVolume:${N.current}`;function P(e){t.runCommand("swapDynamicWithComputedDisplaySet",{displaySet:e}),T(!0)}async function U(e){let o=v.volumeId;if(!o)return;let r=a.cache.getVolume(M);r||(r=await a.volumeLoader.createAndCacheDerivedVolume(o,{volumeId:M}));let[s,l]=u,c=Array.from({length:l-s+1},(e,t)=>s+t),p={dimensionGroupNumbers:"SUBTRACT"===e?[s,l]:c,targetVolume:r};if(i.utilities.dynamicVolume.updateVolumeFromTimeData(v,e,p),y)t.runCommand("updateVolumeData",{volume:r}),n.getRenderingEngine().render(),P(y);else{let e={volumeLoaderSchema:r.volumeId.split(":")[0],displaySetInstanceUID:N.current,SOPClassHandlerId:"@ohif/extension-default.sopClassHandlerModule.stack",Modality:v.metadata.Modality,isMultiFrame:!1,numImageFrames:1,uid:N.current,referenceDisplaySetUID:v.volumeId.split(":")[1],madeInClient:!0,FrameOfReferenceUID:v.metadata.FrameOfReferenceUID,isDerived:!0,imageIds:r.imageIds};g(e),P(e)}}(0,p.useEffect)(()=>{let t=n.EVENTS.VIEWPORT_DATA_CHANGED,i=e.services.cineService.EVENTS.CINE_STATE_CHANGED,{unsubscribe:a}=n.subscribe(t,e=>{e.viewportData.data.forEach(e=>{e.volume?.isDynamicVolume()&&(h(e.volume),O.current=e.displaySetInstanceUID,d([1,e.volume.numDimensionGroups]))})}),{unsubscribe:o}=e.services.cineService.subscribe(i,e=>{w(e.isPlaying)});return()=>{a(),o()}},[n,l,e.services.cineService]),(0,p.useEffect)(()=>{let e=a.Enums.Events.DYNAMIC_VOLUME_DIMENSION_GROUP_CHANGED,t=e=>{E(e.detail.dimensionGroupNumber)};return a.eventTarget.addEventListener(e,t),()=>{a.eventTarget.removeEventListener(e,t)}},[]),(0,p.useEffect)(()=>{let e=o.getDisplaySetsUIDsForViewport(c);if(!e?.length)return;let t=e.map(r.getDisplaySetByUID).find(e=>e.isDynamicVolume);if(!t)return;let i=a.cache.getVolumes().find(e=>e.volumeId.includes(t.displaySetInstanceUID));i&&(h(i),O.current=t.displaySetInstanceUID,d([1,i.numDimensionGroups]))},[c,o,r,n,l]);let R=()=>{w(!0);let e=n.getViewportInfo(c);if(!e)return;let{element:t}=e;l.playClip(t,{framesPerSecond:D,viewportId:c})},F=()=>{w(!1);let{element:e}=n.getViewportInfo(c);l.stopClip(e)};return p.createElement(f,{fps:D,isPlaying:b,onPlayPauseChange:e=>{e?R():F()},minFps:1,maxFps:50,onFpsChange:e=>{I(e),F(),R()},currentDimensionGroupNumber:x,numDimensionGroups:v?.numDimensionGroups||1,onDimensionGroupChange:e=>{v.dimensionGroupNumber=e},onGenerate:U,onDynamicClick:C?()=>void t.runCommand("swapComputedWithDynamicDisplaySet"):null,onDoubleRangeChange:d,rangeValues:u})}let v=function({servicesManager:e,commandsManager:t,tab:i}){return p.createElement(p.Fragment,null,p.createElement("div",{className:"text-foreground flex flex-col","data-cy":"dynamic-volume-panel"},p.createElement(S,{commandsManager:t,servicesManager:e})))};var h=l(438),D=l(669);let I=function({commandsManager:e,servicesManager:t}){let i=(0,D.useSegmentations)({servicesManager:t});return i?.length?p.createElement("div",{className:"flex gap-2"},p.createElement("div",{className:"flex h-8 w-full items-center rounded pr-0.5"},p.createElement(m.Button,{size:"sm",variant:"ghost",className:"pl-1.5",onClick:()=>{e.runCommand("exportTimeReportCSV",{segmentations:i,options:{filename:"TimeData.csv"}})}},p.createElement(m.Icons.Export,null),p.createElement("span",{className:"pl-1"},"Time Data"))),p.createElement("div",{className:"flex h-8 w-full items-center rounded pr-0.5"},p.createElement(m.Button,{size:"sm",variant:"ghost",className:"pl-1.5",onClick:()=>{e.runCommand("exportTimeReportCSV",{segmentations:i,summaryStats:!0,options:{filename:"ROIStats.csv"}})}},p.createElement(m.Icons.Export,null),p.createElement("span",{className:"pl-1"},"ROI Stats")))):null},b="2hot",w="dynamic4D-pt",x="dynamic4D-fusion",E="dynamic4D-ct";function C({colormap:e,voiInverted:t}={}){return{blendMode:"MIP",colormap:e,voi:{windowWidth:5,windowCenter:2.5},voiInverted:t}}function T(){let e={colormap:{name:b,opacity:[{value:0,opacity:0},{value:.1,opacity:1},{value:1,opacity:1}]},voiInverted:!1};return[{viewportOptions:{viewportId:"ptAxial",viewportType:"volume",orientation:"axial",toolGroupId:w,initialImageOptions:{preset:"middle"},syncGroups:[{type:"cameraPosition",id:"axialSync",source:!0,target:!0},{type:"voi",id:"ptWLSync",source:!0,target:!0}]},displaySets:[{id:"ptDisplaySet",options:{...C(e)}}]},{viewportOptions:{viewportId:"ptSagittal",viewportType:"volume",orientation:"sagittal",toolGroupId:w,initialImageOptions:{preset:"middle"},syncGroups:[{type:"cameraPosition",id:"sagittalSync",source:!0,target:!0},{type:"voi",id:"ptWLSync",source:!0,target:!0}]},displaySets:[{id:"ptDisplaySet",options:{...C(e)}}]},{viewportOptions:{viewportId:"ptCoronal",viewportType:"volume",orientation:"coronal",toolGroupId:w,initialImageOptions:{preset:"middle"},syncGroups:[{type:"cameraPosition",id:"coronalSync",source:!0,target:!0},{type:"voi",id:"ptWLSync",source:!0,target:!0}]},displaySets:[{id:"ptDisplaySet",options:{...C(e)}}]}]}function N(){let e={colormap:{name:b,opacity:[{value:0,opacity:0},{value:.1,opacity:.8},{value:1,opacity:.8}]}};return[{viewportOptions:{viewportId:"fusionAxial",viewportType:"volume",orientation:"axial",toolGroupId:x,initialImageOptions:{preset:"middle"},syncGroups:[{type:"cameraPosition",id:"axialSync",source:!0,target:!0},{type:"voi",id:"ctWLSync",source:!1,target:!0},{type:"voi",id:"fusionWLSync",source:!0,target:!0},{type:"voi",id:"ptFusionWLSync",source:!1,target:!0,options:{syncInvertState:!1}},{type:"hydrateseg",id:"sameFORId",source:!0,target:!0,options:{matchingRules:["sameFOR"]}}]},displaySets:[{id:"ctDisplaySet"},{options:{...C(e)},id:"ptDisplaySet"}]},{viewportOptions:{viewportId:"fusionSagittal",viewportType:"volume",orientation:"sagittal",toolGroupId:x,initialImageOptions:{preset:"middle"},syncGroups:[{type:"cameraPosition",id:"sagittalSync",source:!0,target:!0},{type:"voi",id:"ctWLSync",source:!1,target:!0},{type:"voi",id:"fusionWLSync",source:!0,target:!0},{type:"voi",id:"ptFusionWLSync",source:!1,target:!0,options:{syncInvertState:!1}},{type:"hydrateseg",id:"sameFORId",source:!0,target:!0,options:{matchingRules:["sameFOR"]}}]},displaySets:[{id:"ctDisplaySet"},{options:{...C(e)},id:"ptDisplaySet"}]},{viewportOptions:{viewportId:"fusionCoronal",viewportType:"volume",orientation:"coronal",toolGroupId:x,initialImageOptions:{preset:"middle"},syncGroups:[{type:"cameraPosition",id:"coronalSync",source:!0,target:!0},{type:"voi",id:"ctWLSync",source:!1,target:!0},{type:"voi",id:"fusionWLSync",source:!0,target:!0},{type:"voi",id:"ptFusionWLSync",source:!1,target:!0,options:{syncInvertState:!1}},{type:"hydrateseg",id:"sameFORId",source:!0,target:!0,options:{matchingRules:["sameFOR"]}}]},displaySets:[{id:"ctDisplaySet"},{options:{...C(e)},id:"ptDisplaySet"}]}]}let O={id:"default4D",locked:!0,hasUpdatedPriorsInformation:!1,name:"Default",createdDate:"2023-01-01T00:00:00.000Z",modifiedDate:"2023-01-01T00:00:00.000Z",availableTo:{},editableBy:{},imageLoadStrategy:"default",protocolMatchingRules:[{attribute:"ModalitiesInStudy",constraint:{contains:["CT","PT"]}}],numberOfPriorsReferenced:-1,displaySetSelectors:{defaultDisplaySetId:{imageMatchingRules:[],seriesMatchingRules:[{attribute:"numImageFrames",constraint:{greaterThan:{value:0}}}]},ctDisplaySet:{imageMatchingRules:[],seriesMatchingRules:[{attribute:"Modality",constraint:{equals:{value:"CT"}},required:!0},{attribute:"isReconstructable",constraint:{equals:{value:!0}},required:!0}]},ptDisplaySet:{imageMatchingRules:[],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"}}}]},chartDisplaySet:{imageMatchingRules:[],seriesMatchingRules:[{attribute:"Modality",constraint:{equals:{value:"CHT"}},required:!0}]}},stages:[{id:"dataPreparation",name:"Data Preparation",viewportStructure:{layoutType:"grid",properties:{rows:1,columns:3}},viewports:[...T()],createdDate:"2023-01-01T00:00:00.000Z"},{id:"registration",name:"Registration",viewportStructure:{layoutType:"grid",properties:{rows:3,columns:3}},viewports:[...N(),{viewportOptions:{viewportId:"ctAxial",viewportType:"volume",orientation:"axial",toolGroupId:E,initialImageOptions:{preset:"middle"},syncGroups:[{type:"cameraPosition",id:"axialSync",source:!0,target:!0},{type:"voi",id:"ctWLSync",source:!0,target:!0}]},displaySets:[{id:"ctDisplaySet"}]},{viewportOptions:{viewportId:"ctSagittal",viewportType:"volume",orientation:"sagittal",toolGroupId:E,initialImageOptions:{preset:"middle"},syncGroups:[{type:"cameraPosition",id:"sagittalSync",source:!0,target:!0},{type:"voi",id:"ctWLSync",source:!0,target:!0}]},displaySets:[{id:"ctDisplaySet"}]},{viewportOptions:{viewportId:"ctCoronal",viewportType:"volume",orientation:"coronal",toolGroupId:E,initialImageOptions:{preset:"middle"},syncGroups:[{type:"cameraPosition",id:"coronalSync",source:!0,target:!0},{type:"voi",id:"ctWLSync",source:!0,target:!0}]},displaySets:[{id:"ctDisplaySet"}]},...T()],createdDate:"2023-01-01T00:00:00.000Z"},{id:"roiQuantification",name:"ROI Quantification",viewportStructure:{layoutType:"grid",properties:{rows:1,columns:3}},viewports:[...N()],createdDate:"2023-01-01T00:00:00.000Z"},{id:"kineticAnalysis",name:"Kinetic Analysis",viewportStructure:{layoutType:"grid",properties:{rows:2,columns:3,layoutOptions:[{x:0,y:0,width:1/3,height:.5},{x:1/3,y:0,width:1/3,height:.5},{x:2/3,y:0,width:1/3,height:.5},{x:0,y:.5,width:1,height:.5}]}},viewports:[...N(),{viewportOptions:{viewportId:"seriesChart"},displaySets:[{id:"chartDisplaySet",options:{skipLoading:!0}}]}],createdDate:"2023-01-01T00:00:00.000Z"}]},M={id:t,preRegistration:({servicesManager:e,commandsManager:t,configuration:i={}})=>{a.cache.setMaxCacheSize(0x140000000)},getPanelModule:function({commandsManager:e,extensionManager:t,servicesManager:i,configuration:a}){let{toolbarService:n}=i.services;return[{name:"dynamic-volume",iconName:"tab-4d",iconLabel:"4D Workflow",label:"4D Workflow",component:()=>p.createElement(v,{commandsManager:e,servicesManager:i,extensionManager:t})},{name:"dynamic-segmentation",iconName:"tab-segmentation",iconLabel:"Segmentation",label:"Segmentation",component:()=>p.createElement(p.Fragment,null,p.createElement(h.Toolbox,{buttonSectionId:n.sections.dynamicToolbox,title:"Buttons:Threshold Tools"}),p.createElement(D.PanelSegmentation,{servicesManager:i,commandsManager:e,extensionManager:t,configuration:a},p.createElement(I,{servicesManager:i,commandsManager:e})))}]},getHangingProtocolModule:function(){return[{name:O.id,protocol:O}]},getCommandsModule:({servicesManager:t,commandsManager:n,extensionManager:o})=>(({commandsManager:t,servicesManager:n})=>{let{displaySetService:o,viewportGridService:r,segmentationService:s}=n.services,l={...e,getDynamic4DDisplaySet:()=>o.getActiveDisplaySets().find(e=>{let t=e.instances?.[0];return!!t&&(void 0!==t.FrameReferenceTime||void 0!==t.NumberOfTimeSlices||void 0!==t.TemporalPositionIdentifier)}),getComputedDisplaySets:()=>[...o.getDisplaySetCache().values()].filter(e=>e.isDerived),exportTimeReportCSV:({segmentations:e,summaryStats:t})=>{let n,o,r=l.getDynamic4DDisplaySet(),c=r?.displaySetInstanceUID;for(let[e]of a.cache._volumeCache)if(e.includes(c)){n=e;break}n&&(o=a.cache.getVolume(n));let p=r.instances[0],m=[];m.push(`Patient ID,${p.PatientID},`),m.push(`Study Date,${p.StudyDate},`),m.push(`StudyInstanceUID,${p.StudyInstanceUID},`),m.push(`StudyDescription,${p.StudyDescription},`),m.push(`SeriesInstanceUID,${p.SeriesInstanceUID},`),m.push(""),m.push(""),e.forEach(e=>{let a=s.getLabelmapVolume(e.segmentationId),[n,r]=i.utilities.dynamicVolume.getDataInTime(o,{maskVolumeId:a.volumeId});if(t){let t="Operation,Segmentation Label ID",i=o.numTimePoints;for(let e=0;e<i;e++)t+=`,Time Point ${e}`;m.push(t);let a=[],s=[],l=[],c=[],u=[],p=[],d=n.length;for(let e=0;e<i;e++){let t=[],i=0,o=1/0,m=-1/0,y=0,f=0;for(let a=0;a<d;a++){let r=n[a][e];t.push(r),i+=r,r<o&&(o=r,y=a),r>m&&(m=r,f=a)}a.push(i/d),s.push(o),l.push(r[y]),c.push(m),u.push(r[f]),p.push(function(e){let t=e.length,i=e.reduce((e,t)=>e+t,0)/t;return Math.sqrt(e.map(e=>(e-i)**2).reduce((e,t)=>e+t,0)/t)}(t))}let y=`Mean,${e.label}`;for(let e=0;e<i;e++)y+=`,${a[e]}`;m.push(y),y=`Standard Deviation,${e.label}`;for(let e=0;e<i;e++)y+=`,${p[e]}`;m.push(y),y=`Min,${e.label}`;for(let e=0;e<i;e++)y+=`,${s[e]}`;m.push(y),y=`Max,${e.label}`;for(let e=0;e<i;e++)y+=`,${c[e]}`;m.push(y)}else{let t="Pixel Identifier (IJK),Segmentation Label ID",i=o.numTimePoints;for(let e=0;e<i;e++)t+=`,Time Point ${e}`;m.push(t);for(let t=0;t<n.length;t++){let i=`${r[t][0]}_${r[t][1]}_${r[t][2]}`,a=`${i},${e.label}`;for(let e=0;e<n[t].length;e++)a+=`,${n[t][e]}`;m.push(a)}}}),u(m.join("\n"),{filename:`${p.PatientID}.csv`})},swapDynamicWithComputedDisplaySet:({displaySet:e})=>{let i=o.getDisplaySetCache(),a=[i.keys()],{displaySetInstanceUID:n}=e;a.includes(n)||i.set(n,e);let{viewports:s}=r.getState(),c=l.getDynamic4DDisplaySet(),u=[];for(let[e,t]of s){let e=t.viewportOptions,{displaySetInstanceUIDs:i}=t,a=i.indexOf(c.displaySetInstanceUID);if(-1!==a){let o={viewportId:t.viewportId,displaySetInstanceUIDs:[...i.slice(0,a),n,...i.slice(a+1)],viewportOptions:{initialImageOptions:e.initialImageOptions,viewportType:"volume",orientation:e.orientation,background:e.background}};u.push(o)}}t.run("setDisplaySetsForViewports",{viewportsToUpdate:u})},swapComputedWithDynamicDisplaySet:()=>{let e=l.getDynamic4DDisplaySet(),i=o.getDisplaySetCache(),a=[...i.keys()],{displaySetInstanceUID:n}=e;a.includes(n)||i.set(n,e);let{viewports:s}=r.getState(),c=l.getComputedDisplaySets()[0],u=[];for(let[e,t]of s){let e=t.viewportOptions,{displaySetInstanceUIDs:i}=t,a=i.indexOf(c.displaySetInstanceUID);if(-1!==a){let o={viewportId:t.viewportId,displaySetInstanceUIDs:[...i.slice(0,a),n,...i.slice(a+1)],viewportOptions:{initialImageOptions:e.initialImageOptions,viewportType:"volume",orientation:e.orientation,background:e.background}};u.push(o)}}t.run("setDisplaySetsForViewports",{viewportsToUpdate:u})},createNewLabelMapForDynamicVolume:async({label:e})=>{let t,{viewports:i,activeViewportId:a}=r.getState(),n=l.getDynamic4DDisplaySet(),c=n.displaySetInstanceUID;if(i.get(a).displaySetInstanceUIDs.includes(c)&&(t=n),!t){for(let[e,i]of o.getDisplaySetCache())if(i.referenceDisplaySetUID===c){t=i;break}}if(!t)throw Error("No reference display set found based on the dynamic data");let u=o.getDisplaySetByUID(t.displaySetInstanceUID),p=await s.createLabelmapForDisplaySet(u,{label:e}),m=i.values().next().value;return await s.addSegmentationRepresentation(m.viewportId,{segmentationId:p}),p}},c={updateSegmentationsChartDisplaySet:{commandFn:l.updateSegmentationsChartDisplaySet,storeContexts:[],options:{}},exportTimeReportCSV:{commandFn:l.exportTimeReportCSV,storeContexts:[],options:{}},swapDynamicWithComputedDisplaySet:{commandFn:l.swapDynamicWithComputedDisplaySet,storeContexts:[],options:{}},createNewLabelMapForDynamicVolume:{commandFn:l.createNewLabelMapForDynamicVolume,storeContexts:[],options:{}},swapComputedWithDynamicDisplaySet:{commandFn:l.swapComputedWithDynamicDisplaySet,storeContexts:[],options:{}}};return{actions:l,definitions:c,defaultContext:"DYNAMIC-VOLUME:CORNERSTONE"}})({servicesManager:t,commandsManager:n,extensionManager:o})}})(),c})());
package/package.json CHANGED
@@ -1,12 +1,15 @@
1
1
  {
2
2
  "name": "@ohif/extension-cornerstone-dynamic-volume",
3
- "version": "3.13.0-beta.89",
3
+ "version": "3.13.0-beta.92",
4
4
  "description": "OHIF extension for 4D volumes data",
5
5
  "author": "OHIF",
6
6
  "license": "MIT",
7
7
  "repository": "OHIF/Viewers",
8
8
  "main": "dist/ohif-extension-cornerstone-dynamic-volume.umd.js",
9
9
  "module": "src/index.ts",
10
+ "engines": {
11
+ "node": ">=24"
12
+ },
10
13
  "exports": {
11
14
  ".": "./src/index.ts",
12
15
  "./types": "./src/types/index.ts"
@@ -19,21 +22,21 @@
19
22
  "access": "public"
20
23
  },
21
24
  "scripts": {
22
- "dev": "cross-env NODE_ENV=development webpack --config .webpack/webpack.dev.js --watch --output-pathinfo",
23
- "build": "cross-env NODE_ENV=production webpack --config .webpack/webpack.prod.js",
24
- "build:package": "yarn run build",
25
+ "dev": "cross-env NODE_ENV=development rspack build --config .webpack/webpack.dev.js --watch",
26
+ "build": "cross-env NODE_ENV=production rspack build --config .webpack/webpack.prod.js",
27
+ "build:package": "pnpm run build",
25
28
  "clean": "shx rm -rf dist",
26
- "clean:deep": "yarn run clean && shx rm -rf node_modules",
27
- "start": "yarn run dev",
29
+ "clean:deep": "pnpm run clean && shx rm -rf node_modules",
30
+ "start": "pnpm run dev",
28
31
  "test:unit": "jest --watchAll",
29
32
  "test:unit:ci": "jest --ci --runInBand --collectCoverage --passWithNoTests"
30
33
  },
31
34
  "peerDependencies": {
32
- "@ohif/core": "3.13.0-beta.89",
33
- "@ohif/extension-cornerstone": "3.13.0-beta.89",
34
- "@ohif/extension-default": "3.13.0-beta.89",
35
- "@ohif/i18n": "3.13.0-beta.89",
36
- "@ohif/ui": "3.13.0-beta.89",
35
+ "@ohif/core": "3.13.0-beta.92",
36
+ "@ohif/extension-cornerstone": "3.13.0-beta.92",
37
+ "@ohif/extension-default": "3.13.0-beta.92",
38
+ "@ohif/i18n": "3.13.0-beta.92",
39
+ "@ohif/ui": "3.13.0-beta.92",
37
40
  "dcmjs": "0.49.4",
38
41
  "dicom-parser": "1.8.21",
39
42
  "hammerjs": "2.0.8",
@@ -42,8 +45,11 @@
42
45
  },
43
46
  "dependencies": {
44
47
  "@babel/runtime": "7.29.7",
45
- "@cornerstonejs/core": "5.0.0",
46
- "@cornerstonejs/tools": "5.0.0",
48
+ "@cornerstonejs/core": "5.0.2",
49
+ "@cornerstonejs/tools": "5.0.2",
47
50
  "classnames": "2.5.1"
51
+ },
52
+ "devDependencies": {
53
+ "cross-env": "7.0.3"
48
54
  }
49
55
  }
@@ -1,9 +0,0 @@
1
- /**
2
- * @license React
3
- * react.production.min.js
4
- *
5
- * Copyright (c) Facebook, Inc. and its affiliates.
6
- *
7
- * This source code is licensed under the MIT license found in the
8
- * LICENSE file in the root directory of this source tree.
9
- */