@cornerstonejs/dicom-image-loader 2.0.0-beta.25 → 2.0.0-beta.27
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.
- package/dist/dynamic-import/918.min.js.map +1 -1
- package/dist/dynamic-import/cornerstoneDICOMImageLoader.min.js +1 -1
- package/dist/dynamic-import/cornerstoneDICOMImageLoader.min.js.map +1 -1
- package/dist/esm/{src/constants → constants}/index.js +1 -0
- package/dist/esm/constants/index.js.map +1 -0
- package/dist/esm/{src/constants → constants}/transferSyntaxes.js +1 -0
- package/dist/esm/constants/transferSyntaxes.js.map +1 -0
- package/dist/esm/{src/decodeImageFrameWorker.js → decodeImageFrameWorker.js} +1 -0
- package/dist/esm/decodeImageFrameWorker.js.map +1 -0
- package/dist/esm/{src/externalModules.js → externalModules.js} +1 -0
- package/dist/esm/externalModules.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/colorSpaceConverters/convertPALETTECOLOR.js +1 -0
- package/dist/esm/imageLoader/colorSpaceConverters/convertPALETTECOLOR.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/colorSpaceConverters/convertRGBColorByPixel.js +1 -0
- package/dist/esm/imageLoader/colorSpaceConverters/convertRGBColorByPixel.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/colorSpaceConverters/convertRGBColorByPlane.js +1 -0
- package/dist/esm/imageLoader/colorSpaceConverters/convertRGBColorByPlane.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/colorSpaceConverters/convertYBRFull422ByPixel.js +1 -0
- package/dist/esm/imageLoader/colorSpaceConverters/convertYBRFull422ByPixel.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/colorSpaceConverters/convertYBRFullByPixel.js +1 -0
- package/dist/esm/imageLoader/colorSpaceConverters/convertYBRFullByPixel.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/colorSpaceConverters/convertYBRFullByPlane.js +1 -0
- package/dist/esm/imageLoader/colorSpaceConverters/convertYBRFullByPlane.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/colorSpaceConverters/index.js +1 -0
- package/dist/esm/imageLoader/colorSpaceConverters/index.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/configure.js +1 -0
- package/dist/esm/imageLoader/configure.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/convertColorSpace.js +1 -0
- package/dist/esm/imageLoader/convertColorSpace.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/createImage.d.ts +1 -1
- package/dist/esm/{src/imageLoader → imageLoader}/createImage.js +1 -0
- package/dist/esm/imageLoader/createImage.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/decodeImageFrame.js +1 -0
- package/dist/esm/imageLoader/decodeImageFrame.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/decodeJPEGBaseline8BitColor.js +1 -0
- package/dist/esm/imageLoader/decodeJPEGBaseline8BitColor.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/getImageFrame.js +1 -0
- package/dist/esm/imageLoader/getImageFrame.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/getInstanceModule.js +1 -0
- package/dist/esm/imageLoader/getInstanceModule.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/getMinMax.js +1 -0
- package/dist/esm/imageLoader/getMinMax.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/getScalingParameters.js +1 -0
- package/dist/esm/imageLoader/getScalingParameters.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/imageIdToURI.js +1 -0
- package/dist/esm/imageLoader/imageIdToURI.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/index.js +1 -0
- package/dist/esm/imageLoader/index.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/internal/index.js +1 -0
- package/dist/esm/imageLoader/internal/index.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/internal/options.js +1 -0
- package/dist/esm/imageLoader/internal/options.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/internal/rangeRequest.js +1 -0
- package/dist/esm/imageLoader/internal/rangeRequest.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/internal/streamRequest.js +1 -0
- package/dist/esm/imageLoader/internal/streamRequest.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/internal/xhrRequest.js +1 -0
- package/dist/esm/imageLoader/internal/xhrRequest.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/isColorConversionRequired.js +1 -0
- package/dist/esm/imageLoader/isColorConversionRequired.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/isJPEGBaseline8BitColor.js +1 -0
- package/dist/esm/imageLoader/isJPEGBaseline8BitColor.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/isNMReconstructable.js +1 -0
- package/dist/esm/imageLoader/isNMReconstructable.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/registerLoaders.js +1 -0
- package/dist/esm/imageLoader/registerLoaders.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/combineFrameInstance.js +1 -0
- package/dist/esm/imageLoader/wadors/combineFrameInstance.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/extractMultipart.js +1 -0
- package/dist/esm/imageLoader/wadors/extractMultipart.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/findIndexOfString.js +1 -0
- package/dist/esm/imageLoader/wadors/findIndexOfString.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/getImageQualityStatus.js +1 -0
- package/dist/esm/imageLoader/wadors/getImageQualityStatus.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/getPixelData.js +1 -0
- package/dist/esm/imageLoader/wadors/getPixelData.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/getTagValue.js +1 -0
- package/dist/esm/imageLoader/wadors/getTagValue.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/index.js +1 -0
- package/dist/esm/imageLoader/wadors/index.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/loadImage.js +1 -0
- package/dist/esm/imageLoader/wadors/loadImage.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/loadImage_test.js +1 -0
- package/dist/esm/imageLoader/wadors/loadImage_test.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/NMHelpers.js +1 -0
- package/dist/esm/imageLoader/wadors/metaData/NMHelpers.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/USHelpers.js +1 -0
- package/dist/esm/imageLoader/wadors/metaData/USHelpers.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/extractPositioningFromMetadata.js +1 -0
- package/dist/esm/imageLoader/wadors/metaData/extractPositioningFromMetadata.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/getFirstNumberValue.js +1 -0
- package/dist/esm/imageLoader/wadors/metaData/getFirstNumberValue.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/getNumberString.js +1 -0
- package/dist/esm/imageLoader/wadors/metaData/getNumberString.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/getNumberValue.js +1 -0
- package/dist/esm/imageLoader/wadors/metaData/getNumberValue.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/getNumberValues.js +1 -0
- package/dist/esm/imageLoader/wadors/metaData/getNumberValues.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/getOverlayPlaneModule.js +1 -0
- package/dist/esm/imageLoader/wadors/metaData/getOverlayPlaneModule.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/getSequenceItems.js +1 -0
- package/dist/esm/imageLoader/wadors/metaData/getSequenceItems.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/getValue.js +1 -0
- package/dist/esm/imageLoader/wadors/metaData/getValue.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/index.js +1 -0
- package/dist/esm/imageLoader/wadors/metaData/index.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/metaDataProvider.js +3 -2
- package/dist/esm/imageLoader/wadors/metaData/metaDataProvider.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaDataManager.d.ts +2 -2
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaDataManager.js +6 -5
- package/dist/esm/imageLoader/wadors/metaDataManager.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadors/register.js +1 -0
- package/dist/esm/imageLoader/wadors/register.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/combineFrameInstanceDataset.js +1 -0
- package/dist/esm/imageLoader/wadouri/combineFrameInstanceDataset.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/dataSetCacheManager.js +1 -0
- package/dist/esm/imageLoader/wadouri/dataSetCacheManager.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/dataSetCacheManager_test.js +1 -0
- package/dist/esm/imageLoader/wadouri/dataSetCacheManager_test.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/dataset-from-partial-content.js +1 -0
- package/dist/esm/imageLoader/wadouri/dataset-from-partial-content.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/fileManager.js +1 -0
- package/dist/esm/imageLoader/wadouri/fileManager.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/getEncapsulatedImageFrame.js +1 -0
- package/dist/esm/imageLoader/wadouri/getEncapsulatedImageFrame.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/getPixelData.js +1 -0
- package/dist/esm/imageLoader/wadouri/getPixelData.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/getUncompressedImageFrame.js +1 -0
- package/dist/esm/imageLoader/wadouri/getUncompressedImageFrame.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/index.js +1 -0
- package/dist/esm/imageLoader/wadouri/index.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/loadFileRequest.js +1 -0
- package/dist/esm/imageLoader/wadouri/loadFileRequest.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/loadImage.js +1 -0
- package/dist/esm/imageLoader/wadouri/loadImage.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/loadedDataSets.js +1 -0
- package/dist/esm/imageLoader/wadouri/loadedDataSets.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/metaData/USHelpers.js +1 -0
- package/dist/esm/imageLoader/wadouri/metaData/USHelpers.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/metaData/extractPositioningFromDataset.js +1 -0
- package/dist/esm/imageLoader/wadouri/metaData/extractPositioningFromDataset.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/metaData/getImagePixelModule.js +1 -0
- package/dist/esm/imageLoader/wadouri/metaData/getImagePixelModule.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/metaData/getLUTs.js +1 -0
- package/dist/esm/imageLoader/wadouri/metaData/getLUTs.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/metaData/getModalityLUTOutputPixelRepresentation.js +1 -0
- package/dist/esm/imageLoader/wadouri/metaData/getModalityLUTOutputPixelRepresentation.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/metaData/getNumberValues.js +1 -0
- package/dist/esm/imageLoader/wadouri/metaData/getNumberValues.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/metaData/getOverlayPlaneModule.js +1 -0
- package/dist/esm/imageLoader/wadouri/metaData/getOverlayPlaneModule.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/metaData/index.js +1 -0
- package/dist/esm/imageLoader/wadouri/metaData/index.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/metaData/metaDataProvider.js +1 -0
- package/dist/esm/imageLoader/wadouri/metaData/metaDataProvider.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/parseImageId.js +1 -0
- package/dist/esm/imageLoader/wadouri/parseImageId.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/register.js +1 -0
- package/dist/esm/imageLoader/wadouri/register.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/retrieveMultiframeDataset.js +1 -0
- package/dist/esm/imageLoader/wadouri/retrieveMultiframeDataset.js.map +1 -0
- package/dist/esm/{src/imageLoader → imageLoader}/wadouri/unpackBinaryFrame.js +1 -0
- package/dist/esm/imageLoader/wadouri/unpackBinaryFrame.js.map +1 -0
- package/dist/esm/{src/shared → shared}/decoders/decodeBigEndian.d.ts +1 -1
- package/dist/esm/{src/shared → shared}/decoders/decodeBigEndian.js +1 -0
- package/dist/esm/shared/decoders/decodeBigEndian.js.map +1 -0
- package/dist/esm/{src/shared → shared}/decoders/decodeHTJ2K.js +1 -0
- package/dist/esm/shared/decoders/decodeHTJ2K.js.map +1 -0
- package/dist/esm/{src/shared → shared}/decoders/decodeJPEG2000.d.ts +1 -1
- package/dist/esm/{src/shared → shared}/decoders/decodeJPEG2000.js +1 -0
- package/dist/esm/shared/decoders/decodeJPEG2000.js.map +1 -0
- package/dist/esm/{src/shared → shared}/decoders/decodeJPEGBaseline12Bit-js.d.ts +1 -1
- package/dist/esm/{src/shared → shared}/decoders/decodeJPEGBaseline12Bit-js.js +1 -0
- package/dist/esm/shared/decoders/decodeJPEGBaseline12Bit-js.js.map +1 -0
- package/dist/esm/shared/decoders/decodeJPEGBaseline12Bit-wasm-not-yet-working.js +1 -0
- package/dist/esm/shared/decoders/decodeJPEGBaseline12Bit-wasm-not-yet-working.js.map +1 -0
- package/dist/esm/{src/shared → shared}/decoders/decodeJPEGBaseline8Bit.d.ts +1 -1
- package/dist/esm/{src/shared → shared}/decoders/decodeJPEGBaseline8Bit.js +1 -0
- package/dist/esm/shared/decoders/decodeJPEGBaseline8Bit.js.map +1 -0
- package/dist/esm/{src/shared → shared}/decoders/decodeJPEGLS.d.ts +1 -1
- package/dist/esm/{src/shared → shared}/decoders/decodeJPEGLS.js +1 -0
- package/dist/esm/shared/decoders/decodeJPEGLS.js.map +1 -0
- package/dist/esm/{src/shared → shared}/decoders/decodeJPEGLossless.d.ts +1 -1
- package/dist/esm/{src/shared → shared}/decoders/decodeJPEGLossless.js +1 -0
- package/dist/esm/shared/decoders/decodeJPEGLossless.js.map +1 -0
- package/dist/esm/{src/shared → shared}/decoders/decodeLittleEndian.js +1 -0
- package/dist/esm/shared/decoders/decodeLittleEndian.js.map +1 -0
- package/dist/esm/{src/shared → shared}/decoders/decodeRLE.js +1 -0
- package/dist/esm/shared/decoders/decodeRLE.js.map +1 -0
- package/dist/esm/{src/shared → shared}/getMinMax.js +1 -0
- package/dist/esm/shared/getMinMax.js.map +1 -0
- package/dist/esm/{src/shared → shared}/getMinMax_test.js +1 -0
- package/dist/esm/shared/getMinMax_test.js.map +1 -0
- package/dist/esm/{src/shared → shared}/getPixelDataTypeFromMinMax.js +1 -0
- package/dist/esm/shared/getPixelDataTypeFromMinMax.js.map +1 -0
- package/dist/esm/{src/shared → shared}/isColorImage.js +1 -0
- package/dist/esm/shared/isColorImage.js.map +1 -0
- package/dist/esm/{src/shared → shared}/scaling/bilinear.js +1 -0
- package/dist/esm/shared/scaling/bilinear.js.map +1 -0
- package/dist/esm/{src/shared → shared}/scaling/replicate.js +1 -0
- package/dist/esm/shared/scaling/replicate.js.map +1 -0
- package/dist/esm/{src/shared → shared}/scaling/scaleArray.js +1 -0
- package/dist/esm/shared/scaling/scaleArray.js.map +1 -0
- package/dist/esm/types/DICOMLoaderDataSetWithFetchMore.js +1 -0
- package/dist/esm/types/DICOMLoaderDataSetWithFetchMore.js.map +1 -0
- package/dist/esm/types/DICOMLoaderIImage.js +1 -0
- package/dist/esm/types/DICOMLoaderIImage.js.map +1 -0
- package/dist/esm/types/DICOMLoaderImageOptions.js +1 -0
- package/dist/esm/types/DICOMLoaderImageOptions.js.map +1 -0
- package/dist/esm/types/LoadRequestFunction.js +1 -0
- package/dist/esm/types/LoadRequestFunction.js.map +1 -0
- package/dist/esm/types/LoaderDecodeOptions.js +1 -0
- package/dist/esm/types/LoaderDecodeOptions.js.map +1 -0
- package/dist/esm/types/LoaderOptions.js +1 -0
- package/dist/esm/types/LoaderOptions.js.map +1 -0
- package/dist/esm/types/LutType.js +1 -0
- package/dist/esm/types/LutType.js.map +1 -0
- package/dist/esm/types/WADORSMetaData.js +1 -0
- package/dist/esm/types/WADORSMetaData.js.map +1 -0
- package/dist/esm/types/WebWorkerTypes.js +1 -0
- package/dist/esm/types/WebWorkerTypes.js.map +1 -0
- package/dist/esm/types/XHRRequest.js +1 -0
- package/dist/esm/types/XHRRequest.js.map +1 -0
- package/dist/esm/types/index.js +1 -0
- package/dist/esm/types/index.js.map +1 -0
- package/dist/esm/version.js +2 -0
- package/dist/esm/version.js.map +1 -0
- package/package.json +55 -23
- package/dist/920.bundle.min.js +0 -3
- package/dist/920.bundle.min.js.LICENSE.txt +0 -5
- package/dist/920.bundle.min.js.map +0 -1
- package/dist/cornerstoneDICOMImageLoader.bundle.min.js +0 -2
- package/dist/cornerstoneDICOMImageLoader.bundle.min.js.map +0 -1
- package/dist/esm/codecs/jpeg.d.ts +0 -1
- package/dist/esm/codecs/jpeg.js +0 -890
- package/dist/esm/codecs/jpegLossless.d.ts +0 -7
- package/dist/esm/codecs/jpegLossless.js +0 -1219
- package/dist/esm/src/shared/decoders/decodeJPEGBaseline12Bit-wasm-not-yet-working.js +0 -1
- package/dist/esm/src/types/DICOMLoaderDataSetWithFetchMore.js +0 -1
- package/dist/esm/src/types/DICOMLoaderIImage.js +0 -1
- package/dist/esm/src/types/DICOMLoaderImageOptions.js +0 -1
- package/dist/esm/src/types/LoadRequestFunction.js +0 -1
- package/dist/esm/src/types/LoaderDecodeOptions.js +0 -1
- package/dist/esm/src/types/LoaderOptions.js +0 -1
- package/dist/esm/src/types/LutType.js +0 -1
- package/dist/esm/src/types/WADORSMetaData.js +0 -1
- package/dist/esm/src/types/WebWorkerTypes.js +0 -1
- package/dist/esm/src/types/XHRRequest.js +0 -1
- package/dist/esm/src/types/index.js +0 -1
- package/dist/esm/src/version.js +0 -1
- /package/dist/esm/{src/constants → constants}/index.d.ts +0 -0
- /package/dist/esm/{src/constants → constants}/transferSyntaxes.d.ts +0 -0
- /package/dist/esm/{src/decodeImageFrameWorker.d.ts → decodeImageFrameWorker.d.ts} +0 -0
- /package/dist/esm/{src/externalModules.d.ts → externalModules.d.ts} +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/colorSpaceConverters/convertPALETTECOLOR.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/colorSpaceConverters/convertRGBColorByPixel.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/colorSpaceConverters/convertRGBColorByPlane.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/colorSpaceConverters/convertYBRFull422ByPixel.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/colorSpaceConverters/convertYBRFullByPixel.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/colorSpaceConverters/convertYBRFullByPlane.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/colorSpaceConverters/index.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/configure.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/convertColorSpace.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/decodeImageFrame.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/decodeJPEGBaseline8BitColor.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/getImageFrame.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/getInstanceModule.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/getMinMax.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/getScalingParameters.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/imageIdToURI.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/index.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/internal/index.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/internal/options.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/internal/rangeRequest.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/internal/streamRequest.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/internal/xhrRequest.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/isColorConversionRequired.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/isJPEGBaseline8BitColor.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/isNMReconstructable.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/registerLoaders.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/combineFrameInstance.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/extractMultipart.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/findIndexOfString.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/getImageQualityStatus.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/getPixelData.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/getTagValue.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/index.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/loadImage.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/loadImage_test.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/NMHelpers.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/USHelpers.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/extractPositioningFromMetadata.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/getFirstNumberValue.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/getNumberString.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/getNumberValue.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/getNumberValues.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/getOverlayPlaneModule.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/getSequenceItems.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/getValue.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/index.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/metaData/metaDataProvider.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadors/register.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/combineFrameInstanceDataset.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/dataSetCacheManager.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/dataSetCacheManager_test.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/dataset-from-partial-content.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/fileManager.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/getEncapsulatedImageFrame.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/getPixelData.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/getUncompressedImageFrame.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/index.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/loadFileRequest.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/loadImage.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/loadedDataSets.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/metaData/USHelpers.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/metaData/extractPositioningFromDataset.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/metaData/getImagePixelModule.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/metaData/getLUTs.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/metaData/getModalityLUTOutputPixelRepresentation.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/metaData/getNumberValues.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/metaData/getOverlayPlaneModule.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/metaData/index.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/metaData/metaDataProvider.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/parseImageId.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/register.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/retrieveMultiframeDataset.d.ts +0 -0
- /package/dist/esm/{src/imageLoader → imageLoader}/wadouri/unpackBinaryFrame.d.ts +0 -0
- /package/dist/esm/{src/shared → shared}/decoders/decodeHTJ2K.d.ts +0 -0
- /package/dist/esm/{src/shared → shared}/decoders/decodeJPEGBaseline12Bit-wasm-not-yet-working.d.ts +0 -0
- /package/dist/esm/{src/shared → shared}/decoders/decodeLittleEndian.d.ts +0 -0
- /package/dist/esm/{src/shared → shared}/decoders/decodeRLE.d.ts +0 -0
- /package/dist/esm/{src/shared → shared}/getMinMax.d.ts +0 -0
- /package/dist/esm/{src/shared → shared}/getMinMax_test.d.ts +0 -0
- /package/dist/esm/{src/shared → shared}/getPixelDataTypeFromMinMax.d.ts +0 -0
- /package/dist/esm/{src/shared → shared}/isColorImage.d.ts +0 -0
- /package/dist/esm/{src/shared → shared}/scaling/bilinear.d.ts +0 -0
- /package/dist/esm/{src/shared → shared}/scaling/replicate.d.ts +0 -0
- /package/dist/esm/{src/shared → shared}/scaling/scaleArray.d.ts +0 -0
- /package/dist/esm/{src/types → types}/DICOMLoaderDataSetWithFetchMore.d.ts +0 -0
- /package/dist/esm/{src/types → types}/DICOMLoaderIImage.d.ts +0 -0
- /package/dist/esm/{src/types → types}/DICOMLoaderImageOptions.d.ts +0 -0
- /package/dist/esm/{src/types → types}/LoadRequestFunction.d.ts +0 -0
- /package/dist/esm/{src/types → types}/LoaderDecodeOptions.d.ts +0 -0
- /package/dist/esm/{src/types → types}/LoaderOptions.d.ts +0 -0
- /package/dist/esm/{src/types → types}/LutType.d.ts +0 -0
- /package/dist/esm/{src/types → types}/WADORSMetaData.d.ts +0 -0
- /package/dist/esm/{src/types → types}/WebWorkerTypes.d.ts +0 -0
- /package/dist/esm/{src/types → types}/XHRRequest.d.ts +0 -0
- /package/dist/esm/{src/types → types}/index.d.ts +0 -0
- /package/dist/esm/{src/version.d.ts → version.d.ts} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"918.min.js","mappings":"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","sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/runtime/chunk loaded","webpack:///webpack/runtime/create fake namespace object","webpack:///webpack/runtime/startup chunk dependencies","webpack:///./shared/decoders/decodeLittleEndian.ts","webpack:///./shared/decoders/decodeBigEndian.ts","webpack:///./shared/decoders/decodeRLE.ts","webpack:///./shared/decoders/decodeJPEGBaseline8Bit.ts","webpack:///./shared/decoders/decodeJPEGBaseline12Bit-js.ts","webpack:///./shared/decoders/decodeJPEGLossless.ts","webpack:///./shared/decoders/decodeJPEGLS.ts","webpack:///./shared/decoders/decodeJPEG2000.ts","webpack:///./shared/decoders/decodeHTJ2K.ts","webpack:///./shared/getMinMax.ts","webpack:///./decodeImageFrameWorker.js","webpack:///./shared/scaling/bilinear.ts","webpack:///./shared/scaling/replicate.ts","webpack:///./shared/isColorImage.ts","webpack:///./shared/scaling/scaleArray.ts","webpack:///./shared/getPixelDataTypeFromMinMax.ts","webpack:///webpack/bootstrap","webpack:///webpack/runtime/compat get default export","webpack:///webpack/runtime/define property getters","webpack:///webpack/runtime/ensure chunk","webpack:///webpack/runtime/get javascript chunk filename","webpack:///webpack/runtime/global","webpack:///webpack/runtime/hasOwnProperty shorthand","webpack:///webpack/runtime/make namespace object","webpack:///webpack/runtime/publicPath","webpack:///webpack/runtime/importScripts chunk loading","webpack:///webpack/startup"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"918\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"918\"] = factory();\n\telse\n\t\troot[\"918\"] = factory();\n})(this, () => {\nreturn ","var deferred = [];\n__webpack_require__.O = (result, chunkIds, fn, priority) => {\n\tif(chunkIds) {\n\t\tpriority = priority || 0;\n\t\tfor(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];\n\t\tdeferred[i] = [chunkIds, fn, priority];\n\t\treturn;\n\t}\n\tvar notFulfilled = Infinity;\n\tfor (var i = 0; i < deferred.length; i++) {\n\t\tvar [chunkIds, fn, priority] = deferred[i];\n\t\tvar fulfilled = true;\n\t\tfor (var j = 0; j < chunkIds.length; j++) {\n\t\t\tif ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every((key) => (__webpack_require__.O[key](chunkIds[j])))) {\n\t\t\t\tchunkIds.splice(j--, 1);\n\t\t\t} else {\n\t\t\t\tfulfilled = false;\n\t\t\t\tif(priority < notFulfilled) notFulfilled = priority;\n\t\t\t}\n\t\t}\n\t\tif(fulfilled) {\n\t\t\tdeferred.splice(i--, 1)\n\t\t\tvar r = fn();\n\t\t\tif (r !== undefined) result = r;\n\t\t}\n\t}\n\treturn result;\n};","var getProto = Object.getPrototypeOf ? (obj) => (Object.getPrototypeOf(obj)) : (obj) => (obj.__proto__);\nvar leafPrototypes;\n// create a fake namespace object\n// mode & 1: value is a module id, require it\n// mode & 2: merge all properties of value into the ns\n// mode & 4: return value when already ns object\n// mode & 16: return value when it's Promise-like\n// mode & 8|1: behave like require\n__webpack_require__.t = function(value, mode) {\n\tif(mode & 1) value = this(value);\n\tif(mode & 8) return value;\n\tif(typeof value === 'object' && value) {\n\t\tif((mode & 4) && value.__esModule) return value;\n\t\tif((mode & 16) && typeof value.then === 'function') return value;\n\t}\n\tvar ns = Object.create(null);\n\t__webpack_require__.r(ns);\n\tvar def = {};\n\tleafPrototypes = leafPrototypes || [null, getProto({}), getProto([]), getProto(getProto)];\n\tfor(var current = mode & 2 && value; typeof current == 'object' && !~leafPrototypes.indexOf(current); current = getProto(current)) {\n\t\tObject.getOwnPropertyNames(current).forEach((key) => (def[key] = () => (value[key])));\n\t}\n\tdef['default'] = () => (value);\n\t__webpack_require__.d(ns, def);\n\treturn ns;\n};","var next = __webpack_require__.x;\n__webpack_require__.x = () => {\n\treturn __webpack_require__.e(958).then(next);\n};","import type { ByteArray } from 'dicom-parser';\nimport type { Types } from '@cornerstonejs/core';\n\nasync function decodeLittleEndian(\n imageFrame: Types.IImageFrame,\n pixelData: ByteArray\n): Promise<Types.IImageFrame> {\n let arrayBuffer = pixelData.buffer;\n\n let offset = pixelData.byteOffset;\n const length = pixelData.length;\n\n if (imageFrame.bitsAllocated === 16) {\n // if pixel data is not aligned on even boundary, shift it so we can create the 16 bit array\n // buffers on it\n if (offset % 2) {\n arrayBuffer = arrayBuffer.slice(offset);\n offset = 0;\n }\n\n if (imageFrame.pixelRepresentation === 0) {\n imageFrame.pixelData = new Uint16Array(arrayBuffer, offset, length / 2);\n } else {\n imageFrame.pixelData = new Int16Array(arrayBuffer, offset, length / 2);\n }\n } else if (imageFrame.bitsAllocated === 8 || imageFrame.bitsAllocated === 1) {\n imageFrame.pixelData = pixelData;\n } else if (imageFrame.bitsAllocated === 32) {\n // if pixel data is not aligned on even boundary, shift it\n if (offset % 2) {\n arrayBuffer = arrayBuffer.slice(offset);\n offset = 0;\n }\n\n imageFrame.pixelData = new Float32Array(arrayBuffer, offset, length / 4);\n }\n\n return imageFrame;\n}\n\nexport default decodeLittleEndian;\n","import type { ByteArray } from 'dicom-parser';\nimport type { Types } from '@cornerstonejs/core/src';\n\n/* eslint no-bitwise: 0 */\nfunction swap16(val) {\n return ((val & 0xff) << 8) | ((val >> 8) & 0xff);\n}\n\nasync function decodeBigEndian(\n imageFrame: Types.IImageFrame,\n pixelData: ByteArray\n): Promise<Types.IImageFrame> {\n if (imageFrame.bitsAllocated === 16) {\n let arrayBuffer = pixelData.buffer;\n\n let offset = pixelData.byteOffset;\n const length = pixelData.length;\n // if pixel data is not aligned on even boundary, shift it so we can create the 16 bit array\n // buffers on it\n\n if (offset % 2) {\n arrayBuffer = arrayBuffer.slice(offset);\n offset = 0;\n }\n\n if (imageFrame.pixelRepresentation === 0) {\n imageFrame.pixelData = new Uint16Array(arrayBuffer, offset, length / 2);\n } else {\n imageFrame.pixelData = new Int16Array(arrayBuffer, offset, length / 2);\n }\n // Do the byte swap\n for (let i = 0; i < imageFrame.pixelData.length; i++) {\n imageFrame.pixelData[i] = swap16(imageFrame.pixelData[i]);\n }\n } else if (imageFrame.bitsAllocated === 8) {\n imageFrame.pixelData = pixelData;\n }\n\n return imageFrame;\n}\n\nexport default decodeBigEndian;\n","import type { ByteArray } from 'dicom-parser';\nimport type { Types } from '@cornerstonejs/core';\n\nasync function decodeRLE(\n imageFrame: Types.IImageFrame,\n pixelData: ByteArray\n): Promise<Types.IImageFrame> {\n if (imageFrame.bitsAllocated === 8) {\n if (imageFrame.planarConfiguration) {\n return decode8Planar(imageFrame, pixelData);\n }\n\n return decode8(imageFrame, pixelData);\n } else if (imageFrame.bitsAllocated === 16) {\n return decode16(imageFrame, pixelData);\n }\n\n throw new Error('unsupported pixel format for RLE');\n}\n\nfunction decode8(imageFrame: Types.IImageFrame, pixelData: ByteArray) {\n const frameData = pixelData;\n const frameSize = imageFrame.rows * imageFrame.columns;\n const outFrame = new ArrayBuffer(frameSize * imageFrame.samplesPerPixel);\n const header = new DataView(frameData.buffer, frameData.byteOffset);\n const data = new Int8Array(frameData.buffer, frameData.byteOffset);\n const out = new Int8Array(outFrame);\n\n let outIndex = 0;\n const numSegments = header.getInt32(0, true);\n\n for (let s = 0; s < numSegments; ++s) {\n outIndex = s;\n\n let inIndex = header.getInt32((s + 1) * 4, true);\n\n let maxIndex = header.getInt32((s + 2) * 4, true);\n\n if (maxIndex === 0) {\n maxIndex = frameData.length;\n }\n\n const endOfSegment = frameSize * numSegments;\n\n while (inIndex < maxIndex) {\n const n = data[inIndex++];\n\n if (n >= 0 && n <= 127) {\n // copy n bytes\n for (let i = 0; i < n + 1 && outIndex < endOfSegment; ++i) {\n out[outIndex] = data[inIndex++];\n outIndex += imageFrame.samplesPerPixel;\n }\n } else if (n <= -1 && n >= -127) {\n const value = data[inIndex++];\n // run of n bytes\n\n for (let j = 0; j < -n + 1 && outIndex < endOfSegment; ++j) {\n out[outIndex] = value;\n outIndex += imageFrame.samplesPerPixel;\n }\n } /* else if (n === -128) {\n\n } // do nothing */\n }\n }\n imageFrame.pixelData = new Uint8Array(outFrame);\n\n return imageFrame;\n}\n\nfunction decode8Planar(imageFrame: Types.IImageFrame, pixelData: ByteArray) {\n const frameData = pixelData;\n const frameSize = imageFrame.rows * imageFrame.columns;\n const outFrame = new ArrayBuffer(frameSize * imageFrame.samplesPerPixel);\n const header = new DataView(frameData.buffer, frameData.byteOffset);\n const data = new Int8Array(frameData.buffer, frameData.byteOffset);\n const out = new Int8Array(outFrame);\n\n let outIndex = 0;\n const numSegments = header.getInt32(0, true);\n\n for (let s = 0; s < numSegments; ++s) {\n outIndex = s * frameSize;\n\n let inIndex = header.getInt32((s + 1) * 4, true);\n\n let maxIndex = header.getInt32((s + 2) * 4, true);\n\n if (maxIndex === 0) {\n maxIndex = frameData.length;\n }\n\n const endOfSegment = frameSize * numSegments;\n\n while (inIndex < maxIndex) {\n const n = data[inIndex++];\n\n if (n >= 0 && n <= 127) {\n // copy n bytes\n for (let i = 0; i < n + 1 && outIndex < endOfSegment; ++i) {\n out[outIndex] = data[inIndex++];\n outIndex++;\n }\n } else if (n <= -1 && n >= -127) {\n const value = data[inIndex++];\n // run of n bytes\n\n for (let j = 0; j < -n + 1 && outIndex < endOfSegment; ++j) {\n out[outIndex] = value;\n outIndex++;\n }\n } /* else if (n === -128) {\n\n } // do nothing */\n }\n }\n imageFrame.pixelData = new Uint8Array(outFrame);\n\n return imageFrame;\n}\n\nfunction decode16(imageFrame: Types.IImageFrame, pixelData: ByteArray) {\n const frameData = pixelData;\n const frameSize = imageFrame.rows * imageFrame.columns;\n const outFrame = new ArrayBuffer(frameSize * imageFrame.samplesPerPixel * 2);\n\n const header = new DataView(frameData.buffer, frameData.byteOffset);\n const data = new Int8Array(frameData.buffer, frameData.byteOffset);\n const out = new Int8Array(outFrame);\n\n const numSegments = header.getInt32(0, true);\n\n for (let s = 0; s < numSegments; ++s) {\n let outIndex = 0;\n const highByte = s === 0 ? 1 : 0;\n\n let inIndex = header.getInt32((s + 1) * 4, true);\n\n let maxIndex = header.getInt32((s + 2) * 4, true);\n\n if (maxIndex === 0) {\n maxIndex = frameData.length;\n }\n\n while (inIndex < maxIndex) {\n const n = data[inIndex++];\n\n if (n >= 0 && n <= 127) {\n for (let i = 0; i < n + 1 && outIndex < frameSize; ++i) {\n out[outIndex * 2 + highByte] = data[inIndex++];\n outIndex++;\n }\n } else if (n <= -1 && n >= -127) {\n const value = data[inIndex++];\n\n for (let j = 0; j < -n + 1 && outIndex < frameSize; ++j) {\n out[outIndex * 2 + highByte] = value;\n outIndex++;\n }\n } /* else if (n === -128) {\n\n } // do nothing */\n }\n }\n if (imageFrame.pixelRepresentation === 0) {\n imageFrame.pixelData = new Uint16Array(outFrame);\n } else {\n imageFrame.pixelData = new Int16Array(outFrame);\n }\n\n return imageFrame;\n}\n\nexport default decodeRLE;\n","import type {\n LibJpegTurbo8Bit,\n OpenJpegModule,\n} from '@cornerstonejs/codec-libjpeg-turbo-8bit/dist/libjpegturbowasm_decode';\nimport type { ByteArray } from 'dicom-parser';\n// @ts-ignore\nimport libjpegTurboFactory from '@cornerstonejs/codec-libjpeg-turbo-8bit/decodewasmjs';\n\n// @ts-ignore\n// import libjpegTurboWasm from '@cornerstonejs/codec-libjpeg-turbo-8bit/decodewasm';\nconst libjpegTurboWasm = new URL(\n '@cornerstonejs/codec-libjpeg-turbo-8bit/decodewasm',\n import.meta.url\n);\nimport type { Types } from '@cornerstonejs/core/src';\n\nconst local: {\n codec: OpenJpegModule;\n decoder: LibJpegTurbo8Bit;\n} = {\n codec: undefined,\n decoder: undefined,\n};\n\nfunction initLibjpegTurbo(): Promise<void> {\n if (local.codec) {\n return Promise.resolve();\n }\n\n const libjpegTurboModule = libjpegTurboFactory({\n locateFile: (f) => {\n if (f.endsWith('.wasm')) {\n return libjpegTurboWasm.toString();\n }\n\n return f;\n },\n });\n\n return new Promise((resolve, reject) => {\n libjpegTurboModule.then((instance) => {\n local.codec = instance;\n local.decoder = new instance.JPEGDecoder();\n resolve();\n }, reject);\n });\n}\n\n// imageFrame.pixelRepresentation === 1 <-- Signed\n/**\n *\n * @param {*} compressedImageFrame\n * @param {object} imageInfo\n * @param {boolean} imageInfo.signed -\n */\nasync function decodeAsync(\n compressedImageFrame,\n imageInfo\n): Promise<Types.IImageFrame> {\n await initLibjpegTurbo();\n const decoder = local.decoder;\n\n // get pointer to the source/encoded bit stream buffer in WASM memory\n // that can hold the encoded bitstream\n const encodedBufferInWASM = decoder.getEncodedBuffer(\n compressedImageFrame.length\n );\n\n // copy the encoded bitstream into WASM memory buffer\n encodedBufferInWASM.set(compressedImageFrame);\n\n // decode it\n decoder.decode();\n\n // get information about the decoded image\n const frameInfo = decoder.getFrameInfo();\n\n // get the decoded pixels\n const decodedPixelsInWASM = decoder.getDecodedBuffer();\n\n const encodedImageInfo = {\n columns: frameInfo.width,\n rows: frameInfo.height,\n bitsPerPixel: frameInfo.bitsPerSample,\n signed: imageInfo.signed,\n bytesPerPixel: imageInfo.bytesPerPixel,\n componentsPerPixel: frameInfo.componentCount,\n };\n\n const pixelData = getPixelData(frameInfo, decodedPixelsInWASM);\n\n const encodeOptions = {\n frameInfo,\n };\n\n return {\n ...imageInfo,\n pixelData,\n imageInfo: encodedImageInfo,\n encodeOptions,\n ...encodeOptions,\n ...encodedImageInfo,\n };\n}\n\nfunction getPixelData(frameInfo, decodedBuffer: ByteArray) {\n if (frameInfo.isSigned) {\n return new Int8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n }\n\n return new Uint8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n}\n\nexport default decodeAsync;\n","import type { ByteArray } from 'dicom-parser';\nimport type { Types } from '@cornerstonejs/core/src';\nimport type { WebWorkerDecodeConfig } from '../../types';\n\nconst local = {\n JpegImage: undefined,\n decodeConfig: {} as WebWorkerDecodeConfig,\n};\n\nexport function initialize(\n decodeConfig?: WebWorkerDecodeConfig\n): Promise<void> {\n local.decodeConfig = decodeConfig;\n\n if (local.JpegImage) {\n return Promise.resolve();\n }\n\n return new Promise((resolve, reject) => {\n // @ts-ignore\n import('../../../codecs/jpeg').then(({ JpegImage }) => {\n local.JpegImage = JpegImage;\n resolve();\n }, reject);\n });\n}\n\nasync function decodeJPEGBaseline12BitAsync(\n imageFrame: Types.IImageFrame,\n pixelData: ByteArray\n): Promise<Types.IImageFrame> {\n // check to make sure codec is loaded\n await initialize();\n if (typeof local.JpegImage === 'undefined') {\n throw new Error('No JPEG Baseline decoder loaded');\n }\n const jpeg = new local.JpegImage();\n\n jpeg.parse(pixelData);\n\n // Do not use the internal jpeg.js color transformation,\n // since we will handle this afterwards\n jpeg.colorTransform = false;\n\n if (imageFrame.bitsAllocated === 8) {\n imageFrame.pixelData = jpeg.getData(imageFrame.columns, imageFrame.rows);\n\n return imageFrame;\n } else if (imageFrame.bitsAllocated === 16) {\n imageFrame.pixelData = jpeg.getData16(imageFrame.columns, imageFrame.rows);\n\n return imageFrame;\n }\n}\n\nexport default decodeJPEGBaseline12BitAsync;\n","import type { ByteArray } from 'dicom-parser';\nimport type { Types } from '@cornerstonejs/core/src';\nimport type { WebWorkerDecodeConfig } from '../../types';\n\nconst local = {\n jpeg: undefined,\n decodeConfig: {} as WebWorkerDecodeConfig,\n};\n\nexport function initialize(\n decodeConfig?: WebWorkerDecodeConfig\n): Promise<void> {\n local.decodeConfig = decodeConfig;\n\n if (local.jpeg) {\n return Promise.resolve();\n }\n\n return new Promise((resolve, reject) => {\n import('../../../codecs/jpegLossless').then((jpeg) => {\n local.jpeg = jpeg;\n resolve();\n }, reject);\n });\n}\n\nasync function decodeJPEGLossless(\n imageFrame: Types.IImageFrame,\n pixelData: ByteArray\n): Promise<Types.IImageFrame> {\n await initialize();\n\n // check to make sure codec is loaded\n if (\n typeof local.jpeg === 'undefined' ||\n typeof local.jpeg.lossless === 'undefined' ||\n typeof local.jpeg.lossless.Decoder === 'undefined'\n ) {\n throw new Error('No JPEG Lossless decoder loaded');\n }\n\n const byteOutput = imageFrame.bitsAllocated <= 8 ? 1 : 2;\n // console.time('jpeglossless');\n const buffer = pixelData.buffer;\n const decoder = new local.jpeg.lossless.Decoder();\n const decompressedData = decoder.decode(\n buffer,\n pixelData.byteOffset,\n pixelData.length,\n byteOutput\n );\n // console.timeEnd('jpeglossless');\n\n if (imageFrame.pixelRepresentation === 0) {\n if (imageFrame.bitsAllocated === 16) {\n imageFrame.pixelData = new Uint16Array(decompressedData.buffer);\n\n return imageFrame;\n }\n // untested!\n imageFrame.pixelData = new Uint8Array(decompressedData.buffer);\n\n return imageFrame;\n }\n imageFrame.pixelData = new Int16Array(decompressedData.buffer);\n\n return imageFrame;\n}\n\nexport default decodeJPEGLossless;\n","import type {\n CharlsModule,\n JpegLSDecoder,\n} from '@cornerstonejs/codec-charls/dist/charlswasm_decode';\n// @ts-ignore\nimport charlsFactory from '@cornerstonejs/codec-charls/decodewasmjs';\n// @ts-ignore\n// import charlsWasm from '@cornerstonejs/codec-charls/decodewasm';\nconst charlsWasm = new URL(\n '@cornerstonejs/codec-charls/decodewasm',\n import.meta.url\n);\nimport type { ByteArray } from 'dicom-parser';\nimport type { WebWorkerDecodeConfig } from '../../types';\nimport type { Types } from '@cornerstonejs/core/src';\n\nconst local: {\n codec: CharlsModule;\n decoder: JpegLSDecoder;\n decodeConfig: WebWorkerDecodeConfig;\n} = {\n codec: undefined,\n decoder: undefined,\n decodeConfig: {} as WebWorkerDecodeConfig,\n};\n\nfunction getExceptionMessage(exception) {\n return typeof exception === 'number'\n ? local.codec.getExceptionMessage(exception)\n : exception;\n}\n\nexport function initialize(\n decodeConfig?: WebWorkerDecodeConfig\n): Promise<void> {\n local.decodeConfig = decodeConfig;\n\n if (local.codec) {\n return Promise.resolve();\n }\n\n const charlsModule = charlsFactory({\n locateFile: (f) => {\n if (f.endsWith('.wasm')) {\n return charlsWasm.toString();\n }\n\n return f;\n },\n });\n\n return new Promise((resolve, reject) => {\n charlsModule.then((instance) => {\n local.codec = instance;\n local.decoder = new instance.JpegLSDecoder();\n resolve();\n }, reject);\n });\n}\n\n/**\n *\n * @param {*} compressedImageFrame\n * @param {object} imageInfo\n * @param {boolean} imageInfo.signed - (pixelRepresentation === 1)\n */\nasync function decodeAsync(\n compressedImageFrame,\n imageInfo\n): Promise<Types.IImageFrame> {\n try {\n await initialize();\n const decoder = local.decoder;\n\n // get pointer to the source/encoded bit stream buffer in WASM memory\n // that can hold the encoded bitstream\n const encodedBufferInWASM = decoder.getEncodedBuffer(\n compressedImageFrame.length\n );\n\n // copy the encoded bitstream into WASM memory buffer\n encodedBufferInWASM.set(compressedImageFrame);\n\n // decode it\n decoder.decode();\n\n // get information about the decoded image\n const frameInfo = decoder.getFrameInfo();\n const interleaveMode = decoder.getInterleaveMode();\n const nearLossless = decoder.getNearLossless();\n\n // get the decoded pixels\n const decodedPixelsInWASM = decoder.getDecodedBuffer();\n\n const encodedImageInfo = {\n columns: frameInfo.width,\n rows: frameInfo.height,\n bitsPerPixel: frameInfo.bitsPerSample,\n signed: imageInfo.signed,\n bytesPerPixel: imageInfo.bytesPerPixel,\n componentsPerPixel: frameInfo.componentCount,\n };\n\n const pixelData = getPixelData(\n frameInfo,\n decodedPixelsInWASM,\n imageInfo.signed\n );\n\n const encodeOptions = {\n nearLossless,\n interleaveMode,\n frameInfo,\n };\n\n // local.codec.doLeakCheck();\n\n return {\n ...imageInfo,\n pixelData,\n imageInfo: encodedImageInfo,\n encodeOptions,\n ...encodeOptions,\n ...encodedImageInfo,\n };\n } catch (error) {\n // Handle cases where WASM throws an error internally, and it only gives JS a number\n // See https://emscripten.org/docs/porting/Debugging.html#handling-c-exceptions-from-javascript\n // TODO: Copy to other codecs as well\n throw getExceptionMessage(error);\n }\n}\n\nfunction getPixelData(frameInfo, decodedBuffer: ByteArray, signed: boolean) {\n if (frameInfo.bitsPerSample > 8) {\n if (signed) {\n return new Int16Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength / 2\n );\n }\n\n return new Uint16Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength / 2\n );\n }\n\n if (signed) {\n return new Int8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n }\n\n return new Uint8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n}\n\nexport default decodeAsync;\n","// https://emscripten.org/docs/api_reference/module.html\nimport type {\n J2KDecoder,\n OpenJpegModule,\n} from '@cornerstonejs/codec-openjpeg/dist/openjpegwasm_decode';\n// @ts-ignore\nimport openJpegFactory from '@cornerstonejs/codec-openjpeg/decodewasmjs';\n\n// Webpack asset/resource copies this to our output folder\n\n// TODO: At some point maybe we can use this instead.\n// This is closer to what Webpack 5 wants but it doesn't seem to work now\n// const wasm = new URL('./blah.wasm', import.meta.url)\n// @ts-ignore\n// import openjpegWasm from '@cornerstonejs/codec-openjpeg/decodewasm';\nconst openjpegWasm = new URL(\n '@cornerstonejs/codec-openjpeg/decodewasm',\n import.meta.url\n);\n\nimport type { Types } from '@cornerstonejs/core/src';\nimport type { WebWorkerDecodeConfig } from '../../types';\n\nconst local: {\n codec: OpenJpegModule;\n decoder: J2KDecoder;\n decodeConfig: WebWorkerDecodeConfig;\n} = {\n codec: undefined,\n decoder: undefined,\n decodeConfig: {} as WebWorkerDecodeConfig,\n};\n\nexport function initialize(\n decodeConfig?: WebWorkerDecodeConfig\n): Promise<void> {\n local.decodeConfig = decodeConfig;\n\n if (local.codec) {\n return Promise.resolve();\n }\n\n const openJpegModule = openJpegFactory({\n locateFile: (f) => {\n if (f.endsWith('.wasm')) {\n return openjpegWasm.toString();\n }\n\n return f;\n },\n });\n\n return new Promise((resolve, reject) => {\n openJpegModule.then((instance) => {\n local.codec = instance;\n local.decoder = new instance.J2KDecoder();\n resolve();\n }, reject);\n });\n}\n\n// https://github.com/chafey/openjpegjs/blob/master/test/browser/index.html\nasync function decodeAsync(\n compressedImageFrame,\n imageInfo\n): Promise<Types.IImageFrame> {\n await initialize();\n const decoder = local.decoder;\n\n // get pointer to the source/encoded bit stream buffer in WASM memory\n // that can hold the encoded bitstream\n const encodedBufferInWASM = decoder.getEncodedBuffer(\n compressedImageFrame.length\n );\n\n // copy the encoded bitstream into WASM memory buffer\n encodedBufferInWASM.set(compressedImageFrame);\n\n // decode it\n decoder.decode();\n // decoder.decodeSubResolution(decodeLevel, decodeLayer);\n // const resolutionAtLevel = decoder.calculateSizeAtDecompositionLevel(decodeLevel);\n\n // get information about the decoded image\n const frameInfo = decoder.getFrameInfo();\n // get the decoded pixels\n const decodedBufferInWASM = decoder.getDecodedBuffer();\n const imageFrame = new Uint8Array(decodedBufferInWASM.length);\n\n imageFrame.set(decodedBufferInWASM);\n\n const imageOffset = `x: ${decoder.getImageOffset().x}, y: ${\n decoder.getImageOffset().y\n }`;\n const numDecompositions = decoder.getNumDecompositions();\n const numLayers = decoder.getNumLayers();\n const progessionOrder = ['unknown', 'LRCP', 'RLCP', 'RPCL', 'PCRL', 'CPRL'][\n decoder.getProgressionOrder() + 1\n ];\n const reversible = decoder.getIsReversible();\n const blockDimensions = `${decoder.getBlockDimensions().width} x ${\n decoder.getBlockDimensions().height\n }`;\n const tileSize = `${decoder.getTileSize().width} x ${\n decoder.getTileSize().height\n }`;\n const tileOffset = `${decoder.getTileOffset().x}, ${\n decoder.getTileOffset().y\n }`;\n const colorTransform = decoder.getColorSpace();\n\n const decodedSize = `${decodedBufferInWASM.length.toLocaleString()} bytes`;\n const compressionRatio = `${(\n decodedBufferInWASM.length / encodedBufferInWASM.length\n ).toFixed(2)}:1`;\n\n const encodedImageInfo = {\n columns: frameInfo.width,\n rows: frameInfo.height,\n bitsPerPixel: frameInfo.bitsPerSample,\n signed: frameInfo.isSigned,\n bytesPerPixel: imageInfo.bytesPerPixel,\n componentsPerPixel: frameInfo.componentCount,\n };\n const pixelData = getPixelData(frameInfo, decodedBufferInWASM);\n\n const encodeOptions = {\n imageOffset,\n numDecompositions,\n numLayers,\n progessionOrder,\n reversible,\n blockDimensions,\n tileSize,\n tileOffset,\n colorTransform,\n decodedSize,\n compressionRatio,\n };\n\n return {\n ...imageInfo,\n pixelData,\n imageInfo: encodedImageInfo,\n encodeOptions,\n ...encodeOptions,\n ...encodedImageInfo,\n };\n}\n\nfunction getPixelData(frameInfo, decodedBuffer) {\n if (frameInfo.bitsPerSample > 8) {\n if (frameInfo.isSigned) {\n return new Int16Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength / 2\n );\n }\n\n return new Uint16Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength / 2\n );\n }\n\n if (frameInfo.isSigned) {\n return new Int8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n }\n\n return new Uint8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n}\n\nexport default decodeAsync;\n","import type { ByteArray } from 'dicom-parser';\n// @ts-ignore\nimport openJphFactory from '@cornerstonejs/codec-openjph/wasmjs';\n// @ts-ignore\n// import openjphWasm from '@cornerstonejs/codec-openjph/wasm';\nconst openjphWasm = new URL(\n '@cornerstonejs/codec-openjph/wasm',\n import.meta.url\n);\n\nimport type { LoaderDecodeOptions } from '../../types';\n\nconst local: {\n codec: unknown;\n decoder: unknown;\n decodeConfig: LoaderDecodeOptions;\n} = {\n codec: undefined,\n decoder: undefined,\n decodeConfig: {},\n};\n\nfunction calculateSizeAtDecompositionLevel(\n decompositionLevel: number,\n frameWidth: number,\n frameHeight: number\n) {\n const result = { width: frameWidth, height: frameHeight };\n while (decompositionLevel > 0) {\n result.width = Math.ceil(result.width / 2);\n result.height = Math.ceil(result.height / 2);\n decompositionLevel--;\n }\n return result;\n}\n\nexport function initialize(decodeConfig?: LoaderDecodeOptions): Promise<void> {\n local.decodeConfig = decodeConfig;\n\n if (local.codec) {\n return Promise.resolve();\n }\n\n const openJphModule = openJphFactory({\n locateFile: (f) => {\n if (f.endsWith('.wasm')) {\n return openjphWasm;\n }\n\n return f;\n },\n });\n\n return new Promise<void>((resolve, reject) => {\n openJphModule.then((instance) => {\n local.codec = instance;\n local.decoder = new instance.HTJ2KDecoder();\n resolve();\n }, reject);\n });\n}\n\n// https://github.com/chafey/openjpegjs/blob/master/test/browser/index.html\nasync function decodeAsync(compressedImageFrame: ByteArray, imageInfo) {\n await initialize();\n // const decoder = local.decoder; // This is much slower for some reason\n // @ts-expect-error\n const decoder = new local.codec.HTJ2KDecoder();\n\n // get pointer to the source/encoded bit stream buffer in WASM memory\n // that can hold the encoded bitstream\n const encodedBufferInWASM = decoder.getEncodedBuffer(\n compressedImageFrame.length\n );\n\n // copy the encoded bitstream into WASM memory buffer\n encodedBufferInWASM.set(compressedImageFrame);\n\n // decode it\n // decoder.decode();\n const decodeLevel = imageInfo.decodeLevel || 0;\n decoder.decodeSubResolution(decodeLevel);\n // decoder.decodeSubResolution(decodeLevel, decodeLayer);\n // const resolutionAtLevel = decoder.calculateSizeAtDecompositionLevel(decodeLevel);\n\n // get information about the decoded image\n const frameInfo = decoder.getFrameInfo();\n // Overwrite width/height if subresolution\n if (imageInfo.decodeLevel > 0) {\n const { width, height } = calculateSizeAtDecompositionLevel(\n imageInfo.decodeLevel,\n frameInfo.width,\n frameInfo.height\n );\n frameInfo.width = width;\n frameInfo.height = height;\n // console.log(`Decoded sub-resolution of size: ${width} x ${height}`);\n }\n // get the decoded pixels\n const decodedBufferInWASM = decoder.getDecodedBuffer();\n const imageFrame = new Uint8Array(decodedBufferInWASM.length);\n\n imageFrame.set(decodedBufferInWASM);\n\n const imageOffset = `x: ${decoder.getImageOffset().x}, y: ${\n decoder.getImageOffset().y\n }`;\n const numDecompositions = decoder.getNumDecompositions();\n const numLayers = decoder.getNumLayers();\n const progessionOrder = ['unknown', 'LRCP', 'RLCP', 'RPCL', 'PCRL', 'CPRL'][\n decoder.getProgressionOrder() + 1\n ];\n const reversible = decoder.getIsReversible();\n const blockDimensions = `${decoder.getBlockDimensions().width} x ${\n decoder.getBlockDimensions().height\n }`;\n const tileSize = `${decoder.getTileSize().width} x ${\n decoder.getTileSize().height\n }`;\n const tileOffset = `${decoder.getTileOffset().x}, ${\n decoder.getTileOffset().y\n }`;\n // const colorTransform = decoder.getColorSpace();\n\n const decodedSize = `${decodedBufferInWASM.length.toLocaleString()} bytes`;\n const compressionRatio = `${(\n decodedBufferInWASM.length / encodedBufferInWASM.length\n ).toFixed(2)}:1`;\n\n const encodedImageInfo = {\n columns: frameInfo.width,\n rows: frameInfo.height,\n bitsPerPixel: frameInfo.bitsPerSample,\n signed: frameInfo.isSigned,\n bytesPerPixel: imageInfo.bytesPerPixel,\n componentsPerPixel: frameInfo.componentCount,\n };\n // const pixelData = getPixelData(frameInfo, decodedBufferInWASM);\n\n /**\n * Have to truncate the arraybuffer here to the length of the typed array. Not\n * sure why the arraybuffer is so huge, maybe this is allocated by the WASM\n * module? In any case, I think it's too big to postMessage in it's entirety.\n */\n let pixelData = getPixelData(frameInfo, decodedBufferInWASM);\n const { buffer: b, byteOffset, byteLength } = pixelData;\n const pixelDataArrayBuffer = b.slice(byteOffset, byteOffset + byteLength);\n\n // @ts-ignore\n pixelData = new pixelData.constructor(pixelDataArrayBuffer);\n\n const encodeOptions = {\n imageOffset,\n numDecompositions,\n numLayers,\n progessionOrder,\n reversible,\n blockDimensions,\n tileSize,\n tileOffset,\n // colorTransform,\n decodedSize,\n compressionRatio,\n };\n\n return {\n ...imageInfo,\n pixelData,\n imageInfo: encodedImageInfo,\n encodeOptions,\n ...encodeOptions,\n ...encodedImageInfo,\n };\n}\n\nfunction getPixelData(frameInfo, decodedBuffer) {\n if (frameInfo.bitsPerSample > 8) {\n if (frameInfo.isSigned) {\n return new Int16Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength / 2\n );\n }\n\n return new Uint16Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength / 2\n );\n }\n\n if (frameInfo.isSigned) {\n return new Int8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n }\n\n return new Uint8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n}\n\nexport default decodeAsync;\n","import type { Types } from '@cornerstonejs/core';\n\n/**\n * Calculate the minimum and maximum values in an Array\n *\n * @param {Number[]} storedPixelData\n * @return {{min: Number, max: Number}}\n */\nfunction getMinMax(storedPixelData: Types.PixelDataTypedArray): {\n min: number;\n max: number;\n} {\n // we always calculate the min max values since they are not always\n // present in DICOM and we don't want to trust them anyway as cornerstone\n // depends on us providing reliable values for these\n let min = storedPixelData[0];\n\n let max = storedPixelData[0];\n\n let storedPixel;\n const numPixels = storedPixelData.length;\n\n for (let index = 1; index < numPixels; index++) {\n storedPixel = storedPixelData[index];\n min = Math.min(min, storedPixel);\n max = Math.max(max, storedPixel);\n }\n\n return {\n min,\n max,\n };\n}\n\nexport default getMinMax;\n","/* eslint-disable complexity */\nimport bilinear from './shared/scaling/bilinear';\nimport replicate from './shared/scaling/replicate';\nimport { expose } from 'comlink';\n\nimport decodeLittleEndian from './shared/decoders/decodeLittleEndian';\nimport decodeBigEndian from './shared/decoders/decodeBigEndian';\nimport decodeRLE from './shared/decoders/decodeRLE';\nimport decodeJPEGBaseline8Bit from './shared/decoders/decodeJPEGBaseline8Bit';\n// import decodeJPEGBaseline12Bit from './shared/decoders/decodeJPEGBaseline12Bit';\nimport decodeJPEGBaseline12Bit from './shared/decoders/decodeJPEGBaseline12Bit-js';\nimport decodeJPEGLossless from './shared/decoders/decodeJPEGLossless';\nimport decodeJPEGLS from './shared/decoders/decodeJPEGLS';\nimport decodeJPEG2000 from './shared/decoders/decodeJPEG2000';\nimport decodeHTJ2K from './shared/decoders/decodeHTJ2K';\n// Note that the scaling is pixel value scaling, which is applying a modality LUT\nimport applyModalityLUT from './shared/scaling/scaleArray';\nimport getMinMax from './shared/getMinMax';\nimport getPixelDataTypeFromMinMax from './shared/getPixelDataTypeFromMinMax';\nimport isColorImage from './shared/isColorImage';\n\nconst imageUtils = {\n bilinear,\n replicate,\n};\n\n/**\n * Decodes the provided image frame.\n * This is an async function return the result, or you can provide an optional\n * callbackFn that is called with the results.\n */\nasync function decodeImageFrame(\n imageFrame,\n transferSyntax,\n pixelData,\n decodeConfig,\n options,\n callbackFn\n) {\n const start = new Date().getTime();\n\n let decodePromise = null;\n\n let opts;\n\n switch (transferSyntax) {\n case '1.2.840.10008.1.2':\n case '1.2.840.10008.1.2.1':\n // Implicit or Explicit VR Little Endian\n decodePromise = decodeLittleEndian(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.2':\n // Explicit VR Big Endian (retired)\n decodePromise = decodeBigEndian(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.1.99':\n // Deflate transfer syntax (deflated by dicomParser)\n decodePromise = decodeLittleEndian(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.5':\n // RLE Lossless\n decodePromise = decodeRLE(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.4.50':\n // JPEG Baseline lossy process 1 (8 bit)\n opts = {\n ...imageFrame,\n };\n\n decodePromise = decodeJPEGBaseline8Bit(pixelData, opts);\n break;\n case '1.2.840.10008.1.2.4.51':\n // JPEG Baseline lossy process 2 & 4 (12 bit)\n // opts = {\n // ...imageFrame,\n // };\n // decodePromise = decodeJPEGBaseline12Bit(pixelData, opts);\n //throw new Error('Currently unsupported: 1.2.840.10008.1.2.4.51');\n decodePromise = decodeJPEGBaseline12Bit(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.4.57':\n // JPEG Lossless, Nonhierarchical (Processes 14)\n decodePromise = decodeJPEGLossless(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.4.70':\n // JPEG Lossless, Nonhierarchical (Processes 14 [Selection 1])\n decodePromise = decodeJPEGLossless(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.4.80':\n // JPEG-LS Lossless Image Compression\n opts = {\n signed: imageFrame.pixelRepresentation === 1, // imageFrame.signed,\n // shouldn't need...\n bytesPerPixel: imageFrame.bitsAllocated <= 8 ? 1 : 2,\n ...imageFrame,\n };\n\n decodePromise = decodeJPEGLS(pixelData, opts);\n break;\n case '1.2.840.10008.1.2.4.81':\n // JPEG-LS Lossy (Near-Lossless) Image Compression\n opts = {\n signed: imageFrame.pixelRepresentation === 1, // imageFrame.signed,\n // shouldn't need...\n bytesPerPixel: imageFrame.bitsAllocated <= 8 ? 1 : 2,\n ...imageFrame,\n };\n\n decodePromise = decodeJPEGLS(pixelData, opts);\n break;\n case '1.2.840.10008.1.2.4.90':\n opts = {\n ...imageFrame,\n };\n\n // JPEG 2000 Lossless\n // imageFrame, pixelData, decodeConfig, options\n decodePromise = decodeJPEG2000(pixelData, opts);\n break;\n case '1.2.840.10008.1.2.4.91':\n // JPEG 2000 Lossy\n opts = {\n ...imageFrame,\n };\n\n // JPEG 2000 Lossy\n // imageFrame, pixelData, decodeConfig, options\n decodePromise = decodeJPEG2000(pixelData, opts);\n break;\n case '3.2.840.10008.1.2.4.96':\n case '1.2.840.10008.1.2.4.201':\n case '1.2.840.10008.1.2.4.202':\n case '1.2.840.10008.1.2.4.203':\n // HTJ2K\n opts = {\n ...imageFrame,\n };\n\n decodePromise = decodeHTJ2K(pixelData, opts);\n break;\n default:\n throw new Error(`no decoder for transfer syntax ${transferSyntax}`);\n }\n\n /* Don't know if these work...\n // JPEG 2000 Part 2 Multicomponent Image Compression (Lossless Only)\n else if(transferSyntax === \"1.2.840.10008.1.2.4.92\")\n {\n return decodeJPEG2000(dataSet, frame);\n }\n // JPEG 2000 Part 2 Multicomponent Image Compression\n else if(transferSyntax === \"1.2.840.10008.1.2.4.93\")\n {\n return decodeJPEG2000(dataSet, frame);\n }\n */\n\n if (!decodePromise) {\n throw new Error('decodePromise not defined');\n }\n\n const decodedFrame = await decodePromise;\n\n const postProcessed = postProcessDecodedPixels(\n decodedFrame,\n options,\n start,\n decodeConfig\n );\n\n // Call the callbackFn to agree with older arguments\n callbackFn?.(postProcessed);\n\n return postProcessed;\n}\n\nfunction postProcessDecodedPixels(imageFrame, options, start, decodeConfig) {\n const shouldShift =\n imageFrame.pixelRepresentation !== undefined &&\n imageFrame.pixelRepresentation === 1;\n const shift =\n shouldShift && imageFrame.bitsStored !== undefined\n ? 32 - imageFrame.bitsStored\n : undefined;\n\n if (shouldShift && shift !== undefined) {\n for (let i = 0; i < imageFrame.pixelData.length; i++) {\n // eslint-disable-next-line no-bitwise\n imageFrame.pixelData[i] = (imageFrame.pixelData[i] << shift) >> shift;\n }\n }\n\n // Cache the pixelData reference quickly incase we want to set a targetBuffer _and_ scale.\n let pixelDataArray = imageFrame.pixelData;\n imageFrame.pixelDataLength = imageFrame.pixelData.length;\n const { min: minBeforeScale, max: maxBeforeScale } = getMinMax(\n imageFrame.pixelData\n );\n\n const typedArrayConstructors = {\n Uint8Array,\n Uint16Array,\n Int16Array,\n Float32Array,\n };\n\n const type = options.targetBuffer?.type;\n\n const canRenderFloat =\n typeof options.allowFloatRendering !== 'undefined'\n ? options.allowFloatRendering\n : true;\n\n // Sometimes the type is specified before the DICOM header data has been\n // read. This is fine except for color data, where the wrong type gets\n // specified. Don't use the target buffer in that case.\n const invalidType =\n isColorImage(imageFrame.photometricInterpretation) &&\n options.targetBuffer?.offset === undefined;\n\n const willScale = options.preScale?.enabled;\n\n const hasFloatRescale =\n willScale &&\n Object.values(options.preScale.scalingParameters).some(\n (v) => typeof v === 'number' && !Number.isInteger(v)\n );\n const disableScale =\n !options.preScale.enabled || (!canRenderFloat && hasFloatRescale);\n\n if (type && !invalidType) {\n pixelDataArray = _handleTargetBuffer(\n options,\n imageFrame,\n typedArrayConstructors,\n pixelDataArray\n );\n } else if (options.preScale.enabled && !disableScale) {\n pixelDataArray = _handlePreScaleSetup(\n options,\n minBeforeScale,\n maxBeforeScale,\n imageFrame\n );\n } else {\n pixelDataArray = _getDefaultPixelDataArray(\n minBeforeScale,\n maxBeforeScale,\n imageFrame\n );\n }\n\n let minAfterScale = minBeforeScale;\n let maxAfterScale = maxBeforeScale;\n\n if (options.preScale.enabled && !disableScale) {\n const scalingParameters = options.preScale.scalingParameters;\n _validateScalingParameters(scalingParameters);\n\n const { rescaleSlope, rescaleIntercept } = scalingParameters;\n const isSlopeAndInterceptNumbers =\n typeof rescaleSlope === 'number' && typeof rescaleIntercept === 'number';\n\n if (isSlopeAndInterceptNumbers) {\n applyModalityLUT(pixelDataArray, scalingParameters);\n imageFrame.preScale = {\n ...options.preScale,\n scaled: true,\n };\n\n // calculate the min and max after scaling\n const { rescaleIntercept, rescaleSlope, suvbw } = scalingParameters;\n minAfterScale = rescaleSlope * minBeforeScale + rescaleIntercept;\n maxAfterScale = rescaleSlope * maxBeforeScale + rescaleIntercept;\n\n if (suvbw) {\n minAfterScale = minAfterScale * suvbw;\n maxAfterScale = maxAfterScale * suvbw;\n }\n }\n } else if (disableScale) {\n imageFrame.preScale = {\n enabled: true,\n scaled: false,\n };\n\n minAfterScale = minBeforeScale;\n maxAfterScale = maxBeforeScale;\n }\n\n imageFrame.pixelData = pixelDataArray;\n imageFrame.smallestPixelValue = minAfterScale;\n imageFrame.largestPixelValue = maxAfterScale;\n\n const end = new Date().getTime();\n imageFrame.decodeTimeInMS = end - start;\n\n return imageFrame;\n}\n\nfunction _handleTargetBuffer(\n options,\n imageFrame,\n typedArrayConstructors,\n pixelDataArray\n) {\n const {\n arrayBuffer,\n type,\n offset: rawOffset = 0,\n length: rawLength,\n rows,\n } = options.targetBuffer;\n\n const TypedArrayConstructor = typedArrayConstructors[type];\n\n if (!TypedArrayConstructor) {\n throw new Error(`target array ${type} is not supported, or doesn't exist.`);\n }\n\n if (rows && rows != imageFrame.rows) {\n scaleImageFrame(imageFrame, options.targetBuffer, TypedArrayConstructor);\n }\n const imageFrameLength = imageFrame.pixelDataLength;\n\n const offset = rawOffset;\n const length =\n rawLength !== null && rawLength !== undefined\n ? rawLength\n : imageFrameLength - offset;\n\n const imageFramePixelData = imageFrame.pixelData;\n\n if (length !== imageFramePixelData.length) {\n throw new Error(\n `target array for image does not have the same length (${length}) as the decoded image length (${imageFramePixelData.length}).`\n );\n }\n\n // TypedArray.Set is api level and ~50x faster than copying elements even for\n // Arrays of different types, which aren't simply memcpy ops.\n const typedArray = arrayBuffer\n ? new TypedArrayConstructor(arrayBuffer, offset, length)\n : new TypedArrayConstructor(length);\n\n typedArray.set(imageFramePixelData, 0);\n\n // If need to scale, need to scale correct array.\n pixelDataArray = typedArray;\n return pixelDataArray;\n}\n\nfunction _handlePreScaleSetup(\n options,\n minBeforeScale,\n maxBeforeScale,\n imageFrame\n) {\n const scalingParameters = options.preScale.scalingParameters;\n _validateScalingParameters(scalingParameters);\n\n const { rescaleSlope, rescaleIntercept } = scalingParameters;\n const areSlopeAndInterceptNumbers =\n typeof rescaleSlope === 'number' && typeof rescaleIntercept === 'number';\n\n let scaledMin = minBeforeScale;\n let scaledMax = maxBeforeScale;\n\n if (areSlopeAndInterceptNumbers) {\n scaledMin = rescaleSlope * minBeforeScale + rescaleIntercept;\n scaledMax = rescaleSlope * maxBeforeScale + rescaleIntercept;\n }\n\n return _getDefaultPixelDataArray(scaledMin, scaledMax, imageFrame);\n}\n\nfunction _getDefaultPixelDataArray(min, max, imageFrame) {\n const TypedArrayConstructor = getPixelDataTypeFromMinMax(min, max);\n // @ts-ignore\n const typedArray = new TypedArrayConstructor(imageFrame.pixelData.length);\n typedArray.set(imageFrame.pixelData, 0);\n\n return typedArray;\n}\n\nfunction _validateScalingParameters(scalingParameters) {\n if (!scalingParameters) {\n throw new Error(\n 'options.preScale.scalingParameters must be defined if preScale.enabled is true, and scalingParameters cannot be derived from the metadata providers.'\n );\n }\n}\n\nfunction createDestinationImage(\n imageFrame,\n targetBuffer,\n TypedArrayConstructor\n) {\n const { samplesPerPixel } = imageFrame;\n const { rows, columns } = targetBuffer;\n const typedLength = rows * columns * samplesPerPixel;\n const pixelData = new TypedArrayConstructor(typedLength);\n const bytesPerPixel = pixelData.byteLength / typedLength;\n return {\n pixelData,\n rows,\n columns,\n frameInfo: {\n ...imageFrame.frameInfo,\n rows,\n columns,\n },\n imageInfo: {\n ...imageFrame.imageInfo,\n rows,\n columns,\n bytesPerPixel,\n },\n };\n}\n\n/** Scales the image frame, updating the frame in place with a new scaled\n * version of it (in place modification)\n */\nfunction scaleImageFrame(imageFrame, targetBuffer, TypedArrayConstructor) {\n const dest = createDestinationImage(\n imageFrame,\n targetBuffer,\n TypedArrayConstructor\n );\n const { scalingType = 'replicate' } = targetBuffer;\n imageUtils[scalingType](imageFrame, dest);\n Object.assign(imageFrame, dest);\n return imageFrame;\n}\n\nconst obj = {\n decodeTask({\n imageFrame,\n transferSyntax,\n decodeConfig,\n options,\n pixelData,\n callbackFn,\n }) {\n return decodeImageFrame(\n imageFrame,\n transferSyntax,\n pixelData,\n decodeConfig,\n options,\n callbackFn\n );\n },\n};\n\nexpose(obj);\n","/**\n * Performs a bilinear scaling, both scaling up and scaling down.\n * Only supports 1 channel per pixel (grayscale)\n * @param src - src image frame to get map from\n * @param dest - dest image frame to write to\n * @returns destination data buffer\n */\nexport default function bilinear(src, dest) {\n const { rows: srcRows, columns: srcColumns, data: srcData } = src;\n const { rows, columns, data } = dest;\n\n const xSrc1Off = [];\n const xSrc2Off = [];\n const xFrac = [];\n\n // Precompute offsets\n for (let x = 0; x < columns; x++) {\n const xSrc = (x * (srcColumns - 1)) / (columns - 1);\n xSrc1Off[x] = Math.floor(xSrc);\n xSrc2Off[x] = Math.min(xSrc1Off[x] + 1, srcColumns - 1);\n xFrac[x] = xSrc - xSrc1Off[x];\n // console.log(\"x src info\", x, xSrc, xFrac[x]);\n }\n\n for (let y = 0; y < rows; y++) {\n const ySrc = (y * (srcRows - 1)) / (rows - 1);\n const ySrc1Off = Math.floor(ySrc) * srcColumns;\n // Get the second offset, but duplicate the last row so the lookup works\n const ySrc2Off = Math.min(\n ySrc1Off + srcColumns,\n (srcRows - 1) * srcColumns\n );\n const yFrac = ySrc - Math.floor(ySrc);\n const yFracInv = 1 - yFrac;\n const yOff = y * columns;\n\n for (let x = 0; x < columns; x++) {\n // TODO - put the pXY into the data calculation\n const p00 = srcData[ySrc1Off + xSrc1Off[x]];\n const p10 = srcData[ySrc1Off + xSrc2Off[x]];\n const p01 = srcData[ySrc2Off + xSrc1Off[x]];\n const p11 = srcData[ySrc2Off + xSrc2Off[x]];\n const xFracInv = 1 - xFrac[x];\n\n // console.log(\"bilinear for\", x,y, \"from\", ySrc1Off + xSrc1Off[x], ySrc1Off + xSrc2Off[x], ySrc2Off + xSrc1Off[x], ySrc2Off + xSrc2Off[x]);\n // console.log(\"values\", p00, p10, p01, p11);\n // console.log(\"fractions\", xFracInv, xFrac[x], yFracInv, yFrac);\n\n data[yOff + x] =\n (p00 * xFracInv + p10 * xFrac[x]) * yFracInv +\n (p01 * xFracInv + p11 * xFrac[x]) * yFrac;\n }\n }\n return data;\n}\n","/** Handle replicate scaling. Use this function for samplesPerPixel>1 */\n\nexport default function replicate(src, dest) {\n const {\n rows: srcRows,\n columns: srcColumns,\n pixelData: srcData,\n samplesPerPixel = 1,\n } = src;\n const { rows, columns, pixelData } = dest;\n\n const xSrc1Off = [];\n\n // Precompute offsets\n for (let x = 0; x < columns; x++) {\n const xSrc = (x * (srcColumns - 1)) / (columns - 1);\n xSrc1Off[x] = Math.floor(xSrc) * samplesPerPixel;\n // console.log(\"x src info\", x, xSrc, xFrac[x]);\n }\n\n for (let y = 0; y < rows; y++) {\n const ySrc = (y * (srcRows - 1)) / (rows - 1);\n const ySrc1Off = Math.floor(ySrc) * srcColumns * samplesPerPixel;\n const yOff = y * columns;\n\n for (let x = 0; x < columns; x++) {\n for (let sample = 0; sample < samplesPerPixel; sample++) {\n pixelData[yOff + x + sample] = srcData[ySrc1Off + xSrc1Off[x] + sample];\n }\n }\n }\n return pixelData;\n}\n","export default function (photoMetricInterpretation: string): boolean {\n return (\n photoMetricInterpretation === 'RGB' ||\n photoMetricInterpretation === 'PALETTE COLOR' ||\n photoMetricInterpretation === 'YBR_FULL' ||\n photoMetricInterpretation === 'YBR_FULL_422' ||\n photoMetricInterpretation === 'YBR_PARTIAL_422' ||\n photoMetricInterpretation === 'YBR_PARTIAL_420' ||\n photoMetricInterpretation === 'YBR_RCT' ||\n photoMetricInterpretation === 'YBR_ICT'\n );\n}\n","import type { Types } from '@cornerstonejs/core';\n\nexport default function scaleArray(\n array: Types.PixelDataTypedArray,\n scalingParameters\n): boolean {\n const arrayLength = array.length;\n const { rescaleSlope, rescaleIntercept, suvbw } = scalingParameters;\n\n if (scalingParameters.modality === 'PT' && typeof suvbw === 'number') {\n for (let i = 0; i < arrayLength; i++) {\n array[i] = suvbw * (array[i] * rescaleSlope + rescaleIntercept);\n }\n } else {\n for (let i = 0; i < arrayLength; i++) {\n array[i] = array[i] * rescaleSlope + rescaleIntercept;\n }\n }\n\n return true;\n}\n","import type { Types } from '@cornerstonejs/core';\n\nexport default function getPixelDataTypeFromMinMax(\n min: number,\n max: number\n): Types.PixelDataTypedArray {\n let pixelDataType;\n if (Number.isInteger(min) && Number.isInteger(max)) {\n if (min >= 0) {\n if (max <= 255) {\n pixelDataType = Uint8Array;\n } else if (max <= 65535) {\n pixelDataType = Uint16Array;\n }\n } else {\n if (min >= -128 && max <= 127) {\n pixelDataType = Int8Array;\n } else if (min >= -32768 && max <= 32767) {\n pixelDataType = Int16Array;\n }\n }\n }\n\n return pixelDataType || Float32Array;\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n// the startup function\n__webpack_require__.x = () => {\n\t// Load entry module and return exports\n\t// This entry module depends on other loaded chunks and execution need to be delayed\n\tvar __webpack_exports__ = __webpack_require__.O(undefined, [958], () => (__webpack_require__(760)))\n\t__webpack_exports__ = __webpack_require__.O(__webpack_exports__);\n\treturn __webpack_exports__;\n};\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = (chunkId) => {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce((promises, key) => {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks and sibling chunks for the entrypoint\n__webpack_require__.u = (chunkId) => {\n\t// return url for filenames based on template\n\treturn \"\" + chunkId + \".min.js\";\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","var scriptUrl;\nif (__webpack_require__.g.importScripts) scriptUrl = __webpack_require__.g.location + \"\";\nvar document = __webpack_require__.g.document;\nif (!scriptUrl && document) {\n\tif (document.currentScript)\n\t\tscriptUrl = document.currentScript.src;\n\tif (!scriptUrl) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tif(scripts.length) {\n\t\t\tvar i = scripts.length - 1;\n\t\t\twhile (i > -1 && !scriptUrl) scriptUrl = scripts[i--].src;\n\t\t}\n\t}\n}\n// When supporting browsers where an automatic publicPath is not supported you must specify an output.publicPath manually via configuration\n// or pass an empty string (\"\") and set the __webpack_public_path__ variable from your code to use your own logic.\nif (!scriptUrl) throw new Error(\"Automatic publicPath is not supported in this browser\");\nscriptUrl = scriptUrl.replace(/#.*$/, \"\").replace(/\\?.*$/, \"\").replace(/\\/[^\\/]+$/, \"/\");\n__webpack_require__.p = scriptUrl;","__webpack_require__.b = self.location + \"\";\n\n// object to store loaded chunks\n// \"1\" means \"already loaded\"\nvar installedChunks = {\n\t918: 1\n};\n\n// importScripts chunk loading\nvar installChunk = (data) => {\n\tvar [chunkIds, moreModules, runtime] = data;\n\tfor(var moduleId in moreModules) {\n\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t}\n\t}\n\tif(runtime) runtime(__webpack_require__);\n\twhile(chunkIds.length)\n\t\tinstalledChunks[chunkIds.pop()] = 1;\n\tparentChunkLoadingFunction(data);\n};\n__webpack_require__.f.i = (chunkId, promises) => {\n\t// \"1\" is the signal for \"already loaded\"\n\tif(!installedChunks[chunkId]) {\n\t\tif(true) { // all chunks have JS\n\t\t\timportScripts(__webpack_require__.p + __webpack_require__.u(chunkId));\n\t\t}\n\t}\n};\n\nvar chunkLoadingGlobal = this[\"webpackChunk\"] = this[\"webpackChunk\"] || [];\nvar parentChunkLoadingFunction = chunkLoadingGlobal.push.bind(chunkLoadingGlobal);\nchunkLoadingGlobal.push = installChunk;\n\n// no HMR\n\n// no HMR manifest","// run startup\nvar __webpack_exports__ = __webpack_require__.x();\n"],"names":["root","factory","exports","module","define","amd","this","deferred","leafPrototypes","getProto","next","async","imageFrame","pixelData","arrayBuffer","buffer","offset","byteOffset","length","bitsAllocated","slice","pixelRepresentation","Uint16Array","Int16Array","Float32Array","i","val","planarConfiguration","frameData","frameSize","rows","columns","outFrame","ArrayBuffer","samplesPerPixel","header","DataView","data","Int8Array","out","outIndex","numSegments","getInt32","s","inIndex","maxIndex","endOfSegment","n","value","j","Uint8Array","decode8Planar","decode8","highByte","decode16","Error","libjpegTurboWasm","URL","local","codec","undefined","decoder","compressedImageFrame","imageInfo","Promise","resolve","libjpegTurboModule","libjpegTurboFactory","locateFile","f","endsWith","toString","reject","then","instance","JPEGDecoder","initLibjpegTurbo","getEncodedBuffer","set","decode","frameInfo","getFrameInfo","decodedPixelsInWASM","getDecodedBuffer","encodedImageInfo","width","height","bitsPerPixel","bitsPerSample","signed","bytesPerPixel","componentsPerPixel","componentCount","decodedBuffer","isSigned","byteLength","getPixelData","encodeOptions","JpegImage","decodeConfig","jpeg","parse","colorTransform","getData","getData16","lossless","Decoder","byteOutput","decompressedData","charlsWasm","charlsModule","charlsFactory","JpegLSDecoder","initialize","interleaveMode","getInterleaveMode","nearLossless","getNearLossless","error","exception","getExceptionMessage","openjpegWasm","openJpegModule","openJpegFactory","J2KDecoder","encodedBufferInWASM","decodedBufferInWASM","imageOffset","getImageOffset","x","y","numDecompositions","getNumDecompositions","numLayers","getNumLayers","progessionOrder","getProgressionOrder","reversible","getIsReversible","blockDimensions","getBlockDimensions","tileSize","getTileSize","tileOffset","getTileOffset","getColorSpace","decodedSize","toLocaleString","compressionRatio","toFixed","openjphWasm","openJphModule","openJphFactory","HTJ2KDecoder","decodeLevel","decodeSubResolution","decompositionLevel","frameWidth","frameHeight","result","Math","ceil","calculateSizeAtDecompositionLevel","b","pixelDataArrayBuffer","constructor","storedPixelData","storedPixel","min","max","numPixels","index","imageUtils","bilinear","src","dest","srcRows","srcColumns","srcData","xSrc1Off","xSrc2Off","xFrac","xSrc","floor","ySrc","ySrc1Off","ySrc2Off","yFrac","yFracInv","yOff","p00","p10","p01","p11","xFracInv","replicate","sample","decodeImageFrame","transferSyntax","options","callbackFn","start","Date","getTime","opts","decodePromise","decodeLittleEndian","decodeBigEndian","decodeRLE","decodeJPEGBaseline8Bit","decodeJPEGBaseline12Bit","decodeJPEGLossless","decodeJPEGLS","decodeJPEG2000","decodeHTJ2K","postProcessed","shouldShift","shift","bitsStored","pixelDataArray","pixelDataLength","minBeforeScale","maxBeforeScale","getMinMax","typedArrayConstructors","type","targetBuffer","canRenderFloat","allowFloatRendering","invalidType","photoMetricInterpretation","photometricInterpretation","willScale","preScale","enabled","hasFloatRescale","Object","values","scalingParameters","some","v","Number","isInteger","disableScale","rawOffset","rawLength","TypedArrayConstructor","typedLength","createDestinationImage","scalingType","assign","scaleImageFrame","imageFrameLength","imageFramePixelData","typedArray","_handleTargetBuffer","_validateScalingParameters","rescaleSlope","rescaleIntercept","scaledMin","scaledMax","_getDefaultPixelDataArray","_handlePreScaleSetup","minAfterScale","maxAfterScale","array","arrayLength","suvbw","modality","applyModalityLUT","scaled","smallestPixelValue","largestPixelValue","end","decodeTimeInMS","postProcessDecodedPixels","pixelDataType","getPixelDataTypeFromMinMax","obj","decodeTask","expose","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","call","m","__webpack_exports__","O","chunkIds","fn","priority","notFulfilled","Infinity","fulfilled","keys","every","key","splice","r","getter","__esModule","d","a","getPrototypeOf","t","mode","ns","create","def","current","indexOf","getOwnPropertyNames","forEach","definition","o","defineProperty","enumerable","get","e","chunkId","all","reduce","promises","u","g","globalThis","Function","window","prop","prototype","hasOwnProperty","Symbol","toStringTag","scriptUrl","importScripts","location","document","currentScript","scripts","getElementsByTagName","replace","p","self","installedChunks","chunkLoadingGlobal","parentChunkLoadingFunction","push","bind","moreModules","runtime","pop"],"sourceRoot":""}
|
|
1
|
+
{"version":3,"file":"918.min.js","mappings":"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","sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/runtime/chunk loaded","webpack:///webpack/runtime/create fake namespace object","webpack:///webpack/runtime/startup chunk dependencies","webpack:///./shared/decoders/decodeLittleEndian.ts","webpack:///./shared/decoders/decodeBigEndian.ts","webpack:///./shared/decoders/decodeRLE.ts","webpack:///./shared/decoders/decodeJPEGBaseline8Bit.ts","webpack:///./shared/decoders/decodeJPEGBaseline12Bit-js.ts","webpack:///./shared/decoders/decodeJPEGLossless.ts","webpack:///./shared/decoders/decodeJPEGLS.ts","webpack:///./shared/decoders/decodeJPEG2000.ts","webpack:///./shared/decoders/decodeHTJ2K.ts","webpack:///./shared/getMinMax.ts","webpack:///./decodeImageFrameWorker.js","webpack:///./shared/scaling/bilinear.ts","webpack:///./shared/scaling/replicate.ts","webpack:///./shared/isColorImage.ts","webpack:///./shared/scaling/scaleArray.ts","webpack:///./shared/getPixelDataTypeFromMinMax.ts","webpack:///webpack/bootstrap","webpack:///webpack/runtime/compat get default export","webpack:///webpack/runtime/define property getters","webpack:///webpack/runtime/ensure chunk","webpack:///webpack/runtime/get javascript chunk filename","webpack:///webpack/runtime/global","webpack:///webpack/runtime/hasOwnProperty shorthand","webpack:///webpack/runtime/make namespace object","webpack:///webpack/runtime/publicPath","webpack:///webpack/runtime/importScripts chunk loading","webpack:///webpack/startup"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"918\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"918\"] = factory();\n\telse\n\t\troot[\"918\"] = factory();\n})(this, () => {\nreturn ","var deferred = [];\n__webpack_require__.O = (result, chunkIds, fn, priority) => {\n\tif(chunkIds) {\n\t\tpriority = priority || 0;\n\t\tfor(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];\n\t\tdeferred[i] = [chunkIds, fn, priority];\n\t\treturn;\n\t}\n\tvar notFulfilled = Infinity;\n\tfor (var i = 0; i < deferred.length; i++) {\n\t\tvar [chunkIds, fn, priority] = deferred[i];\n\t\tvar fulfilled = true;\n\t\tfor (var j = 0; j < chunkIds.length; j++) {\n\t\t\tif ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every((key) => (__webpack_require__.O[key](chunkIds[j])))) {\n\t\t\t\tchunkIds.splice(j--, 1);\n\t\t\t} else {\n\t\t\t\tfulfilled = false;\n\t\t\t\tif(priority < notFulfilled) notFulfilled = priority;\n\t\t\t}\n\t\t}\n\t\tif(fulfilled) {\n\t\t\tdeferred.splice(i--, 1)\n\t\t\tvar r = fn();\n\t\t\tif (r !== undefined) result = r;\n\t\t}\n\t}\n\treturn result;\n};","var getProto = Object.getPrototypeOf ? (obj) => (Object.getPrototypeOf(obj)) : (obj) => (obj.__proto__);\nvar leafPrototypes;\n// create a fake namespace object\n// mode & 1: value is a module id, require it\n// mode & 2: merge all properties of value into the ns\n// mode & 4: return value when already ns object\n// mode & 16: return value when it's Promise-like\n// mode & 8|1: behave like require\n__webpack_require__.t = function(value, mode) {\n\tif(mode & 1) value = this(value);\n\tif(mode & 8) return value;\n\tif(typeof value === 'object' && value) {\n\t\tif((mode & 4) && value.__esModule) return value;\n\t\tif((mode & 16) && typeof value.then === 'function') return value;\n\t}\n\tvar ns = Object.create(null);\n\t__webpack_require__.r(ns);\n\tvar def = {};\n\tleafPrototypes = leafPrototypes || [null, getProto({}), getProto([]), getProto(getProto)];\n\tfor(var current = mode & 2 && value; typeof current == 'object' && !~leafPrototypes.indexOf(current); current = getProto(current)) {\n\t\tObject.getOwnPropertyNames(current).forEach((key) => (def[key] = () => (value[key])));\n\t}\n\tdef['default'] = () => (value);\n\t__webpack_require__.d(ns, def);\n\treturn ns;\n};","var next = __webpack_require__.x;\n__webpack_require__.x = () => {\n\treturn __webpack_require__.e(958).then(next);\n};","import type { ByteArray } from 'dicom-parser';\nimport type { Types } from '@cornerstonejs/core';\n\nasync function decodeLittleEndian(\n imageFrame: Types.IImageFrame,\n pixelData: ByteArray\n): Promise<Types.IImageFrame> {\n let arrayBuffer = pixelData.buffer;\n\n let offset = pixelData.byteOffset;\n const length = pixelData.length;\n\n if (imageFrame.bitsAllocated === 16) {\n // if pixel data is not aligned on even boundary, shift it so we can create the 16 bit array\n // buffers on it\n if (offset % 2) {\n arrayBuffer = arrayBuffer.slice(offset);\n offset = 0;\n }\n\n if (imageFrame.pixelRepresentation === 0) {\n imageFrame.pixelData = new Uint16Array(arrayBuffer, offset, length / 2);\n } else {\n imageFrame.pixelData = new Int16Array(arrayBuffer, offset, length / 2);\n }\n } else if (imageFrame.bitsAllocated === 8 || imageFrame.bitsAllocated === 1) {\n imageFrame.pixelData = pixelData;\n } else if (imageFrame.bitsAllocated === 32) {\n // if pixel data is not aligned on even boundary, shift it\n if (offset % 2) {\n arrayBuffer = arrayBuffer.slice(offset);\n offset = 0;\n }\n\n imageFrame.pixelData = new Float32Array(arrayBuffer, offset, length / 4);\n }\n\n return imageFrame;\n}\n\nexport default decodeLittleEndian;\n","import type { ByteArray } from 'dicom-parser';\nimport type { Types } from '@cornerstonejs/core';\n\n/* eslint no-bitwise: 0 */\nfunction swap16(val) {\n return ((val & 0xff) << 8) | ((val >> 8) & 0xff);\n}\n\nasync function decodeBigEndian(\n imageFrame: Types.IImageFrame,\n pixelData: ByteArray\n): Promise<Types.IImageFrame> {\n if (imageFrame.bitsAllocated === 16) {\n let arrayBuffer = pixelData.buffer;\n\n let offset = pixelData.byteOffset;\n const length = pixelData.length;\n // if pixel data is not aligned on even boundary, shift it so we can create the 16 bit array\n // buffers on it\n\n if (offset % 2) {\n arrayBuffer = arrayBuffer.slice(offset);\n offset = 0;\n }\n\n if (imageFrame.pixelRepresentation === 0) {\n imageFrame.pixelData = new Uint16Array(arrayBuffer, offset, length / 2);\n } else {\n imageFrame.pixelData = new Int16Array(arrayBuffer, offset, length / 2);\n }\n // Do the byte swap\n for (let i = 0; i < imageFrame.pixelData.length; i++) {\n imageFrame.pixelData[i] = swap16(imageFrame.pixelData[i]);\n }\n } else if (imageFrame.bitsAllocated === 8) {\n imageFrame.pixelData = pixelData;\n }\n\n return imageFrame;\n}\n\nexport default decodeBigEndian;\n","import type { ByteArray } from 'dicom-parser';\nimport type { Types } from '@cornerstonejs/core';\n\nasync function decodeRLE(\n imageFrame: Types.IImageFrame,\n pixelData: ByteArray\n): Promise<Types.IImageFrame> {\n if (imageFrame.bitsAllocated === 8) {\n if (imageFrame.planarConfiguration) {\n return decode8Planar(imageFrame, pixelData);\n }\n\n return decode8(imageFrame, pixelData);\n } else if (imageFrame.bitsAllocated === 16) {\n return decode16(imageFrame, pixelData);\n }\n\n throw new Error('unsupported pixel format for RLE');\n}\n\nfunction decode8(imageFrame: Types.IImageFrame, pixelData: ByteArray) {\n const frameData = pixelData;\n const frameSize = imageFrame.rows * imageFrame.columns;\n const outFrame = new ArrayBuffer(frameSize * imageFrame.samplesPerPixel);\n const header = new DataView(frameData.buffer, frameData.byteOffset);\n const data = new Int8Array(frameData.buffer, frameData.byteOffset);\n const out = new Int8Array(outFrame);\n\n let outIndex = 0;\n const numSegments = header.getInt32(0, true);\n\n for (let s = 0; s < numSegments; ++s) {\n outIndex = s;\n\n let inIndex = header.getInt32((s + 1) * 4, true);\n\n let maxIndex = header.getInt32((s + 2) * 4, true);\n\n if (maxIndex === 0) {\n maxIndex = frameData.length;\n }\n\n const endOfSegment = frameSize * numSegments;\n\n while (inIndex < maxIndex) {\n const n = data[inIndex++];\n\n if (n >= 0 && n <= 127) {\n // copy n bytes\n for (let i = 0; i < n + 1 && outIndex < endOfSegment; ++i) {\n out[outIndex] = data[inIndex++];\n outIndex += imageFrame.samplesPerPixel;\n }\n } else if (n <= -1 && n >= -127) {\n const value = data[inIndex++];\n // run of n bytes\n\n for (let j = 0; j < -n + 1 && outIndex < endOfSegment; ++j) {\n out[outIndex] = value;\n outIndex += imageFrame.samplesPerPixel;\n }\n } /* else if (n === -128) {\n\n } // do nothing */\n }\n }\n imageFrame.pixelData = new Uint8Array(outFrame);\n\n return imageFrame;\n}\n\nfunction decode8Planar(imageFrame: Types.IImageFrame, pixelData: ByteArray) {\n const frameData = pixelData;\n const frameSize = imageFrame.rows * imageFrame.columns;\n const outFrame = new ArrayBuffer(frameSize * imageFrame.samplesPerPixel);\n const header = new DataView(frameData.buffer, frameData.byteOffset);\n const data = new Int8Array(frameData.buffer, frameData.byteOffset);\n const out = new Int8Array(outFrame);\n\n let outIndex = 0;\n const numSegments = header.getInt32(0, true);\n\n for (let s = 0; s < numSegments; ++s) {\n outIndex = s * frameSize;\n\n let inIndex = header.getInt32((s + 1) * 4, true);\n\n let maxIndex = header.getInt32((s + 2) * 4, true);\n\n if (maxIndex === 0) {\n maxIndex = frameData.length;\n }\n\n const endOfSegment = frameSize * numSegments;\n\n while (inIndex < maxIndex) {\n const n = data[inIndex++];\n\n if (n >= 0 && n <= 127) {\n // copy n bytes\n for (let i = 0; i < n + 1 && outIndex < endOfSegment; ++i) {\n out[outIndex] = data[inIndex++];\n outIndex++;\n }\n } else if (n <= -1 && n >= -127) {\n const value = data[inIndex++];\n // run of n bytes\n\n for (let j = 0; j < -n + 1 && outIndex < endOfSegment; ++j) {\n out[outIndex] = value;\n outIndex++;\n }\n } /* else if (n === -128) {\n\n } // do nothing */\n }\n }\n imageFrame.pixelData = new Uint8Array(outFrame);\n\n return imageFrame;\n}\n\nfunction decode16(imageFrame: Types.IImageFrame, pixelData: ByteArray) {\n const frameData = pixelData;\n const frameSize = imageFrame.rows * imageFrame.columns;\n const outFrame = new ArrayBuffer(frameSize * imageFrame.samplesPerPixel * 2);\n\n const header = new DataView(frameData.buffer, frameData.byteOffset);\n const data = new Int8Array(frameData.buffer, frameData.byteOffset);\n const out = new Int8Array(outFrame);\n\n const numSegments = header.getInt32(0, true);\n\n for (let s = 0; s < numSegments; ++s) {\n let outIndex = 0;\n const highByte = s === 0 ? 1 : 0;\n\n let inIndex = header.getInt32((s + 1) * 4, true);\n\n let maxIndex = header.getInt32((s + 2) * 4, true);\n\n if (maxIndex === 0) {\n maxIndex = frameData.length;\n }\n\n while (inIndex < maxIndex) {\n const n = data[inIndex++];\n\n if (n >= 0 && n <= 127) {\n for (let i = 0; i < n + 1 && outIndex < frameSize; ++i) {\n out[outIndex * 2 + highByte] = data[inIndex++];\n outIndex++;\n }\n } else if (n <= -1 && n >= -127) {\n const value = data[inIndex++];\n\n for (let j = 0; j < -n + 1 && outIndex < frameSize; ++j) {\n out[outIndex * 2 + highByte] = value;\n outIndex++;\n }\n } /* else if (n === -128) {\n\n } // do nothing */\n }\n }\n if (imageFrame.pixelRepresentation === 0) {\n imageFrame.pixelData = new Uint16Array(outFrame);\n } else {\n imageFrame.pixelData = new Int16Array(outFrame);\n }\n\n return imageFrame;\n}\n\nexport default decodeRLE;\n","import type {\n LibJpegTurbo8Bit,\n OpenJpegModule,\n} from '@cornerstonejs/codec-libjpeg-turbo-8bit/dist/libjpegturbowasm_decode';\nimport type { ByteArray } from 'dicom-parser';\n// @ts-ignore\nimport libjpegTurboFactory from '@cornerstonejs/codec-libjpeg-turbo-8bit/decodewasmjs';\n\n// @ts-ignore\n// import libjpegTurboWasm from '@cornerstonejs/codec-libjpeg-turbo-8bit/decodewasm';\nconst libjpegTurboWasm = new URL(\n '@cornerstonejs/codec-libjpeg-turbo-8bit/decodewasm',\n import.meta.url\n);\nimport type { Types } from '@cornerstonejs/core';\n\nconst local: {\n codec: OpenJpegModule;\n decoder: LibJpegTurbo8Bit;\n} = {\n codec: undefined,\n decoder: undefined,\n};\n\nfunction initLibjpegTurbo(): Promise<void> {\n if (local.codec) {\n return Promise.resolve();\n }\n\n const libjpegTurboModule = libjpegTurboFactory({\n locateFile: (f) => {\n if (f.endsWith('.wasm')) {\n return libjpegTurboWasm.toString();\n }\n\n return f;\n },\n });\n\n return new Promise((resolve, reject) => {\n libjpegTurboModule.then((instance) => {\n local.codec = instance;\n local.decoder = new instance.JPEGDecoder();\n resolve();\n }, reject);\n });\n}\n\n// imageFrame.pixelRepresentation === 1 <-- Signed\n/**\n *\n * @param {*} compressedImageFrame\n * @param {object} imageInfo\n * @param {boolean} imageInfo.signed -\n */\nasync function decodeAsync(\n compressedImageFrame,\n imageInfo\n): Promise<Types.IImageFrame> {\n await initLibjpegTurbo();\n const decoder = local.decoder;\n\n // get pointer to the source/encoded bit stream buffer in WASM memory\n // that can hold the encoded bitstream\n const encodedBufferInWASM = decoder.getEncodedBuffer(\n compressedImageFrame.length\n );\n\n // copy the encoded bitstream into WASM memory buffer\n encodedBufferInWASM.set(compressedImageFrame);\n\n // decode it\n decoder.decode();\n\n // get information about the decoded image\n const frameInfo = decoder.getFrameInfo();\n\n // get the decoded pixels\n const decodedPixelsInWASM = decoder.getDecodedBuffer();\n\n const encodedImageInfo = {\n columns: frameInfo.width,\n rows: frameInfo.height,\n bitsPerPixel: frameInfo.bitsPerSample,\n signed: imageInfo.signed,\n bytesPerPixel: imageInfo.bytesPerPixel,\n componentsPerPixel: frameInfo.componentCount,\n };\n\n const pixelData = getPixelData(frameInfo, decodedPixelsInWASM);\n\n const encodeOptions = {\n frameInfo,\n };\n\n return {\n ...imageInfo,\n pixelData,\n imageInfo: encodedImageInfo,\n encodeOptions,\n ...encodeOptions,\n ...encodedImageInfo,\n };\n}\n\nfunction getPixelData(frameInfo, decodedBuffer: ByteArray) {\n if (frameInfo.isSigned) {\n return new Int8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n }\n\n return new Uint8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n}\n\nexport default decodeAsync;\n","import type { ByteArray } from 'dicom-parser';\nimport type { Types } from '@cornerstonejs/core';\nimport type { WebWorkerDecodeConfig } from '../../types';\n\nconst local = {\n JpegImage: undefined,\n decodeConfig: {} as WebWorkerDecodeConfig,\n};\n\nexport function initialize(\n decodeConfig?: WebWorkerDecodeConfig\n): Promise<void> {\n local.decodeConfig = decodeConfig;\n\n if (local.JpegImage) {\n return Promise.resolve();\n }\n\n return new Promise((resolve, reject) => {\n // @ts-ignore\n import('../../../codecs/jpeg').then(({ JpegImage }) => {\n local.JpegImage = JpegImage;\n resolve();\n }, reject);\n });\n}\n\nasync function decodeJPEGBaseline12BitAsync(\n imageFrame: Types.IImageFrame,\n pixelData: ByteArray\n): Promise<Types.IImageFrame> {\n // check to make sure codec is loaded\n await initialize();\n if (typeof local.JpegImage === 'undefined') {\n throw new Error('No JPEG Baseline decoder loaded');\n }\n const jpeg = new local.JpegImage();\n\n jpeg.parse(pixelData);\n\n // Do not use the internal jpeg.js color transformation,\n // since we will handle this afterwards\n jpeg.colorTransform = false;\n\n if (imageFrame.bitsAllocated === 8) {\n imageFrame.pixelData = jpeg.getData(imageFrame.columns, imageFrame.rows);\n\n return imageFrame;\n } else if (imageFrame.bitsAllocated === 16) {\n imageFrame.pixelData = jpeg.getData16(imageFrame.columns, imageFrame.rows);\n\n return imageFrame;\n }\n}\n\nexport default decodeJPEGBaseline12BitAsync;\n","import type { ByteArray } from 'dicom-parser';\nimport type { Types } from '@cornerstonejs/core';\nimport type { WebWorkerDecodeConfig } from '../../types';\n\nconst local = {\n jpeg: undefined,\n decodeConfig: {} as WebWorkerDecodeConfig,\n};\n\nexport function initialize(\n decodeConfig?: WebWorkerDecodeConfig\n): Promise<void> {\n local.decodeConfig = decodeConfig;\n\n if (local.jpeg) {\n return Promise.resolve();\n }\n\n return new Promise((resolve, reject) => {\n import('../../../codecs/jpegLossless').then((jpeg) => {\n local.jpeg = jpeg;\n resolve();\n }, reject);\n });\n}\n\nasync function decodeJPEGLossless(\n imageFrame: Types.IImageFrame,\n pixelData: ByteArray\n): Promise<Types.IImageFrame> {\n await initialize();\n\n // check to make sure codec is loaded\n if (\n typeof local.jpeg === 'undefined' ||\n typeof local.jpeg.lossless === 'undefined' ||\n typeof local.jpeg.lossless.Decoder === 'undefined'\n ) {\n throw new Error('No JPEG Lossless decoder loaded');\n }\n\n const byteOutput = imageFrame.bitsAllocated <= 8 ? 1 : 2;\n // console.time('jpeglossless');\n const buffer = pixelData.buffer;\n const decoder = new local.jpeg.lossless.Decoder();\n const decompressedData = decoder.decode(\n buffer,\n pixelData.byteOffset,\n pixelData.length,\n byteOutput\n );\n // console.timeEnd('jpeglossless');\n\n if (imageFrame.pixelRepresentation === 0) {\n if (imageFrame.bitsAllocated === 16) {\n imageFrame.pixelData = new Uint16Array(decompressedData.buffer);\n\n return imageFrame;\n }\n // untested!\n imageFrame.pixelData = new Uint8Array(decompressedData.buffer);\n\n return imageFrame;\n }\n imageFrame.pixelData = new Int16Array(decompressedData.buffer);\n\n return imageFrame;\n}\n\nexport default decodeJPEGLossless;\n","import type {\n CharlsModule,\n JpegLSDecoder,\n} from '@cornerstonejs/codec-charls/dist/charlswasm_decode';\n// @ts-ignore\nimport charlsFactory from '@cornerstonejs/codec-charls/decodewasmjs';\n// @ts-ignore\n// import charlsWasm from '@cornerstonejs/codec-charls/decodewasm';\nconst charlsWasm = new URL(\n '@cornerstonejs/codec-charls/decodewasm',\n import.meta.url\n);\nimport type { ByteArray } from 'dicom-parser';\nimport type { WebWorkerDecodeConfig } from '../../types';\nimport type { Types } from '@cornerstonejs/core';\n\nconst local: {\n codec: CharlsModule;\n decoder: JpegLSDecoder;\n decodeConfig: WebWorkerDecodeConfig;\n} = {\n codec: undefined,\n decoder: undefined,\n decodeConfig: {} as WebWorkerDecodeConfig,\n};\n\nfunction getExceptionMessage(exception) {\n return typeof exception === 'number'\n ? local.codec.getExceptionMessage(exception)\n : exception;\n}\n\nexport function initialize(\n decodeConfig?: WebWorkerDecodeConfig\n): Promise<void> {\n local.decodeConfig = decodeConfig;\n\n if (local.codec) {\n return Promise.resolve();\n }\n\n const charlsModule = charlsFactory({\n locateFile: (f) => {\n if (f.endsWith('.wasm')) {\n return charlsWasm.toString();\n }\n\n return f;\n },\n });\n\n return new Promise((resolve, reject) => {\n charlsModule.then((instance) => {\n local.codec = instance;\n local.decoder = new instance.JpegLSDecoder();\n resolve();\n }, reject);\n });\n}\n\n/**\n *\n * @param {*} compressedImageFrame\n * @param {object} imageInfo\n * @param {boolean} imageInfo.signed - (pixelRepresentation === 1)\n */\nasync function decodeAsync(\n compressedImageFrame,\n imageInfo\n): Promise<Types.IImageFrame> {\n try {\n await initialize();\n const decoder = local.decoder;\n\n // get pointer to the source/encoded bit stream buffer in WASM memory\n // that can hold the encoded bitstream\n const encodedBufferInWASM = decoder.getEncodedBuffer(\n compressedImageFrame.length\n );\n\n // copy the encoded bitstream into WASM memory buffer\n encodedBufferInWASM.set(compressedImageFrame);\n\n // decode it\n decoder.decode();\n\n // get information about the decoded image\n const frameInfo = decoder.getFrameInfo();\n const interleaveMode = decoder.getInterleaveMode();\n const nearLossless = decoder.getNearLossless();\n\n // get the decoded pixels\n const decodedPixelsInWASM = decoder.getDecodedBuffer();\n\n const encodedImageInfo = {\n columns: frameInfo.width,\n rows: frameInfo.height,\n bitsPerPixel: frameInfo.bitsPerSample,\n signed: imageInfo.signed,\n bytesPerPixel: imageInfo.bytesPerPixel,\n componentsPerPixel: frameInfo.componentCount,\n };\n\n const pixelData = getPixelData(\n frameInfo,\n decodedPixelsInWASM,\n imageInfo.signed\n );\n\n const encodeOptions = {\n nearLossless,\n interleaveMode,\n frameInfo,\n };\n\n // local.codec.doLeakCheck();\n\n return {\n ...imageInfo,\n pixelData,\n imageInfo: encodedImageInfo,\n encodeOptions,\n ...encodeOptions,\n ...encodedImageInfo,\n };\n } catch (error) {\n // Handle cases where WASM throws an error internally, and it only gives JS a number\n // See https://emscripten.org/docs/porting/Debugging.html#handling-c-exceptions-from-javascript\n // TODO: Copy to other codecs as well\n throw getExceptionMessage(error);\n }\n}\n\nfunction getPixelData(frameInfo, decodedBuffer: ByteArray, signed: boolean) {\n if (frameInfo.bitsPerSample > 8) {\n if (signed) {\n return new Int16Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength / 2\n );\n }\n\n return new Uint16Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength / 2\n );\n }\n\n if (signed) {\n return new Int8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n }\n\n return new Uint8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n}\n\nexport default decodeAsync;\n","// https://emscripten.org/docs/api_reference/module.html\nimport type {\n J2KDecoder,\n OpenJpegModule,\n} from '@cornerstonejs/codec-openjpeg/dist/openjpegwasm_decode';\n// @ts-ignore\nimport openJpegFactory from '@cornerstonejs/codec-openjpeg/decodewasmjs';\n\n// Webpack asset/resource copies this to our output folder\n\n// TODO: At some point maybe we can use this instead.\n// This is closer to what Webpack 5 wants but it doesn't seem to work now\n// const wasm = new URL('./blah.wasm', import.meta.url)\n// @ts-ignore\n// import openjpegWasm from '@cornerstonejs/codec-openjpeg/decodewasm';\nconst openjpegWasm = new URL(\n '@cornerstonejs/codec-openjpeg/decodewasm',\n import.meta.url\n);\n\nimport type { Types } from '@cornerstonejs/core';\nimport type { WebWorkerDecodeConfig } from '../../types';\n\nconst local: {\n codec: OpenJpegModule;\n decoder: J2KDecoder;\n decodeConfig: WebWorkerDecodeConfig;\n} = {\n codec: undefined,\n decoder: undefined,\n decodeConfig: {} as WebWorkerDecodeConfig,\n};\n\nexport function initialize(\n decodeConfig?: WebWorkerDecodeConfig\n): Promise<void> {\n local.decodeConfig = decodeConfig;\n\n if (local.codec) {\n return Promise.resolve();\n }\n\n const openJpegModule = openJpegFactory({\n locateFile: (f) => {\n if (f.endsWith('.wasm')) {\n return openjpegWasm.toString();\n }\n\n return f;\n },\n });\n\n return new Promise((resolve, reject) => {\n openJpegModule.then((instance) => {\n local.codec = instance;\n local.decoder = new instance.J2KDecoder();\n resolve();\n }, reject);\n });\n}\n\n// https://github.com/chafey/openjpegjs/blob/master/test/browser/index.html\nasync function decodeAsync(\n compressedImageFrame,\n imageInfo\n): Promise<Types.IImageFrame> {\n await initialize();\n const decoder = local.decoder;\n\n // get pointer to the source/encoded bit stream buffer in WASM memory\n // that can hold the encoded bitstream\n const encodedBufferInWASM = decoder.getEncodedBuffer(\n compressedImageFrame.length\n );\n\n // copy the encoded bitstream into WASM memory buffer\n encodedBufferInWASM.set(compressedImageFrame);\n\n // decode it\n decoder.decode();\n // decoder.decodeSubResolution(decodeLevel, decodeLayer);\n // const resolutionAtLevel = decoder.calculateSizeAtDecompositionLevel(decodeLevel);\n\n // get information about the decoded image\n const frameInfo = decoder.getFrameInfo();\n // get the decoded pixels\n const decodedBufferInWASM = decoder.getDecodedBuffer();\n const imageFrame = new Uint8Array(decodedBufferInWASM.length);\n\n imageFrame.set(decodedBufferInWASM);\n\n const imageOffset = `x: ${decoder.getImageOffset().x}, y: ${\n decoder.getImageOffset().y\n }`;\n const numDecompositions = decoder.getNumDecompositions();\n const numLayers = decoder.getNumLayers();\n const progessionOrder = ['unknown', 'LRCP', 'RLCP', 'RPCL', 'PCRL', 'CPRL'][\n decoder.getProgressionOrder() + 1\n ];\n const reversible = decoder.getIsReversible();\n const blockDimensions = `${decoder.getBlockDimensions().width} x ${\n decoder.getBlockDimensions().height\n }`;\n const tileSize = `${decoder.getTileSize().width} x ${\n decoder.getTileSize().height\n }`;\n const tileOffset = `${decoder.getTileOffset().x}, ${\n decoder.getTileOffset().y\n }`;\n const colorTransform = decoder.getColorSpace();\n\n const decodedSize = `${decodedBufferInWASM.length.toLocaleString()} bytes`;\n const compressionRatio = `${(\n decodedBufferInWASM.length / encodedBufferInWASM.length\n ).toFixed(2)}:1`;\n\n const encodedImageInfo = {\n columns: frameInfo.width,\n rows: frameInfo.height,\n bitsPerPixel: frameInfo.bitsPerSample,\n signed: frameInfo.isSigned,\n bytesPerPixel: imageInfo.bytesPerPixel,\n componentsPerPixel: frameInfo.componentCount,\n };\n const pixelData = getPixelData(frameInfo, decodedBufferInWASM);\n\n const encodeOptions = {\n imageOffset,\n numDecompositions,\n numLayers,\n progessionOrder,\n reversible,\n blockDimensions,\n tileSize,\n tileOffset,\n colorTransform,\n decodedSize,\n compressionRatio,\n };\n\n return {\n ...imageInfo,\n pixelData,\n imageInfo: encodedImageInfo,\n encodeOptions,\n ...encodeOptions,\n ...encodedImageInfo,\n };\n}\n\nfunction getPixelData(frameInfo, decodedBuffer) {\n if (frameInfo.bitsPerSample > 8) {\n if (frameInfo.isSigned) {\n return new Int16Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength / 2\n );\n }\n\n return new Uint16Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength / 2\n );\n }\n\n if (frameInfo.isSigned) {\n return new Int8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n }\n\n return new Uint8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n}\n\nexport default decodeAsync;\n","import type { ByteArray } from 'dicom-parser';\n// @ts-ignore\nimport openJphFactory from '@cornerstonejs/codec-openjph/wasmjs';\n// @ts-ignore\n// import openjphWasm from '@cornerstonejs/codec-openjph/wasm';\nconst openjphWasm = new URL(\n '@cornerstonejs/codec-openjph/wasm',\n import.meta.url\n);\n\nimport type { LoaderDecodeOptions } from '../../types';\n\nconst local: {\n codec: unknown;\n decoder: unknown;\n decodeConfig: LoaderDecodeOptions;\n} = {\n codec: undefined,\n decoder: undefined,\n decodeConfig: {},\n};\n\nfunction calculateSizeAtDecompositionLevel(\n decompositionLevel: number,\n frameWidth: number,\n frameHeight: number\n) {\n const result = { width: frameWidth, height: frameHeight };\n while (decompositionLevel > 0) {\n result.width = Math.ceil(result.width / 2);\n result.height = Math.ceil(result.height / 2);\n decompositionLevel--;\n }\n return result;\n}\n\nexport function initialize(decodeConfig?: LoaderDecodeOptions): Promise<void> {\n local.decodeConfig = decodeConfig;\n\n if (local.codec) {\n return Promise.resolve();\n }\n\n const openJphModule = openJphFactory({\n locateFile: (f) => {\n if (f.endsWith('.wasm')) {\n return openjphWasm;\n }\n\n return f;\n },\n });\n\n return new Promise<void>((resolve, reject) => {\n openJphModule.then((instance) => {\n local.codec = instance;\n local.decoder = new instance.HTJ2KDecoder();\n resolve();\n }, reject);\n });\n}\n\n// https://github.com/chafey/openjpegjs/blob/master/test/browser/index.html\nasync function decodeAsync(compressedImageFrame: ByteArray, imageInfo) {\n await initialize();\n // const decoder = local.decoder; // This is much slower for some reason\n // @ts-expect-error\n const decoder = new local.codec.HTJ2KDecoder();\n\n // get pointer to the source/encoded bit stream buffer in WASM memory\n // that can hold the encoded bitstream\n const encodedBufferInWASM = decoder.getEncodedBuffer(\n compressedImageFrame.length\n );\n\n // copy the encoded bitstream into WASM memory buffer\n encodedBufferInWASM.set(compressedImageFrame);\n\n // decode it\n // decoder.decode();\n const decodeLevel = imageInfo.decodeLevel || 0;\n decoder.decodeSubResolution(decodeLevel);\n // decoder.decodeSubResolution(decodeLevel, decodeLayer);\n // const resolutionAtLevel = decoder.calculateSizeAtDecompositionLevel(decodeLevel);\n\n // get information about the decoded image\n const frameInfo = decoder.getFrameInfo();\n // Overwrite width/height if subresolution\n if (imageInfo.decodeLevel > 0) {\n const { width, height } = calculateSizeAtDecompositionLevel(\n imageInfo.decodeLevel,\n frameInfo.width,\n frameInfo.height\n );\n frameInfo.width = width;\n frameInfo.height = height;\n // console.log(`Decoded sub-resolution of size: ${width} x ${height}`);\n }\n // get the decoded pixels\n const decodedBufferInWASM = decoder.getDecodedBuffer();\n const imageFrame = new Uint8Array(decodedBufferInWASM.length);\n\n imageFrame.set(decodedBufferInWASM);\n\n const imageOffset = `x: ${decoder.getImageOffset().x}, y: ${\n decoder.getImageOffset().y\n }`;\n const numDecompositions = decoder.getNumDecompositions();\n const numLayers = decoder.getNumLayers();\n const progessionOrder = ['unknown', 'LRCP', 'RLCP', 'RPCL', 'PCRL', 'CPRL'][\n decoder.getProgressionOrder() + 1\n ];\n const reversible = decoder.getIsReversible();\n const blockDimensions = `${decoder.getBlockDimensions().width} x ${\n decoder.getBlockDimensions().height\n }`;\n const tileSize = `${decoder.getTileSize().width} x ${\n decoder.getTileSize().height\n }`;\n const tileOffset = `${decoder.getTileOffset().x}, ${\n decoder.getTileOffset().y\n }`;\n // const colorTransform = decoder.getColorSpace();\n\n const decodedSize = `${decodedBufferInWASM.length.toLocaleString()} bytes`;\n const compressionRatio = `${(\n decodedBufferInWASM.length / encodedBufferInWASM.length\n ).toFixed(2)}:1`;\n\n const encodedImageInfo = {\n columns: frameInfo.width,\n rows: frameInfo.height,\n bitsPerPixel: frameInfo.bitsPerSample,\n signed: frameInfo.isSigned,\n bytesPerPixel: imageInfo.bytesPerPixel,\n componentsPerPixel: frameInfo.componentCount,\n };\n // const pixelData = getPixelData(frameInfo, decodedBufferInWASM);\n\n /**\n * Have to truncate the arraybuffer here to the length of the typed array. Not\n * sure why the arraybuffer is so huge, maybe this is allocated by the WASM\n * module? In any case, I think it's too big to postMessage in it's entirety.\n */\n let pixelData = getPixelData(frameInfo, decodedBufferInWASM);\n const { buffer: b, byteOffset, byteLength } = pixelData;\n const pixelDataArrayBuffer = b.slice(byteOffset, byteOffset + byteLength);\n\n // @ts-ignore\n pixelData = new pixelData.constructor(pixelDataArrayBuffer);\n\n const encodeOptions = {\n imageOffset,\n numDecompositions,\n numLayers,\n progessionOrder,\n reversible,\n blockDimensions,\n tileSize,\n tileOffset,\n // colorTransform,\n decodedSize,\n compressionRatio,\n };\n\n return {\n ...imageInfo,\n pixelData,\n imageInfo: encodedImageInfo,\n encodeOptions,\n ...encodeOptions,\n ...encodedImageInfo,\n };\n}\n\nfunction getPixelData(frameInfo, decodedBuffer) {\n if (frameInfo.bitsPerSample > 8) {\n if (frameInfo.isSigned) {\n return new Int16Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength / 2\n );\n }\n\n return new Uint16Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength / 2\n );\n }\n\n if (frameInfo.isSigned) {\n return new Int8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n }\n\n return new Uint8Array(\n decodedBuffer.buffer,\n decodedBuffer.byteOffset,\n decodedBuffer.byteLength\n );\n}\n\nexport default decodeAsync;\n","import type { Types } from '@cornerstonejs/core';\n\n/**\n * Calculate the minimum and maximum values in an Array\n *\n * @param {Number[]} storedPixelData\n * @return {{min: Number, max: Number}}\n */\nfunction getMinMax(storedPixelData: Types.PixelDataTypedArray): {\n min: number;\n max: number;\n} {\n // we always calculate the min max values since they are not always\n // present in DICOM and we don't want to trust them anyway as cornerstone\n // depends on us providing reliable values for these\n let min = storedPixelData[0];\n\n let max = storedPixelData[0];\n\n let storedPixel;\n const numPixels = storedPixelData.length;\n\n for (let index = 1; index < numPixels; index++) {\n storedPixel = storedPixelData[index];\n min = Math.min(min, storedPixel);\n max = Math.max(max, storedPixel);\n }\n\n return {\n min,\n max,\n };\n}\n\nexport default getMinMax;\n","/* eslint-disable complexity */\nimport bilinear from './shared/scaling/bilinear';\nimport replicate from './shared/scaling/replicate';\nimport { expose } from 'comlink';\n\nimport decodeLittleEndian from './shared/decoders/decodeLittleEndian';\nimport decodeBigEndian from './shared/decoders/decodeBigEndian';\nimport decodeRLE from './shared/decoders/decodeRLE';\nimport decodeJPEGBaseline8Bit from './shared/decoders/decodeJPEGBaseline8Bit';\n// import decodeJPEGBaseline12Bit from './shared/decoders/decodeJPEGBaseline12Bit';\nimport decodeJPEGBaseline12Bit from './shared/decoders/decodeJPEGBaseline12Bit-js';\nimport decodeJPEGLossless from './shared/decoders/decodeJPEGLossless';\nimport decodeJPEGLS from './shared/decoders/decodeJPEGLS';\nimport decodeJPEG2000 from './shared/decoders/decodeJPEG2000';\nimport decodeHTJ2K from './shared/decoders/decodeHTJ2K';\n// Note that the scaling is pixel value scaling, which is applying a modality LUT\nimport applyModalityLUT from './shared/scaling/scaleArray';\nimport getMinMax from './shared/getMinMax';\nimport getPixelDataTypeFromMinMax from './shared/getPixelDataTypeFromMinMax';\nimport isColorImage from './shared/isColorImage';\n\nconst imageUtils = {\n bilinear,\n replicate,\n};\n\n/**\n * Decodes the provided image frame.\n * This is an async function return the result, or you can provide an optional\n * callbackFn that is called with the results.\n */\nasync function decodeImageFrame(\n imageFrame,\n transferSyntax,\n pixelData,\n decodeConfig,\n options,\n callbackFn\n) {\n const start = new Date().getTime();\n\n let decodePromise = null;\n\n let opts;\n\n switch (transferSyntax) {\n case '1.2.840.10008.1.2':\n case '1.2.840.10008.1.2.1':\n // Implicit or Explicit VR Little Endian\n decodePromise = decodeLittleEndian(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.2':\n // Explicit VR Big Endian (retired)\n decodePromise = decodeBigEndian(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.1.99':\n // Deflate transfer syntax (deflated by dicomParser)\n decodePromise = decodeLittleEndian(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.5':\n // RLE Lossless\n decodePromise = decodeRLE(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.4.50':\n // JPEG Baseline lossy process 1 (8 bit)\n opts = {\n ...imageFrame,\n };\n\n decodePromise = decodeJPEGBaseline8Bit(pixelData, opts);\n break;\n case '1.2.840.10008.1.2.4.51':\n // JPEG Baseline lossy process 2 & 4 (12 bit)\n // opts = {\n // ...imageFrame,\n // };\n // decodePromise = decodeJPEGBaseline12Bit(pixelData, opts);\n //throw new Error('Currently unsupported: 1.2.840.10008.1.2.4.51');\n decodePromise = decodeJPEGBaseline12Bit(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.4.57':\n // JPEG Lossless, Nonhierarchical (Processes 14)\n decodePromise = decodeJPEGLossless(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.4.70':\n // JPEG Lossless, Nonhierarchical (Processes 14 [Selection 1])\n decodePromise = decodeJPEGLossless(imageFrame, pixelData);\n break;\n case '1.2.840.10008.1.2.4.80':\n // JPEG-LS Lossless Image Compression\n opts = {\n signed: imageFrame.pixelRepresentation === 1, // imageFrame.signed,\n // shouldn't need...\n bytesPerPixel: imageFrame.bitsAllocated <= 8 ? 1 : 2,\n ...imageFrame,\n };\n\n decodePromise = decodeJPEGLS(pixelData, opts);\n break;\n case '1.2.840.10008.1.2.4.81':\n // JPEG-LS Lossy (Near-Lossless) Image Compression\n opts = {\n signed: imageFrame.pixelRepresentation === 1, // imageFrame.signed,\n // shouldn't need...\n bytesPerPixel: imageFrame.bitsAllocated <= 8 ? 1 : 2,\n ...imageFrame,\n };\n\n decodePromise = decodeJPEGLS(pixelData, opts);\n break;\n case '1.2.840.10008.1.2.4.90':\n opts = {\n ...imageFrame,\n };\n\n // JPEG 2000 Lossless\n // imageFrame, pixelData, decodeConfig, options\n decodePromise = decodeJPEG2000(pixelData, opts);\n break;\n case '1.2.840.10008.1.2.4.91':\n // JPEG 2000 Lossy\n opts = {\n ...imageFrame,\n };\n\n // JPEG 2000 Lossy\n // imageFrame, pixelData, decodeConfig, options\n decodePromise = decodeJPEG2000(pixelData, opts);\n break;\n case '3.2.840.10008.1.2.4.96':\n case '1.2.840.10008.1.2.4.201':\n case '1.2.840.10008.1.2.4.202':\n case '1.2.840.10008.1.2.4.203':\n // HTJ2K\n opts = {\n ...imageFrame,\n };\n\n decodePromise = decodeHTJ2K(pixelData, opts);\n break;\n default:\n throw new Error(`no decoder for transfer syntax ${transferSyntax}`);\n }\n\n /* Don't know if these work...\n // JPEG 2000 Part 2 Multicomponent Image Compression (Lossless Only)\n else if(transferSyntax === \"1.2.840.10008.1.2.4.92\")\n {\n return decodeJPEG2000(dataSet, frame);\n }\n // JPEG 2000 Part 2 Multicomponent Image Compression\n else if(transferSyntax === \"1.2.840.10008.1.2.4.93\")\n {\n return decodeJPEG2000(dataSet, frame);\n }\n */\n\n if (!decodePromise) {\n throw new Error('decodePromise not defined');\n }\n\n const decodedFrame = await decodePromise;\n\n const postProcessed = postProcessDecodedPixels(\n decodedFrame,\n options,\n start,\n decodeConfig\n );\n\n // Call the callbackFn to agree with older arguments\n callbackFn?.(postProcessed);\n\n return postProcessed;\n}\n\nfunction postProcessDecodedPixels(imageFrame, options, start, decodeConfig) {\n const shouldShift =\n imageFrame.pixelRepresentation !== undefined &&\n imageFrame.pixelRepresentation === 1;\n const shift =\n shouldShift && imageFrame.bitsStored !== undefined\n ? 32 - imageFrame.bitsStored\n : undefined;\n\n if (shouldShift && shift !== undefined) {\n for (let i = 0; i < imageFrame.pixelData.length; i++) {\n // eslint-disable-next-line no-bitwise\n imageFrame.pixelData[i] = (imageFrame.pixelData[i] << shift) >> shift;\n }\n }\n\n // Cache the pixelData reference quickly incase we want to set a targetBuffer _and_ scale.\n let pixelDataArray = imageFrame.pixelData;\n imageFrame.pixelDataLength = imageFrame.pixelData.length;\n const { min: minBeforeScale, max: maxBeforeScale } = getMinMax(\n imageFrame.pixelData\n );\n\n const typedArrayConstructors = {\n Uint8Array,\n Uint16Array,\n Int16Array,\n Float32Array,\n };\n\n const type = options.targetBuffer?.type;\n\n const canRenderFloat =\n typeof options.allowFloatRendering !== 'undefined'\n ? options.allowFloatRendering\n : true;\n\n // Sometimes the type is specified before the DICOM header data has been\n // read. This is fine except for color data, where the wrong type gets\n // specified. Don't use the target buffer in that case.\n const invalidType =\n isColorImage(imageFrame.photometricInterpretation) &&\n options.targetBuffer?.offset === undefined;\n\n const willScale = options.preScale?.enabled;\n\n const hasFloatRescale =\n willScale &&\n Object.values(options.preScale.scalingParameters).some(\n (v) => typeof v === 'number' && !Number.isInteger(v)\n );\n const disableScale =\n !options.preScale.enabled || (!canRenderFloat && hasFloatRescale);\n\n if (type && !invalidType) {\n pixelDataArray = _handleTargetBuffer(\n options,\n imageFrame,\n typedArrayConstructors,\n pixelDataArray\n );\n } else if (options.preScale.enabled && !disableScale) {\n pixelDataArray = _handlePreScaleSetup(\n options,\n minBeforeScale,\n maxBeforeScale,\n imageFrame\n );\n } else {\n pixelDataArray = _getDefaultPixelDataArray(\n minBeforeScale,\n maxBeforeScale,\n imageFrame\n );\n }\n\n let minAfterScale = minBeforeScale;\n let maxAfterScale = maxBeforeScale;\n\n if (options.preScale.enabled && !disableScale) {\n const scalingParameters = options.preScale.scalingParameters;\n _validateScalingParameters(scalingParameters);\n\n const { rescaleSlope, rescaleIntercept } = scalingParameters;\n const isSlopeAndInterceptNumbers =\n typeof rescaleSlope === 'number' && typeof rescaleIntercept === 'number';\n\n if (isSlopeAndInterceptNumbers) {\n applyModalityLUT(pixelDataArray, scalingParameters);\n imageFrame.preScale = {\n ...options.preScale,\n scaled: true,\n };\n\n // calculate the min and max after scaling\n const { rescaleIntercept, rescaleSlope, suvbw } = scalingParameters;\n minAfterScale = rescaleSlope * minBeforeScale + rescaleIntercept;\n maxAfterScale = rescaleSlope * maxBeforeScale + rescaleIntercept;\n\n if (suvbw) {\n minAfterScale = minAfterScale * suvbw;\n maxAfterScale = maxAfterScale * suvbw;\n }\n }\n } else if (disableScale) {\n imageFrame.preScale = {\n enabled: true,\n scaled: false,\n };\n\n minAfterScale = minBeforeScale;\n maxAfterScale = maxBeforeScale;\n }\n\n imageFrame.pixelData = pixelDataArray;\n imageFrame.smallestPixelValue = minAfterScale;\n imageFrame.largestPixelValue = maxAfterScale;\n\n const end = new Date().getTime();\n imageFrame.decodeTimeInMS = end - start;\n\n return imageFrame;\n}\n\nfunction _handleTargetBuffer(\n options,\n imageFrame,\n typedArrayConstructors,\n pixelDataArray\n) {\n const {\n arrayBuffer,\n type,\n offset: rawOffset = 0,\n length: rawLength,\n rows,\n } = options.targetBuffer;\n\n const TypedArrayConstructor = typedArrayConstructors[type];\n\n if (!TypedArrayConstructor) {\n throw new Error(`target array ${type} is not supported, or doesn't exist.`);\n }\n\n if (rows && rows != imageFrame.rows) {\n scaleImageFrame(imageFrame, options.targetBuffer, TypedArrayConstructor);\n }\n const imageFrameLength = imageFrame.pixelDataLength;\n\n const offset = rawOffset;\n const length =\n rawLength !== null && rawLength !== undefined\n ? rawLength\n : imageFrameLength - offset;\n\n const imageFramePixelData = imageFrame.pixelData;\n\n if (length !== imageFramePixelData.length) {\n throw new Error(\n `target array for image does not have the same length (${length}) as the decoded image length (${imageFramePixelData.length}).`\n );\n }\n\n // TypedArray.Set is api level and ~50x faster than copying elements even for\n // Arrays of different types, which aren't simply memcpy ops.\n const typedArray = arrayBuffer\n ? new TypedArrayConstructor(arrayBuffer, offset, length)\n : new TypedArrayConstructor(length);\n\n typedArray.set(imageFramePixelData, 0);\n\n // If need to scale, need to scale correct array.\n pixelDataArray = typedArray;\n return pixelDataArray;\n}\n\nfunction _handlePreScaleSetup(\n options,\n minBeforeScale,\n maxBeforeScale,\n imageFrame\n) {\n const scalingParameters = options.preScale.scalingParameters;\n _validateScalingParameters(scalingParameters);\n\n const { rescaleSlope, rescaleIntercept } = scalingParameters;\n const areSlopeAndInterceptNumbers =\n typeof rescaleSlope === 'number' && typeof rescaleIntercept === 'number';\n\n let scaledMin = minBeforeScale;\n let scaledMax = maxBeforeScale;\n\n if (areSlopeAndInterceptNumbers) {\n scaledMin = rescaleSlope * minBeforeScale + rescaleIntercept;\n scaledMax = rescaleSlope * maxBeforeScale + rescaleIntercept;\n }\n\n return _getDefaultPixelDataArray(scaledMin, scaledMax, imageFrame);\n}\n\nfunction _getDefaultPixelDataArray(min, max, imageFrame) {\n const TypedArrayConstructor = getPixelDataTypeFromMinMax(min, max);\n // @ts-ignore\n const typedArray = new TypedArrayConstructor(imageFrame.pixelData.length);\n typedArray.set(imageFrame.pixelData, 0);\n\n return typedArray;\n}\n\nfunction _validateScalingParameters(scalingParameters) {\n if (!scalingParameters) {\n throw new Error(\n 'options.preScale.scalingParameters must be defined if preScale.enabled is true, and scalingParameters cannot be derived from the metadata providers.'\n );\n }\n}\n\nfunction createDestinationImage(\n imageFrame,\n targetBuffer,\n TypedArrayConstructor\n) {\n const { samplesPerPixel } = imageFrame;\n const { rows, columns } = targetBuffer;\n const typedLength = rows * columns * samplesPerPixel;\n const pixelData = new TypedArrayConstructor(typedLength);\n const bytesPerPixel = pixelData.byteLength / typedLength;\n return {\n pixelData,\n rows,\n columns,\n frameInfo: {\n ...imageFrame.frameInfo,\n rows,\n columns,\n },\n imageInfo: {\n ...imageFrame.imageInfo,\n rows,\n columns,\n bytesPerPixel,\n },\n };\n}\n\n/** Scales the image frame, updating the frame in place with a new scaled\n * version of it (in place modification)\n */\nfunction scaleImageFrame(imageFrame, targetBuffer, TypedArrayConstructor) {\n const dest = createDestinationImage(\n imageFrame,\n targetBuffer,\n TypedArrayConstructor\n );\n const { scalingType = 'replicate' } = targetBuffer;\n imageUtils[scalingType](imageFrame, dest);\n Object.assign(imageFrame, dest);\n return imageFrame;\n}\n\nconst obj = {\n decodeTask({\n imageFrame,\n transferSyntax,\n decodeConfig,\n options,\n pixelData,\n callbackFn,\n }) {\n return decodeImageFrame(\n imageFrame,\n transferSyntax,\n pixelData,\n decodeConfig,\n options,\n callbackFn\n );\n },\n};\n\nexpose(obj);\n","/**\n * Performs a bilinear scaling, both scaling up and scaling down.\n * Only supports 1 channel per pixel (grayscale)\n * @param src - src image frame to get map from\n * @param dest - dest image frame to write to\n * @returns destination data buffer\n */\nexport default function bilinear(src, dest) {\n const { rows: srcRows, columns: srcColumns, data: srcData } = src;\n const { rows, columns, data } = dest;\n\n const xSrc1Off = [];\n const xSrc2Off = [];\n const xFrac = [];\n\n // Precompute offsets\n for (let x = 0; x < columns; x++) {\n const xSrc = (x * (srcColumns - 1)) / (columns - 1);\n xSrc1Off[x] = Math.floor(xSrc);\n xSrc2Off[x] = Math.min(xSrc1Off[x] + 1, srcColumns - 1);\n xFrac[x] = xSrc - xSrc1Off[x];\n // console.log(\"x src info\", x, xSrc, xFrac[x]);\n }\n\n for (let y = 0; y < rows; y++) {\n const ySrc = (y * (srcRows - 1)) / (rows - 1);\n const ySrc1Off = Math.floor(ySrc) * srcColumns;\n // Get the second offset, but duplicate the last row so the lookup works\n const ySrc2Off = Math.min(\n ySrc1Off + srcColumns,\n (srcRows - 1) * srcColumns\n );\n const yFrac = ySrc - Math.floor(ySrc);\n const yFracInv = 1 - yFrac;\n const yOff = y * columns;\n\n for (let x = 0; x < columns; x++) {\n // TODO - put the pXY into the data calculation\n const p00 = srcData[ySrc1Off + xSrc1Off[x]];\n const p10 = srcData[ySrc1Off + xSrc2Off[x]];\n const p01 = srcData[ySrc2Off + xSrc1Off[x]];\n const p11 = srcData[ySrc2Off + xSrc2Off[x]];\n const xFracInv = 1 - xFrac[x];\n\n // console.log(\"bilinear for\", x,y, \"from\", ySrc1Off + xSrc1Off[x], ySrc1Off + xSrc2Off[x], ySrc2Off + xSrc1Off[x], ySrc2Off + xSrc2Off[x]);\n // console.log(\"values\", p00, p10, p01, p11);\n // console.log(\"fractions\", xFracInv, xFrac[x], yFracInv, yFrac);\n\n data[yOff + x] =\n (p00 * xFracInv + p10 * xFrac[x]) * yFracInv +\n (p01 * xFracInv + p11 * xFrac[x]) * yFrac;\n }\n }\n return data;\n}\n","/** Handle replicate scaling. Use this function for samplesPerPixel>1 */\n\nexport default function replicate(src, dest) {\n const {\n rows: srcRows,\n columns: srcColumns,\n pixelData: srcData,\n samplesPerPixel = 1,\n } = src;\n const { rows, columns, pixelData } = dest;\n\n const xSrc1Off = [];\n\n // Precompute offsets\n for (let x = 0; x < columns; x++) {\n const xSrc = (x * (srcColumns - 1)) / (columns - 1);\n xSrc1Off[x] = Math.floor(xSrc) * samplesPerPixel;\n // console.log(\"x src info\", x, xSrc, xFrac[x]);\n }\n\n for (let y = 0; y < rows; y++) {\n const ySrc = (y * (srcRows - 1)) / (rows - 1);\n const ySrc1Off = Math.floor(ySrc) * srcColumns * samplesPerPixel;\n const yOff = y * columns;\n\n for (let x = 0; x < columns; x++) {\n for (let sample = 0; sample < samplesPerPixel; sample++) {\n pixelData[yOff + x + sample] = srcData[ySrc1Off + xSrc1Off[x] + sample];\n }\n }\n }\n return pixelData;\n}\n","export default function (photoMetricInterpretation: string): boolean {\n return (\n photoMetricInterpretation === 'RGB' ||\n photoMetricInterpretation === 'PALETTE COLOR' ||\n photoMetricInterpretation === 'YBR_FULL' ||\n photoMetricInterpretation === 'YBR_FULL_422' ||\n photoMetricInterpretation === 'YBR_PARTIAL_422' ||\n photoMetricInterpretation === 'YBR_PARTIAL_420' ||\n photoMetricInterpretation === 'YBR_RCT' ||\n photoMetricInterpretation === 'YBR_ICT'\n );\n}\n","import type { Types } from '@cornerstonejs/core';\n\nexport default function scaleArray(\n array: Types.PixelDataTypedArray,\n scalingParameters\n): boolean {\n const arrayLength = array.length;\n const { rescaleSlope, rescaleIntercept, suvbw } = scalingParameters;\n\n if (scalingParameters.modality === 'PT' && typeof suvbw === 'number') {\n for (let i = 0; i < arrayLength; i++) {\n array[i] = suvbw * (array[i] * rescaleSlope + rescaleIntercept);\n }\n } else {\n for (let i = 0; i < arrayLength; i++) {\n array[i] = array[i] * rescaleSlope + rescaleIntercept;\n }\n }\n\n return true;\n}\n","import type { Types } from '@cornerstonejs/core';\n\nexport default function getPixelDataTypeFromMinMax(\n min: number,\n max: number\n): Types.PixelDataTypedArray {\n let pixelDataType;\n if (Number.isInteger(min) && Number.isInteger(max)) {\n if (min >= 0) {\n if (max <= 255) {\n pixelDataType = Uint8Array;\n } else if (max <= 65535) {\n pixelDataType = Uint16Array;\n }\n } else {\n if (min >= -128 && max <= 127) {\n pixelDataType = Int8Array;\n } else if (min >= -32768 && max <= 32767) {\n pixelDataType = Int16Array;\n }\n }\n }\n\n return pixelDataType || Float32Array;\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n// the startup function\n__webpack_require__.x = () => {\n\t// Load entry module and return exports\n\t// This entry module depends on other loaded chunks and execution need to be delayed\n\tvar __webpack_exports__ = __webpack_require__.O(undefined, [958], () => (__webpack_require__(760)))\n\t__webpack_exports__ = __webpack_require__.O(__webpack_exports__);\n\treturn __webpack_exports__;\n};\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = (chunkId) => {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce((promises, key) => {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks and sibling chunks for the entrypoint\n__webpack_require__.u = (chunkId) => {\n\t// return url for filenames based on template\n\treturn \"\" + chunkId + \".min.js\";\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","var scriptUrl;\nif (__webpack_require__.g.importScripts) scriptUrl = __webpack_require__.g.location + \"\";\nvar document = __webpack_require__.g.document;\nif (!scriptUrl && document) {\n\tif (document.currentScript)\n\t\tscriptUrl = document.currentScript.src;\n\tif (!scriptUrl) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tif(scripts.length) {\n\t\t\tvar i = scripts.length - 1;\n\t\t\twhile (i > -1 && !scriptUrl) scriptUrl = scripts[i--].src;\n\t\t}\n\t}\n}\n// When supporting browsers where an automatic publicPath is not supported you must specify an output.publicPath manually via configuration\n// or pass an empty string (\"\") and set the __webpack_public_path__ variable from your code to use your own logic.\nif (!scriptUrl) throw new Error(\"Automatic publicPath is not supported in this browser\");\nscriptUrl = scriptUrl.replace(/#.*$/, \"\").replace(/\\?.*$/, \"\").replace(/\\/[^\\/]+$/, \"/\");\n__webpack_require__.p = scriptUrl;","__webpack_require__.b = self.location + \"\";\n\n// object to store loaded chunks\n// \"1\" means \"already loaded\"\nvar installedChunks = {\n\t918: 1\n};\n\n// importScripts chunk loading\nvar installChunk = (data) => {\n\tvar [chunkIds, moreModules, runtime] = data;\n\tfor(var moduleId in moreModules) {\n\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t}\n\t}\n\tif(runtime) runtime(__webpack_require__);\n\twhile(chunkIds.length)\n\t\tinstalledChunks[chunkIds.pop()] = 1;\n\tparentChunkLoadingFunction(data);\n};\n__webpack_require__.f.i = (chunkId, promises) => {\n\t// \"1\" is the signal for \"already loaded\"\n\tif(!installedChunks[chunkId]) {\n\t\tif(true) { // all chunks have JS\n\t\t\timportScripts(__webpack_require__.p + __webpack_require__.u(chunkId));\n\t\t}\n\t}\n};\n\nvar chunkLoadingGlobal = this[\"webpackChunk\"] = this[\"webpackChunk\"] || [];\nvar parentChunkLoadingFunction = chunkLoadingGlobal.push.bind(chunkLoadingGlobal);\nchunkLoadingGlobal.push = installChunk;\n\n// no HMR\n\n// no HMR manifest","// run startup\nvar __webpack_exports__ = __webpack_require__.x();\n"],"names":["root","factory","exports","module","define","amd","this","deferred","leafPrototypes","getProto","next","async","imageFrame","pixelData","arrayBuffer","buffer","offset","byteOffset","length","bitsAllocated","slice","pixelRepresentation","Uint16Array","Int16Array","Float32Array","i","val","planarConfiguration","frameData","frameSize","rows","columns","outFrame","ArrayBuffer","samplesPerPixel","header","DataView","data","Int8Array","out","outIndex","numSegments","getInt32","s","inIndex","maxIndex","endOfSegment","n","value","j","Uint8Array","decode8Planar","decode8","highByte","decode16","Error","libjpegTurboWasm","URL","local","codec","undefined","decoder","compressedImageFrame","imageInfo","Promise","resolve","libjpegTurboModule","libjpegTurboFactory","locateFile","f","endsWith","toString","reject","then","instance","JPEGDecoder","initLibjpegTurbo","getEncodedBuffer","set","decode","frameInfo","getFrameInfo","decodedPixelsInWASM","getDecodedBuffer","encodedImageInfo","width","height","bitsPerPixel","bitsPerSample","signed","bytesPerPixel","componentsPerPixel","componentCount","decodedBuffer","isSigned","byteLength","getPixelData","encodeOptions","JpegImage","decodeConfig","jpeg","parse","colorTransform","getData","getData16","lossless","Decoder","byteOutput","decompressedData","charlsWasm","charlsModule","charlsFactory","JpegLSDecoder","initialize","interleaveMode","getInterleaveMode","nearLossless","getNearLossless","error","exception","getExceptionMessage","openjpegWasm","openJpegModule","openJpegFactory","J2KDecoder","encodedBufferInWASM","decodedBufferInWASM","imageOffset","getImageOffset","x","y","numDecompositions","getNumDecompositions","numLayers","getNumLayers","progessionOrder","getProgressionOrder","reversible","getIsReversible","blockDimensions","getBlockDimensions","tileSize","getTileSize","tileOffset","getTileOffset","getColorSpace","decodedSize","toLocaleString","compressionRatio","toFixed","openjphWasm","openJphModule","openJphFactory","HTJ2KDecoder","decodeLevel","decodeSubResolution","decompositionLevel","frameWidth","frameHeight","result","Math","ceil","calculateSizeAtDecompositionLevel","b","pixelDataArrayBuffer","constructor","storedPixelData","storedPixel","min","max","numPixels","index","imageUtils","bilinear","src","dest","srcRows","srcColumns","srcData","xSrc1Off","xSrc2Off","xFrac","xSrc","floor","ySrc","ySrc1Off","ySrc2Off","yFrac","yFracInv","yOff","p00","p10","p01","p11","xFracInv","replicate","sample","decodeImageFrame","transferSyntax","options","callbackFn","start","Date","getTime","opts","decodePromise","decodeLittleEndian","decodeBigEndian","decodeRLE","decodeJPEGBaseline8Bit","decodeJPEGBaseline12Bit","decodeJPEGLossless","decodeJPEGLS","decodeJPEG2000","decodeHTJ2K","postProcessed","shouldShift","shift","bitsStored","pixelDataArray","pixelDataLength","minBeforeScale","maxBeforeScale","getMinMax","typedArrayConstructors","type","targetBuffer","canRenderFloat","allowFloatRendering","invalidType","photoMetricInterpretation","photometricInterpretation","willScale","preScale","enabled","hasFloatRescale","Object","values","scalingParameters","some","v","Number","isInteger","disableScale","rawOffset","rawLength","TypedArrayConstructor","typedLength","createDestinationImage","scalingType","assign","scaleImageFrame","imageFrameLength","imageFramePixelData","typedArray","_handleTargetBuffer","_validateScalingParameters","rescaleSlope","rescaleIntercept","scaledMin","scaledMax","_getDefaultPixelDataArray","_handlePreScaleSetup","minAfterScale","maxAfterScale","array","arrayLength","suvbw","modality","applyModalityLUT","scaled","smallestPixelValue","largestPixelValue","end","decodeTimeInMS","postProcessDecodedPixels","pixelDataType","getPixelDataTypeFromMinMax","obj","decodeTask","expose","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","call","m","__webpack_exports__","O","chunkIds","fn","priority","notFulfilled","Infinity","fulfilled","keys","every","key","splice","r","getter","__esModule","d","a","getPrototypeOf","t","mode","ns","create","def","current","indexOf","getOwnPropertyNames","forEach","definition","o","defineProperty","enumerable","get","e","chunkId","all","reduce","promises","u","g","globalThis","Function","window","prop","prototype","hasOwnProperty","Symbol","toStringTag","scriptUrl","importScripts","location","document","currentScript","scripts","getElementsByTagName","replace","p","self","installedChunks","chunkLoadingGlobal","parentChunkLoadingFunction","push","bind","moreModules","runtime","pop"],"sourceRoot":""}
|