@ohif/extension-cornerstone-dicom-rt 3.12.0-beta.7 → 3.12.0-beta.70
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-cornerstone-dicom-rt.umd.js.LICENSE.txt */
|
|
2
|
-
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("@ohif/core"),require("@ohif/i18n"),require("dcmjs"),require("@cornerstonejs/tools/enums"),require("@ohif/ui-next"),require("@ohif/extension-cornerstone"),require("@ohif/core/src")):"function"==typeof define&&define.amd?define(["@ohif/core","@ohif/i18n","dcmjs","@cornerstonejs/tools/enums","@ohif/ui-next","@ohif/extension-cornerstone","@ohif/core/src"],t):"object"==typeof exports?exports["ohif-extension-cornerstone-dicom-rt"]=t(require("@ohif/core"),require("@ohif/i18n"),require("dcmjs"),require("@cornerstonejs/tools/enums"),require("@ohif/ui-next"),require("@ohif/extension-cornerstone"),require("@ohif/core/src")):e["ohif-extension-cornerstone-dicom-rt"]=t(e["@ohif/core"],e["@ohif/i18n"],e.dcmjs,e["@cornerstonejs/tools/enums"],e["@ohif/ui-next"],e["@ohif/extension-cornerstone"],e["@ohif/core/src"])}(globalThis,(e,t,r,n,o,s,i)=>(()=>{var a,c,u={2:t=>{"use strict";t.exports=e},55:e=>{"use strict";e.exports=o},111:e=>{"use strict";e.exports=r},183:e=>{"use strict";e.exports="SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED"},249:(e,t)=>{"use strict";var r=Symbol.for("react.element"),n=Symbol.for("react.portal"),o=Symbol.for("react.fragment"),s=Symbol.for("react.strict_mode"),i=Symbol.for("react.profiler"),a=Symbol.for("react.provider"),c=Symbol.for("react.context"),u=Symbol.for("react.forward_ref"),l=Symbol.for("react.suspense"),f=Symbol.for("react.memo"),d=Symbol.for("react.lazy"),p=Symbol.iterator;var S={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},y=Object.assign,I={};function m(e,t,r){this.props=e,this.context=t,this.refs=I,this.updater=r||S}function v(){}function h(e,t,r){this.props=e,this.context=t,this.refs=I,this.updater=r||S}m.prototype.isReactComponent={},m.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")},m.prototype.forceUpdate=function(e){this.updater.enqueueForceUpdate(this,e,"forceUpdate")},v.prototype=m.prototype;var b=h.prototype=new v;b.constructor=h,y(b,m.prototype),b.isPureReactComponent=!0;var D=Array.isArray,R=Object.prototype.hasOwnProperty,g={current:null},O={key:!0,ref:!0,__self:!0,__source:!0};function C(e,t,n){var o,s={},i=null,a=null;if(null!=t)for(o in void 0!==t.ref&&(a=t.ref),void 0!==t.key&&(i=""+t.key),t)R.call(t,o)&&!O.hasOwnProperty(o)&&(s[o]=t[o]);var c=arguments.length-2;if(1===c)s.children=n;else if(1<c){for(var u=Array(c),l=0;l<c;l++)u[l]=arguments[l+2];s.children=u}if(e&&e.defaultProps)for(o in c=e.defaultProps)void 0===s[o]&&(s[o]=c[o]);return{$$typeof:r,type:e,key:i,ref:a,props:s,_owner:g.current}}function U(e){return"object"==typeof e&&null!==e&&e.$$typeof===r}var w=/\/+/g;function T(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 E(e,t,o,s,i){var a=typeof e;"undefined"!==a&&"boolean"!==a||(e=null);var c=!1;if(null===e)c=!0;else switch(a){case"string":case"number":c=!0;break;case"object":switch(e.$$typeof){case r:case n:c=!0}}if(c)return i=i(c=e),e=""===s?"."+T(c,0):s,D(i)?(o="",null!=e&&(o=e.replace(w,"$&/")+"/"),E(i,t,o,"",function(e){return e})):null!=i&&(U(i)&&(i=function(e,t){return{$$typeof:r,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(w,"$&/")+"/")+e)),t.push(i)),1;if(c=0,s=""===s?".":s+":",D(e))for(var u=0;u<e.length;u++){var l=s+T(a=e[u],u);c+=E(a,t,o,l,i)}else if(l=function(e){return null===e||"object"!=typeof e?null:"function"==typeof(e=p&&e[p]||e["@@iterator"])?e:null}(e),"function"==typeof l)for(e=l.call(e),u=0;!(a=e.next()).done;)c+=E(a=a.value,t,o,l=s+T(a,u++),i);else if("object"===a)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 P(e,t,r){if(null==e)return e;var n=[],o=0;return E(e,n,"","",function(e){return t.call(r,e,o++)}),n}function _(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 x={current:null},j={transition:null},q={ReactCurrentDispatcher:x,ReactCurrentBatchConfig:j,ReactCurrentOwner:g};function k(){throw Error("act(...) is not supported in production builds of React.")}t.Children={map:P,forEach:function(e,t,r){P(e,function(){t.apply(this,arguments)},r)},count:function(e){var t=0;return P(e,function(){t++}),t},toArray:function(e){return P(e,function(e){return e})||[]},only:function(e){if(!U(e))throw Error("React.Children.only expected to receive a single React element child.");return e}},t.Component=m,t.Fragment=o,t.Profiler=i,t.PureComponent=h,t.StrictMode=s,t.Suspense=l,t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=q,t.act=k,t.cloneElement=function(e,t,n){if(null==e)throw Error("React.cloneElement(...): The argument must be a React element, but you passed "+e+".");var o=y({},e.props),s=e.key,i=e.ref,a=e._owner;if(null!=t){if(void 0!==t.ref&&(i=t.ref,a=g.current),void 0!==t.key&&(s=""+t.key),e.type&&e.type.defaultProps)var c=e.type.defaultProps;for(u in t)R.call(t,u)&&!O.hasOwnProperty(u)&&(o[u]=void 0===t[u]&&void 0!==c?c[u]:t[u])}var u=arguments.length-2;if(1===u)o.children=n;else if(1<u){c=Array(u);for(var l=0;l<u;l++)c[l]=arguments[l+2];o.children=c}return{$$typeof:r,type:e.type,key:s,ref:i,props:o,_owner:a}},t.createContext=function(e){return(e={$$typeof:c,_currentValue:e,_currentValue2:e,_threadCount:0,Provider:null,Consumer:null,_defaultValue:null,_globalName:null}).Provider={$$typeof:a,_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:u,render:e}},t.isValidElement=U,t.lazy=function(e){return{$$typeof:d,_payload:{_status:-1,_result:e},_init:_}},t.memo=function(e,t){return{$$typeof:f,type:e,compare:void 0===t?null:t}},t.startTransition=function(e){var t=j.transition;j.transition={};try{e()}finally{j.transition=t}},t.unstable_act=k,t.useCallback=function(e,t){return x.current.useCallback(e,t)},t.useContext=function(e){return x.current.useContext(e)},t.useDebugValue=function(){},t.useDeferredValue=function(e){return x.current.useDeferredValue(e)},t.useEffect=function(e,t){return x.current.useEffect(e,t)},t.useId=function(){return x.current.useId()},t.useImperativeHandle=function(e,t,r){return x.current.useImperativeHandle(e,t,r)},t.useInsertionEffect=function(e,t){return x.current.useInsertionEffect(e,t)},t.useLayoutEffect=function(e,t){return x.current.useLayoutEffect(e,t)},t.useMemo=function(e,t){return x.current.useMemo(e,t)},t.useReducer=function(e,t,r){return x.current.useReducer(e,t,r)},t.useRef=function(e){return x.current.useRef(e)},t.useState=function(e){return x.current.useState(e)},t.useSyncExternalStore=function(e,t,r){return x.current.useSyncExternalStore(e,t,r)},t.useTransition=function(){return x.current.useTransition()},t.version="18.3.1"},326:(e,t,r)=>{"use strict";e.exports=r(249)},404:e=>{"use strict";e.exports=n},459:e=>{"use strict";e.exports=i},545:e=>{"use strict";e.exports=t},585:(e,t,r)=>{"use strict";r.r(t),r.d(t,{default:()=>p});var n=r(326),o=r(598),s=r.n(o),i=r(55),a=r(669);const c=function({servicesManager:e,rtDisplaySet:t,viewportId:r,preHydrateCallbacks:n,hydrateRTDisplaySet:o}){return a.utils.promptHydrationDialog({servicesManager:e,viewportId:r,displaySet:t,preHydrateCallbacks:n,hydrateCallback:o,type:"RTSTRUCT"})};const u=function(e,t,r){const n=t.getCustomization("cornerstone.overlayViewportTools");return e.createToolGroupAndAddTools(r,n)};var l=r(459);function f(){return f=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)({}).hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},f.apply(null,arguments)}function d(e){const{servicesManager:t,commandsManager:r}=(0,l.useSystem)(),{children:o,displaySets:s,viewportOptions:d}=e,{displaySetService:p,toolGroupService:S,segmentationService:y,customizationService:I}=t.services,m=d.viewportId,v=`RTToolGroup-${m}`;if(s.length>1)throw new Error("RT viewport should only have a single display set");const h=I.getCustomization("ui.loadingIndicatorTotalPercent"),b=s[0],[{viewports:D,activeViewportId:R},g]=(0,i.useViewportGrid)(),{setPositionPresentation:O}=(0,a.usePositionPresentationStore)(),[C,U]=(0,n.useState)(!b.isLoaded),[w,T]=(0,n.useState)({percentComplete:null,totalSegments:null}),E=(0,n.useRef)(null),P=b.referencedDisplaySetInstanceUID;if(!P){const e=I.getCustomization("missingReferenceDisplaySetHandler"),{handled:t}=e();if(t)return}const _=p.getDisplaySetByUID(P),x=function(e){const t=e.images[0],r={PatientID:t.PatientID,PatientName:t.PatientName,PatientSex:t.PatientSex,PatientAge:t.PatientAge,SliceThickness:t.SliceThickness,StudyDate:t.StudyDate,SeriesDescription:t.SeriesDescription,SeriesInstanceUID:t.SeriesInstanceUID,SeriesNumber:t.SeriesNumber,ManufacturerModelName:t.ManufacturerModelName,SpacingBetweenSlices:t.SpacingBetweenSlices};return r}(_);E.current={displaySet:_,metadata:x},(0,n.useEffect)(()=>{C||m===R&&c({servicesManager:t,viewportId:m,rtDisplaySet:b,hydrateRTDisplaySet:async()=>r.runCommand("hydrateSecondaryDisplaySet",{displaySet:b,viewportId:m})})},[t,m,b,C,r,R]),(0,n.useEffect)(()=>{const{unsubscribe:e}=y.subscribe(y.EVENTS.SEGMENTATION_LOADING_COMPLETE,e=>{if(e.rtDisplaySet.displaySetInstanceUID===b.displaySetInstanceUID&&U(!1),b?.firstSegmentedSliceImageId&&d?.presentationIds){const{firstSegmentedSliceImageId:e}=b,{presentationIds:t}=d;O(t.positionPresentationId,{viewportType:"stack",viewReference:{referencedImageId:e},viewPresentation:{}})}});return()=>{e()}},[b]),(0,n.useEffect)(()=>{const e=y.subscribe(y.EVENTS.SEGMENT_LOADING_COMPLETE,({percentComplete:e,numSegments:t})=>{T({percentComplete:e,totalSegments:t})}),t=p.subscribe(p.EVENTS.DISPLAY_SETS_REMOVED,({displaySetInstanceUIDs:e})=>{const t=D.get(R);e.includes(t.displaySetInstanceUID)&&g.setDisplaySetsForViewport({viewportId:R,displaySetInstanceUIDs:[]})});return()=>{e.unsubscribe(),t.unsubscribe()}},[b,p,D,R,g]),(0,n.useEffect)(()=>{let e=S.getToolGroup(v);if(!e)return e=u(S,I,v),()=>{y.removeSegmentationRepresentations(m),E.current=null,S.destroyToolGroup(v)}},[]);const j=(0,n.useCallback)(()=>{const{displaySet:t}=E.current;return n.createElement(a.OHIFCornerstoneViewport,f({},e,{displaySets:[t,b],viewportOptions:{viewportType:d.viewportType,toolGroupId:v,orientation:d.orientation,viewportId:d.viewportId,presentationIds:d.presentationIds},onElementEnabled:t=>{e.onElementEnabled?.(t)}}))},[m,b,v]);let q=null;return E.current&&_.displaySetInstanceUID===E.current.displaySet.displaySetInstanceUID?(o&&o.length&&(q=o.map((e,t)=>e&&n.cloneElement(e,{viewportId:m,key:t}))),n.createElement(n.Fragment,null,n.createElement("div",{className:"relative flex h-full w-full flex-row overflow-hidden"},C&&n.createElement(h,{className:"h-full w-full",totalNumbers:w.totalSegments,percentComplete:w.percentComplete,loadingText:"Loading RTSTRUCT..."}),j(),q))):null}d.propTypes={displaySets:s().arrayOf(s().object),viewportId:s().string.isRequired,dataSource:s().object,children:s().node};const p=d},598:(e,t,r)=>{e.exports=r(856)()},669:e=>{"use strict";e.exports=s},856:(e,t,r)=>{"use strict";var n=r(183);function o(){}function s(){}s.resetWarningCache=o,e.exports=function(){function e(e,t,r,o,s,i){if(i!==n){var a=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 a.name="Invariant Violation",a}}function t(){return e}e.isRequired=e;var r={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:s,resetWarningCache:o};return r.PropTypes=r,r}}},l={};function f(e){var t=l[e];if(void 0!==t)return t.exports;var r=l[e]={exports:{}};return u[e](r,r.exports,f),r.exports}f.m=u,a=[],f.O=(e,t,r,n)=>{if(!t){var o=1/0;for(u=0;u<a.length;u++){for(var[t,r,n]=a[u],s=!0,i=0;i<t.length;i++)(!1&n||o>=n)&&Object.keys(f.O).every(e=>f.O[e](t[i]))?t.splice(i--,1):(s=!1,n<o&&(o=n));if(s){a.splice(u--,1);var c=r();void 0!==c&&(e=c)}}return e}n=n||0;for(var u=a.length;u>0&&a[u-1][2]>n;u--)a[u]=a[u-1];a[u]=[t,r,n]},f.F={},f.E=e=>{Object.keys(f.F).map(t=>{f.F[t](e)})},f.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return f.d(t,{a:t}),t},f.d=(e,t)=>{for(var r in t)f.o(t,r)&&!f.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},f.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),f.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},c={524:0},f.F.j=e=>{if(!f.o(c,e)||void 0===c[e]){c[e]=null;var t=document.createElement("link");t.charset="utf-8",f.nc&&t.setAttribute("nonce",f.nc),t.rel="prefetch",t.as="script",t.href=f.p+f.u(e),document.head.appendChild(t)}},f.O.j=e=>0===c[e],f.O(0,[524],()=>{f.E(524)},5);var d={};return(()=>{"use strict";f.r(d),f.d(d,{default:()=>C});const e=JSON.parse('{"UU":"@ohif/extension-cornerstone-dicom-rt"}').UU,t=`${e}.sopClassHandlerModule.dicom-rt`;var r=f(326),n=f(2),o=f(545),s=f.n(o),i=f(111),a=f.n(i);const{DicomMessage:c,DicomMetaDictionary:u}=a().data,l=a().data.Colors.dicomlab2RGB;async function p(e,t,r){const n=e.getModuleEntry("@ohif/extension-cornerstone.utilityModule.common"),o=e.getActiveDataSource()[0],{bulkDataURI:s}=o.getConfig?.()||{},{dicomLoaderService:i}=n.exports;t.isLoaded=!0;let a=t.instance;if(s&&s.enabled)await async function(e,t){if(!e||!e.ROIContourSequence)return Promise.reject("Invalid instance object or ROIContourSequence");const r=new Map;for(const n of e.ROIContourSequence){const o=n.ReferencedROINumber;if(n&&n.ContourSequence)for(const s of n.ContourSequence){if(!s||!s.ContourData)return Promise.reject("Invalid Contour or ContourData");const n=s.ContourData;if(Array.isArray(n))r.has(o)?r.get(o).push(Promise.resolve(n)):r.set(o,[Promise.resolve(n)]);else{if(!n||!n.BulkDataURI)return Promise.reject(`Invalid ContourData: ${n}`);{const s=n.BulkDataURI;if(!t||!t.retrieve||!t.retrieve.bulkDataURI)return Promise.reject("Invalid datasource object or retrieve function");const i=t.retrieve.bulkDataURI({BulkDataURI:s,StudyInstanceUID:e.StudyInstanceUID,SeriesInstanceUID:e.SeriesInstanceUID,SOPInstanceUID:e.SOPInstanceUID});r.has(o)?r.get(o).push(i):r.set(o,[i])}}}else r.set(o,[Promise.resolve([])])}const n=new Map;for(const[e,t]of r.entries())n.set(e,await Promise.allSettled(t));e.ROIContourSequence.forEach(e=>{try{const t=e.ReferencedROINumber,r=n.get(t);e.ContourSequence&&e.ContourSequence.forEach((e,t)=>{const n=r[t];if("fulfilled"===n.status)if(Array.isArray(n.value)&&n.value.every(Number.isFinite))e.ContourData=n.value;else{const t=new Uint8Array(n.value),r=(new TextDecoder).decode(t);"string"==typeof r&&r.includes("\\")?e.ContourData=r.split("\\").map(parseFloat):e.ContourData=[]}else console.error(n.reason)})}catch(e){console.error(e)}})}(a,o);else{const e=await i.findDicomDataPromise(t,null,r),n=c.readFile(e),o=u.naturalizeDataset(n.dict);o._meta=u.namifyDataset(n.meta),a=o}const{StructureSetROISequence:l,ROIContourSequence:f,RTROIObservationsSequence:d}=a,p={StructureSetLabel:a.StructureSetLabel,SeriesInstanceUID:a.SeriesInstanceUID,ROIContours:[],visible:!0,ReferencedSOPInstanceUIDsSet:new Set};for(let e=0;e<f.length;e++){const t=f[e],{ContourSequence:r}=t;if(!r)continue;const n=!1,o=y(r),s=[];for(let e=0;e<o.length;e++){const{ContourData:t,NumberOfContourPoints:r,ContourGeometricType:n,ContourImageSequence:i}=o[e];let a=!1;const c=[];for(let e=0;e<3*r;e+=3)c.push({x:t[e],y:t[e+1],z:t[e+2]});switch(n){case"CLOSED_PLANAR":case"OPEN_PLANAR":case"POINT":a=!0;break;default:continue}s.push({numberOfPoints:r,points:c,type:n,isSupported:a}),i?.ReferencedSOPInstanceUID&&p.ReferencedSOPInstanceUIDsSet.add(i?.ReferencedSOPInstanceUID)}S(p,l,d,t,s,n)}return p}function S(e,t,r,n,o,s){const i=t.find(e=>e.ROINumber===n.ReferencedROINumber),a={ROINumber:i.ROINumber,ROIName:i.ROIName,ROIGenerationAlgorithm:i.ROIGenerationAlgorithm,ROIDescription:i.ROIDescription,isSupported:s,contourPoints:o,visible:!0};!function(e,t){let{ROIDisplayColor:r,RecommendedDisplayCIELabValue:n}=e;!r&&n&&(r=l(n));r&&(t.colorArray=[...r])}(n,a),r&&function(e,t,r){const n=t.find(e=>e.ReferencedROINumber===r);if(n){const{ObservationNumber:t,ROIObservationDescription:r,RTROIInterpretedType:o,ROIInterpreter:s}=n;e.RTROIObservations={ObservationNumber:t,ROIObservationDescription:r,RTROIInterpretedType:o,ROIInterpreter:s}}}(a,r,n.ReferencedROINumber),e.ROIContours.push(a)}function y(e){return Array.isArray(e)?e:[e]}const I=["1.2.840.10008.5.1.4.1.1.481.3"],m={};function v(e,r,o){const i=e[0],{StudyInstanceUID:a,SeriesInstanceUID:c,SOPInstanceUID:u,SeriesDescription:l,SeriesNumber:f,SeriesDate:d,SOPClassUID:S,wadoRoot:y,wadoUri:v,wadoUriRoot:h}=i,b={Modality:"RTSTRUCT",loading:!1,isReconstructable:!1,displaySetInstanceUID:n.utils.guid(),SeriesDescription:l,SeriesNumber:f,SeriesDate:d,SOPInstanceUID:u,SeriesInstanceUID:c,StudyInstanceUID:a,SOPClassHandlerId:t,SOPClassUID:S,referencedImages:null,referencedSeriesInstanceUID:null,referencedDisplaySetInstanceUID:null,isDerivedDisplaySet:!0,isLoaded:!1,isHydrated:!1,structureSet:null,sopClassUids:I,instance:i,wadoRoot:y,wadoUriRoot:h,wadoUri:v,isOverlayDisplaySet:!0,label:l||`${s().t("Series")} ${f} - ${s().t("RTSTRUCT")}`};let D=i.ReferencedSeriesSequence;if(i.ReferencedFrameOfReferenceSequence&&!i.ReferencedSeriesSequence&&(i.ReferencedSeriesSequence=function(e){const t=[];return e.forEach(e=>{const{RTReferencedStudySequence:r}=e;r.forEach(e=>{const{RTReferencedSeriesSequence:r}=e;r.forEach(e=>{const r=[],{ContourImageSequence:n,SeriesInstanceUID:o}=e;n.forEach(e=>{r.push({ReferencedSOPInstanceUID:e.ReferencedSOPInstanceUID,ReferencedSOPClassUID:e.ReferencedSOPClassUID})});const s={SeriesInstanceUID:o,ReferencedInstanceSequence:r};t.push(s)})})}),t}(i.ReferencedFrameOfReferenceSequence),D=i.ReferencedSeriesSequence),!D)throw new Error("ReferencedSeriesSequence is missing for the RTSTRUCT");const R=D[0];b.referencedImages=i.ReferencedSeriesSequence.ReferencedInstanceSequence,b.referencedSeriesInstanceUID=R.SeriesInstanceUID;const{displaySetService:g}=r.services,O=g.getDisplaySetsForSeries(b.referencedSeriesInstanceUID);if(O&&0!==O.length){const e=O[0];b.referencedDisplaySetInstanceUID=e.displaySetInstanceUID,b.isReconstructable=e.isReconstructable}else{const{unsubscribe:e}=g.subscribe(g.EVENTS.DISPLAY_SETS_ADDED,({displaySetsAdded:t})=>{const r=t[0];r.SeriesInstanceUID===b.referencedSeriesInstanceUID&&(b.referencedDisplaySetInstanceUID=r.displaySetInstanceUID,b.isReconstructable=r.isReconstructable,e())})}return b.load=({headers:e,createSegmentation:t=!0})=>function(e,t,r,n,o=!0){const{SOPInstanceUID:s}=e,{segmentationService:i}=t.services;(e.loading||e.isLoaded)&&m[s],0;return e.loading=!0,m[s]=new Promise(async(t,s)=>{if(!e.structureSet){const t=await p(r,e,n);e.structureSet=t}o?i.createSegmentationForRTDisplaySet(e).then(()=>{e.loading=!1,t()}).catch(t=>{e.loading=!1,s(t)}):(e.loading=!1,t())}),m[s]}(b,r,o,e,t),[b]}const h=function(e){const{servicesManager:t,extensionManager:r}=e;return[{name:"dicom-rt",sopClassUids:I,getDisplaySetsFromSeries:e=>v(e,t,r)}]};var b=f(404);const D=({commandsManager:e,servicesManager:t})=>{const r=t.services,{displaySetService:n,viewportGridService:o}=r,s={hydrateRTSDisplaySet:({displaySet:t,viewportId:r})=>{if("RTSTRUCT"!==t.Modality)throw new Error("Display set is not an RTSTRUCT");const s=n.getDisplaySetByUID(t.referencedDisplaySetInstanceUID);e.runCommand("updateStoredSegmentationPresentation",{displaySet:t,type:b.SegmentationRepresentations.Contour}),e.runCommand("updateStoredPositionPresentation",{viewportId:r,displaySetInstanceUIDs:[s.displaySetInstanceUID]}),o.setDisplaySetsForViewport({viewportId:r,displaySetInstanceUIDs:[s.displaySetInstanceUID]})}};return{actions:s,definitions:{hydrateRTSDisplaySet:{commandFn:s.hydrateRTSDisplaySet,storeContexts:[],options:{}}},defaultContext:"cornerstone-dicom-rt"}};function R(){return R=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)({}).hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},R.apply(null,arguments)}const g=r.lazy(()=>Promise.resolve().then(f.bind(f,585))),O=e=>r.createElement(r.Suspense,{fallback:r.createElement("div",null,"Loading...")},r.createElement(g,e)),C={id:e,getCommandsModule:D,getViewportModule:({servicesManager:e,extensionManager:t,commandsManager:n})=>[{name:"dicom-rt",component:o=>r.createElement(O,R({servicesManager:e,extensionManager:t,commandsManager:n},o))}],getSopClassHandlerModule:h}})(),d=f.O(d)})());
|
|
2
|
+
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("@ohif/core"),require("@ohif/i18n"),require("dcmjs"),require("@cornerstonejs/tools/enums"),require("@ohif/ui-next"),require("@ohif/extension-cornerstone"),require("@ohif/core/src")):"function"==typeof define&&define.amd?define(["@ohif/core","@ohif/i18n","dcmjs","@cornerstonejs/tools/enums","@ohif/ui-next","@ohif/extension-cornerstone","@ohif/core/src"],t):"object"==typeof exports?exports["ohif-extension-cornerstone-dicom-rt"]=t(require("@ohif/core"),require("@ohif/i18n"),require("dcmjs"),require("@cornerstonejs/tools/enums"),require("@ohif/ui-next"),require("@ohif/extension-cornerstone"),require("@ohif/core/src")):e["ohif-extension-cornerstone-dicom-rt"]=t(e["@ohif/core"],e["@ohif/i18n"],e.dcmjs,e["@cornerstonejs/tools/enums"],e["@ohif/ui-next"],e["@ohif/extension-cornerstone"],e["@ohif/core/src"])}(globalThis,(e,t,r,n,o,s,a)=>(()=>{var i,c,u={585:(e,t,r)=>{"use strict";r.r(t),r.d(t,{default:()=>p});var n=r(326),o=r(598),s=r.n(o),a=r(55),i=r(669);const c=function({servicesManager:e,rtDisplaySet:t,viewportId:r,preHydrateCallbacks:n,hydrateRTDisplaySet:o}){return i.utils.promptHydrationDialog({servicesManager:e,viewportId:r,displaySet:t,preHydrateCallbacks:n,hydrateCallback:o,type:"RTSTRUCT"})};const u=function(e,t,r){const n=t.getCustomization("cornerstone.overlayViewportTools");return e.createToolGroupAndAddTools(r,n)};var l=r(459);function f(){return f=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)({}).hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},f.apply(null,arguments)}function d(e){const{servicesManager:t,commandsManager:r}=(0,l.useSystem)(),{children:o,displaySets:s,viewportOptions:d}=e,{displaySetService:p,toolGroupService:S,segmentationService:y,customizationService:I}=t.services,m=d.viewportId,v=`RTToolGroup-${m}`;if(s.length>1)throw new Error("RT viewport should only have a single display set");const D=I.getCustomization("ui.loadingIndicatorTotalPercent"),h=s[0],[{viewports:b,activeViewportId:R},g]=(0,a.useViewportGrid)(),{setPositionPresentation:O}=(0,i.usePositionPresentationStore)(),[C,U]=(0,n.useState)(!h.isLoaded),[w,E]=(0,n.useState)({percentComplete:null,totalSegments:null}),T=(0,n.useRef)(null),P=h.referencedDisplaySetInstanceUID;if(!P){const e=I.getCustomization("missingReferenceDisplaySetHandler"),{handled:t}=e();if(t)return}const _=p.getDisplaySetByUID(P),x=function(e){const t=e.images[0],r={PatientID:t.PatientID,PatientName:t.PatientName,PatientSex:t.PatientSex,PatientAge:t.PatientAge,SliceThickness:t.SliceThickness,StudyDate:t.StudyDate,SeriesDescription:t.SeriesDescription,SeriesInstanceUID:t.SeriesInstanceUID,SeriesNumber:t.SeriesNumber,ManufacturerModelName:t.ManufacturerModelName,SpacingBetweenSlices:t.SpacingBetweenSlices};return r}(_);T.current={displaySet:_,metadata:x},(0,n.useEffect)(()=>{C||m===R&&c({servicesManager:t,viewportId:m,rtDisplaySet:h,hydrateRTDisplaySet:async()=>r.runCommand("hydrateSecondaryDisplaySet",{displaySet:h,viewportId:m})})},[t,m,h,C,r,R]),(0,n.useEffect)(()=>{const{unsubscribe:e}=y.subscribe(y.EVENTS.SEGMENTATION_LOADING_COMPLETE,e=>{if(e.rtDisplaySet.displaySetInstanceUID===h.displaySetInstanceUID&&U(!1),h?.firstSegmentedSliceImageId&&d?.presentationIds){const{firstSegmentedSliceImageId:e}=h,{presentationIds:t}=d;O(t.positionPresentationId,{viewportType:"stack",viewReference:{referencedImageId:e},viewPresentation:{}})}});return()=>{e()}},[h]),(0,n.useEffect)(()=>{const e=y.subscribe(y.EVENTS.SEGMENT_LOADING_COMPLETE,({percentComplete:e,numSegments:t})=>{E({percentComplete:e,totalSegments:t})}),t=p.subscribe(p.EVENTS.DISPLAY_SETS_REMOVED,({displaySetInstanceUIDs:e})=>{const t=b.get(R);e.includes(t.displaySetInstanceUID)&&g.setDisplaySetsForViewport({viewportId:R,displaySetInstanceUIDs:[]})});return()=>{e.unsubscribe(),t.unsubscribe()}},[h,p,b,R,g]),(0,n.useEffect)(()=>{let e=S.getToolGroup(v);if(!e)return e=u(S,I,v),()=>{y.removeSegmentationRepresentations(m),T.current=null,S.destroyToolGroup(v)}},[]);const N=(0,n.useCallback)(()=>{const{displaySet:t}=T.current;return n.createElement(i.OHIFCornerstoneViewport,f({},e,{displaySets:[t,h],viewportOptions:{viewportType:d.viewportType,toolGroupId:v,orientation:d.orientation,viewportId:d.viewportId,presentationIds:d.presentationIds},onElementEnabled:t=>{e.onElementEnabled?.(t)}}))},[m,h,v]);let M=null;return T.current&&_.displaySetInstanceUID===T.current.displaySet.displaySetInstanceUID?(o&&o.length&&(M=o.map((e,t)=>e&&n.cloneElement(e,{viewportId:m,key:t}))),n.createElement(n.Fragment,null,n.createElement("div",{className:"relative flex h-full w-full flex-row overflow-hidden"},C&&n.createElement(D,{className:"h-full w-full",totalNumbers:w.totalSegments,percentComplete:w.percentComplete,loadingText:"Loading RTSTRUCT..."}),N(),M))):null}d.propTypes={displaySets:s().arrayOf(s().object),viewportId:s().string.isRequired,dataSource:s().object,children:s().node};const p=d},856:(e,t,r)=>{"use strict";var n=r(183);function o(){}function s(){}s.resetWarningCache=o,e.exports=function(){function e(e,t,r,o,s,a){if(a!==n){var i=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 i.name="Invariant Violation",i}}function t(){return e}e.isRequired=e;var r={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:s,resetWarningCache:o};return r.PropTypes=r,r}},598:(e,t,r)=>{e.exports=r(856)()},183:e=>{"use strict";e.exports="SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED"},249:(e,t)=>{"use strict";var r=Symbol.for("react.element"),n=Symbol.for("react.portal"),o=Symbol.for("react.fragment"),s=Symbol.for("react.strict_mode"),a=Symbol.for("react.profiler"),i=Symbol.for("react.provider"),c=Symbol.for("react.context"),u=Symbol.for("react.forward_ref"),l=Symbol.for("react.suspense"),f=Symbol.for("react.memo"),d=Symbol.for("react.lazy"),p=Symbol.iterator;var S={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},y=Object.assign,I={};function m(e,t,r){this.props=e,this.context=t,this.refs=I,this.updater=r||S}function v(){}function D(e,t,r){this.props=e,this.context=t,this.refs=I,this.updater=r||S}m.prototype.isReactComponent={},m.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")},m.prototype.forceUpdate=function(e){this.updater.enqueueForceUpdate(this,e,"forceUpdate")},v.prototype=m.prototype;var h=D.prototype=new v;h.constructor=D,y(h,m.prototype),h.isPureReactComponent=!0;var b=Array.isArray,R=Object.prototype.hasOwnProperty,g={current:null},O={key:!0,ref:!0,__self:!0,__source:!0};function C(e,t,n){var o,s={},a=null,i=null;if(null!=t)for(o in void 0!==t.ref&&(i=t.ref),void 0!==t.key&&(a=""+t.key),t)R.call(t,o)&&!O.hasOwnProperty(o)&&(s[o]=t[o]);var c=arguments.length-2;if(1===c)s.children=n;else if(1<c){for(var u=Array(c),l=0;l<c;l++)u[l]=arguments[l+2];s.children=u}if(e&&e.defaultProps)for(o in c=e.defaultProps)void 0===s[o]&&(s[o]=c[o]);return{$$typeof:r,type:e,key:a,ref:i,props:s,_owner:g.current}}function U(e){return"object"==typeof e&&null!==e&&e.$$typeof===r}var w=/\/+/g;function E(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 T(e,t,o,s,a){var i=typeof e;"undefined"!==i&&"boolean"!==i||(e=null);var c=!1;if(null===e)c=!0;else switch(i){case"string":case"number":c=!0;break;case"object":switch(e.$$typeof){case r:case n:c=!0}}if(c)return a=a(c=e),e=""===s?"."+E(c,0):s,b(a)?(o="",null!=e&&(o=e.replace(w,"$&/")+"/"),T(a,t,o,"",function(e){return e})):null!=a&&(U(a)&&(a=function(e,t){return{$$typeof:r,type:e.type,key:t,ref:e.ref,props:e.props,_owner:e._owner}}(a,o+(!a.key||c&&c.key===a.key?"":(""+a.key).replace(w,"$&/")+"/")+e)),t.push(a)),1;if(c=0,s=""===s?".":s+":",b(e))for(var u=0;u<e.length;u++){var l=s+E(i=e[u],u);c+=T(i,t,o,l,a)}else if(l=function(e){return null===e||"object"!=typeof e?null:"function"==typeof(e=p&&e[p]||e["@@iterator"])?e:null}(e),"function"==typeof l)for(e=l.call(e),u=0;!(i=e.next()).done;)c+=T(i=i.value,t,o,l=s+E(i,u++),a);else if("object"===i)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 P(e,t,r){if(null==e)return e;var n=[],o=0;return T(e,n,"","",function(e){return t.call(r,e,o++)}),n}function _(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 x={current:null},N={transition:null},M={ReactCurrentDispatcher:x,ReactCurrentBatchConfig:N,ReactCurrentOwner:g};function j(){throw Error("act(...) is not supported in production builds of React.")}t.Children={map:P,forEach:function(e,t,r){P(e,function(){t.apply(this,arguments)},r)},count:function(e){var t=0;return P(e,function(){t++}),t},toArray:function(e){return P(e,function(e){return e})||[]},only:function(e){if(!U(e))throw Error("React.Children.only expected to receive a single React element child.");return e}},t.Component=m,t.Fragment=o,t.Profiler=a,t.PureComponent=D,t.StrictMode=s,t.Suspense=l,t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=M,t.act=j,t.cloneElement=function(e,t,n){if(null==e)throw Error("React.cloneElement(...): The argument must be a React element, but you passed "+e+".");var o=y({},e.props),s=e.key,a=e.ref,i=e._owner;if(null!=t){if(void 0!==t.ref&&(a=t.ref,i=g.current),void 0!==t.key&&(s=""+t.key),e.type&&e.type.defaultProps)var c=e.type.defaultProps;for(u in t)R.call(t,u)&&!O.hasOwnProperty(u)&&(o[u]=void 0===t[u]&&void 0!==c?c[u]:t[u])}var u=arguments.length-2;if(1===u)o.children=n;else if(1<u){c=Array(u);for(var l=0;l<u;l++)c[l]=arguments[l+2];o.children=c}return{$$typeof:r,type:e.type,key:s,ref:a,props:o,_owner:i}},t.createContext=function(e){return(e={$$typeof:c,_currentValue:e,_currentValue2:e,_threadCount:0,Provider:null,Consumer:null,_defaultValue:null,_globalName:null}).Provider={$$typeof:i,_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:u,render:e}},t.isValidElement=U,t.lazy=function(e){return{$$typeof:d,_payload:{_status:-1,_result:e},_init:_}},t.memo=function(e,t){return{$$typeof:f,type:e,compare:void 0===t?null:t}},t.startTransition=function(e){var t=N.transition;N.transition={};try{e()}finally{N.transition=t}},t.unstable_act=j,t.useCallback=function(e,t){return x.current.useCallback(e,t)},t.useContext=function(e){return x.current.useContext(e)},t.useDebugValue=function(){},t.useDeferredValue=function(e){return x.current.useDeferredValue(e)},t.useEffect=function(e,t){return x.current.useEffect(e,t)},t.useId=function(){return x.current.useId()},t.useImperativeHandle=function(e,t,r){return x.current.useImperativeHandle(e,t,r)},t.useInsertionEffect=function(e,t){return x.current.useInsertionEffect(e,t)},t.useLayoutEffect=function(e,t){return x.current.useLayoutEffect(e,t)},t.useMemo=function(e,t){return x.current.useMemo(e,t)},t.useReducer=function(e,t,r){return x.current.useReducer(e,t,r)},t.useRef=function(e){return x.current.useRef(e)},t.useState=function(e){return x.current.useState(e)},t.useSyncExternalStore=function(e,t,r){return x.current.useSyncExternalStore(e,t,r)},t.useTransition=function(){return x.current.useTransition()},t.version="18.3.1"},326:(e,t,r)=>{"use strict";e.exports=r(249)},404:e=>{"use strict";e.exports=n},2:t=>{"use strict";t.exports=e},459:e=>{"use strict";e.exports=a},669:e=>{"use strict";e.exports=s},545:e=>{"use strict";e.exports=t},55:e=>{"use strict";e.exports=o},111:e=>{"use strict";e.exports=r}},l={};function f(e){var t=l[e];if(void 0!==t)return t.exports;var r=l[e]={exports:{}};return u[e](r,r.exports,f),r.exports}f.m=u,i=[],f.O=(e,t,r,n)=>{if(!t){var o=1/0;for(u=0;u<i.length;u++){for(var[t,r,n]=i[u],s=!0,a=0;a<t.length;a++)(!1&n||o>=n)&&Object.keys(f.O).every(e=>f.O[e](t[a]))?t.splice(a--,1):(s=!1,n<o&&(o=n));if(s){i.splice(u--,1);var c=r();void 0!==c&&(e=c)}}return e}n=n||0;for(var u=i.length;u>0&&i[u-1][2]>n;u--)i[u]=i[u-1];i[u]=[t,r,n]},f.F={},f.E=e=>{Object.keys(f.F).map(t=>{f.F[t](e)})},f.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return f.d(t,{a:t}),t},f.d=(e,t)=>{for(var r in t)f.o(t,r)&&!f.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},f.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),f.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},c={524:0},f.F.j=e=>{if(!f.o(c,e)||void 0===c[e]){c[e]=null;var t=document.createElement("link");f.nc&&t.setAttribute("nonce",f.nc),t.rel="prefetch",t.as="script",t.href=f.p+f.u(e),document.head.appendChild(t)}},f.O.j=e=>0===c[e],f.O(0,[524],()=>{f.E(524)},5);var d={};return(()=>{"use strict";f.r(d),f.d(d,{default:()=>E});const e=JSON.parse('{"UU":"@ohif/extension-cornerstone-dicom-rt"}').UU,t=`${e}.sopClassHandlerModule.dicom-rt`;var r=f(326),n=f(2),o=f(545),s=f.n(o),a=f(111),i=f.n(a);const{DicomMessage:c,DicomMetaDictionary:u}=i().data,l=i().data.Colors.dicomlab2RGB;const p=async({extensionManager:e,rtStructDisplaySet:t,headers:r})=>{const n=e.getModuleEntry("@ohif/extension-cornerstone.utilityModule.common"),{dicomLoaderService:o}=n.exports,s=await o.findDicomDataPromise(t,null,r),a=c.readFile(s),i=u.naturalizeDataset(a.dict);return i._meta=u.namifyDataset(a.meta),i};async function S(e,t,r){const n=e.getActiveDataSource()[0],{bulkDataURI:o}=n.getConfig?.()||{};t.isLoaded=!0;let s=t.instance;s=o&&o.enabled?await async function({instance:e,dataSource:t,extensionManager:r,rtStructDisplaySet:n,headers:o}){let s=e;if(!(s&&s.ROIContourSequence||(s=await p({extensionManager:r,rtStructDisplaySet:n,headers:o}),s&&s.ROIContourSequence)))return Promise.reject("Invalid instance object or ROIContourSequence");const a=new Map;for(const e of s.ROIContourSequence){const r=e.ReferencedROINumber;if(e&&e.ContourSequence)for(const n of e.ContourSequence){if(!n||!n.ContourData)return Promise.reject("Invalid Contour or ContourData");const e=n.ContourData;if(Array.isArray(e))a.has(r)?a.get(r).push(Promise.resolve(e)):a.set(r,[Promise.resolve(e)]);else{if(!e||!e.BulkDataURI)return Promise.reject(`Invalid ContourData: ${e}`);{const n=e.BulkDataURI;if(!t||!t.retrieve||!t.retrieve.bulkDataURI)return Promise.reject("Invalid dataSource object or retrieve function");const o=t.retrieve.bulkDataURI({BulkDataURI:n,StudyInstanceUID:s.StudyInstanceUID,SeriesInstanceUID:s.SeriesInstanceUID,SOPInstanceUID:s.SOPInstanceUID});a.has(r)?a.get(r).push(o):a.set(r,[o])}}}else a.set(r,[Promise.resolve([])])}const i=new Map;for(const[e,t]of a.entries())i.set(e,await Promise.allSettled(t));return s.ROIContourSequence.forEach(e=>{try{const t=e.ReferencedROINumber,r=i.get(t);e.ContourSequence&&e.ContourSequence.forEach((e,t)=>{const n=r[t];if("fulfilled"===n.status)if(Array.isArray(n.value)&&n.value.every(Number.isFinite))e.ContourData=n.value;else{const t=new Uint8Array(n.value),r=(new TextDecoder).decode(t);"string"==typeof r&&r.includes("\\")?e.ContourData=r.split("\\").map(parseFloat):e.ContourData=[]}else console.error(n.reason)})}catch(e){console.error(e)}}),s}({instance:s,dataSource:n,extensionManager:e,rtStructDisplaySet:t,headers:r}):await p({extensionManager:e,rtStructDisplaySet:t,headers:r});const{StructureSetROISequence:a,ROIContourSequence:i,RTROIObservationsSequence:c}=s,u={StructureSetLabel:s.StructureSetLabel,SeriesInstanceUID:s.SeriesInstanceUID,ROIContours:[],visible:!0,ReferencedSOPInstanceUIDsSet:new Set};for(let e=0;e<i.length;e++){const t=i[e],{ContourSequence:r}=t;if(!r)continue;const n=I(r),o=[];for(const e of n){const{ContourData:t,NumberOfContourPoints:r,ContourGeometricType:n,ContourImageSequence:s}=e,a=[];for(let e=0;e<3*r;e+=3)a.push({x:t[e],y:t[e+1],z:t[e+2]});const i=new Map([["CLOSED_PLANAR",!1],["OPEN_NONPLANAR",!1],["OPEN_PLANAR",!1],["POINT",!0]]);o.push({numberOfPoints:r,points:a,type:n,isSupported:i.get(n)??!1}),s?.ReferencedSOPInstanceUID&&u.ReferencedSOPInstanceUIDsSet.add(s?.ReferencedSOPInstanceUID)}y(u,a,c,t,o)}return u}function y(e,t,r,n,o){const s=t.find(e=>e.ROINumber===n.ReferencedROINumber),a={ROINumber:s.ROINumber,ROIName:s.ROIName,ROIGenerationAlgorithm:s.ROIGenerationAlgorithm,ROIDescription:s.ROIDescription,contourPoints:o,visible:!0,colorArray:[]};!function(e,t){let{ROIDisplayColor:r,RecommendedDisplayCIELabValue:n}=e;!r&&n&&(r=l(n));r&&(t.colorArray=[...r])}(n,a),r&&function(e,t,r){const n=t.find(e=>e.ReferencedROINumber===r);if(n){const{ObservationNumber:t,ROIObservationDescription:r,RTROIInterpretedType:o,ROIInterpreter:s}=n;e.RTROIObservations={ObservationNumber:t,ROIObservationDescription:r,RTROIInterpretedType:o,ROIInterpreter:s}}}(a,r,n.ReferencedROINumber),e.ROIContours.push(a)}function I(e){return Array.isArray(e)?e:[e]}const{sopClassDictionary:m}=n.utils,v=[m.RTStructureSetStorage],D=new Set,h={};function b(e,r,o){const a=e[0],{StudyInstanceUID:i,SeriesInstanceUID:c,SOPInstanceUID:u,SeriesDescription:l,SeriesNumber:f,SeriesDate:d,SOPClassUID:p,wadoRoot:y,wadoUri:I,wadoUriRoot:m}=a,b={Modality:"RTSTRUCT",loading:!1,isReconstructable:!1,displaySetInstanceUID:n.utils.guid(),SeriesDescription:l,SeriesNumber:f,SeriesDate:d,SOPInstanceUID:u,SeriesInstanceUID:c,StudyInstanceUID:i,SOPClassHandlerId:t,SOPClassUID:p,referencedImages:null,referencedSeriesInstanceUID:null,referencedDisplaySetInstanceUID:null,isDerivedDisplaySet:!0,isLoaded:!1,isHydrated:!1,structureSet:null,sopClassUids:v,instance:a,wadoRoot:y,wadoUriRoot:m,wadoUri:I,isOverlayDisplaySet:!0,label:l||`${s().t("Series")} ${f} - ${s().t("RTSTRUCT")}`};let R=a.ReferencedSeriesSequence;if(a.ReferencedFrameOfReferenceSequence&&!a.ReferencedSeriesSequence&&(a.ReferencedSeriesSequence=function(e){const t=[];return e.forEach(e=>{const{RTReferencedStudySequence:r}=e;r.forEach(e=>{const{RTReferencedSeriesSequence:r}=e;r.forEach(e=>{const r=[],{ContourImageSequence:n,SeriesInstanceUID:o}=e;n.forEach(e=>{r.push({ReferencedSOPInstanceUID:e.ReferencedSOPInstanceUID,ReferencedSOPClassUID:e.ReferencedSOPClassUID})});const s={SeriesInstanceUID:o,ReferencedInstanceSequence:r};t.push(s)})})}),t}(a.ReferencedFrameOfReferenceSequence),R=a.ReferencedSeriesSequence),!R)throw new Error("ReferencedSeriesSequence is missing for the RTSTRUCT");const g=R[0];b.referencedImages=a.ReferencedSeriesSequence.ReferencedInstanceSequence,b.referencedSeriesInstanceUID=g.SeriesInstanceUID;const{displaySetService:O}=r.services,C=O.getDisplaySetsForSeries(b.referencedSeriesInstanceUID);if(C&&0!==C.length){const e=C[0];b.referencedDisplaySetInstanceUID=e.displaySetInstanceUID,b.isReconstructable=e.isReconstructable}else{const{unsubscribe:e}=O.subscribe(O.EVENTS.DISPLAY_SETS_ADDED,({displaySetsAdded:t})=>{const r=t[0];r.SeriesInstanceUID===b.referencedSeriesInstanceUID&&(b.referencedDisplaySetInstanceUID=r.displaySetInstanceUID,b.isReconstructable=r.isReconstructable,e())})}return b.load=({headers:e,createSegmentation:t=!0})=>function(e,t,r,n,o=!0){const{SOPInstanceUID:s}=e,{segmentationService:a}=t.services;if((e.loading||e.isLoaded)&&h[s]&&D.has(e.displaySetInstanceUID))return h[s];e.loading=!0;const{unsubscribe:i}=a.subscribe(a.EVENTS.SEGMENTATION_LOADING_COMPLETE,t=>{t.rtDisplaySet?.displaySetInstanceUID===e.displaySetInstanceUID&&(D.add(e.displaySetInstanceUID),i())});return h[s]=new Promise(async(t,s)=>{try{if(!e.structureSet){const t=await S(r,e,n);e.structureSet=t}o&&await a.createSegmentationForRTDisplaySet(e),t()}catch(e){s(e)}finally{e.loading=!1}}),h[s]}(b,r,o,e,t),[b]}const R=function(e){const{servicesManager:t,extensionManager:r}=e;return[{name:"dicom-rt",sopClassUids:v,getDisplaySetsFromSeries:e=>b(e,t,r)}]};var g=f(404);const O=({commandsManager:e,servicesManager:t})=>{const r=t.services,{displaySetService:n,viewportGridService:o}=r,s={hydrateRTSDisplaySet:({displaySet:t,viewportId:r})=>{if("RTSTRUCT"!==t.Modality)throw new Error("Display set is not an RTSTRUCT");const s=n.getDisplaySetByUID(t.referencedDisplaySetInstanceUID);e.runCommand("updateStoredSegmentationPresentation",{displaySet:t,type:g.SegmentationRepresentations.Contour}),e.runCommand("updateStoredPositionPresentation",{viewportId:r,displaySetInstanceUIDs:[s.displaySetInstanceUID]}),o.setDisplaySetsForViewport({viewportId:r,displaySetInstanceUIDs:[s.displaySetInstanceUID]})}};return{actions:s,definitions:{hydrateRTSDisplaySet:{commandFn:s.hydrateRTSDisplaySet,storeContexts:[],options:{}}},defaultContext:"cornerstone-dicom-rt"}};function C(){return C=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)({}).hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},C.apply(null,arguments)}const U=r.lazy(()=>Promise.resolve().then(f.bind(f,585))),w=e=>r.createElement(r.Suspense,{fallback:r.createElement("div",null,"Loading...")},r.createElement(U,e)),E={id:e,getCommandsModule:O,getViewportModule:({servicesManager:e,extensionManager:t,commandsManager:n})=>[{name:"dicom-rt",component:o=>r.createElement(w,C({servicesManager:e,extensionManager:t,commandsManager:n},o))}],getSopClassHandlerModule:R}})(),d=f.O(d)})());
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ohif/extension-cornerstone-dicom-rt",
|
|
3
|
-
"version": "3.12.0-beta.
|
|
3
|
+
"version": "3.12.0-beta.70",
|
|
4
4
|
"description": "DICOM RT read workflow",
|
|
5
5
|
"author": "OHIF",
|
|
6
6
|
"license": "MIT",
|
|
@@ -33,19 +33,19 @@
|
|
|
33
33
|
"start": "yarn run dev"
|
|
34
34
|
},
|
|
35
35
|
"peerDependencies": {
|
|
36
|
-
"@ohif/core": "3.12.0-beta.
|
|
37
|
-
"@ohif/extension-cornerstone": "3.12.0-beta.
|
|
38
|
-
"@ohif/extension-default": "3.12.0-beta.
|
|
39
|
-
"@ohif/i18n": "3.12.0-beta.
|
|
40
|
-
"prop-types": "
|
|
41
|
-
"react": "
|
|
42
|
-
"react-dom": "
|
|
43
|
-
"react-i18next": "
|
|
44
|
-
"react-router": "
|
|
45
|
-
"react-router-dom": "
|
|
36
|
+
"@ohif/core": "3.12.0-beta.70",
|
|
37
|
+
"@ohif/extension-cornerstone": "3.12.0-beta.70",
|
|
38
|
+
"@ohif/extension-default": "3.12.0-beta.70",
|
|
39
|
+
"@ohif/i18n": "3.12.0-beta.70",
|
|
40
|
+
"prop-types": "15.8.1",
|
|
41
|
+
"react": "18.3.1",
|
|
42
|
+
"react-dom": "18.3.1",
|
|
43
|
+
"react-i18next": "12.3.1",
|
|
44
|
+
"react-router": "6.30.1",
|
|
45
|
+
"react-router-dom": "6.30.1"
|
|
46
46
|
},
|
|
47
47
|
"dependencies": {
|
|
48
|
-
"@babel/runtime": "
|
|
49
|
-
"react-color": "
|
|
48
|
+
"@babel/runtime": "7.28.2",
|
|
49
|
+
"react-color": "2.19.3"
|
|
50
50
|
}
|
|
51
51
|
}
|