@ohif/extension-cornerstone-dicom-seg 3.10.0-beta.98 → 3.10.0
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-seg.umd.js.LICENSE.txt */
|
|
2
|
-
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("@cornerstonejs/adapters"),require("@cornerstonejs/core"),require("@cornerstonejs/tools"),require("@cornerstonejs/tools/enums"),require("@kitware/vtk.js/Common/Core/DataArray"),require("@kitware/vtk.js/Common/DataModel/ImageData"),require("@kitware/vtk.js/Filters/General/ImageMarchingSquares"),require("@ohif/core"),require("@ohif/extension-cornerstone"),require("@ohif/extension-default"),require("@ohif/ui"),require("@ohif/ui-next"),require("dcmjs")):"function"==typeof define&&define.amd?define(["@cornerstonejs/adapters","@cornerstonejs/core","@cornerstonejs/tools","@cornerstonejs/tools/enums","@kitware/vtk.js/Common/Core/DataArray","@kitware/vtk.js/Common/DataModel/ImageData","@kitware/vtk.js/Filters/General/ImageMarchingSquares","@ohif/core","@ohif/extension-cornerstone","@ohif/extension-default","@ohif/ui","@ohif/ui-next","dcmjs"],t):"object"==typeof exports?exports["ohif-extension-cornerstone-dicom-seg"]=t(require("@cornerstonejs/adapters"),require("@cornerstonejs/core"),require("@cornerstonejs/tools"),require("@cornerstonejs/tools/enums"),require("@kitware/vtk.js/Common/Core/DataArray"),require("@kitware/vtk.js/Common/DataModel/ImageData"),require("@kitware/vtk.js/Filters/General/ImageMarchingSquares"),require("@ohif/core"),require("@ohif/extension-cornerstone"),require("@ohif/extension-default"),require("@ohif/ui"),require("@ohif/ui-next"),require("dcmjs")):e["ohif-extension-cornerstone-dicom-seg"]=t(e["@cornerstonejs/adapters"],e["@cornerstonejs/core"],e["@cornerstonejs/tools"],e["@cornerstonejs/tools/enums"],e["@kitware/vtk.js/Common/Core/DataArray"],e["@kitware/vtk.js/Common/DataModel/ImageData"],e["@kitware/vtk.js/Filters/General/ImageMarchingSquares"],e["@ohif/core"],e["@ohif/extension-cornerstone"],e["@ohif/extension-default"],e["@ohif/ui"],e["@ohif/ui-next"],e.dcmjs)}(globalThis,((e,t,n,r,o,a,s,i,c,u,l,d,p)=>(()=>{var f,m,g={292:(e,t,n)=>{"use strict";n.r(t),n.d(t,{default:()=>_});var r=n(326);n(741);Object.create(null);function o(){if(console&&console.warn){for(var e,t=arguments.length,n=new Array(t),r=0;r<t;r++)n[r]=arguments[r];"string"==typeof n[0]&&(n[0]="react-i18next:: ".concat(n[0])),(e=console).warn.apply(e,n)}}var a={};function s(){for(var e=arguments.length,t=new Array(e),n=0;n<e;n++)t[n]=arguments[n];"string"==typeof t[0]&&a[t[0]]||("string"==typeof t[0]&&(a[t[0]]=new Date),o.apply(void 0,t))}var i=function(e,t){return function(){if(e.isInitialized)t();else{e.on("initialized",(function n(){setTimeout((function(){e.off("initialized",n)}),0),t()}))}}};function c(e,t,n){e.loadNamespaces(t,i(e,n))}function u(e,t,n,r){"string"==typeof n&&(n=[n]),n.forEach((function(t){e.options.ns.indexOf(t)<0&&e.options.ns.push(t)})),e.loadLanguages(t,i(e,r))}function l(e){return l="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},l(e)}function d(e){var t=function(e,t){if("object"!=l(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var r=n.call(e,t||"default");if("object"!=l(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}(e,"string");return"symbol"==l(t)?t:t+""}function p(e,t,n){return(t=d(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}var f=/&(?:amp|#38|lt|#60|gt|#62|apos|#39|quot|#34|nbsp|#160|copy|#169|reg|#174|hellip|#8230|#x2F|#47);/g,m={"&":"&","&":"&","<":"<","<":"<",">":">",">":">","'":"'","'":"'",""":'"',""":'"'," ":" "," ":" ","©":"©","©":"©","®":"®","®":"®","…":"…","…":"…","/":"/","/":"/"},g=function(e){return m[e]};var S={bindI18n:"languageChanged",bindI18nStore:"",transEmptyNodeValue:"",transSupportBasicHtmlNodes:!0,transWrapTextNodes:"",transKeepBasicHtmlNodesFor:["br","strong","i","p"],useSuspense:!0,unescape:function(e){return e.replace(f,g)}};var y;function v(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,d(r.key),r)}}var h=(0,r.createContext)(),b=function(){function e(){!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.usedNamespaces={}}return function(e,t,n){t&&v(e.prototype,t),n&&v(e,n),Object.defineProperty(e,"prototype",{writable:!1})}(e,[{key:"addUsedNamespaces",value:function(e){var t=this;e.forEach((function(e){t.usedNamespaces[e]||(t.usedNamespaces[e]=!0)}))}},{key:"getUsedNamespaces",value:function(){return Object.keys(this.usedNamespaces)}}]),e}();function I(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,r=Array(t);n<t;n++)r[n]=e[n];return r}function w(e,t){return function(e){if(Array.isArray(e))return e}(e)||function(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var r,o,a,s,i=[],c=!0,u=!1;try{if(a=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;c=!1}else for(;!(c=(r=a.call(n)).done)&&(i.push(r.value),i.length!==t);c=!0);}catch(e){u=!0,o=e}finally{try{if(!c&&null!=n.return&&(s=n.return(),Object(s)!==s))return}finally{if(u)throw o}}return i}}(e,t)||function(e,t){if(e){if("string"==typeof e)return I(e,t);var n={}.toString.call(e).slice(8,-1);return"Object"===n&&e.constructor&&(n=e.constructor.name),"Map"===n||"Set"===n?Array.from(e):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?I(e,t):void 0}}(e,t)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function E(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function D(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?E(Object(n),!0).forEach((function(t){p(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):E(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function C(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=t.i18n,o=(0,r.useContext)(h)||{},a=o.i18n,i=o.defaultNS,d=n||a||y;if(d&&!d.reportNamespaces&&(d.reportNamespaces=new b),!d){s("You will need to pass in an i18next instance by using initReactI18next");var p=function(e,t){return"string"==typeof t?t:t&&"object"===l(t)&&"string"==typeof t.defaultValue?t.defaultValue:Array.isArray(e)?e[e.length-1]:e},f=[p,{},!1];return f.t=p,f.i18n={},f.ready=!1,f}d.options.react&&void 0!==d.options.react.wait&&s("It seems you are still using the old wait option, you may migrate to the new useSuspense behaviour.");var m=D(D(D({},S),d.options.react),t),g=m.useSuspense,v=m.keyPrefix,I=e||i||d.options&&d.options.defaultNS;I="string"==typeof I?[I]:I||["translation"],d.reportNamespaces.addUsedNamespaces&&d.reportNamespaces.addUsedNamespaces(I);var E=(d.isInitialized||d.initializedStoreOnce)&&I.every((function(e){return function(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};return t.languages&&t.languages.length?void 0!==t.options.ignoreJSONStructure?t.hasLoadedNamespace(e,{lng:n.lng,precheck:function(t,r){if(n.bindI18n&&n.bindI18n.indexOf("languageChanging")>-1&&t.services.backendConnector.backend&&t.isLanguageChangingTo&&!r(t.isLanguageChangingTo,e))return!1}}):function(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r=t.languages[0],o=!!t.options&&t.options.fallbackLng,a=t.languages[t.languages.length-1];if("cimode"===r.toLowerCase())return!0;var s=function(e,n){var r=t.services.backendConnector.state["".concat(e,"|").concat(n)];return-1===r||2===r};return!(n.bindI18n&&n.bindI18n.indexOf("languageChanging")>-1&&t.services.backendConnector.backend&&t.isLanguageChangingTo&&!s(t.isLanguageChangingTo,e)||!t.hasResourceBundle(r,e)&&t.services.backendConnector.backend&&(!t.options.resources||t.options.partialBundledLanguages)&&(!s(r,e)||o&&!s(a,e)))}(e,t,n):(s("i18n.languages were undefined or empty",t.languages),!0)}(e,d,m)}));function C(){return d.getFixedT(t.lng||null,"fallback"===m.nsMode?I:I[0],v)}var O=w((0,r.useState)(C),2),T=O[0],x=O[1],k=I.join();t.lng&&(k="".concat(t.lng).concat(k));var j,P,M,N=(j=k,M=(0,r.useRef)(),(0,r.useEffect)((function(){M.current=P?M.current:j}),[j,P]),M.current),R=(0,r.useRef)(!0);(0,r.useEffect)((function(){var e=m.bindI18n,n=m.bindI18nStore;function r(){R.current&&x(C)}return R.current=!0,E||g||(t.lng?u(d,t.lng,I,(function(){R.current&&x(C)})):c(d,I,(function(){R.current&&x(C)}))),E&&N&&N!==k&&R.current&&x(C),e&&d&&d.on(e,r),n&&d&&d.store.on(n,r),function(){R.current=!1,e&&d&&e.split(" ").forEach((function(e){return d.off(e,r)})),n&&d&&n.split(" ").forEach((function(e){return d.store.off(e,r)}))}}),[d,k]);var U=(0,r.useRef)(!0);(0,r.useEffect)((function(){R.current&&!U.current&&x(C),U.current=!1}),[d,v]);var _=[T,d,E];if(_.t=T,_.i18n=d,_.ready=E,E)return _;if(!E&&!g)return _;throw new Promise((function(e){t.lng?u(d,t.lng,I,(function(){return e()})):c(d,I,(function(){return e()}))}))}var O=n(307),T=n(55);const x=function(e,t,n){const r=t.getCustomization("cornerstone.overlayViewportTools");return e.createToolGroupAndAddTools(n,r)},k=0,j=5;const P=function({servicesManager:e,segDisplaySet:t,viewportId:n,preHydrateCallbacks:r,hydrateCallback:o}){const{uiViewportDialogService:a}=e.services,s=e._extensionManager._appConfig;return new Promise((async function(e,i){const c=s?.disableConfirmationPrompts?j:await function(e,t){return new Promise((function(n,r){const o="Do you want to open this Segmentation?",a=[{id:"no-hydrate",type:O.ButtonEnums.type.secondary,text:"No",value:k},{id:"yes-hydrate",type:O.ButtonEnums.type.primary,text:"Yes",value:j}],s=t=>{e.hide(),n(t)};e.show({viewportId:t,type:"info",message:o,actions:a,onSubmit:s,onOutsideClick:()=>{e.hide(),n(k)},onKeyPress:e=>{"Enter"===e.key&&s(j)}})}))}(a,n);c===j&&(r?.forEach((e=>{e()})),window.setTimeout((async()=>{const r=await o({segDisplaySet:t,viewportId:n});e(r)}),0))}))};function M({isHydrated:e,onStatusClick:t}){let n=null,o=null;switch(e){case!0:o=()=>r.createElement(T.Icons.ByName,{name:"status-alert"}),n=()=>r.createElement("div",null,"This Segmentation is loaded in the segmentation panel");break;case!1:o=()=>r.createElement(T.Icons.ByName,{className:"text-aqua-pale",name:"status-untracked"}),n=()=>r.createElement("div",null,"Click LOAD to load segmentation.")}const a=()=>{const{t:n}=C("Common"),a=n("LOAD");return r.createElement("div",{className:"flex h-6 cursor-default text-sm leading-6 text-white"},r.createElement("div",{className:"bg-customgray-100 flex min-w-[45px] items-center rounded-l-xl rounded-r p-1"},r.createElement(o,null),r.createElement("span",{className:"ml-1"},"SEG")),!e&&r.createElement(O.ViewportActionButton,{onInteraction:t},a))};return r.createElement(r.Fragment,null,n&&r.createElement(T.Tooltip,null,r.createElement(T.TooltipTrigger,{asChild:!0},r.createElement("span",null,r.createElement(a,null))),r.createElement(T.TooltipContent,{side:"bottom"},r.createElement(n,null))),!n&&r.createElement(a,null))}var N=n(669),R=n(404);function U(){return U=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)({}).hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},U.apply(null,arguments)}const _=function(e){const{children:t,displaySets:n,viewportOptions:o,servicesManager:a,extensionManager:s,commandsManager:i}=e,{t:c}=C("SEGViewport"),u=o.viewportId,{displaySetService:l,toolGroupService:d,segmentationService:p,customizationService:f,viewportActionCornersService:m}=a.services,g=f.getCustomization("ui.loadingIndicatorTotalPercent"),S=`SEGToolGroup-${u}`;if(n.length>1)throw new Error("SEG viewport should only have a single display set");const y=n[0],[v,h]=(0,T.useViewportGrid)(),[b,I]=(0,r.useState)(1),{setPositionPresentation:w}=(0,N.usePositionPresentationStore)(),[E,D]=(0,r.useState)(y.isHydrated),[k,j]=(0,r.useState)(!y.isLoaded),[_,A]=(0,r.useState)(null),[L,G]=(0,r.useState)({percentComplete:null,totalSegments:null}),F=(0,r.useRef)(null),{viewports:q,activeViewportId:V}=v,B=y.referencedDisplaySetInstanceUID,$=l.getDisplaySetByUID(B),H=function(e,t){const{SharedFunctionalGroupsSequence:n}=t.instance,r=Array.isArray(n)?n[0]:n,{PixelMeasuresSequence:o}=r,a=Array.isArray(o)?o[0]:o,{SpacingBetweenSlices:s,SliceThickness:i}=a,c=e.images[0],u={PatientID:c.PatientID,PatientName:c.PatientName,PatientSex:c.PatientSex,PatientAge:c.PatientAge,SliceThickness:c.SliceThickness||i,StudyDate:c.StudyDate,SeriesDescription:c.SeriesDescription,SeriesInstanceUID:c.SeriesInstanceUID,SeriesNumber:c.SeriesNumber,ManufacturerModelName:c.ManufacturerModelName,SpacingBetweenSlices:c.SpacingBetweenSlices||s};return u}($,y);F.current={displaySet:$,metadata:H};const z=()=>{A(null)},Y=(0,r.useCallback)((()=>{v?.viewports.forEach((({viewportId:e})=>{i.runCommand("storePresentation",{viewportId:e})}))}),[v]),J=(0,r.useCallback)((()=>{const{component:t}=s.getModuleEntry("@ohif/extension-cornerstone.viewportModule.cornerstone");return r.createElement(t,U({},e,{displaySets:[y],viewportOptions:{viewportType:o.viewportType,toolGroupId:S,orientation:o.orientation,viewportId:o.viewportId,presentationIds:o.presentationIds},onElementEnabled:t=>{e.onElementEnabled?.(t),(e=>{A(e.detail.element)})(t)},onElementDisabled:z}))}),[u,y,S]),K=(0,r.useCallback)((e=>{const t=y.displaySetInstanceUID,n=p.getSegmentation(t),{segments:r}=n,o=Object.keys(r).length;let a=b+e;a>o-1?a=1:0===a&&(a=o-1),p.jumpToSegmentCenter(t,a,u),I(a)}),[b]),W=(0,r.useCallback)((()=>{i.runCommand("updateStoredSegmentationPresentation",{displaySet:y,type:R.SegmentationRepresentations.Labelmap}),i.runCommand("updateStoredPositionPresentation",{viewportId:u,displaySetInstanceUID:$.displaySetInstanceUID}),h.setDisplaySetsForViewport({viewportId:u,displaySetInstanceUIDs:[$.displaySetInstanceUID]})}),[i,u,$,y]);(0,r.useEffect)((()=>{k||P({servicesManager:a,viewportId:u,segDisplaySet:y,preHydrateCallbacks:[Y],hydrateCallback:W}).then((e=>{e&&D(!0)}))}),[a,u,y,k,W]),(0,r.useEffect)((()=>{p.clearSegmentationRepresentations(u);const{unsubscribe:e}=p.subscribe(p.EVENTS.SEGMENTATION_LOADING_COMPLETE,(e=>{if(e.segDisplaySet.displaySetInstanceUID===y.displaySetInstanceUID&&j(!1),y?.firstSegmentedSliceImageId&&o?.presentationIds){const{firstSegmentedSliceImageId:e}=y,{presentationIds:t}=o;w(t.positionPresentationId,{viewReference:{referencedImageId:e}})}}));return()=>{e()}}),[y]),(0,r.useEffect)((()=>{const{unsubscribe:e}=p.subscribe(p.EVENTS.SEGMENT_LOADING_COMPLETE,(({percentComplete:e,numSegments:t})=>{G({percentComplete:e,totalSegments:t})}));return()=>{e()}}),[y]),(0,r.useEffect)((()=>{const e=l.subscribe(l.EVENTS.DISPLAY_SETS_REMOVED,(({displaySetInstanceUIDs:e})=>{const t=q.get(V);e.includes(t.displaySetInstanceUID)&&h.setDisplaySetsForViewport({viewportId:V,displaySetInstanceUIDs:[]})}));return()=>{e.unsubscribe()}}),[]),(0,r.useEffect)((()=>{let e=d.getToolGroup(S);if(!e)return i.runCommand("updateStoredSegmentationPresentation",{displaySet:y,type:R.SegmentationRepresentations.Labelmap}),p.clearSegmentationRepresentations(u),e=x(d,f,S),()=>{p.clearSegmentationRepresentations(u),d.destroyToolGroup(S)}}),[]);const Q=(0,r.useCallback)((async()=>{Y(),W()}),[Y,W]);(0,r.useEffect)((()=>{m.addComponents([{viewportId:u,id:"viewportStatusComponent",component:M({isHydrated:E,onStatusClick:Q}),indexPriority:-100,location:m.LOCATIONS.topLeft},{viewportId:u,id:"viewportActionArrowsComponent",component:r.createElement(O.ViewportActionArrows,{key:"actionArrows",onArrowsClick:K,className:u===V?"visible":"invisible group-hover/pane:visible"}),indexPriority:0,location:m.LOCATIONS.topRight}])}),[V,E,K,Q,m,u]);let X=null;return F.current&&$.displaySetInstanceUID===F.current.displaySet.displaySetInstanceUID?(t&&t.length&&(X=t.map(((e,t)=>e&&r.cloneElement(e,{viewportId:u,key:t})))),r.createElement(r.Fragment,null,r.createElement("div",{className:"relative flex h-full w-full flex-row overflow-hidden"},k&&r.createElement(g,{className:"h-full w-full",totalNumbers:L.totalSegments,percentComplete:L.percentComplete,loadingText:"Loading SEG..."}),J(),X))):null}},249:(e,t)=>{"use strict";var n=Symbol.for("react.element"),r=Symbol.for("react.portal"),o=Symbol.for("react.fragment"),a=Symbol.for("react.strict_mode"),s=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"),d=Symbol.for("react.memo"),p=Symbol.for("react.lazy"),f=Symbol.iterator;var m={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},g=Object.assign,S={};function y(e,t,n){this.props=e,this.context=t,this.refs=S,this.updater=n||m}function v(){}function h(e,t,n){this.props=e,this.context=t,this.refs=S,this.updater=n||m}y.prototype.isReactComponent={},y.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")},y.prototype.forceUpdate=function(e){this.updater.enqueueForceUpdate(this,e,"forceUpdate")},v.prototype=y.prototype;var b=h.prototype=new v;b.constructor=h,g(b,y.prototype),b.isPureReactComponent=!0;var I=Array.isArray,w=Object.prototype.hasOwnProperty,E={current:null},D={key:!0,ref:!0,__self:!0,__source:!0};function C(e,t,r){var o,a={},s=null,i=null;if(null!=t)for(o in void 0!==t.ref&&(i=t.ref),void 0!==t.key&&(s=""+t.key),t)w.call(t,o)&&!D.hasOwnProperty(o)&&(a[o]=t[o]);var c=arguments.length-2;if(1===c)a.children=r;else if(1<c){for(var u=Array(c),l=0;l<c;l++)u[l]=arguments[l+2];a.children=u}if(e&&e.defaultProps)for(o in c=e.defaultProps)void 0===a[o]&&(a[o]=c[o]);return{$$typeof:n,type:e,key:s,ref:i,props:a,_owner:E.current}}function O(e){return"object"==typeof e&&null!==e&&e.$$typeof===n}var T=/\/+/g;function x(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 k(e,t,o,a,s){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 n:case r:c=!0}}if(c)return s=s(c=e),e=""===a?"."+x(c,0):a,I(s)?(o="",null!=e&&(o=e.replace(T,"$&/")+"/"),k(s,t,o,"",(function(e){return e}))):null!=s&&(O(s)&&(s=function(e,t){return{$$typeof:n,type:e.type,key:t,ref:e.ref,props:e.props,_owner:e._owner}}(s,o+(!s.key||c&&c.key===s.key?"":(""+s.key).replace(T,"$&/")+"/")+e)),t.push(s)),1;if(c=0,a=""===a?".":a+":",I(e))for(var u=0;u<e.length;u++){var l=a+x(i=e[u],u);c+=k(i,t,o,l,s)}else if(l=function(e){return null===e||"object"!=typeof e?null:"function"==typeof(e=f&&e[f]||e["@@iterator"])?e:null}(e),"function"==typeof l)for(e=l.call(e),u=0;!(i=e.next()).done;)c+=k(i=i.value,t,o,l=a+x(i,u++),s);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 j(e,t,n){if(null==e)return e;var r=[],o=0;return k(e,r,"","",(function(e){return t.call(n,e,o++)})),r}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 M={current:null},N={transition:null},R={ReactCurrentDispatcher:M,ReactCurrentBatchConfig:N,ReactCurrentOwner:E};function U(){throw Error("act(...) is not supported in production builds of React.")}t.Children={map:j,forEach:function(e,t,n){j(e,(function(){t.apply(this,arguments)}),n)},count:function(e){var t=0;return j(e,(function(){t++})),t},toArray:function(e){return j(e,(function(e){return e}))||[]},only:function(e){if(!O(e))throw Error("React.Children.only expected to receive a single React element child.");return e}},t.Component=y,t.Fragment=o,t.Profiler=s,t.PureComponent=h,t.StrictMode=a,t.Suspense=l,t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=R,t.act=U,t.cloneElement=function(e,t,r){if(null==e)throw Error("React.cloneElement(...): The argument must be a React element, but you passed "+e+".");var o=g({},e.props),a=e.key,s=e.ref,i=e._owner;if(null!=t){if(void 0!==t.ref&&(s=t.ref,i=E.current),void 0!==t.key&&(a=""+t.key),e.type&&e.type.defaultProps)var c=e.type.defaultProps;for(u in t)w.call(t,u)&&!D.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=r;else if(1<u){c=Array(u);for(var l=0;l<u;l++)c[l]=arguments[l+2];o.children=c}return{$$typeof:n,type:e.type,key:a,ref:s,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=O,t.lazy=function(e){return{$$typeof:p,_payload:{_status:-1,_result:e},_init:P}},t.memo=function(e,t){return{$$typeof:d,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=U,t.useCallback=function(e,t){return M.current.useCallback(e,t)},t.useContext=function(e){return M.current.useContext(e)},t.useDebugValue=function(){},t.useDeferredValue=function(e){return M.current.useDeferredValue(e)},t.useEffect=function(e,t){return M.current.useEffect(e,t)},t.useId=function(){return M.current.useId()},t.useImperativeHandle=function(e,t,n){return M.current.useImperativeHandle(e,t,n)},t.useInsertionEffect=function(e,t){return M.current.useInsertionEffect(e,t)},t.useLayoutEffect=function(e,t){return M.current.useLayoutEffect(e,t)},t.useMemo=function(e,t){return M.current.useMemo(e,t)},t.useReducer=function(e,t,n){return M.current.useReducer(e,t,n)},t.useRef=function(e){return M.current.useRef(e)},t.useState=function(e){return M.current.useState(e)},t.useSyncExternalStore=function(e,t,n){return M.current.useSyncExternalStore(e,t,n)},t.useTransition=function(){return M.current.useTransition()},t.version="18.3.1"},326:(e,t,n)=>{"use strict";e.exports=n(249)},741:e=>{e.exports={area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0}},142:t=>{"use strict";t.exports=e},557:e=>{"use strict";e.exports=t},713:e=>{"use strict";e.exports=n},404:e=>{"use strict";e.exports=r},670:e=>{"use strict";e.exports=o},322:e=>{"use strict";e.exports=a},934:e=>{"use strict";e.exports=s},2:e=>{"use strict";e.exports=i},669:e=>{"use strict";e.exports=c},438:e=>{"use strict";e.exports=u},307:e=>{"use strict";e.exports=l},55:e=>{"use strict";e.exports=d},111:e=>{"use strict";e.exports=p}},S={};function y(e){var t=S[e];if(void 0!==t)return t.exports;var n=S[e]={exports:{}};return g[e](n,n.exports,y),n.exports}y.m=g,f=[],y.O=(e,t,n,r)=>{if(!t){var o=1/0;for(c=0;c<f.length;c++){for(var[t,n,r]=f[c],a=!0,s=0;s<t.length;s++)(!1&r||o>=r)&&Object.keys(y.O).every((e=>y.O[e](t[s])))?t.splice(s--,1):(a=!1,r<o&&(o=r));if(a){f.splice(c--,1);var i=n();void 0!==i&&(e=i)}}return e}r=r||0;for(var c=f.length;c>0&&f[c-1][2]>r;c--)f[c]=f[c-1];f[c]=[t,n,r]},y.F={},y.E=e=>{Object.keys(y.F).map((t=>{y.F[t](e)}))},y.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return y.d(t,{a:t}),t},y.d=(e,t)=>{for(var n in t)y.o(t,n)&&!y.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},y.miniCssF=e=>{},y.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),y.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},y.p="/",m={524:0},y.F.j=e=>{if(!y.o(m,e)||void 0===m[e]){m[e]=null;var t=document.createElement("link");y.nc&&t.setAttribute("nonce",y.nc),t.rel="prefetch",t.as="script",t.href=y.p+y.u(e),document.head.appendChild(t)}},y.O.j=e=>0===m[e],y.O(0,[524],(()=>{y.E(524)}),5);var v={};return(()=>{"use strict";y.r(v),y.d(v,{default:()=>N});const e=JSON.parse('{"UU":"@ohif/extension-cornerstone-dicom-seg"}').UU,t=`${e}.sopClassHandlerModule.dicom-seg`;var n=y(326),r=y(2),o=y(557),a=y(713),s=y(142),i=y(111),c=y.n(i);const u=["1.2.840.10008.5.1.4.1.1.66.4"],l={};function d(e,n,i){const d=e[0],{StudyInstanceUID:p,SeriesInstanceUID:f,SOPInstanceUID:m,SeriesDescription:g,SeriesNumber:S,SeriesDate:y,SOPClassUID:v,wadoRoot:h,wadoUri:b,wadoUriRoot:I}=d,w={Modality:"SEG",loading:!1,isReconstructable:!0,displaySetInstanceUID:r.utils.guid(),SeriesDescription:g,SeriesNumber:S,SeriesDate:y,SOPInstanceUID:m,SeriesInstanceUID:f,StudyInstanceUID:p,SOPClassHandlerId:t,SOPClassUID:v,referencedImages:null,referencedSeriesInstanceUID:null,referencedDisplaySetInstanceUID:null,isDerivedDisplaySet:!0,isLoaded:!1,isHydrated:!1,segments:{},sopClassUids:u,instance:d,instances:[d],wadoRoot:h,wadoUriRoot:I,wadoUri:b,isOverlayDisplaySet:!0},E=d.ReferencedSeriesSequence;if(!E)return void console.error("ReferencedSeriesSequence is missing for the SEG");const D=E[0]||E;w.referencedImages=d.ReferencedSeriesSequence.ReferencedInstanceSequence,w.referencedSeriesInstanceUID=D.SeriesInstanceUID;const{displaySetService:C}=n.services,O=C.getDisplaySetsForSeries(w.referencedSeriesInstanceUID)[0];if(O)w.referencedDisplaySetInstanceUID=O.displaySetInstanceUID;else{const{unsubscribe:e}=C.subscribe(C.EVENTS.DISPLAY_SETS_ADDED,(({displaySetsAdded:t})=>{const n=t[0];n.SeriesInstanceUID===w.referencedSeriesInstanceUID&&(w.referencedDisplaySetInstanceUID=n.displaySetInstanceUID,e())}))}return w.load=async({headers:e})=>await function(e,t,n,r){const{SOPInstanceUID:i}=e,{segmentationService:u}=t.services;if((e.loading||e.isLoaded)&&l[i]&&function(e){return a.segmentation.state.getSegmentation(e.displaySetInstanceUID)}(e))return l[i];return e.loading=!0,l[i]=new Promise((async(i,l)=>{if(!e.segments||0===Object.keys(e.segments).length)try{await async function({extensionManager:e,servicesManager:t,segDisplaySet:n,headers:r}){const i=e.getModuleEntry("@ohif/extension-cornerstone.utilityModule.common"),{segmentationService:u,uiNotificationService:l}=t.services,{dicomLoaderService:d}=i.exports,p=await d.findDicomDataPromise(n,null,r),f=t.services.displaySetService.getDisplaySetByUID(n.referencedDisplaySetInstanceUID);if(!f)throw new Error("referencedDisplaySet is missing for SEG");const{instances:m}=f,g=m.map((({imageId:e})=>e)),S=.001,y=!0;o.eventTarget.addEventListener(s.Enums.Events.SEGMENTATION_LOAD_PROGRESS,(e=>{const{percentComplete:t}=e.detail;u._broadcastEvent(u.EVENTS.SEGMENT_LOADING_COMPLETE,{percentComplete:t})}));const v=await s.adaptersSEG.Cornerstone3D.Segmentation.generateToolState(g,p,o.metaData,{skipOverlapping:y,tolerance:S,eventTarget:o.eventTarget,triggerEvent:o.triggerEvent});let h=!0;v.segMetadata.data.forEach(((e,t)=>{var n;t>0&&(e.rgba=e.RecommendedDisplayCIELabValue,e.rgba?e.rgba=(n=e.rgba,c().data.Colors.dicomlab2RGB(n).map((e=>Math.round(255*e)))):(h=!1,e.rgba=a.CONSTANTS.COLOR_LUT[t%a.CONSTANTS.COLOR_LUT.length]))})),v.overlappingSegments&&l.show({title:"Overlapping Segments",message:"Unsupported overlapping segments detected, segmentation rendering results may be incorrect.",type:"warning"});h||l.show({title:"DICOM SEG import",message:"RecommendedDisplayCIELabValue not found for one or more segments. The default color was used instead.",type:"warning",duration:5e3});Object.assign(n,v)}({extensionManager:n,servicesManager:t,segDisplaySet:e,headers:r})}catch(t){return e.loading=!1,l(t)}u.createSegmentationForSEGDisplaySet(e).then((()=>{e.loading=!1,i()})).catch((t=>{e.loading=!1,l(t)}))})),l[i]}(w,n,i,e),[w]}const p=function({servicesManager:e,extensionManager:t}){return[{name:"dicom-seg",sopClassUids:u,getDisplaySetsFromSeries:n=>d(n,e,t)}]},f={id:"@ohif/seg",name:"Segmentations",protocolMatchingRules:[],toolGroupIds:["default"],numberOfPriorsReferenced:0,defaultViewport:{viewportOptions:{viewportType:"stack",toolGroupId:"default",allowUnmatchedView:!0,syncGroups:[{type:"hydrateseg",id:"sameFORId",source:!0,target:!0}]},displaySets:[{id:"segDisplaySetId",matchedDisplaySetsIndex:-1}]},displaySetSelectors:{segDisplaySetId:{seriesMatchingRules:[{attribute:"Modality",constraint:{equals:"SEG"}}]}},stages:[{name:"Segmentations",viewportStructure:{layoutType:"grid",properties:{rows:1,columns:1}},viewports:[{viewportOptions:{allowUnmatchedView:!0,syncGroups:[{type:"hydrateseg",id:"sameFORId",source:!0,target:!0}]},displaySets:[{id:"segDisplaySetId"}]}]}]};const m=function(){return[{name:f.id,protocol:f}]};var g=y(438),S=y(934),h=y.n(S),b=y(670),I=y.n(b),w=y(322),E=y.n(w);const{segmentation:D}=a.utilities,{datasetToBlob:C}=c().data,{Cornerstone3D:{Segmentation:{generateSegmentation:O}}}=s.adaptersSEG,{Cornerstone3D:{RTSS:{generateRTSSFromSegmentations:T}}}=s.adaptersRT,{downloadDICOMData:x}=s.helpers,k=({servicesManager:e,extensionManager:t})=>{const{segmentationService:n,uiDialogService:s,displaySetService:i,viewportGridService:u,toolGroupService:l}=e.services,d={loadSegmentationsForViewport:async({segmentations:e,viewportId:t})=>{const r=(({viewportId:e,viewportGridService:t})=>{const{viewports:n,activeViewportId:r}=t.getState(),o=e||r;return n.get(o)})({viewportId:t,viewportGridService:u}),o=r.displaySetInstanceUIDs[0],a=e[0],s=a.segmentationId,c=a.config.label,l=a.config.segments,d=i.getDisplaySetByUID(o);return await n.createLabelmapForDisplaySet(d,{segmentationId:s,segments:l,label:c}),n.addOrUpdateSegmentation(a),await n.addSegmentationRepresentation(r.viewportId,{segmentationId:s}),s},generateSegmentation:({segmentationId:e,options:t={}})=>{const r=a.segmentation.state.getSegmentation(e),{imageIds:s}=r.representationData.Labelmap,i=s.map((e=>o.cache.getImage(e))),u=i.map((e=>o.cache.getImage(e.referencedImageId))),l=[];let d=0;for(const e of i){const t=new Set,n=e.getPixelData(),{rows:r,columns:o}=e;for(let e=0;e<n.length;e++){const r=n[e];0!==r&&t.add(r)}l[d++]={segmentsOnLabelmap:Array.from(t),pixelData:n,rows:r,columns:o}}const p=l.map((e=>e.segmentsOnLabelmap)),f={segmentsOnLabelmap:Array.from(new Set(p.flat())),metadata:[],labelmaps2D:l},m=n.getSegmentation(e),g=n.getRepresentationsForSegmentation(e);Object.entries(m.segments).forEach((([t,r])=>{if(!r)return;const{label:o}=r,a=g[0],s=n.getSegmentColor(a.viewportId,e,r.segmentIndex),i=c().data.Colors.rgb2DICOMLAB(s.slice(0,3).map((e=>e/255))).map((e=>Math.round(e))),u={SegmentNumber:t.toString(),SegmentLabel:o,SegmentAlgorithmType:r?.algorithmType||"MANUAL",SegmentAlgorithmName:r?.algorithmName||"OHIF Brush",RecommendedDisplayCIELabValue:i,SegmentedPropertyCategoryCodeSequence:{CodeValue:"T-D0050",CodingSchemeDesignator:"SRT",CodeMeaning:"Tissue"},SegmentedPropertyTypeCodeSequence:{CodeValue:"T-D0050",CodingSchemeDesignator:"SRT",CodeMeaning:"Tissue"}};f.metadata[t]=u}));return O(u,f,o.metaData,t)},downloadSegmentation:({segmentationId:e})=>{const t=n.getSegmentation(e),r=d.generateSegmentation({segmentationId:e});x(r.dataset,`${t.label}`)},storeSegmentation:async({segmentationId:e,dataSource:o})=>{const a=await(0,g.createReportDialogPrompt)(s,{extensionManager:t});if(1!==a.action&&!a.value)return;const i=n.getSegmentation(e);if(!i)throw new Error("No segmentation found");const{label:c}=i,u=a.value||c||"Research Derived Series",l=d.generateSegmentation({segmentationId:e,options:{SeriesDescription:u}});if(!l||!l.dataset)throw new Error("Error during segmentation generation");const{dataset:p}=l;return await o.store.dicom(p),p.wadoRoot=o.getConfig().wadoRoot,r.DicomMetadataStore.addInstances([p],!0),p},downloadRTSS:({segmentationId:e})=>{const t=n.getSegmentation(e),s={vtkImageMarchingSquares:h(),vtkDataArray:I(),vtkImageData:E()},i=T(t,r.classes.MetadataProvider,r.DicomMetadataStore,o.cache,a.Enums,s);try{const e=C(i),t=URL.createObjectURL(e);window.location.assign(t)}catch(e){console.warn(e)}},setBrushSize:({value:e,toolNames:t})=>{const n=Number(e);l.getToolGroupIds()?.forEach((e=>{0===t?.length?D.setBrushSizeForToolGroup(e,n):t?.forEach((t=>{D.setBrushSizeForToolGroup(e,n,t)}))}))},setThresholdRange:({value:e,toolNames:t=["ThresholdCircularBrush","ThresholdSphereBrush"]})=>{l.getToolGroupIds()?.forEach((n=>{const r=l.getToolGroup(n);t?.forEach((t=>{r.setToolConfiguration(t,{strategySpecificConfiguration:{THRESHOLD:{threshold:e}}})}))}))}},p={loadSegmentationDisplaySetsForViewport:{commandFn:d.loadSegmentationDisplaySetsForViewport},loadSegmentationsForViewport:{commandFn:d.loadSegmentationsForViewport},generateSegmentation:{commandFn:d.generateSegmentation},downloadSegmentation:{commandFn:d.downloadSegmentation},storeSegmentation:{commandFn:d.storeSegmentation},downloadRTSS:{commandFn:d.downloadRTSS},setBrushSize:{commandFn:d.setBrushSize},setThresholdRange:{commandFn:d.setThresholdRange}};return{actions:d,definitions:p,defaultContext:"SEGMENTATION"}};function j(){return j=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)({}).hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},j.apply(null,arguments)}const P=n.lazy((()=>Promise.resolve().then(y.bind(y,292)))),M=e=>n.createElement(n.Suspense,{fallback:n.createElement("div",null,"Loading...")},n.createElement(P,e)),N={id:e,getCommandsModule:k,getToolbarModule:function({servicesManager:e}){const{segmentationService:t,toolbarService:n,toolGroupService:r}=e.services;return[{name:"evaluate.cornerstone.hasSegmentation",evaluate:({viewportId:e})=>{const n=t.getSegmentationRepresentations(e);return{disabled:!n?.length}}},{name:"evaluate.cornerstone.segmentation",evaluate:({viewportId:e,button:o,toolNames:a,disabledText:s})=>{const i=t.getSegmentationRepresentations(e);if(!i?.length)return{disabled:!0,disabledText:s??"No segmentations available"};const c=r.getToolGroupForViewport(e);if(!c)return{disabled:!0,disabledText:s??"Not available on the current viewport"};const u=n.getToolNameForButton(o);if(!c.hasTool(u)&&!a)return{disabled:!0,disabledText:s??"Not available on the current viewport"};return{disabled:!1,isActive:a?a.includes(c.getActivePrimaryMouseButtonTool()):c.getActivePrimaryMouseButtonTool()===u}}}]},getViewportModule:({servicesManager:e,extensionManager:t,commandsManager:r})=>[{name:"dicom-seg",component:o=>n.createElement(M,j({servicesManager:e,extensionManager:t,commandsManager:r},o))}],getSopClassHandlerModule:p,getHangingProtocolModule:m}})(),v=y.O(v)})()));
|
|
2
|
+
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("@cornerstonejs/adapters"),require("@cornerstonejs/core"),require("@cornerstonejs/tools"),require("@cornerstonejs/tools/enums"),require("@ohif/core"),require("@ohif/extension-cornerstone"),require("@ohif/extension-default"),require("@ohif/ui-next"),require("dcmjs")):"function"==typeof define&&define.amd?define(["@cornerstonejs/adapters","@cornerstonejs/core","@cornerstonejs/tools","@cornerstonejs/tools/enums","@ohif/core","@ohif/extension-cornerstone","@ohif/extension-default","@ohif/ui-next","dcmjs"],t):"object"==typeof exports?exports["ohif-extension-cornerstone-dicom-seg"]=t(require("@cornerstonejs/adapters"),require("@cornerstonejs/core"),require("@cornerstonejs/tools"),require("@cornerstonejs/tools/enums"),require("@ohif/core"),require("@ohif/extension-cornerstone"),require("@ohif/extension-default"),require("@ohif/ui-next"),require("dcmjs")):e["ohif-extension-cornerstone-dicom-seg"]=t(e["@cornerstonejs/adapters"],e["@cornerstonejs/core"],e["@cornerstonejs/tools"],e["@cornerstonejs/tools/enums"],e["@ohif/core"],e["@ohif/extension-cornerstone"],e["@ohif/extension-default"],e["@ohif/ui-next"],e.dcmjs)}(globalThis,((e,t,n,r,o,a,i,s,c)=>(()=>{var u,l,d={292:(e,t,n)=>{"use strict";n.r(t),n.d(t,{default:()=>U});var r=n(326);n(741);Object.create(null);function o(){if(console&&console.warn){for(var e,t=arguments.length,n=new Array(t),r=0;r<t;r++)n[r]=arguments[r];"string"==typeof n[0]&&(n[0]="react-i18next:: ".concat(n[0])),(e=console).warn.apply(e,n)}}var a={};function i(){for(var e=arguments.length,t=new Array(e),n=0;n<e;n++)t[n]=arguments[n];"string"==typeof t[0]&&a[t[0]]||("string"==typeof t[0]&&(a[t[0]]=new Date),o.apply(void 0,t))}var s=function(e,t){return function(){if(e.isInitialized)t();else{e.on("initialized",(function n(){setTimeout((function(){e.off("initialized",n)}),0),t()}))}}};function c(e,t,n){e.loadNamespaces(t,s(e,n))}function u(e,t,n,r){"string"==typeof n&&(n=[n]),n.forEach((function(t){e.options.ns.indexOf(t)<0&&e.options.ns.push(t)})),e.loadLanguages(t,s(e,r))}function l(e){return l="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},l(e)}function d(e){var t=function(e,t){if("object"!=l(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var r=n.call(e,t||"default");if("object"!=l(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}(e,"string");return"symbol"==l(t)?t:t+""}function p(e,t,n){return(t=d(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}var f=/&(?:amp|#38|lt|#60|gt|#62|apos|#39|quot|#34|nbsp|#160|copy|#169|reg|#174|hellip|#8230|#x2F|#47);/g,m={"&":"&","&":"&","<":"<","<":"<",">":">",">":">","'":"'","'":"'",""":'"',""":'"'," ":" "," ":" ","©":"©","©":"©","®":"®","®":"®","…":"…","…":"…","/":"/","/":"/"},g=function(e){return m[e]};var S={bindI18n:"languageChanged",bindI18nStore:"",transEmptyNodeValue:"",transSupportBasicHtmlNodes:!0,transWrapTextNodes:"",transKeepBasicHtmlNodesFor:["br","strong","i","p"],useSuspense:!0,unescape:function(e){return e.replace(f,g)}};var y;function v(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,d(r.key),r)}}var b=(0,r.createContext)(),h=function(){function e(){!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.usedNamespaces={}}return function(e,t,n){t&&v(e.prototype,t),n&&v(e,n),Object.defineProperty(e,"prototype",{writable:!1})}(e,[{key:"addUsedNamespaces",value:function(e){var t=this;e.forEach((function(e){t.usedNamespaces[e]||(t.usedNamespaces[e]=!0)}))}},{key:"getUsedNamespaces",value:function(){return Object.keys(this.usedNamespaces)}}]),e}();function I(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,r=Array(t);n<t;n++)r[n]=e[n];return r}function w(e,t){return function(e){if(Array.isArray(e))return e}(e)||function(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var r,o,a,i,s=[],c=!0,u=!1;try{if(a=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;c=!1}else for(;!(c=(r=a.call(n)).done)&&(s.push(r.value),s.length!==t);c=!0);}catch(e){u=!0,o=e}finally{try{if(!c&&null!=n.return&&(i=n.return(),Object(i)!==i))return}finally{if(u)throw o}}return s}}(e,t)||function(e,t){if(e){if("string"==typeof e)return I(e,t);var n={}.toString.call(e).slice(8,-1);return"Object"===n&&e.constructor&&(n=e.constructor.name),"Map"===n||"Set"===n?Array.from(e):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?I(e,t):void 0}}(e,t)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function E(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function D(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?E(Object(n),!0).forEach((function(t){p(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):E(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function O(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=t.i18n,o=(0,r.useContext)(b)||{},a=o.i18n,s=o.defaultNS,d=n||a||y;if(d&&!d.reportNamespaces&&(d.reportNamespaces=new h),!d){i("You will need to pass in an i18next instance by using initReactI18next");var p=function(e,t){return"string"==typeof t?t:t&&"object"===l(t)&&"string"==typeof t.defaultValue?t.defaultValue:Array.isArray(e)?e[e.length-1]:e},f=[p,{},!1];return f.t=p,f.i18n={},f.ready=!1,f}d.options.react&&void 0!==d.options.react.wait&&i("It seems you are still using the old wait option, you may migrate to the new useSuspense behaviour.");var m=D(D(D({},S),d.options.react),t),g=m.useSuspense,v=m.keyPrefix,I=e||s||d.options&&d.options.defaultNS;I="string"==typeof I?[I]:I||["translation"],d.reportNamespaces.addUsedNamespaces&&d.reportNamespaces.addUsedNamespaces(I);var E=(d.isInitialized||d.initializedStoreOnce)&&I.every((function(e){return function(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};return t.languages&&t.languages.length?void 0!==t.options.ignoreJSONStructure?t.hasLoadedNamespace(e,{lng:n.lng,precheck:function(t,r){if(n.bindI18n&&n.bindI18n.indexOf("languageChanging")>-1&&t.services.backendConnector.backend&&t.isLanguageChangingTo&&!r(t.isLanguageChangingTo,e))return!1}}):function(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r=t.languages[0],o=!!t.options&&t.options.fallbackLng,a=t.languages[t.languages.length-1];if("cimode"===r.toLowerCase())return!0;var i=function(e,n){var r=t.services.backendConnector.state["".concat(e,"|").concat(n)];return-1===r||2===r};return!(n.bindI18n&&n.bindI18n.indexOf("languageChanging")>-1&&t.services.backendConnector.backend&&t.isLanguageChangingTo&&!i(t.isLanguageChangingTo,e)||!t.hasResourceBundle(r,e)&&t.services.backendConnector.backend&&(!t.options.resources||t.options.partialBundledLanguages)&&(!i(r,e)||o&&!i(a,e)))}(e,t,n):(i("i18n.languages were undefined or empty",t.languages),!0)}(e,d,m)}));function O(){return d.getFixedT(t.lng||null,"fallback"===m.nsMode?I:I[0],v)}var C=w((0,r.useState)(O),2),T=C[0],x=C[1],R=I.join();t.lng&&(R="".concat(t.lng).concat(R));var N,P,j,_=(N=R,j=(0,r.useRef)(),(0,r.useEffect)((function(){j.current=P?j.current:N}),[N,P]),j.current),M=(0,r.useRef)(!0);(0,r.useEffect)((function(){var e=m.bindI18n,n=m.bindI18nStore;function r(){M.current&&x(O)}return M.current=!0,E||g||(t.lng?u(d,t.lng,I,(function(){M.current&&x(O)})):c(d,I,(function(){M.current&&x(O)}))),E&&_&&_!==R&&M.current&&x(O),e&&d&&d.on(e,r),n&&d&&d.store.on(n,r),function(){M.current=!1,e&&d&&e.split(" ").forEach((function(e){return d.off(e,r)})),n&&d&&n.split(" ").forEach((function(e){return d.store.off(e,r)}))}}),[d,R]);var U=(0,r.useRef)(!0);(0,r.useEffect)((function(){M.current&&!U.current&&x(O),U.current=!1}),[d,v]);var k=[T,d,E];if(k.t=T,k.i18n=d,k.ready=E,E)return k;if(!E&&!g)return k;throw new Promise((function(e){t.lng?u(d,t.lng,I,(function(){return e()})):c(d,I,(function(){return e()}))}))}var C=n(55);const T=function(e,t,n){const r=t.getCustomization("cornerstone.overlayViewportTools");return e.createToolGroupAndAddTools(n,r)},x=0,R=5;const N=function({servicesManager:e,segDisplaySet:t,viewportId:n,preHydrateCallbacks:r,hydrateCallback:o}){const{uiViewportDialogService:a,customizationService:i}=e.services,s=e._extensionManager._appConfig;return new Promise((async function(e,c){const u=s?.disableConfirmationPrompts?R:await function(e,t,n){return new Promise((function(r,o){const a=t.getCustomization("viewportNotification.hydrateSEGMessage"),i=[{id:"no-hydrate",type:"secondary",text:"No",value:x},{id:"yes-hydrate",type:"primary",text:"Yes",value:R}],s=t=>{e.hide(),r(t)};e.show({viewportId:n,type:"info",message:a,actions:i,onSubmit:s,onOutsideClick:()=>{e.hide(),r(x)},onKeyPress:e=>{"Enter"===e.key&&s(R)}})}))}(a,i,n);u===R&&(r?.forEach((e=>{e()})),window.setTimeout((async()=>{const r=await o({segDisplaySet:t,viewportId:n});e(r)}),0))}))};function P({isHydrated:e,onStatusClick:t}){let n=null,o=null;switch(e){case!0:o=()=>r.createElement(C.Icons.ByName,{name:"status-alert"}),n=()=>r.createElement("div",null,"This Segmentation is loaded in the segmentation panel");break;case!1:o=()=>r.createElement(C.Icons.ByName,{className:"text-muted-foreground h-4 w-4",name:"status-untracked"}),n=()=>r.createElement("div",null,"Click LOAD to load segmentation.")}const a=()=>{const{t:n}=O("Common"),a=n("LOAD");return r.createElement("div",{className:"flex h-6 cursor-default text-sm leading-6 text-white"},r.createElement("div",{className:"bg-customgray-100 flex min-w-[45px] items-center rounded-l-xl rounded-r p-1"},r.createElement(o,null),r.createElement("span",{className:"ml-1"},"SEG")),!e&&r.createElement(C.ViewportActionButton,{onInteraction:t},a))};return r.createElement(r.Fragment,null,n&&r.createElement(C.Tooltip,null,r.createElement(C.TooltipTrigger,{asChild:!0},r.createElement("span",null,r.createElement(a,null))),r.createElement(C.TooltipContent,{side:"bottom"},r.createElement(n,null))),!n&&r.createElement(a,null))}var j=n(669),_=n(404);function M(){return M=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)({}).hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},M.apply(null,arguments)}const U=function(e){const{children:t,displaySets:n,viewportOptions:o,servicesManager:a,extensionManager:i,commandsManager:s}=e,{t:c}=O("SEGViewport"),u=o.viewportId,{displaySetService:l,toolGroupService:d,segmentationService:p,customizationService:f,viewportActionCornersService:m}=a.services,g=f.getCustomization("ui.loadingIndicatorTotalPercent"),S=`SEGToolGroup-${u}`;if(n.length>1)throw new Error("SEG viewport should only have a single display set");const y=n[0],[v,b]=(0,C.useViewportGrid)(),{setPositionPresentation:h}=(0,j.usePositionPresentationStore)(),[I,w]=(0,r.useState)(y.isHydrated),[E,D]=(0,r.useState)(!y.isLoaded),[x,R]=(0,r.useState)(null),[U,k]=(0,r.useState)({percentComplete:null,totalSegments:null}),A=(0,r.useRef)(null),{viewports:L,activeViewportId:G}=v,F=y.referencedDisplaySetInstanceUID,V=l.getDisplaySetByUID(F),q=function(e,t){const{SharedFunctionalGroupsSequence:n}=t.instance,r=Array.isArray(n)?n[0]:n,{PixelMeasuresSequence:o}=r,a=Array.isArray(o)?o[0]:o,{SpacingBetweenSlices:i,SliceThickness:s}=a,c=e.images[0],u={PatientID:c.PatientID,PatientName:c.PatientName,PatientSex:c.PatientSex,PatientAge:c.PatientAge,SliceThickness:c.SliceThickness||s,StudyDate:c.StudyDate,SeriesDescription:c.SeriesDescription,SeriesInstanceUID:c.SeriesInstanceUID,SeriesNumber:c.SeriesNumber,ManufacturerModelName:c.ManufacturerModelName,SpacingBetweenSlices:c.SpacingBetweenSlices||i};return u}(V,y);A.current={displaySet:V,metadata:q};const $=()=>{R(null)},B=(0,r.useCallback)((()=>{v?.viewports.forEach((({viewportId:e})=>{s.runCommand("storePresentation",{viewportId:e})}))}),[v]),H=(0,r.useCallback)((()=>{const{component:t}=i.getModuleEntry("@ohif/extension-cornerstone.viewportModule.cornerstone");return r.createElement(t,M({},e,{displaySets:[y],viewportOptions:{viewportType:o.viewportType,toolGroupId:S,orientation:o.orientation,viewportId:o.viewportId,presentationIds:o.presentationIds},onElementEnabled:t=>{e.onElementEnabled?.(t),(e=>{R(e.detail.element)})(t)},onElementDisabled:$}))}),[u,y,S]),z=(0,r.useCallback)((e=>{j.utils.handleSegmentChange({direction:e,segDisplaySet:y,viewportId:u,selectedSegmentObjectIndex:0,segmentationService:p})}),[0]),Y=(0,r.useCallback)((()=>{s.runCommand("updateStoredSegmentationPresentation",{displaySet:y,type:_.SegmentationRepresentations.Labelmap}),s.runCommand("updateStoredPositionPresentation",{viewportId:u,displaySetInstanceUID:V.displaySetInstanceUID}),s.runCommand("loadSegmentationDisplaySetsForViewport",{viewportId:u,displaySetInstanceUIDs:[V.displaySetInstanceUID]})}),[s,u,V,y]);(0,r.useEffect)((()=>{E||N({servicesManager:a,viewportId:u,segDisplaySet:y,preHydrateCallbacks:[B],hydrateCallback:Y}).then((e=>{e&&w(!0)}))}),[a,u,y,E,Y]),(0,r.useEffect)((()=>{p.clearSegmentationRepresentations(u);const{unsubscribe:e}=p.subscribe(p.EVENTS.SEGMENTATION_LOADING_COMPLETE,(e=>{if(e.segDisplaySet.displaySetInstanceUID===y.displaySetInstanceUID&&D(!1),y?.firstSegmentedSliceImageId&&o?.presentationIds){const{firstSegmentedSliceImageId:e}=y,{presentationIds:t}=o;h(t.positionPresentationId,{viewReference:{referencedImageId:e}})}}));return()=>{e()}}),[y]),(0,r.useEffect)((()=>{const{unsubscribe:e}=p.subscribe(p.EVENTS.SEGMENT_LOADING_COMPLETE,(({percentComplete:e,numSegments:t})=>{k({percentComplete:e,totalSegments:t})}));return()=>{e()}}),[y]),(0,r.useEffect)((()=>{const e=l.subscribe(l.EVENTS.DISPLAY_SETS_REMOVED,(({displaySetInstanceUIDs:e})=>{const t=L.get(G);e.includes(t.displaySetInstanceUID)&&b.setDisplaySetsForViewport({viewportId:G,displaySetInstanceUIDs:[]})}));return()=>{e.unsubscribe()}}),[]),(0,r.useEffect)((()=>{let e=d.getToolGroup(S);if(!e)return s.runCommand("updateStoredSegmentationPresentation",{displaySet:y,type:_.SegmentationRepresentations.Labelmap}),p.clearSegmentationRepresentations(u),e=T(d,f,S),()=>{p.clearSegmentationRepresentations(u),d.destroyToolGroup(S)}}),[]);const J=(0,r.useCallback)((async()=>{B(),Y()}),[B,Y]);(0,r.useEffect)((()=>{m.addComponents([{viewportId:u,id:"viewportStatusComponent",component:P({isHydrated:I,onStatusClick:J}),indexPriority:-100,location:m.LOCATIONS.topLeft},{viewportId:u,id:"viewportActionArrowsComponent",component:r.createElement(C.ViewportActionArrows,{key:"actionArrows",onArrowsClick:z,className:u===G?"visible":"invisible group-hover/pane:visible"}),indexPriority:0,location:m.LOCATIONS.topRight}])}),[G,I,z,J,m,u]);let K=null;return A.current&&V.displaySetInstanceUID===A.current.displaySet.displaySetInstanceUID?(t&&t.length&&(K=t.map(((e,t)=>e&&r.cloneElement(e,{viewportId:u,key:t})))),r.createElement(r.Fragment,null,r.createElement("div",{className:"relative flex h-full w-full flex-row overflow-hidden"},E&&r.createElement(g,{className:"h-full w-full",totalNumbers:U.totalSegments,percentComplete:U.percentComplete,loadingText:"Loading SEG..."}),H(),K))):null}},249:(e,t)=>{"use strict";var n=Symbol.for("react.element"),r=Symbol.for("react.portal"),o=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"),u=Symbol.for("react.forward_ref"),l=Symbol.for("react.suspense"),d=Symbol.for("react.memo"),p=Symbol.for("react.lazy"),f=Symbol.iterator;var m={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},g=Object.assign,S={};function y(e,t,n){this.props=e,this.context=t,this.refs=S,this.updater=n||m}function v(){}function b(e,t,n){this.props=e,this.context=t,this.refs=S,this.updater=n||m}y.prototype.isReactComponent={},y.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")},y.prototype.forceUpdate=function(e){this.updater.enqueueForceUpdate(this,e,"forceUpdate")},v.prototype=y.prototype;var h=b.prototype=new v;h.constructor=b,g(h,y.prototype),h.isPureReactComponent=!0;var I=Array.isArray,w=Object.prototype.hasOwnProperty,E={current:null},D={key:!0,ref:!0,__self:!0,__source:!0};function O(e,t,r){var o,a={},i=null,s=null;if(null!=t)for(o in void 0!==t.ref&&(s=t.ref),void 0!==t.key&&(i=""+t.key),t)w.call(t,o)&&!D.hasOwnProperty(o)&&(a[o]=t[o]);var c=arguments.length-2;if(1===c)a.children=r;else if(1<c){for(var u=Array(c),l=0;l<c;l++)u[l]=arguments[l+2];a.children=u}if(e&&e.defaultProps)for(o in c=e.defaultProps)void 0===a[o]&&(a[o]=c[o]);return{$$typeof:n,type:e,key:i,ref:s,props:a,_owner:E.current}}function C(e){return"object"==typeof e&&null!==e&&e.$$typeof===n}var T=/\/+/g;function x(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 R(e,t,o,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 r:c=!0}}if(c)return i=i(c=e),e=""===a?"."+x(c,0):a,I(i)?(o="",null!=e&&(o=e.replace(T,"$&/")+"/"),R(i,t,o,"",(function(e){return e}))):null!=i&&(C(i)&&(i=function(e,t){return{$$typeof:n,type:e.type,key:t,ref:e.ref,props:e.props,_owner:e._owner}}(i,o+(!i.key||c&&c.key===i.key?"":(""+i.key).replace(T,"$&/")+"/")+e)),t.push(i)),1;if(c=0,a=""===a?".":a+":",I(e))for(var u=0;u<e.length;u++){var l=a+x(s=e[u],u);c+=R(s,t,o,l,i)}else if(l=function(e){return null===e||"object"!=typeof e?null:"function"==typeof(e=f&&e[f]||e["@@iterator"])?e:null}(e),"function"==typeof l)for(e=l.call(e),u=0;!(s=e.next()).done;)c+=R(s=s.value,t,o,l=a+x(s,u++),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 r=[],o=0;return R(e,r,"","",(function(e){return t.call(n,e,o++)})),r}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 j={current:null},_={transition:null},M={ReactCurrentDispatcher:j,ReactCurrentBatchConfig:_,ReactCurrentOwner:E};function U(){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(!C(e))throw Error("React.Children.only expected to receive a single React element child.");return e}},t.Component=y,t.Fragment=o,t.Profiler=i,t.PureComponent=b,t.StrictMode=a,t.Suspense=l,t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=M,t.act=U,t.cloneElement=function(e,t,r){if(null==e)throw Error("React.cloneElement(...): The argument must be a React element, but you passed "+e+".");var o=g({},e.props),a=e.key,i=e.ref,s=e._owner;if(null!=t){if(void 0!==t.ref&&(i=t.ref,s=E.current),void 0!==t.key&&(a=""+t.key),e.type&&e.type.defaultProps)var c=e.type.defaultProps;for(u in t)w.call(t,u)&&!D.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=r;else if(1<u){c=Array(u);for(var l=0;l<u;l++)c[l]=arguments[l+2];o.children=c}return{$$typeof:n,type:e.type,key:a,ref:i,props:o,_owner:s}},t.createContext=function(e){return(e={$$typeof:c,_currentValue:e,_currentValue2:e,_threadCount:0,Provider:null,Consumer:null,_defaultValue:null,_globalName:null}).Provider={$$typeof:s,_context:e},e.Consumer=e},t.createElement=O,t.createFactory=function(e){var t=O.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=C,t.lazy=function(e){return{$$typeof:p,_payload:{_status:-1,_result:e},_init:P}},t.memo=function(e,t){return{$$typeof:d,type:e,compare:void 0===t?null:t}},t.startTransition=function(e){var t=_.transition;_.transition={};try{e()}finally{_.transition=t}},t.unstable_act=U,t.useCallback=function(e,t){return j.current.useCallback(e,t)},t.useContext=function(e){return j.current.useContext(e)},t.useDebugValue=function(){},t.useDeferredValue=function(e){return j.current.useDeferredValue(e)},t.useEffect=function(e,t){return j.current.useEffect(e,t)},t.useId=function(){return j.current.useId()},t.useImperativeHandle=function(e,t,n){return j.current.useImperativeHandle(e,t,n)},t.useInsertionEffect=function(e,t){return j.current.useInsertionEffect(e,t)},t.useLayoutEffect=function(e,t){return j.current.useLayoutEffect(e,t)},t.useMemo=function(e,t){return j.current.useMemo(e,t)},t.useReducer=function(e,t,n){return j.current.useReducer(e,t,n)},t.useRef=function(e){return j.current.useRef(e)},t.useState=function(e){return j.current.useState(e)},t.useSyncExternalStore=function(e,t,n){return j.current.useSyncExternalStore(e,t,n)},t.useTransition=function(){return j.current.useTransition()},t.version="18.3.1"},326:(e,t,n)=>{"use strict";e.exports=n(249)},741:e=>{e.exports={area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0}},142:t=>{"use strict";t.exports=e},557:e=>{"use strict";e.exports=t},713:e=>{"use strict";e.exports=n},404:e=>{"use strict";e.exports=r},2:e=>{"use strict";e.exports=o},669:e=>{"use strict";e.exports=a},438:e=>{"use strict";e.exports=i},55:e=>{"use strict";e.exports=s},111:e=>{"use strict";e.exports=c}},p={};function f(e){var t=p[e];if(void 0!==t)return t.exports;var n=p[e]={exports:{}};return d[e](n,n.exports,f),n.exports}f.m=d,u=[],f.O=(e,t,n,r)=>{if(!t){var o=1/0;for(c=0;c<u.length;c++){for(var[t,n,r]=u[c],a=!0,i=0;i<t.length;i++)(!1&r||o>=r)&&Object.keys(f.O).every((e=>f.O[e](t[i])))?t.splice(i--,1):(a=!1,r<o&&(o=r));if(a){u.splice(c--,1);var s=n();void 0!==s&&(e=s)}}return e}r=r||0;for(var c=u.length;c>0&&u[c-1][2]>r;c--)u[c]=u[c-1];u[c]=[t,n,r]},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 n in t)f.o(t,n)&&!f.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},f.miniCssF=e=>{},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})},f.p="/",l={524:0},f.F.j=e=>{if(!f.o(l,e)||void 0===l[e]){l[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===l[e],f.O(0,[524],(()=>{f.E(524)}),5);var m={};return(()=>{"use strict";f.r(m),f.d(m,{default:()=>T});const e=JSON.parse('{"UU":"@ohif/extension-cornerstone-dicom-seg"}').UU,t=`${e}.sopClassHandlerModule.dicom-seg`;var n=f(326),r=f(2),o=f(557),a=f(713),i=f(142),s=f(111),c=f.n(s);const u=["1.2.840.10008.5.1.4.1.1.66.4"],l={};function d(e,n,s){const d=e[0],{StudyInstanceUID:p,SeriesInstanceUID:f,SOPInstanceUID:m,SeriesDescription:g,SeriesNumber:S,SeriesDate:y,SOPClassUID:v,wadoRoot:b,wadoUri:h,wadoUriRoot:I}=d,w={Modality:"SEG",loading:!1,isReconstructable:!0,displaySetInstanceUID:r.utils.guid(),SeriesDescription:g,SeriesNumber:S,SeriesDate:y,SOPInstanceUID:m,SeriesInstanceUID:f,StudyInstanceUID:p,SOPClassHandlerId:t,SOPClassUID:v,referencedImages:null,referencedSeriesInstanceUID:null,referencedDisplaySetInstanceUID:null,isDerivedDisplaySet:!0,isLoaded:!1,isHydrated:!1,segments:{},sopClassUids:u,instance:d,instances:[d],wadoRoot:b,wadoUriRoot:I,wadoUri:h,isOverlayDisplaySet:!0},E=d.ReferencedSeriesSequence;if(!E)return void console.error("ReferencedSeriesSequence is missing for the SEG");const D=E[0]||E;w.referencedImages=d.ReferencedSeriesSequence.ReferencedInstanceSequence,w.referencedSeriesInstanceUID=D.SeriesInstanceUID;const{displaySetService:O}=n.services,C=O.getDisplaySetsForSeries(w.referencedSeriesInstanceUID)[0];if(C)w.referencedDisplaySetInstanceUID=C.displaySetInstanceUID;else{const{unsubscribe:e}=O.subscribe(O.EVENTS.DISPLAY_SETS_ADDED,(({displaySetsAdded:t})=>{const n=t[0];n.SeriesInstanceUID===w.referencedSeriesInstanceUID&&(w.referencedDisplaySetInstanceUID=n.displaySetInstanceUID,e())}))}return w.load=async({headers:e})=>await function(e,t,n,r){const{SOPInstanceUID:s}=e,{segmentationService:u}=t.services;if((e.loading||e.isLoaded)&&l[s]&&function(e){return a.segmentation.state.getSegmentation(e.displaySetInstanceUID)}(e))return l[s];return e.loading=!0,l[s]=new Promise((async(s,l)=>{if(!e.segments||0===Object.keys(e.segments).length)try{await async function({extensionManager:e,servicesManager:t,segDisplaySet:n,headers:r}){const s=e.getModuleEntry("@ohif/extension-cornerstone.utilityModule.common"),{segmentationService:u,uiNotificationService:l}=t.services,{dicomLoaderService:d}=s.exports,p=await d.findDicomDataPromise(n,null,r),f=t.services.displaySetService.getDisplaySetByUID(n.referencedDisplaySetInstanceUID);if(!f)throw new Error("referencedDisplaySet is missing for SEG");let{imageIds:m}=f;if(!m){const{images:e}=f;m=e.map((e=>e.imageId))}const g=.001;o.eventTarget.addEventListener(i.Enums.Events.SEGMENTATION_LOAD_PROGRESS,(e=>{const{percentComplete:t}=e.detail;u._broadcastEvent(u.EVENTS.SEGMENT_LOADING_COMPLETE,{percentComplete:t})}));const S=await i.adaptersSEG.Cornerstone3D.Segmentation.createFromDICOMSegBuffer(m,p,{metadataProvider:o.metaData,tolerance:g});let y=!0;S.segMetadata.data.forEach(((e,t)=>{var n;t>0&&(e.rgba=e.RecommendedDisplayCIELabValue,e.rgba?e.rgba=(n=e.rgba,c().data.Colors.dicomlab2RGB(n).map((e=>Math.round(255*e)))):(y=!1,e.rgba=a.CONSTANTS.COLOR_LUT[t%a.CONSTANTS.COLOR_LUT.length]))})),y||l.show({title:"DICOM SEG import",message:"RecommendedDisplayCIELabValue not found for one or more segments. The default color was used instead.",type:"warning",duration:5e3});Object.assign(n,S)}({extensionManager:n,servicesManager:t,segDisplaySet:e,headers:r})}catch(t){return e.loading=!1,l(t)}u.createSegmentationForSEGDisplaySet(e).then((()=>{e.loading=!1,s()})).catch((t=>{e.loading=!1,l(t)}))})),l[s]}(w,n,s,e),[w]}const p=function({servicesManager:e,extensionManager:t}){return[{name:"dicom-seg",sopClassUids:u,getDisplaySetsFromSeries:n=>d(n,e,t)}]},g={id:"@ohif/seg",name:"Segmentations",protocolMatchingRules:[],toolGroupIds:["default"],numberOfPriorsReferenced:0,defaultViewport:{viewportOptions:{viewportType:"stack",toolGroupId:"default",allowUnmatchedView:!0,syncGroups:[{type:"hydrateseg",id:"sameFORId",source:!0,target:!0}]},displaySets:[{id:"segDisplaySetId",matchedDisplaySetsIndex:-1}]},displaySetSelectors:{segDisplaySetId:{seriesMatchingRules:[{attribute:"Modality",constraint:{equals:"SEG"}}]}},stages:[{name:"Segmentations",viewportStructure:{layoutType:"grid",properties:{rows:1,columns:1}},viewports:[{viewportOptions:{allowUnmatchedView:!0,syncGroups:[{type:"hydrateseg",id:"sameFORId",source:!0,target:!0}]},displaySets:[{id:"segDisplaySetId"}]}]}]};const S=function(){return[{name:g.id,protocol:g}]};var y=f(438);const v={NO_NEVER:-1,CANCEL:0,CREATE_REPORT:1,ADD_SERIES:2,SET_STUDY_AND_SERIES:3,NO_NOT_FOR_SERIES:4},{datasetToBlob:b}=c().data,{Cornerstone3D:{Segmentation:{generateSegmentation:h}}}=i.adaptersSEG,{Cornerstone3D:{RTSS:{generateRTSSFromSegmentations:I}}}=i.adaptersRT,{downloadDICOMData:w}=i.helpers,E=({servicesManager:e,extensionManager:t})=>{const{segmentationService:n,displaySetService:i,viewportGridService:s,toolGroupService:u}=e.services,l={loadSegmentationsForViewport:async({segmentations:e,viewportId:t})=>{const r=(({viewportId:e,viewportGridService:t})=>{const{viewports:n,activeViewportId:r}=t.getState(),o=e||r;return n.get(o)})({viewportId:t,viewportGridService:s}),o=r.displaySetInstanceUIDs[0],a=e[0],c=a.segmentationId,u=a.config.label,l=a.config.segments,d=i.getDisplaySetByUID(o);return await n.createLabelmapForDisplaySet(d,{segmentationId:c,segments:l,label:u}),n.addOrUpdateSegmentation(a),await n.addSegmentationRepresentation(r.viewportId,{segmentationId:c}),c},generateSegmentation:({segmentationId:e,options:t={}})=>{const r=a.segmentation.state.getSegmentation(e),{imageIds:i}=r.representationData.Labelmap,s=i.map((e=>o.cache.getImage(e))),u=s.map((e=>o.cache.getImage(e.referencedImageId))),l=[];let d=0;for(const e of s){const t=new Set,n=e.getPixelData(),{rows:r,columns:o}=e;for(let e=0;e<n.length;e++){const r=n[e];0!==r&&t.add(r)}l[d++]={segmentsOnLabelmap:Array.from(t),pixelData:n,rows:r,columns:o}}const p=l.map((e=>e.segmentsOnLabelmap)),f={segmentsOnLabelmap:Array.from(new Set(p.flat())),metadata:[],labelmaps2D:l},m=n.getSegmentation(e),g=n.getRepresentationsForSegmentation(e);Object.entries(m.segments).forEach((([t,r])=>{if(!r)return;const{label:o}=r,a=g[0],i=n.getSegmentColor(a.viewportId,e,r.segmentIndex),s=c().data.Colors.rgb2DICOMLAB(i.slice(0,3).map((e=>e/255))).map((e=>Math.round(e))),u={SegmentNumber:t.toString(),SegmentLabel:o,SegmentAlgorithmType:r?.algorithmType||"MANUAL",SegmentAlgorithmName:r?.algorithmName||"OHIF Brush",RecommendedDisplayCIELabValue:s,SegmentedPropertyCategoryCodeSequence:{CodeValue:"T-D0050",CodingSchemeDesignator:"SRT",CodeMeaning:"Tissue"},SegmentedPropertyTypeCodeSequence:{CodeValue:"T-D0050",CodingSchemeDesignator:"SRT",CodeMeaning:"Tissue"}};f.metadata[t]=u}));return h(u,f,o.metaData,t)},downloadSegmentation:({segmentationId:e})=>{const t=n.getSegmentation(e),r=l.generateSegmentation({segmentationId:e});w(r.dataset,`${t.label}`)},storeSegmentation:async({segmentationId:o,dataSource:a})=>{const i=n.getSegmentation(o);if(!i)throw new Error("No segmentation found");const{label:s}=i,c=a??t.getActiveDataSource(),{value:u,dataSourceName:d,action:p}=await(0,y.createReportDialogPrompt)({servicesManager:e,extensionManager:t,title:"Store Segmentation"});if(p===v.CREATE_REPORT)try{const e=d?t.getDataSources(d)[0]:c,n=l.generateSegmentation({segmentationId:o,options:{SeriesDescription:u||s||"Research Derived Series"}});if(!n||!n.dataset)throw new Error("Error during segmentation generation");const{dataset:a}=n;return await e.store.dicom(a),a.wadoRoot=e.getConfig().wadoRoot,r.DicomMetadataStore.addInstances([a],!0),a}catch(e){throw console.debug("Error storing segmentation:",e),e}},downloadRTSS:async({segmentationId:e})=>{const t=n.getSegmentation(e),o=n.getRepresentationsForSegmentation(e)[0];Object.entries(t.segments).forEach((([t,r])=>{r.color=n.getSegmentColor(o.viewportId,e,t)}));const a=await I(t,r.classes.MetadataProvider,r.DicomMetadataStore);try{const e=b(a),t=URL.createObjectURL(e);window.location.assign(t)}catch(e){console.warn(e)}}},d={loadSegmentationsForViewport:{commandFn:l.loadSegmentationsForViewport},generateSegmentation:{commandFn:l.generateSegmentation},downloadSegmentation:{commandFn:l.downloadSegmentation},storeSegmentation:{commandFn:l.storeSegmentation},downloadRTSS:{commandFn:l.downloadRTSS}};return{actions:l,definitions:d,defaultContext:"SEGMENTATION"}};function D(){return D=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)({}).hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},D.apply(null,arguments)}const O=n.lazy((()=>Promise.resolve().then(f.bind(f,292)))),C=e=>n.createElement(n.Suspense,{fallback:n.createElement("div",null,"Loading...")},n.createElement(O,e)),T={id:e,getCommandsModule:E,getToolbarModule:function({servicesManager:e}){const{segmentationService:t,toolbarService:n,toolGroupService:r}=e.services;return[{name:"evaluate.cornerstone.hasSegmentation",evaluate:({viewportId:e})=>{const n=t.getSegmentationRepresentations(e);return{disabled:!n?.length}}},{name:"evaluate.cornerstone.segmentation",evaluate:({viewportId:e,button:o,toolNames:a,disabledText:i})=>{const s=t.getSegmentationRepresentations(e);if(!s?.length)return{disabled:!0,disabledText:i??"No segmentations available"};const c=t.getActiveSegmentation(e);if(!Object.keys(c.segments).length)return{disabled:!0,disabledText:"Add segment to enable this tool"};const u=r.getToolGroupForViewport(e);if(!u)return{disabled:!0,disabledText:i??"Not available on the current viewport"};if(!a)return{disabled:!1};const l=n.getToolNameForButton(o);if(!u.hasTool(l)&&!a)return{disabled:!0,disabledText:i??"Not available on the current viewport"};return{disabled:!1,isActive:a?a.includes(u.getActivePrimaryMouseButtonTool()):u.getActivePrimaryMouseButtonTool()===l}}}]},getViewportModule:({servicesManager:e,extensionManager:t,commandsManager:r})=>[{name:"dicom-seg",component:o=>n.createElement(C,D({servicesManager:e,extensionManager:t,commandsManager:r},o))}],getSopClassHandlerModule:p,getHangingProtocolModule:S}})(),m=f.O(m)})()));
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ohif/extension-cornerstone-dicom-seg",
|
|
3
|
-
"version": "3.10.0
|
|
3
|
+
"version": "3.10.0",
|
|
4
4
|
"description": "DICOM SEG read workflow",
|
|
5
5
|
"author": "OHIF",
|
|
6
6
|
"license": "MIT",
|
|
@@ -33,10 +33,10 @@
|
|
|
33
33
|
"start": "yarn run dev"
|
|
34
34
|
},
|
|
35
35
|
"peerDependencies": {
|
|
36
|
-
"@ohif/core": "3.10.0
|
|
37
|
-
"@ohif/extension-cornerstone": "3.10.0
|
|
38
|
-
"@ohif/extension-default": "3.10.0
|
|
39
|
-
"@ohif/i18n": "3.10.0
|
|
36
|
+
"@ohif/core": "3.10.0",
|
|
37
|
+
"@ohif/extension-cornerstone": "3.10.0",
|
|
38
|
+
"@ohif/extension-default": "3.10.0",
|
|
39
|
+
"@ohif/i18n": "3.10.0",
|
|
40
40
|
"prop-types": "^15.6.2",
|
|
41
41
|
"react": "^18.3.1",
|
|
42
42
|
"react-dom": "^18.3.1",
|
|
@@ -46,9 +46,9 @@
|
|
|
46
46
|
},
|
|
47
47
|
"dependencies": {
|
|
48
48
|
"@babel/runtime": "^7.20.13",
|
|
49
|
-
"@cornerstonejs/adapters": "^
|
|
50
|
-
"@cornerstonejs/core": "^
|
|
51
|
-
"@kitware/vtk.js": "32.
|
|
49
|
+
"@cornerstonejs/adapters": "^3.9.5",
|
|
50
|
+
"@cornerstonejs/core": "^3.9.5",
|
|
51
|
+
"@kitware/vtk.js": "32.12.0",
|
|
52
52
|
"react-color": "^2.19.3"
|
|
53
53
|
}
|
|
54
54
|
}
|