Skip to main content
Version: 3.12.0-beta.74 (Latest)

uiModalService

ModalService

Props Kept same as before

PropDescription
contentThis is now expected to be a React component type (a function or class that returns JSX)
contentPropsThis continues to be the way to pass data to your custom dialog component. However, several specific props that used to be passed here (like onClose, actions) are no longer valid.
titleThe title text to display in the dialog header.
shouldCloseOnEscAllows closing the modal when the escape key is pressed.
shouldCloseOnOverlayClickAllows closing the modal when the overlay is clicked.

Renamed Props:

PropDescription
containerDimensionsrenamed to containerClassName

Removed Props:

PropDescription
movableIt's removed because modals shouldn't be movable. If you need to move a dialog, use uidDialogService and dialogs instead.
isOpenalways assumed true when show is called.
contentDimensionsRemoved, it is now component's responsibility to set the size for the content
customClassNamerenamed to className
closeButtonThe component now manages modal closing internally. If you need a close button, you can add one, perhaps by checking out the FooterActions component.

Frequently Asked Questions

Q: Why did my dialog's background color change?

A: This can happen if you were previously setting the background color on the dialog's content directly. With the new API, the dialog's content is wrapped in a container. You should now pass any background or text color classes using the containerClassName property.

For example:

- containerClassName: 'w-[70%] max-w-[900px]',
+ containerClassName: 'w-[70%] max-w-[900px] bg-primary-dark text-foreground',

Migration Steps:

Rename of containerDimensions to containerClassName and removal of contentDimensions

Before

uiModalService.show({
title: 'Download High-Quality Image',
content: CornerstoneViewportDownloadForm,
contentProps: {
activeViewportId,
},
containerDimensions: 'w-[70%] max-w-[900px]',
contentDimensions: 'h-[493px] w-[460px] pl-[12px] pr-[12px]',
});

After: the component is responsible for setting the size

function CornerstoneViewportDownloadForm({ activeViewportId }) {
return (
<div className="h-[493px] w-[460px] pl-[12px] pr-[12px]">
<h2 className="text-lg font-bold">Download Image</h2>
<p>Viewport ID: {activeViewportId}</p>
<button className="mt-4 bg-blue-500 text-white p-2 rounded">Download</button>
</div>
);
}

// Show the modal
uiModalService.show({
title: 'Download High-Quality Image',
content: CornerstoneViewportDownloadForm,
contentProps: { activeViewportId },
containerClassName: 'w-[70%] max-w-[900px]',
});

onClose

Previously, you had to pass in the onClose as hide function automatically added to the component.

- uiModalService.show({
- title: 'Untrack Series',
- content: UntrackSeriesModal,
- contentProps: { onConfirm },
- onClose: () => uiModalService.hide(),
- });

+ uiModalService.show({
+ title: 'Untrack Series',
+ content: UntrackSeriesModal,
+ contentProps: {
+ onConfirm,
+ hide, // passed in automatically in the background
+ },
+ });
  1. Update Footer Action Buttons:

    Previously, footer buttons might have been implemented using generic <Button> components. The new approach uses a dedicated <FooterAction> component for better structure and consistency.

    - <Button
    - name="Cancel"
    - size={ButtonEnums.size.medium}
    - type={ButtonEnums.type.secondary}
    - onClick={onClose}
    - > Cancel </Button>
    + <FooterAction>
    + <FooterAction.Right>
    + <FooterAction.Secondary onClick={hide}>Cancel</FooterAction.Secondary>
    + </FooterAction.Right>
    + </FooterAction>

Example: Simple Alert Modal

This example shows how to migrate a simple alert modal.

Before:

uiModalService.show({
title: 'Untrack Series',
content: UntrackSeriesModal,
contentProps: {
onConfirm,
hide, // passed in automatically in the background
},
});

After:

function UntrackSeriesModal({ onConfirm, hide }) {
return (
<div>
{/* Modal content */}
</div>
);
}

// Show the modal
uiModalService.show({
title: 'Untrack Series',
content: UntrackSeriesModal,
contentProps: {
onConfirm,
hide, // passed in automatically in the background
},
});