From 6fac3599ce8ea99349386b726d28dd7447761ea6 Mon Sep 17 00:00:00 2001 From: Alireza Date: Wed, 8 Nov 2023 23:04:09 -0500 Subject: [PATCH] Add new metadata fields to DICOM JSON generator script --- .scripts/dicom-json-generator.js | 15 +++++++++++++++ .../docs/configuration/dataSources/dicom-json.md | 16 ++++++++++++++++ 2 files changed, 31 insertions(+) diff --git a/.scripts/dicom-json-generator.js b/.scripts/dicom-json-generator.js index 3ee6777a900..97d32ec82bf 100644 --- a/.scripts/dicom-json-generator.js +++ b/.scripts/dicom-json-generator.js @@ -216,12 +216,27 @@ function conditionalMetaData(instance) { ...(instance.RadiopharmaceuticalInformationSequence && { RadiopharmaceuticalInformationSequence: instance.RadiopharmaceuticalInformationSequence, }), + ...(instance.ROIContourSequence && { + ROIContourSequence: instance.ROIContourSequence, + }), + ...(instance.StructureSetROISequence && { + StructureSetROISequence: instance.StructureSetROISequence, + }), + ...(instance.ReferencedFrameOfReferenceSequence && { + ReferencedFrameOfReferenceSequence: instance.ReferencedFrameOfReferenceSequence, + }), ...(instance.CorrectedImage && { CorrectedImage: instance.CorrectedImage }), ...(instance.Units && { Units: instance.Units }), ...(instance.DecayCorrection && { DecayCorrection: instance.DecayCorrection }), ...(instance.AcquisitionDate && { AcquisitionDate: instance.AcquisitionDate }), ...(instance.AcquisitionTime && { AcquisitionTime: instance.AcquisitionTime }), ...(instance.PatientWeight && { PatientWeight: instance.PatientWeight }), + ...(instance.NumberOfFrames && { NumberOfFrames: instance.NumberOfFrames }), + ...(instance.FrameTime && { FrameTime: instance.FrameTime }), + ...(instance.EncapsulatedDocument && { EncapsulatedDocument: instance.EncapsulatedDocument }), + ...(instance.SequenceOfUltrasoundRegions && { + SequenceOfUltrasoundRegions: instance.SequenceOfUltrasoundRegions, + }), }; } diff --git a/platform/docs/docs/configuration/dataSources/dicom-json.md b/platform/docs/docs/configuration/dataSources/dicom-json.md index 37fbda55240..f85bf95b745 100644 --- a/platform/docs/docs/configuration/dataSources/dicom-json.md +++ b/platform/docs/docs/configuration/dataSources/dicom-json.md @@ -28,6 +28,20 @@ dataset. Let's have a look at the JSON file: JSON file stores the metadata for the study level, series level and instance level. A JSON launch file should follow the same structure as the one below. +:::tip +You can use our script to generate the JSON file from a hosted endpoint. See +`.scripts/dicom-json-generator.js` + +You could run it like this: + +```bash +node .scripts/dicom-json-generator.js '/path/to/study/folder' 'url/to/dicom/server/folder' 'json/output/file.json' +``` + +Some modalities require additional metadata to be added to the JSON file. You can read more about the minimum amount of metadata required for the viewer to work [here](../../faq.md#what-are-the-list-of-required-metadata-for-the-ohif-viewer-to-work). We will handle this in the script. For example, the script will add the CodeSequences for SR in order to display the measurements in the viewer. +::: + + Note that at the instance level metadata we are storing both the `metadata` and also the `url` for the dicom file on the dicom server. In this case we are referring to @@ -35,6 +49,8 @@ referring to which is stored in another directory in our s3. (You can actually try downloading the dicom file by opening the url in your browser). +The URL to the script in the given example is `https://ohif-dicom-json-example.s3.amazonaws.com/LIDC-IDRI-0001/01-01-2000-30178`. This URL serves as the parent directory that contains all the series within their respective folders. + ```json { "studies": [