export function getToolbarModule({ servicesManager }: withAppTypes) { const { segmentationService, toolbarService, toolGroupService } = servicesManager.services; return [ { name: 'evaluate.cornerstone.hasSegmentation', evaluate: ({ viewportId }) => { const segmentations = segmentationService.getSegmentationRepresentations(viewportId); return { disabled: !segmentations?.length, }; }, }, { name: 'evaluate.cornerstone.segmentation', evaluate: ({ viewportId, button, toolNames, disabledText }) => { // Todo: we need to pass in the button section Id since we are kind of // forcing the button to have black background since initially // it is designed for the toolbox not the toolbar on top // we should then branch the buttonSectionId to have different styles const segmentations = segmentationService.getSegmentationRepresentations(viewportId); if (!segmentations?.length) { return { disabled: true, disabledText: disabledText ?? 'No segmentations available', }; } const activeSegmentation = segmentationService.getActiveSegmentation(viewportId); if (!Object.keys(activeSegmentation.segments).length) { return { disabled: true, disabledText: 'Add segment to enable this tool', }; } const toolGroup = toolGroupService.getToolGroupForViewport(viewportId); if (!toolGroup) { return { disabled: true, disabledText: disabledText ?? 'Not available on the current viewport', }; } const toolName = toolbarService.getToolNameForButton(button); if (!toolGroup.hasTool(toolName) && !toolNames) { return { disabled: true, disabledText: disabledText ?? 'Not available on the current viewport', }; } const isPrimaryActive = toolNames ? toolNames.includes(toolGroup.getActivePrimaryMouseButtonTool()) : toolGroup.getActivePrimaryMouseButtonTool() === toolName; return { disabled: false, isActive: isPrimaryActive, }; }, }, ]; }