All files / packages/tools/src/stateManagement/segmentation addSegmentationRepresentations.ts

78.12% Statements 25/32
52.63% Branches 10/19
100% Functions 9/9
89.47% Lines 17/19

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78                                          15x     120x     15x   30x       15x 17x         15x   15x   15x 1x   17x     136x       17x 34x                               17x     17x 1x      
import _cloneDeep from 'lodash.clonedeep';
import {
  SegmentationRepresentationConfig,
  RepresentationPublicInput,
} from '../../types/SegmentationStateTypes';
import Representations from '../../enums/SegmentationRepresentations';
import { getToolGroup } from '../../store/ToolGroupManager';
 
import { labelmapDisplay } from '../../tools/displayTools/Labelmap';
import { contourDisplay } from '../../tools/displayTools/Contour';
 
/**
 * Set the specified segmentation representations on the viewports of the specified
 * toolGroup. It accepts a second argument which is a toolGroup specific representation
 * configuration.
 *
 * @param toolGroupId - The Id of the toolGroup to add the segmentation representations to
 * @param representationInputArray - An array of segmentation representations to add to the toolGroup
 * @param toolGroupSpecificRepresentationConfig - The toolGroup specific configuration
 * for the segmentation representations
 */
async function addSegmentationRepresentations(
  toolGroupId: string,
  representationInputArray: RepresentationPublicInput[],
  toolGroupSpecificRepresentationConfig?: SegmentationRepresentationConfig
): Promise<string[]> {
  // Check if there exists a toolGroup with the toolGroupId
  const toolGroup = getToolGroup(toolGroupId)E;
 
  if (!toolGroup) {
    throw new Error(`No tool group found for toolGroupId: ${toolGroupId}`);
  }
 
  const promises = representationInputArray.map((representationInput) => {
    return _addSegmentationRepresentation(
      toolGroupId,
      representationInput,
      toolGroupSpecificRepresentationConfig
    );
  });
 
  const segmentationRepresentationUIDs = await Promise.all(promises);
 
  return segmentationRepresentationUIDs;
}
 
async function _addSegmentationRepresentation(
  toolGroupId: string,
  representationInput: RepresentationPublicInput,
  toolGroupSpecificRepresentationConfig?: SegmentationRepresentationConfigI
): Promise<string> {
  let segmentationRepresentationUID;
 
  if (representationInput.type === Representations.Labelmap) {
    segmentationRepresentationUID =
      await labelmapDisplay.addSegmentationRepresentation(
        toolGroupId,
        representationInput,
        toolGroupSpecificRepresentationConfig
      );
  } else if (representationInput.type === Representations.Contour) {
    segmentationRepresentationUID =
      await contourDisplay.addSegmentationRepresentation(
        toolGroupId,
        representationInput,
        toolGroupSpecificRepresentationConfig
      );
  } else {
    throw new Error(
      `The representation type ${representationInput.type} is not supported`
    );
  }
 
  return segmentationRepresentationUID;
}
 
export default addSegmentationRepresentations;