152 lines
		
	
	
		
			7.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
			
		
		
	
	
			152 lines
		
	
	
		
			7.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
import dicomParser from "dicom-parser";
 | 
						|
import dcmjs from 'dcmjs'
 | 
						|
const CharLs = require('@cornerstonejs/codec-charls')
 | 
						|
const codecWrapper = {
 | 
						|
  codec: undefined,
 | 
						|
  Decoder: undefined,
 | 
						|
  Encoder: undefined,
 | 
						|
  encoderName: "JpegLSEncoder",
 | 
						|
  decoderName: "JpegLSDecoder",
 | 
						|
};
 | 
						|
function setCodec(codecConfig, encoderName, decoderName, codec = {}) {
 | 
						|
  codecConfig.Encoder = codec[encoderName];
 | 
						|
  codecConfig.Decoder = codec[decoderName];
 | 
						|
  codecConfig.codec = codec;
 | 
						|
}
 | 
						|
CharLs().then(res => {
 | 
						|
  setCodec(codecWrapper, codecWrapper.encoderName, codecWrapper.decoderName, res);
 | 
						|
})
 | 
						|
 | 
						|
export const encoder = function (file, config) {
 | 
						|
  return new Promise(async (resolve, reject) => {
 | 
						|
    try {
 | 
						|
      const reader = new FileReader()
 | 
						|
      let AnonymizeFixedList = config.AnonymizeFixedList
 | 
						|
      let AnonymizeNotFixedList = config.AnonymizeNotFixedList
 | 
						|
      let DicomStoreInfo = config.DicomStoreInfo
 | 
						|
      reader.onload = async (event) => {
 | 
						|
        let buffer = event.target.result
 | 
						|
        let data = dicomParser.parseDicom(new Uint8Array(buffer))
 | 
						|
        let frameCount = data.string('x00280008')
 | 
						|
        let height = data.uint16('x00280011')
 | 
						|
        let width = data.uint16('x00280010')
 | 
						|
        let bitsPerSample = data.uint16('x00280100')
 | 
						|
        let componentCount = data.string('x00280004')
 | 
						|
        let transportSyntax = data.string('x00020010')
 | 
						|
        let dataset = dcmjs.data.DicomMessage.readFile(buffer)
 | 
						|
        let pixelDataElement = data.elements.x7fe00010
 | 
						|
        let pixelDataOffset = pixelDataElement.dataOffset
 | 
						|
        let pixelDataLength = pixelDataElement.length
 | 
						|
        let pixelDataBytes = data.byteArray.subarray(pixelDataOffset, pixelDataOffset + pixelDataLength)
 | 
						|
        if ((transportSyntax === '1.2.840.10008.1.2.1' || transportSyntax === '1.2.840.10008.1.2') && ~componentCount.indexOf('MONOCHROME') && !frameCount) {
 | 
						|
          let encoder = new codecWrapper.Encoder()
 | 
						|
          let decodedBytes = encoder.getDecodedBuffer({width: width, height: height, bitsPerSample: bitsPerSample, componentCount: 1})
 | 
						|
          encoder.setNearLossless(0)
 | 
						|
          decodedBytes.set(pixelDataBytes)
 | 
						|
          encoder.encode()
 | 
						|
          let encodedBytes = encoder.getEncodedBuffer();
 | 
						|
          dataset.dict['7FE00010'].Value[0] = encodedBytes.buffer
 | 
						|
          dataset.meta['00020010'].Value[0] = '1.2.840.10008.1.2.4.80'
 | 
						|
          for (var i = 0; i < AnonymizeFixedList.length; i++) {
 | 
						|
            let AnonymizeFixed = AnonymizeFixedList[i]
 | 
						|
            if (dataset.dict[AnonymizeFixed.Group + AnonymizeFixed.Element]) {
 | 
						|
              dataset.dict[AnonymizeFixed.Group + AnonymizeFixed.Element].Value[0] = AnonymizeFixed.ReplaceValue
 | 
						|
            } else {
 | 
						|
              dataset.dict[AnonymizeFixed.Group + AnonymizeFixed.Element] = {
 | 
						|
                vr: AnonymizeFixed.ValueRepresentation,
 | 
						|
                Value: [
 | 
						|
                  AnonymizeFixed.ReplaceValue
 | 
						|
                ]
 | 
						|
              }
 | 
						|
            }
 | 
						|
          }
 | 
						|
          for (var i = 0; i < AnonymizeNotFixedList.length; i++) {
 | 
						|
            let AnonymizeNotFixed = AnonymizeNotFixedList[i]
 | 
						|
            if (AnonymizeNotFixed.Group + AnonymizeNotFixed.Element === '00100020') {
 | 
						|
              if (dataset.dict[AnonymizeNotFixed.Group + AnonymizeNotFixed.Element]) {
 | 
						|
                dataset.dict[AnonymizeNotFixed.Group + AnonymizeNotFixed.Element].Value[0] =  `${DicomStoreInfo.TrialCode}-${DicomStoreInfo.SubjectCode}`
 | 
						|
              } else {
 | 
						|
                dataset.dict[AnonymizeNotFixed.Group + AnonymizeNotFixed.Element] = {
 | 
						|
                  vr: AnonymizeNotFixed.ValueRepresentation,
 | 
						|
                  Value: [
 | 
						|
                    `${DicomStoreInfo.TrialCode}-${DicomStoreInfo.SubjectCode}`
 | 
						|
                  ]
 | 
						|
                }
 | 
						|
              }
 | 
						|
            } else {
 | 
						|
              if (dataset.dict[AnonymizeNotFixed.Group + AnonymizeNotFixed.Element]) {
 | 
						|
                dataset.dict[AnonymizeNotFixed.Group + AnonymizeNotFixed.Element].Value[0] = DicomStoreInfo[AnonymizeNotFixed.ReplaceValue] ? DicomStoreInfo[AnonymizeNotFixed.ReplaceValue].toString() : ''
 | 
						|
              } else {
 | 
						|
                dataset.dict[AnonymizeNotFixed.Group + AnonymizeNotFixed.Element] = {
 | 
						|
                  vr: AnonymizeNotFixed.ValueRepresentation,
 | 
						|
                  Value: [
 | 
						|
                    DicomStoreInfo[AnonymizeNotFixed.ReplaceValue]
 | 
						|
                  ]
 | 
						|
                }
 | 
						|
              }
 | 
						|
            }
 | 
						|
 | 
						|
          }
 | 
						|
          let newDicomFile = dataset.write()
 | 
						|
          const bufferArray = new Uint8Array(newDicomFile)
 | 
						|
          const blob = new Blob([bufferArray], { type: 'application/octet-stream' })
 | 
						|
          resolve({blob, data})
 | 
						|
        } else {
 | 
						|
          // let encoder = new codecWrapper.Encoder()
 | 
						|
          // let decodedBytes = encoder.getDecodedBuffer({width: width, height: height, bitsPerSample: bitsPerSample, componentCount: 1})
 | 
						|
          // encoder.setNearLossless(0)
 | 
						|
          // decodedBytes.set(pixelDataBytes)
 | 
						|
          // encoder.encode()
 | 
						|
          for (var i = 0; i < AnonymizeFixedList.length; i++) {
 | 
						|
            let AnonymizeFixed = AnonymizeFixedList[i]
 | 
						|
            if (dataset.dict[AnonymizeFixed.Group + AnonymizeFixed.Element]) {
 | 
						|
              dataset.dict[AnonymizeFixed.Group + AnonymizeFixed.Element].Value[0] = AnonymizeFixed.ReplaceValue
 | 
						|
            } else {
 | 
						|
              dataset.dict[AnonymizeFixed.Group + AnonymizeFixed.Element] = {
 | 
						|
                vr: AnonymizeFixed.ValueRepresentation,
 | 
						|
                Value: [
 | 
						|
                  AnonymizeFixed.ReplaceValue
 | 
						|
                ]
 | 
						|
              }
 | 
						|
            }
 | 
						|
          }
 | 
						|
          for (var i = 0; i < AnonymizeNotFixedList.length; i++) {
 | 
						|
            let AnonymizeNotFixed = AnonymizeNotFixedList[i]
 | 
						|
            if (AnonymizeNotFixed.Group + AnonymizeNotFixed.Element === '00100020') {
 | 
						|
              if (dataset.dict[AnonymizeNotFixed.Group + AnonymizeNotFixed.Element]) {
 | 
						|
                dataset.dict[AnonymizeNotFixed.Group + AnonymizeNotFixed.Element].Value[0] =  `${DicomStoreInfo.TrialCode}-${DicomStoreInfo.SubjectCode}`
 | 
						|
              } else {
 | 
						|
                dataset.dict[AnonymizeNotFixed.Group + AnonymizeNotFixed.Element] = {
 | 
						|
                  vr: AnonymizeNotFixed.ValueRepresentation,
 | 
						|
                  Value: [
 | 
						|
                    `${DicomStoreInfo.TrialCode}-${DicomStoreInfo.SubjectCode}`
 | 
						|
                  ]
 | 
						|
                }
 | 
						|
              }
 | 
						|
            } else {
 | 
						|
              if (dataset.dict[AnonymizeNotFixed.Group + AnonymizeNotFixed.Element]) {
 | 
						|
                dataset.dict[AnonymizeNotFixed.Group + AnonymizeNotFixed.Element].Value[0] = DicomStoreInfo[AnonymizeNotFixed.ReplaceValue] ? DicomStoreInfo[AnonymizeNotFixed.ReplaceValue].toString() : ''
 | 
						|
              } else {
 | 
						|
                dataset.dict[AnonymizeNotFixed.Group + AnonymizeNotFixed.Element] = {
 | 
						|
                  vr: AnonymizeNotFixed.ValueRepresentation,
 | 
						|
                  Value: [
 | 
						|
                    DicomStoreInfo[AnonymizeNotFixed.ReplaceValue]
 | 
						|
                  ]
 | 
						|
                }
 | 
						|
              }
 | 
						|
            }
 | 
						|
          }
 | 
						|
          let newDicomFile = dataset.write()
 | 
						|
          const bufferArray = new Uint8Array(newDicomFile)
 | 
						|
          const blob = new Blob([bufferArray], { type: 'application/octet-stream' })
 | 
						|
          resolve({blob, data})
 | 
						|
        }
 | 
						|
      };
 | 
						|
      reader.readAsArrayBuffer(file);
 | 
						|
    } catch (e) {
 | 
						|
      console.log(e)
 | 
						|
      reject(e)
 | 
						|
    }
 | 
						|
  })
 | 
						|
}
 |