All files / core/src/utilities getViewportsWithVolumeURI.ts

0% Statements 0/8
0% Branches 0/2
0% Functions 0/3
0% Lines 0/8

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                                                                         
import type { IVolumeViewport } from '../types';
import {
  getRenderingEngines,
  getRenderingEngine,
} from '../RenderingEngine/getRenderingEngine';
 
/**
 * Retrieves viewports containing a specific volume ID.
 *
 * @param volumeId - The ID of the volume to search for within viewports.
 * @param renderingEngineId - (Optional) The ID of a specific rendering engine to search in.
 * @returns An array of volume viewports that contain the specified volume ID.
 */
function getViewportsWithVolumeURI(
  volumeURI: string,
  renderingEngineId?: string
): IVolumeViewport[] {
  // If rendering engine is not provided, use all rendering engines
  const renderingEngines = renderingEngineId
    ? [getRenderingEngine(renderingEngineId)]
    : getRenderingEngines();
 
  const targetViewports: IVolumeViewport[] = [];
 
  renderingEngines.forEach((renderingEngine) => {
    const viewports = renderingEngine.getVolumeViewports();
    const filteredViewports = viewports.filter((vp) =>
      vp.hasVolumeURI(volumeURI)
    );
    targetViewports.push(...filteredViewports);
  });
 
  return targetViewports;
}
 
export default getViewportsWithVolumeURI;